mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
software/liblitesdcard/sdcard: add FatFs disk functions.
This commit is contained in:
parent
e27ed657e9
commit
04d0ba6187
1 changed files with 32 additions and 9 deletions
|
@ -12,6 +12,8 @@
|
||||||
#include <generated/mem.h>
|
#include <generated/mem.h>
|
||||||
#include <system.h>
|
#include <system.h>
|
||||||
|
|
||||||
|
#include "fat/ff.h"
|
||||||
|
#include "fat/diskio.h"
|
||||||
#include "sdcard.h"
|
#include "sdcard.h"
|
||||||
|
|
||||||
#define SDCARD_DEBUG
|
#define SDCARD_DEBUG
|
||||||
|
@ -713,15 +715,36 @@ int sdcard_test(unsigned int blocks)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint8_t sdcard_read_block(uint32_t addr, uint8_t *buf) {
|
/*-----------------------------------------------------------------------*/
|
||||||
int n;
|
/* SDCard FatFs disk functions */
|
||||||
|
/*-----------------------------------------------------------------------*/
|
||||||
|
|
||||||
// FIXME: handle errors, avoid recopy.
|
static DSTATUS spisdcardstatus = STA_NOINIT;
|
||||||
|
|
||||||
sdcard_read(addr, 1);
|
DSTATUS disk_status(uint8_t drv) {
|
||||||
for(n=0; n<SD_BLOCK_SIZE; n++)
|
if (drv) return STA_NOINIT;
|
||||||
buf[n] = sdread_buf[n];
|
return spisdcardstatus;
|
||||||
return 1;
|
}
|
||||||
|
|
||||||
|
DSTATUS disk_initialize(uint8_t drv) {
|
||||||
|
uint8_t r;
|
||||||
|
|
||||||
|
if (drv) return RES_NOTRDY;
|
||||||
|
|
||||||
|
r = sdcard_init();
|
||||||
|
|
||||||
|
spisdcardstatus = r ? 0 : STA_NOINIT;
|
||||||
|
return spisdcardstatus;
|
||||||
|
}
|
||||||
|
|
||||||
|
DRESULT disk_read(uint8_t drv, uint8_t *buf, uint32_t sector, uint32_t count) {
|
||||||
|
while (count) {
|
||||||
|
sdcard_read(sector, 1);
|
||||||
|
memcpy((char*) buf, (char*) sdread_buf, SD_BLOCK_SIZE);
|
||||||
|
buf += SD_BLOCK_SIZE;
|
||||||
|
count--;
|
||||||
|
}
|
||||||
|
return RES_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* CSR_SDCORE_BASE */
|
#endif /* CSR_SDCORE_BASE */
|
||||||
|
|
Loading…
Reference in a new issue