sd_spi_io.h 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158
  1. #pragma once
  2. #include <stdint.h>
  3. #include <stdbool.h>
  4. #define __IO volatile
  5. #define SD_TIMEOUT_MS (1000)
  6. #define SD_BLOCK_SIZE 512
  7. typedef enum {
  8. SdSpiStatusOK,
  9. SdSpiStatusError,
  10. SdSpiStatusTimeout,
  11. } SdSpiStatus;
  12. /**
  13. * @brief Card Specific Data: CSD Register
  14. */
  15. typedef struct {
  16. /* Header part */
  17. uint8_t CSDStruct : 2; /* CSD structure */
  18. uint8_t Reserved1 : 6; /* Reserved */
  19. uint8_t TAAC : 8; /* Data read access-time 1 */
  20. uint8_t NSAC : 8; /* Data read access-time 2 in CLK cycles */
  21. uint8_t MaxBusClkFrec : 8; /* Max. bus clock frequency */
  22. uint16_t CardComdClasses : 12; /* Card command classes */
  23. uint8_t RdBlockLen : 4; /* Max. read data block length */
  24. uint8_t PartBlockRead : 1; /* Partial blocks for read allowed */
  25. uint8_t WrBlockMisalign : 1; /* Write block misalignment */
  26. uint8_t RdBlockMisalign : 1; /* Read block misalignment */
  27. uint8_t DSRImpl : 1; /* DSR implemented */
  28. /* v1 or v2 struct */
  29. union csd_version {
  30. struct {
  31. uint8_t Reserved1 : 2; /* Reserved */
  32. uint16_t DeviceSize : 12; /* Device Size */
  33. uint8_t MaxRdCurrentVDDMin : 3; /* Max. read current @ VDD min */
  34. uint8_t MaxRdCurrentVDDMax : 3; /* Max. read current @ VDD max */
  35. uint8_t MaxWrCurrentVDDMin : 3; /* Max. write current @ VDD min */
  36. uint8_t MaxWrCurrentVDDMax : 3; /* Max. write current @ VDD max */
  37. uint8_t DeviceSizeMul : 3; /* Device size multiplier */
  38. } v1;
  39. struct {
  40. uint8_t Reserved1 : 6; /* Reserved */
  41. uint32_t DeviceSize : 22; /* Device Size */
  42. uint8_t Reserved2 : 1; /* Reserved */
  43. } v2;
  44. } version;
  45. uint8_t EraseSingleBlockEnable : 1; /* Erase single block enable */
  46. uint8_t EraseSectorSize : 7; /* Erase group size multiplier */
  47. uint8_t WrProtectGrSize : 7; /* Write protect group size */
  48. uint8_t WrProtectGrEnable : 1; /* Write protect group enable */
  49. uint8_t Reserved2 : 2; /* Reserved */
  50. uint8_t WrSpeedFact : 3; /* Write speed factor */
  51. uint8_t MaxWrBlockLen : 4; /* Max. write data block length */
  52. uint8_t WriteBlockPartial : 1; /* Partial blocks for write allowed */
  53. uint8_t Reserved3 : 5; /* Reserved */
  54. uint8_t FileFormatGrouop : 1; /* File format group */
  55. uint8_t CopyFlag : 1; /* Copy flag (OTP) */
  56. uint8_t PermWrProtect : 1; /* Permanent write protection */
  57. uint8_t TempWrProtect : 1; /* Temporary write protection */
  58. uint8_t FileFormat : 2; /* File Format */
  59. uint8_t Reserved4 : 2; /* Reserved */
  60. uint8_t crc : 7; /* Reserved */
  61. uint8_t Reserved5 : 1; /* always 1*/
  62. } SD_CSD;
  63. /**
  64. * @brief Card Identification Data: CID Register
  65. */
  66. typedef struct {
  67. uint8_t ManufacturerID; /* ManufacturerID */
  68. char OEM_AppliID[2]; /* OEM/Application ID */
  69. char ProdName[5]; /* Product Name */
  70. uint8_t ProdRev; /* Product Revision */
  71. uint32_t ProdSN; /* Product Serial Number */
  72. uint8_t Reserved1; /* Reserved1 */
  73. uint8_t ManufactYear; /* Manufacturing Year */
  74. uint8_t ManufactMonth; /* Manufacturing Month */
  75. uint8_t CID_CRC; /* CID CRC */
  76. uint8_t Reserved2; /* always 1 */
  77. } SD_CID;
  78. /**
  79. * @brief SD Card information structure
  80. */
  81. typedef struct {
  82. SD_CSD Csd;
  83. SD_CID Cid;
  84. uint64_t CardCapacity; /*!< Card Capacity */
  85. uint32_t CardBlockSize; /*!< Card Block Size */
  86. uint32_t LogBlockNbr; /*!< Specifies the Card logical Capacity in blocks */
  87. uint32_t LogBlockSize; /*!< Specifies logical block size in bytes */
  88. } SD_CardInfo;
  89. /**
  90. * @brief SD card max mount retry count
  91. *
  92. * @return uint8_t
  93. */
  94. uint8_t sd_max_mount_retry_count();
  95. /**
  96. * @brief Init sd card
  97. *
  98. * @param power_reset reset card power
  99. * @return SdSpiStatus
  100. */
  101. SdSpiStatus sd_init(bool power_reset);
  102. /**
  103. * @brief Get card state
  104. *
  105. * @return SdSpiStatus
  106. */
  107. SdSpiStatus sd_get_card_state(void);
  108. /**
  109. * @brief Get card info
  110. *
  111. * @param card_info
  112. * @return SdSpiStatus
  113. */
  114. SdSpiStatus sd_get_card_info(SD_CardInfo* card_info);
  115. /**
  116. * @brief Read blocks
  117. *
  118. * @param data
  119. * @param address
  120. * @param blocks
  121. * @param timeout_ms
  122. * @return SdSpiStatus
  123. */
  124. SdSpiStatus sd_read_blocks(uint32_t* data, uint32_t address, uint32_t blocks, uint32_t timeout_ms);
  125. /**
  126. * @brief Write blocks
  127. *
  128. * @param data
  129. * @param address
  130. * @param blocks
  131. * @param timeout_ms
  132. * @return SdSpiStatus
  133. */
  134. SdSpiStatus
  135. sd_write_blocks(uint32_t* data, uint32_t address, uint32_t blocks, uint32_t timeout_ms);
  136. /**
  137. * @brief Get card CSD register
  138. *
  139. * @param Cid
  140. * @return SdSpiStatus
  141. */
  142. SdSpiStatus sd_get_cid(SD_CID* cid);