123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182 |
- #include "diskio.h"
- #include <ffconf.h> /* import ff config */
- #define DISK_MAX_PHY_DRV _VOLUMES
- const char* const disk_volume_strs[] = {
- _VOLUME_STRS
- };
- static DSTATUS translate_error(int error)
- {
- switch (error) {
- case 0:
- return RES_OK;
- case EINVAL:
- return RES_PARERR;
- case ENODEV:
- return RES_NOTRDY;
- default:
- return RES_ERROR;
- }
- }
- DSTATUS disk_status (
- BYTE pdrv
- )
- {
- int result;
- if (pdrv >= DISK_MAX_PHY_DRV)
- return STA_NODISK;
- result = disk_access_status(disk_volume_strs[pdrv]);
- return translate_error(result);
- }
- DSTATUS disk_initialize (
- BYTE pdrv
- )
- {
- int result;
- if (pdrv >= DISK_MAX_PHY_DRV)
- return STA_NODISK;
- #ifdef CONFIG_DISKIO_CACHE
- diskio_cache_invalid(disk_volume_strs[pdrv]);
- #endif
- result = disk_access_init(disk_volume_strs[pdrv]);
- return translate_error(result);
- }
- DRESULT disk_read (
- BYTE pdrv,
- BYTE *buff,
- DWORD sector,
- UINT count
- )
- {
- int result;
- if (pdrv >= DISK_MAX_PHY_DRV)
- return STA_NODISK;
- #ifdef CONFIG_DISKIO_CACHE
- result = diskio_cache_read(disk_volume_strs[pdrv], buff, sector, count);
- #else
- result = disk_access_read(disk_volume_strs[pdrv], buff, sector, count);
- #endif
- return translate_error(result);
- }
- DRESULT disk_write (
- BYTE pdrv,
- const BYTE *buff,
- DWORD sector,
- UINT count
- )
- {
- int result;
- if (pdrv >= DISK_MAX_PHY_DRV)
- return STA_NODISK;
- #ifdef CONFIG_DISKIO_CACHE
- result = diskio_cache_write(disk_volume_strs[pdrv], buff, sector, count);
- #else
- result = disk_access_write(disk_volume_strs[pdrv], buff, sector, count);
- #endif
- return translate_error(result);
- }
- DRESULT disk_ioctl (
- BYTE pdrv,
- BYTE cmd,
- void *buff
- )
- {
- int result = RES_OK;
- if (pdrv >= DISK_MAX_PHY_DRV)
- return STA_NODISK;
- switch (cmd) {
- case CTRL_SYNC:
- #ifdef CONFIG_DISKIO_CACHE
- diskio_cache_flush(disk_volume_strs[pdrv]);
- #endif
- if(disk_access_ioctl(disk_volume_strs[pdrv], DISK_IOCTL_CTRL_SYNC, buff) != 0) {
- result = RES_ERROR;
- }
- break;
- case GET_SECTOR_SIZE:
- if(disk_access_ioctl(disk_volume_strs[pdrv], DISK_IOCTL_GET_SECTOR_SIZE, buff) != 0) {
- result = RES_ERROR;
- }
- break;
- case GET_SECTOR_COUNT:
- if(disk_access_ioctl(disk_volume_strs[pdrv], DISK_IOCTL_GET_SECTOR_COUNT, buff) != 0) {
- result = RES_ERROR;
- }
- break;
- case GET_BLOCK_SIZE:
- if (disk_access_ioctl(disk_volume_strs[pdrv], DISK_IOCTL_GET_ERASE_BLOCK_SZ, buff) != 0) {
- result = RES_ERROR;
- }
- break;
- case DISK_HW_DETECT:
- if (disk_access_ioctl(disk_volume_strs[pdrv], DISK_IOCTL_HW_DETECT, buff) != 0) {
- result = RES_ERROR;
- }
- break;
- default:
- result = RES_PARERR;
- break;
- }
- return result;
- }
|