sd_spi_io.h 4.5 KB

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