diskio.c 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234
  1. /*-----------------------------------------------------------------------*/
  2. /* Low level disk I/O module skeleton for FatFs (C)ChaN, 2016 */
  3. /*-----------------------------------------------------------------------*/
  4. /* If a working storage control module is available, it should be */
  5. /* attached to the FatFs via a glue function rather than modifying it. */
  6. /* This is an example of glue functions to attach various exsisting */
  7. /* storage control modules to the FatFs module with a defined API. */
  8. /*-----------------------------------------------------------------------*/
  9. #include "diskio.h" /* FatFs lower layer API */
  10. #include "dev_sdio.h"
  11. #include "sfud.h"
  12. /* 为每个设备定义一个物理编号 */
  13. #define DEV_FLASH 0 /* Example: Map SPI FLASH to physical drive 0 */
  14. #define DEV_MMC 1 /* Example: Map MMC/SD card to physical drive 1 */
  15. #define FLASH_SECTOR_SIZE 4096
  16. /*-----------------------------------------------------------------------*/
  17. /* 设备初始化 */
  18. /*-----------------------------------------------------------------------*/
  19. DSTATUS disk_initialize(
  20. BYTE pdrv /* 物理编号 */
  21. )
  22. {
  23. DSTATUS status = STA_NOINIT;
  24. switch (pdrv)
  25. {
  26. case DEV_MMC: /* SD CARD */
  27. if (sdcard_init() == SD_RES_OK)
  28. {
  29. status = RES_OK;
  30. }
  31. break;
  32. case DEV_FLASH: /* SPI FLASH */
  33. if (sfud_init() == SFUD_SUCCESS)
  34. {
  35. status = RES_OK;
  36. }
  37. status = RES_OK;
  38. break;
  39. default:
  40. break;
  41. }
  42. return status;
  43. }
  44. /*-----------------------------------------------------------------------*/
  45. /* 获取设备状态 */
  46. /*-----------------------------------------------------------------------*/
  47. DSTATUS disk_status(
  48. BYTE pdrv /* 物理编号 */
  49. )
  50. {
  51. DSTATUS status = STA_NOINIT;
  52. switch (pdrv)
  53. {
  54. case DEV_MMC: /* SD CARD */
  55. status &= ~STA_NOINIT;
  56. break;
  57. case DEV_FLASH: /* SPI FLASH */
  58. status &= ~STA_NOINIT;
  59. break;
  60. default:
  61. break;
  62. }
  63. return status;
  64. }
  65. /*-----------------------------------------------------------------------*/
  66. /* 读扇区:读取扇区内容到指定存储区 */
  67. /*-----------------------------------------------------------------------*/
  68. DRESULT disk_read(
  69. BYTE pdrv, /* 设备物理编号(0..) */
  70. BYTE *buff, /* 数据缓存区 */
  71. DWORD sector, /* 扇区首地址 */
  72. UINT count /* 扇区个数(1..128) */
  73. )
  74. {
  75. DRESULT status = RES_PARERR;
  76. switch (pdrv)
  77. {
  78. case DEV_MMC: /* SD CARD */
  79. if (count == 1)
  80. {
  81. SDIO_BlockRead(sector, (uint32_t *)buff);
  82. }
  83. else
  84. {
  85. SDIO_MultiBlockRead(sector, count, (uint32_t *)buff);
  86. }
  87. status = RES_OK;
  88. break;
  89. case DEV_FLASH: /* SPI FLASH */
  90. {
  91. sfud_err result = SFUD_SUCCESS;
  92. sfud_flash *spi_flash = sfud_get_device(SFUD_W25_DEVICE_INDEX);
  93. result = sfud_read(spi_flash, sector * FLASH_SECTOR_SIZE, count * FLASH_SECTOR_SIZE, buff);
  94. if (result == SFUD_SUCCESS)
  95. {
  96. status = RES_OK;
  97. }
  98. else
  99. {
  100. status = RES_ERROR;
  101. }
  102. }
  103. break;
  104. default:
  105. break;
  106. }
  107. return status;
  108. }
  109. DRESULT disk_write(
  110. BYTE pdrv, /* 设备物理编号(0..) */
  111. const BYTE *buff, /* 欲写入数据的缓存区 */
  112. DWORD sector, /* 扇区首地址 */
  113. UINT count /* 扇区个数(1..128) */
  114. )
  115. {
  116. DRESULT status = RES_PARERR;
  117. if (!count)
  118. {
  119. return RES_PARERR; /* Check parameter */
  120. }
  121. switch (pdrv)
  122. {
  123. case DEV_MMC: /* SD CARD */
  124. if (count == 1)
  125. {
  126. SDIO_BlockWrite(sector, (uint32_t *)buff);
  127. }
  128. else
  129. {
  130. SDIO_MultiBlockWrite(sector, count, (uint32_t *)buff);
  131. }
  132. status = RES_OK;
  133. break;
  134. case DEV_FLASH: /* SPI FLASH */
  135. {
  136. sfud_err result = SFUD_SUCCESS;
  137. sfud_flash *spi_flash = sfud_get_device(SFUD_W25_DEVICE_INDEX);
  138. sfud_erase_write(spi_flash, sector * FLASH_SECTOR_SIZE, count * FLASH_SECTOR_SIZE, buff);
  139. if (result == SFUD_SUCCESS)
  140. {
  141. status = RES_OK;
  142. }
  143. else
  144. {
  145. status = RES_ERROR;
  146. }
  147. }
  148. break;
  149. default:
  150. break;
  151. }
  152. return status;
  153. }
  154. DRESULT disk_ioctl(
  155. BYTE pdrv, /* 物理编号 */
  156. BYTE cmd, /* 控制指令 */
  157. void *buff /* 写入或者读取数据地址指针 */
  158. )
  159. {
  160. DRESULT status = RES_PARERR;
  161. switch (pdrv)
  162. {
  163. case DEV_MMC: /* SD CARD */
  164. switch (cmd)
  165. {
  166. // Get R/W sector size (WORD)
  167. case GET_SECTOR_SIZE:
  168. *(WORD *)buff = 512;
  169. break;
  170. // Get erase block size in unit of sector (DWORD)
  171. case GET_BLOCK_SIZE:
  172. *(DWORD *)buff = SD_cardInfo.CardBlockSize;
  173. break;
  174. case GET_SECTOR_COUNT:
  175. *(DWORD *)buff = SD_cardInfo.CardCapacity / 512;
  176. break;
  177. case CTRL_SYNC:
  178. default:
  179. break;
  180. }
  181. status = RES_OK;
  182. break;
  183. case DEV_FLASH: /* SPI FLASH */
  184. switch (cmd)
  185. {
  186. // Get R/W sector size (WORD)
  187. case GET_SECTOR_SIZE:
  188. *(WORD *)buff = FLASH_SECTOR_SIZE;
  189. break;
  190. // Get erase block size in unit of sector (DWORD)
  191. case GET_BLOCK_SIZE:
  192. *(DWORD *)buff = 1;
  193. break;
  194. case GET_SECTOR_COUNT:
  195. {
  196. sfud_flash *spi_flash = sfud_get_device(SFUD_W25_DEVICE_INDEX);
  197. *(DWORD *)buff = spi_flash->chip.capacity / FLASH_SECTOR_SIZE;
  198. }
  199. break;
  200. case CTRL_SYNC:
  201. default:
  202. break;
  203. }
  204. status = RES_OK;
  205. break;
  206. default:
  207. status = RES_PARERR;
  208. }
  209. return status;
  210. }