fsl_sdmmc_common.h 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258
  1. /*
  2. * Copyright (c) 2015, Freescale Semiconductor, Inc.
  3. * Copyright 2016-2018 NXP
  4. * All rights reserved.
  5. *
  6. * SPDX-License-Identifier: BSD-3-Clause
  7. */
  8. #ifndef _FSL_SDMMC_COMMON_H_
  9. #define _FSL_SDMMC_COMMON_H_
  10. #include "fsl_common.h"
  11. #include "fsl_sdmmc_host.h"
  12. #include "fsl_sdmmc_spec.h"
  13. #include "stdlib.h"
  14. /*!
  15. * @addtogroup CARD
  16. * @{
  17. */
  18. /*******************************************************************************
  19. * Definitions
  20. ******************************************************************************/
  21. /*! @brief Middleware version. */
  22. #define FSL_SDMMC_DRIVER_VERSION (MAKE_VERSION(2U, 2U, 11U)) /*2.2.11*/
  23. /*! @brief Reverse byte sequence in uint32_t */
  24. #define SWAP_WORD_BYTE_SEQUENCE(x) (__REV(x))
  25. /*! @brief Reverse byte sequence for each half word in uint32_t */
  26. #define SWAP_HALF_WROD_BYTE_SEQUENCE(x) (__REV16(x))
  27. /*! @brief Maximum loop count to check the card operation voltage range */
  28. #define FSL_SDMMC_MAX_VOLTAGE_RETRIES (1000U)
  29. /*! @brief Maximum loop count to send the cmd */
  30. #define FSL_SDMMC_MAX_CMD_RETRIES (10U)
  31. /*! @brief Default block size */
  32. #define FSL_SDMMC_DEFAULT_BLOCK_SIZE (512U)
  33. #ifndef SDMMC_GLOBAL_BUFFER_SIZE
  34. /*! @brief SDMMC global data buffer size, word unit*/
  35. #define SDMMC_GLOBAL_BUFFER_SIZE (128U)
  36. #endif
  37. /*! @brief SDMMC enable software tuning */
  38. #define SDMMC_ENABLE_SOFTWARE_TUNING (0U)
  39. /* Common definition for cache line size align */
  40. #if defined(FSL_SDK_ENABLE_DRIVER_CACHE_CONTROL) && FSL_SDK_ENABLE_DRIVER_CACHE_CONTROL
  41. #if defined(FSL_FEATURE_L1DCACHE_LINESIZE_BYTE)
  42. #if defined(FSL_FEATURE_L2DCACHE_LINESIZE_BYTE)
  43. #define SDMMC_DATA_BUFFER_ALIGN_CACHE MAX(FSL_FEATURE_L1DCACHE_LINESIZE_BYTE, FSL_FEATURE_L2DCACHE_LINESIZE_BYTE)
  44. #else
  45. #define SDMMC_DATA_BUFFER_ALIGN_CACHE FSL_FEATURE_L1DCACHE_LINESIZE_BYTE
  46. #endif
  47. #else
  48. #define SDMMC_DATA_BUFFER_ALIGN_CACHE 1
  49. #endif
  50. #else
  51. #define SDMMC_DATA_BUFFER_ALIGN_CACHE 1
  52. #endif
  53. /*! @brief SD/MMC error log. */
  54. #if defined SDMMC_ENABLE_LOG_PRINT
  55. #include "fsl_debug_console.h"
  56. #define SDMMC_LOG(...) PRINTF(__VA_ARGS__)
  57. #else
  58. #define SDMMC_LOG(format, ...)
  59. #endif
  60. /*! @brief SD/MMC card API's running status. */
  61. enum _sdmmc_status
  62. {
  63. kStatus_SDMMC_NotSupportYet = MAKE_STATUS(kStatusGroup_SDMMC, 0U), /*!< Haven't supported */
  64. kStatus_SDMMC_TransferFailed = MAKE_STATUS(kStatusGroup_SDMMC, 1U), /*!< Send command failed */
  65. kStatus_SDMMC_SetCardBlockSizeFailed = MAKE_STATUS(kStatusGroup_SDMMC, 2U), /*!< Set block size failed */
  66. kStatus_SDMMC_HostNotSupport = MAKE_STATUS(kStatusGroup_SDMMC, 3U), /*!< Host doesn't support */
  67. kStatus_SDMMC_CardNotSupport = MAKE_STATUS(kStatusGroup_SDMMC, 4U), /*!< Card doesn't support */
  68. kStatus_SDMMC_AllSendCidFailed = MAKE_STATUS(kStatusGroup_SDMMC, 5U), /*!< Send CID failed */
  69. kStatus_SDMMC_SendRelativeAddressFailed = MAKE_STATUS(kStatusGroup_SDMMC, 6U), /*!< Send relative address failed */
  70. kStatus_SDMMC_SendCsdFailed = MAKE_STATUS(kStatusGroup_SDMMC, 7U), /*!< Send CSD failed */
  71. kStatus_SDMMC_SelectCardFailed = MAKE_STATUS(kStatusGroup_SDMMC, 8U), /*!< Select card failed */
  72. kStatus_SDMMC_SendScrFailed = MAKE_STATUS(kStatusGroup_SDMMC, 9U), /*!< Send SCR failed */
  73. kStatus_SDMMC_SetDataBusWidthFailed = MAKE_STATUS(kStatusGroup_SDMMC, 10U), /*!< Set bus width failed */
  74. kStatus_SDMMC_GoIdleFailed = MAKE_STATUS(kStatusGroup_SDMMC, 11U), /*!< Go idle failed */
  75. kStatus_SDMMC_HandShakeOperationConditionFailed =
  76. MAKE_STATUS(kStatusGroup_SDMMC, 12U), /*!< Send Operation Condition failed */
  77. kStatus_SDMMC_SendApplicationCommandFailed =
  78. MAKE_STATUS(kStatusGroup_SDMMC, 13U), /*!< Send application command failed */
  79. kStatus_SDMMC_SwitchFailed = MAKE_STATUS(kStatusGroup_SDMMC, 14U), /*!< Switch command failed */
  80. kStatus_SDMMC_StopTransmissionFailed = MAKE_STATUS(kStatusGroup_SDMMC, 15U), /*!< Stop transmission failed */
  81. kStatus_SDMMC_WaitWriteCompleteFailed = MAKE_STATUS(kStatusGroup_SDMMC, 16U), /*!< Wait write complete failed */
  82. kStatus_SDMMC_SetBlockCountFailed = MAKE_STATUS(kStatusGroup_SDMMC, 17U), /*!< Set block count failed */
  83. kStatus_SDMMC_SetRelativeAddressFailed = MAKE_STATUS(kStatusGroup_SDMMC, 18U), /*!< Set relative address failed */
  84. kStatus_SDMMC_SwitchBusTimingFailed = MAKE_STATUS(kStatusGroup_SDMMC, 19U), /*!< Switch high speed failed */
  85. kStatus_SDMMC_SendExtendedCsdFailed = MAKE_STATUS(kStatusGroup_SDMMC, 20U), /*!< Send EXT_CSD failed */
  86. kStatus_SDMMC_ConfigureBootFailed = MAKE_STATUS(kStatusGroup_SDMMC, 21U), /*!< Configure boot failed */
  87. kStatus_SDMMC_ConfigureExtendedCsdFailed = MAKE_STATUS(kStatusGroup_SDMMC, 22U), /*!< Configure EXT_CSD failed */
  88. kStatus_SDMMC_EnableHighCapacityEraseFailed =
  89. MAKE_STATUS(kStatusGroup_SDMMC, 23U), /*!< Enable high capacity erase failed */
  90. kStatus_SDMMC_SendTestPatternFailed = MAKE_STATUS(kStatusGroup_SDMMC, 24U), /*!< Send test pattern failed */
  91. kStatus_SDMMC_ReceiveTestPatternFailed = MAKE_STATUS(kStatusGroup_SDMMC, 25U), /*!< Receive test pattern failed */
  92. kStatus_SDMMC_SDIO_ResponseError = MAKE_STATUS(kStatusGroup_SDMMC, 26U), /*!< sdio response error */
  93. kStatus_SDMMC_SDIO_InvalidArgument =
  94. MAKE_STATUS(kStatusGroup_SDMMC, 27U), /*!< sdio invalid argument response error */
  95. kStatus_SDMMC_SDIO_SendOperationConditionFail =
  96. MAKE_STATUS(kStatusGroup_SDMMC, 28U), /*!< sdio send operation condition fail */
  97. kStatus_SDMMC_InvalidVoltage = MAKE_STATUS(kStatusGroup_SDMMC, 29U), /*!< invaild voltage */
  98. kStatus_SDMMC_SDIO_SwitchHighSpeedFail = MAKE_STATUS(kStatusGroup_SDMMC, 30U), /*!< switch to high speed fail */
  99. kStatus_SDMMC_SDIO_ReadCISFail = MAKE_STATUS(kStatusGroup_SDMMC, 31U), /*!< read CIS fail */
  100. kStatus_SDMMC_SDIO_InvalidCard = MAKE_STATUS(kStatusGroup_SDMMC, 32U), /*!< invaild SDIO card */
  101. kStatus_SDMMC_TuningFail = MAKE_STATUS(kStatusGroup_SDMMC, 33U), /*!< tuning fail */
  102. kStatus_SDMMC_SwitchVoltageFail = MAKE_STATUS(kStatusGroup_SDMMC, 34U), /*!< switch voltage fail*/
  103. kStatus_SDMMC_SwitchVoltage18VFail33VSuccess = MAKE_STATUS(kStatusGroup_SDMMC, 35U), /*!< switch voltage fail*/
  104. kStatus_SDMMC_ReTuningRequest = MAKE_STATUS(kStatusGroup_SDMMC, 36U), /*!< retuning request */
  105. kStatus_SDMMC_SetDriverStrengthFail = MAKE_STATUS(kStatusGroup_SDMMC, 37U), /*!< set driver strength fail */
  106. kStatus_SDMMC_SetPowerClassFail = MAKE_STATUS(kStatusGroup_SDMMC, 38U), /*!< set power class fail */
  107. kStatus_SDMMC_HostNotReady = MAKE_STATUS(kStatusGroup_SDMMC, 39U), /*!< host controller not ready */
  108. kStatus_SDMMC_CardDetectFailed = MAKE_STATUS(kStatusGroup_SDMMC, 40U), /*!< card detect failed */
  109. kStatus_SDMMC_AuSizeNotSetProperly = MAKE_STATUS(kStatusGroup_SDMMC, 41U), /*!< AU size not set properly */
  110. };
  111. /*! @brief card operation voltage */
  112. typedef enum _sdmmc_operation_voltage
  113. {
  114. kCARD_OperationVoltageNone = 0U, /*!< indicate current voltage setting is not setting by suser*/
  115. kCARD_OperationVoltage330V = 1U, /*!< card operation voltage around 3.3v */
  116. kCARD_OperationVoltage300V = 2U, /*!< card operation voltage around 3.0v */
  117. kCARD_OperationVoltage180V = 3U, /*!< card operation voltage around 1.8v */
  118. } sdmmc_operation_voltage_t;
  119. /*************************************************************************************************
  120. * API
  121. ************************************************************************************************/
  122. #if defined(__cplusplus)
  123. extern "C" {
  124. #endif
  125. /*!
  126. * @name common function
  127. * @{
  128. */
  129. /*!
  130. * @brief Selects the card to put it into transfer state.
  131. *
  132. * @param base SDMMCHOST peripheral base address.
  133. * @param transfer SDMMCHOST transfer function.
  134. * @param relativeAddress Relative address.
  135. * @param isSelected True to put card into transfer state.
  136. * @retval kStatus_SDMMC_TransferFailed Transfer failed.
  137. * @retval kStatus_Success Operate successfully.
  138. */
  139. status_t SDMMC_SelectCard(SDMMCHOST_TYPE *base,
  140. SDMMCHOST_TRANSFER_FUNCTION transfer,
  141. uint32_t relativeAddress,
  142. bool isSelected);
  143. /*!
  144. * @brief Sends an application command.
  145. *
  146. * @param base SDMMCHOST peripheral base address.
  147. * @param transfer SDMMCHOST transfer function.
  148. * @param relativeAddress Card relative address.
  149. * @retval kStatus_SDMMC_TransferFailed Transfer failed.
  150. * @retval kStatus_SDMMC_CardNotSupport Card doesn't support.
  151. * @retval kStatus_Success Operate successfully.
  152. */
  153. status_t SDMMC_SendApplicationCommand(SDMMCHOST_TYPE *base,
  154. SDMMCHOST_TRANSFER_FUNCTION transfer,
  155. uint32_t relativeAddress);
  156. /*!
  157. * @brief Sets the block count.
  158. *
  159. * @param base SDMMCHOST peripheral base address.
  160. * @param transfer SDMMCHOST transfer function.
  161. * @param blockCount Block count.
  162. * @retval kStatus_SDMMC_TransferFailed Transfer failed.
  163. * @retval kStatus_Success Operate successfully.
  164. */
  165. status_t SDMMC_SetBlockCount(SDMMCHOST_TYPE *base, SDMMCHOST_TRANSFER_FUNCTION transfer, uint32_t blockCount);
  166. /*!
  167. * @brief Sets the card to be idle state.
  168. *
  169. * @param base SDMMCHOST peripheral base address.
  170. * @param transfer SDMMCHOST transfer function.
  171. * @retval kStatus_SDMMC_TransferFailed Transfer failed.
  172. * @retval kStatus_Success Operate successfully.
  173. */
  174. status_t SDMMC_GoIdle(SDMMCHOST_TYPE *base, SDMMCHOST_TRANSFER_FUNCTION transfer);
  175. /*!
  176. * @brief Sets data block size.
  177. *
  178. * @param base SDMMCHOST peripheral base address.
  179. * @param transfer SDMMCHOST transfer function.
  180. * @param blockSize Block size.
  181. * @retval kStatus_SDMMC_TransferFailed Transfer failed.
  182. * @retval kStatus_Success Operate successfully.
  183. */
  184. status_t SDMMC_SetBlockSize(SDMMCHOST_TYPE *base, SDMMCHOST_TRANSFER_FUNCTION transfer, uint32_t blockSize);
  185. /*!
  186. * @brief Sets card to inactive status
  187. *
  188. * @param base SDMMCHOST peripheral base address.
  189. * @param transfer SDMMCHOST transfer function.
  190. * @retval kStatus_SDMMC_TransferFailed Transfer failed.
  191. * @retval kStatus_Success Operate successfully.
  192. */
  193. status_t SDMMC_SetCardInactive(SDMMCHOST_TYPE *base, SDMMCHOST_TRANSFER_FUNCTION transfer);
  194. /*!
  195. * @brief provide a simple delay function for sdmmc
  196. *
  197. * @param num Delay num*10000.
  198. */
  199. void SDMMC_Delay(uint32_t num);
  200. /*!
  201. * @brief provide a voltage switch function for SD/SDIO card
  202. * @deprecated Do not use this function, it has been superceded by SDMMC_SwitchToVoltage.
  203. * @param base SDMMCHOST peripheral base address.
  204. * @param transfer SDMMCHOST transfer function.
  205. */
  206. status_t SDMMC_SwitchVoltage(SDMMCHOST_TYPE *base, SDMMCHOST_TRANSFER_FUNCTION transfer);
  207. /*!
  208. * @brief provide a voltage switch function for SD/SDIO card
  209. *
  210. * @param base SDMMCHOST peripheral base address.
  211. * @param transfer SDMMCHOST transfer function.
  212. * @param switchVoltageFunc voltage switch function.
  213. * @return error code.
  214. */
  215. status_t SDMMC_SwitchToVoltage(SDMMCHOST_TYPE *base,
  216. SDMMCHOST_TRANSFER_FUNCTION transfer,
  217. sdmmchost_card_switch_voltage_t switchVoltageFunc);
  218. /*!
  219. * @brief excute tuning
  220. *
  221. * @param base SDMMCHOST peripheral base address.
  222. * @param transfer Host transfer function
  223. * @param tuningCmd Tuning cmd
  224. * @param blockSize Tuning block size
  225. */
  226. status_t SDMMC_ExecuteTuning(SDMMCHOST_TYPE *base,
  227. SDMMCHOST_TRANSFER_FUNCTION transfer,
  228. uint32_t tuningCmd,
  229. uint32_t blockSize);
  230. /* @} */
  231. #if defined(__cplusplus)
  232. }
  233. #endif
  234. /* @} */
  235. #endif /* _FSL_SDMMC_COMMON_H_ */