stm32f10x_sdio.h 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337
  1. /******************** (C) COPYRIGHT 2008 STMicroelectronics ********************
  2. * File Name : stm32f10x_sdio.h
  3. * Author : MCD Application Team
  4. * Version : V2.0.3
  5. * Date : 09/22/2008
  6. * Description : This file contains all the functions prototypes for the
  7. * SDIO firmware library.
  8. ********************************************************************************
  9. * THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
  10. * WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE TIME.
  11. * AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY DIRECT,
  12. * INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING FROM THE
  13. * CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE CODING
  14. * INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
  15. *******************************************************************************/
  16. /* Define to prevent recursive inclusion -------------------------------------*/
  17. #ifndef __STM32F10x_SDIO_H
  18. #define __STM32F10x_SDIO_H
  19. /* Includes ------------------------------------------------------------------*/
  20. #include "stm32f10x_map.h"
  21. /* Exported types ------------------------------------------------------------*/
  22. typedef struct
  23. {
  24. u8 SDIO_ClockDiv;
  25. u32 SDIO_ClockEdge;
  26. u32 SDIO_ClockBypass;
  27. u32 SDIO_ClockPowerSave;
  28. u32 SDIO_BusWide;
  29. u32 SDIO_HardwareFlowControl;
  30. } SDIO_InitTypeDef;
  31. typedef struct
  32. {
  33. u32 SDIO_Argument;
  34. u32 SDIO_CmdIndex;
  35. u32 SDIO_Response;
  36. u32 SDIO_Wait;
  37. u32 SDIO_CPSM;
  38. } SDIO_CmdInitTypeDef;
  39. typedef struct
  40. {
  41. u32 SDIO_DataTimeOut;
  42. u32 SDIO_DataLength;
  43. u32 SDIO_DataBlockSize;
  44. u32 SDIO_TransferDir;
  45. u32 SDIO_TransferMode;
  46. u32 SDIO_DPSM;
  47. } SDIO_DataInitTypeDef;
  48. /* Exported constants --------------------------------------------------------*/
  49. /* SDIO Clock Edge -----------------------------------------------------------*/
  50. #define SDIO_ClockEdge_Rising ((u32)0x00000000)
  51. #define SDIO_ClockEdge_Falling ((u32)0x00002000)
  52. #define IS_SDIO_CLOCK_EDGE(EDGE) (((EDGE) == SDIO_ClockEdge_Rising) || \
  53. ((EDGE) == SDIO_ClockEdge_Falling))
  54. /* SDIO Clock Bypass ----------------------------------------------------------*/
  55. #define SDIO_ClockBypass_Disable ((u32)0x00000000)
  56. #define SDIO_ClockBypass_Enable ((u32)0x00000400)
  57. #define IS_SDIO_CLOCK_BYPASS(BYPASS) (((BYPASS) == SDIO_ClockBypass_Disable) || \
  58. ((BYPASS) == SDIO_ClockBypass_Enable))
  59. /* SDIO Clock Power Save ----------------------------------------------------*/
  60. #define SDIO_ClockPowerSave_Disable ((u32)0x00000000)
  61. #define SDIO_ClockPowerSave_Enable ((u32)0x00000200)
  62. #define IS_SDIO_CLOCK_POWER_SAVE(SAVE) (((SAVE) == SDIO_ClockPowerSave_Disable) || \
  63. ((SAVE) == SDIO_ClockPowerSave_Enable))
  64. /* SDIO Bus Wide -------------------------------------------------------------*/
  65. #define SDIO_BusWide_1b ((u32)0x00000000)
  66. #define SDIO_BusWide_4b ((u32)0x00000800)
  67. #define SDIO_BusWide_8b ((u32)0x00001000)
  68. #define IS_SDIO_BUS_WIDE(WIDE) (((WIDE) == SDIO_BusWide_1b) || ((WIDE) == SDIO_BusWide_4b) || \
  69. ((WIDE) == SDIO_BusWide_8b))
  70. /* SDIO Hardware Flow Control -----------------------------------------------*/
  71. #define SDIO_HardwareFlowControl_Disable ((u32)0x00000000)
  72. #define SDIO_HardwareFlowControl_Enable ((u32)0x00004000)
  73. #define IS_SDIO_HARDWARE_FLOW_CONTROL(CONTROL) (((CONTROL) == SDIO_HardwareFlowControl_Disable) || \
  74. ((CONTROL) == SDIO_HardwareFlowControl_Enable))
  75. /* SDIO Power State ----------------------------------------------------------*/
  76. #define SDIO_PowerState_OFF ((u32)0x00000000)
  77. #define SDIO_PowerState_ON ((u32)0x00000003)
  78. #define IS_SDIO_POWER_STATE(STATE) (((STATE) == SDIO_PowerState_OFF) || ((STATE) == SDIO_PowerState_ON))
  79. /* SDIO Interrupt soucres ----------------------------------------------------*/
  80. #define SDIO_IT_CCRCFAIL ((u32)0x00000001)
  81. #define SDIO_IT_DCRCFAIL ((u32)0x00000002)
  82. #define SDIO_IT_CTIMEOUT ((u32)0x00000004)
  83. #define SDIO_IT_DTIMEOUT ((u32)0x00000008)
  84. #define SDIO_IT_TXUNDERR ((u32)0x00000010)
  85. #define SDIO_IT_RXOVERR ((u32)0x00000020)
  86. #define SDIO_IT_CMDREND ((u32)0x00000040)
  87. #define SDIO_IT_CMDSENT ((u32)0x00000080)
  88. #define SDIO_IT_DATAEND ((u32)0x00000100)
  89. #define SDIO_IT_STBITERR ((u32)0x00000200)
  90. #define SDIO_IT_DBCKEND ((u32)0x00000400)
  91. #define SDIO_IT_CMDACT ((u32)0x00000800)
  92. #define SDIO_IT_TXACT ((u32)0x00001000)
  93. #define SDIO_IT_RXACT ((u32)0x00002000)
  94. #define SDIO_IT_TXFIFOHE ((u32)0x00004000)
  95. #define SDIO_IT_RXFIFOHF ((u32)0x00008000)
  96. #define SDIO_IT_TXFIFOF ((u32)0x00010000)
  97. #define SDIO_IT_RXFIFOF ((u32)0x00020000)
  98. #define SDIO_IT_TXFIFOE ((u32)0x00040000)
  99. #define SDIO_IT_RXFIFOE ((u32)0x00080000)
  100. #define SDIO_IT_TXDAVL ((u32)0x00100000)
  101. #define SDIO_IT_RXDAVL ((u32)0x00200000)
  102. #define SDIO_IT_SDIOIT ((u32)0x00400000)
  103. #define SDIO_IT_CEATAEND ((u32)0x00800000)
  104. #define IS_SDIO_IT(IT) ((((IT) & (u32)0xFF000000) == 0x00) && ((IT) != (u32)0x00))
  105. /* SDIO Command Index -------------------------------------------------------*/
  106. #define IS_SDIO_CMD_INDEX(INDEX) ((INDEX) < 0x40)
  107. /* SDIO Response Type --------------------------------------------------------*/
  108. #define SDIO_Response_No ((u32)0x00000000)
  109. #define SDIO_Response_Short ((u32)0x00000040)
  110. #define SDIO_Response_Long ((u32)0x000000C0)
  111. #define IS_SDIO_RESPONSE(RESPONSE) (((RESPONSE) == SDIO_Response_No) || \
  112. ((RESPONSE) == SDIO_Response_Short) || \
  113. ((RESPONSE) == SDIO_Response_Long))
  114. /* SDIO Wait Interrupt State -------------------------------------------------*/
  115. #define SDIO_Wait_No ((u32)0x00000000) /* SDIO No Wait, TimeOut is enabled */
  116. #define SDIO_Wait_IT ((u32)0x00000100) /* SDIO Wait Interrupt Request */
  117. #define SDIO_Wait_Pend ((u32)0x00000200) /* SDIO Wait End of transfer */
  118. #define IS_SDIO_WAIT(WAIT) (((WAIT) == SDIO_Wait_No) || ((WAIT) == SDIO_Wait_IT) || \
  119. ((WAIT) == SDIO_Wait_Pend))
  120. /* SDIO CPSM State -----------------------------------------------------------*/
  121. #define SDIO_CPSM_Disable ((u32)0x00000000)
  122. #define SDIO_CPSM_Enable ((u32)0x00000400)
  123. #define IS_SDIO_CPSM(CPSM) (((CPSM) == SDIO_CPSM_Enable) || ((CPSM) == SDIO_CPSM_Disable))
  124. /* SDIO Response Registers ---------------------------------------------------*/
  125. #define SDIO_RESP1 ((u32)0x00000000)
  126. #define SDIO_RESP2 ((u32)0x00000004)
  127. #define SDIO_RESP3 ((u32)0x00000008)
  128. #define SDIO_RESP4 ((u32)0x0000000C)
  129. #define IS_SDIO_RESP(RESP) (((RESP) == SDIO_RESP1) || ((RESP) == SDIO_RESP2) || \
  130. ((RESP) == SDIO_RESP3) || ((RESP) == SDIO_RESP4))
  131. /* SDIO Data Length ----------------------------------------------------------*/
  132. #define IS_SDIO_DATA_LENGTH(LENGTH) ((LENGTH) <= 0x01FFFFFF)
  133. /* SDIO Data Block Size ------------------------------------------------------*/
  134. #define SDIO_DataBlockSize_1b ((u32)0x00000000)
  135. #define SDIO_DataBlockSize_2b ((u32)0x00000010)
  136. #define SDIO_DataBlockSize_4b ((u32)0x00000020)
  137. #define SDIO_DataBlockSize_8b ((u32)0x00000030)
  138. #define SDIO_DataBlockSize_16b ((u32)0x00000040)
  139. #define SDIO_DataBlockSize_32b ((u32)0x00000050)
  140. #define SDIO_DataBlockSize_64b ((u32)0x00000060)
  141. #define SDIO_DataBlockSize_128b ((u32)0x00000070)
  142. #define SDIO_DataBlockSize_256b ((u32)0x00000080)
  143. #define SDIO_DataBlockSize_512b ((u32)0x00000090)
  144. #define SDIO_DataBlockSize_1024b ((u32)0x000000A0)
  145. #define SDIO_DataBlockSize_2048b ((u32)0x000000B0)
  146. #define SDIO_DataBlockSize_4096b ((u32)0x000000C0)
  147. #define SDIO_DataBlockSize_8192b ((u32)0x000000D0)
  148. #define SDIO_DataBlockSize_16384b ((u32)0x000000E0)
  149. #define IS_SDIO_BLOCK_SIZE(SIZE) (((SIZE) == SDIO_DataBlockSize_1b) || \
  150. ((SIZE) == SDIO_DataBlockSize_2b) || \
  151. ((SIZE) == SDIO_DataBlockSize_4b) || \
  152. ((SIZE) == SDIO_DataBlockSize_8b) || \
  153. ((SIZE) == SDIO_DataBlockSize_16b) || \
  154. ((SIZE) == SDIO_DataBlockSize_32b) || \
  155. ((SIZE) == SDIO_DataBlockSize_64b) || \
  156. ((SIZE) == SDIO_DataBlockSize_128b) || \
  157. ((SIZE) == SDIO_DataBlockSize_256b) || \
  158. ((SIZE) == SDIO_DataBlockSize_512b) || \
  159. ((SIZE) == SDIO_DataBlockSize_1024b) || \
  160. ((SIZE) == SDIO_DataBlockSize_2048b) || \
  161. ((SIZE) == SDIO_DataBlockSize_4096b) || \
  162. ((SIZE) == SDIO_DataBlockSize_8192b) || \
  163. ((SIZE) == SDIO_DataBlockSize_16384b))
  164. /* SDIO Transfer Direction ---------------------------------------------------*/
  165. #define SDIO_TransferDir_ToCard ((u32)0x00000000)
  166. #define SDIO_TransferDir_ToSDIO ((u32)0x00000002)
  167. #define IS_SDIO_TRANSFER_DIR(DIR) (((DIR) == SDIO_TransferDir_ToCard) || \
  168. ((DIR) == SDIO_TransferDir_ToSDIO))
  169. /* SDIO Transfer Type --------------------------------------------------------*/
  170. #define SDIO_TransferMode_Block ((u32)0x00000000)
  171. #define SDIO_TransferMode_Stream ((u32)0x00000004)
  172. #define IS_SDIO_TRANSFER_MODE(MODE) (((MODE) == SDIO_TransferMode_Stream) || \
  173. ((MODE) == SDIO_TransferMode_Block))
  174. /* SDIO DPSM State -----------------------------------------------------------*/
  175. #define SDIO_DPSM_Disable ((u32)0x00000000)
  176. #define SDIO_DPSM_Enable ((u32)0x00000001)
  177. #define IS_SDIO_DPSM(DPSM) (((DPSM) == SDIO_DPSM_Enable) || ((DPSM) == SDIO_DPSM_Disable))
  178. /* SDIO Flags ----------------------------------------------------------------*/
  179. #define SDIO_FLAG_CCRCFAIL ((u32)0x00000001)
  180. #define SDIO_FLAG_DCRCFAIL ((u32)0x00000002)
  181. #define SDIO_FLAG_CTIMEOUT ((u32)0x00000004)
  182. #define SDIO_FLAG_DTIMEOUT ((u32)0x00000008)
  183. #define SDIO_FLAG_TXUNDERR ((u32)0x00000010)
  184. #define SDIO_FLAG_RXOVERR ((u32)0x00000020)
  185. #define SDIO_FLAG_CMDREND ((u32)0x00000040)
  186. #define SDIO_FLAG_CMDSENT ((u32)0x00000080)
  187. #define SDIO_FLAG_DATAEND ((u32)0x00000100)
  188. #define SDIO_FLAG_STBITERR ((u32)0x00000200)
  189. #define SDIO_FLAG_DBCKEND ((u32)0x00000400)
  190. #define SDIO_FLAG_CMDACT ((u32)0x00000800)
  191. #define SDIO_FLAG_TXACT ((u32)0x00001000)
  192. #define SDIO_FLAG_RXACT ((u32)0x00002000)
  193. #define SDIO_FLAG_TXFIFOHE ((u32)0x00004000)
  194. #define SDIO_FLAG_RXFIFOHF ((u32)0x00008000)
  195. #define SDIO_FLAG_TXFIFOF ((u32)0x00010000)
  196. #define SDIO_FLAG_RXFIFOF ((u32)0x00020000)
  197. #define SDIO_FLAG_TXFIFOE ((u32)0x00040000)
  198. #define SDIO_FLAG_RXFIFOE ((u32)0x00080000)
  199. #define SDIO_FLAG_TXDAVL ((u32)0x00100000)
  200. #define SDIO_FLAG_RXDAVL ((u32)0x00200000)
  201. #define SDIO_FLAG_SDIOIT ((u32)0x00400000)
  202. #define SDIO_FLAG_CEATAEND ((u32)0x00800000)
  203. #define IS_SDIO_FLAG(FLAG) (((FLAG) == SDIO_FLAG_CCRCFAIL) || \
  204. ((FLAG) == SDIO_FLAG_DCRCFAIL) || \
  205. ((FLAG) == SDIO_FLAG_CTIMEOUT) || \
  206. ((FLAG) == SDIO_FLAG_DTIMEOUT) || \
  207. ((FLAG) == SDIO_FLAG_TXUNDERR) || \
  208. ((FLAG) == SDIO_FLAG_RXOVERR) || \
  209. ((FLAG) == SDIO_FLAG_CMDREND) || \
  210. ((FLAG) == SDIO_FLAG_CMDSENT) || \
  211. ((FLAG) == SDIO_FLAG_DATAEND) || \
  212. ((FLAG) == SDIO_FLAG_STBITERR) || \
  213. ((FLAG) == SDIO_FLAG_DBCKEND) || \
  214. ((FLAG) == SDIO_FLAG_CMDACT) || \
  215. ((FLAG) == SDIO_FLAG_TXACT) || \
  216. ((FLAG) == SDIO_FLAG_RXACT) || \
  217. ((FLAG) == SDIO_FLAG_TXFIFOHE) || \
  218. ((FLAG) == SDIO_FLAG_RXFIFOHF) || \
  219. ((FLAG) == SDIO_FLAG_TXFIFOF) || \
  220. ((FLAG) == SDIO_FLAG_RXFIFOF) || \
  221. ((FLAG) == SDIO_FLAG_TXFIFOE) || \
  222. ((FLAG) == SDIO_FLAG_RXFIFOE) || \
  223. ((FLAG) == SDIO_FLAG_TXDAVL) || \
  224. ((FLAG) == SDIO_FLAG_RXDAVL) || \
  225. ((FLAG) == SDIO_FLAG_SDIOIT) || \
  226. ((FLAG) == SDIO_FLAG_CEATAEND))
  227. #define IS_SDIO_CLEAR_FLAG(FLAG) ((((FLAG) & (u32)0xFF3FF800) == 0x00) && ((FLAG) != (u32)0x00))
  228. #define IS_SDIO_GET_IT(IT) (((IT) == SDIO_IT_CCRCFAIL) || \
  229. ((IT) == SDIO_IT_DCRCFAIL) || \
  230. ((IT) == SDIO_IT_CTIMEOUT) || \
  231. ((IT) == SDIO_IT_DTIMEOUT) || \
  232. ((IT) == SDIO_IT_TXUNDERR) || \
  233. ((IT) == SDIO_IT_RXOVERR) || \
  234. ((IT) == SDIO_IT_CMDREND) || \
  235. ((IT) == SDIO_IT_CMDSENT) || \
  236. ((IT) == SDIO_IT_DATAEND) || \
  237. ((IT) == SDIO_IT_STBITERR) || \
  238. ((IT) == SDIO_IT_DBCKEND) || \
  239. ((IT) == SDIO_IT_CMDACT) || \
  240. ((IT) == SDIO_IT_TXACT) || \
  241. ((IT) == SDIO_IT_RXACT) || \
  242. ((IT) == SDIO_IT_TXFIFOHE) || \
  243. ((IT) == SDIO_IT_RXFIFOHF) || \
  244. ((IT) == SDIO_IT_TXFIFOF) || \
  245. ((IT) == SDIO_IT_RXFIFOF) || \
  246. ((IT) == SDIO_IT_TXFIFOE) || \
  247. ((IT) == SDIO_IT_RXFIFOE) || \
  248. ((IT) == SDIO_IT_TXDAVL) || \
  249. ((IT) == SDIO_IT_RXDAVL) || \
  250. ((IT) == SDIO_IT_SDIOIT) || \
  251. ((IT) == SDIO_IT_CEATAEND))
  252. #define IS_SDIO_CLEAR_IT(IT) ((((IT) & (u32)0xFF3FF800) == 0x00) && ((IT) != (u32)0x00))
  253. /* SDIO Read Wait Mode -------------------------------------------------------*/
  254. #define SDIO_ReadWaitMode_CLK ((u32)0x00000000)
  255. #define SDIO_ReadWaitMode_DATA2 ((u32)0x00000001)
  256. #define IS_SDIO_READWAIT_MODE(MODE) (((MODE) == SDIO_ReadWaitMode_CLK) || \
  257. ((MODE) == SDIO_ReadWaitMode_DATA2))
  258. /* Exported macro ------------------------------------------------------------*/
  259. /* Exported functions ------------------------------------------------------- */
  260. void SDIO_DeInit(void);
  261. void SDIO_Init(SDIO_InitTypeDef* SDIO_InitStruct);
  262. void SDIO_StructInit(SDIO_InitTypeDef* SDIO_InitStruct);
  263. void SDIO_ClockCmd(FunctionalState NewState);
  264. void SDIO_SetPowerState(u32 SDIO_PowerState);
  265. u32 SDIO_GetPowerState(void);
  266. void SDIO_ITConfig(u32 SDIO_IT, FunctionalState NewState);
  267. void SDIO_DMACmd(FunctionalState NewState);
  268. void SDIO_SendCommand(SDIO_CmdInitTypeDef *SDIO_CmdInitStruct);
  269. void SDIO_CmdStructInit(SDIO_CmdInitTypeDef* SDIO_CmdInitStruct);
  270. u8 SDIO_GetCommandResponse(void);
  271. u32 SDIO_GetResponse(u32 SDIO_RESP);
  272. void SDIO_DataConfig(SDIO_DataInitTypeDef* SDIO_DataInitStruct);
  273. void SDIO_DataStructInit(SDIO_DataInitTypeDef* SDIO_DataInitStruct);
  274. u32 SDIO_GetDataCounter(void);
  275. u32 SDIO_ReadData(void);
  276. void SDIO_WriteData(u32 Data);
  277. u32 SDIO_GetFIFOCount(void);
  278. void SDIO_StartSDIOReadWait(FunctionalState NewState);
  279. void SDIO_StopSDIOReadWait(FunctionalState NewState);
  280. void SDIO_SetSDIOReadWaitMode(u32 SDIO_ReadWaitMode);
  281. void SDIO_SetSDIOOperation(FunctionalState NewState);
  282. void SDIO_SendSDIOSuspendCmd(FunctionalState NewState);
  283. void SDIO_CommandCompletionCmd(FunctionalState NewState);
  284. void SDIO_CEATAITCmd(FunctionalState NewState);
  285. void SDIO_SendCEATACmd(FunctionalState NewState);
  286. FlagStatus SDIO_GetFlagStatus(u32 SDIO_FLAG);
  287. void SDIO_ClearFlag(u32 SDIO_FLAG);
  288. ITStatus SDIO_GetITStatus(u32 SDIO_IT);
  289. void SDIO_ClearITPendingBit(u32 SDIO_IT);
  290. #endif /* __STM32F10x_SDIO_H */
  291. /******************* (C) COPYRIGHT 2008 STMicroelectronics *****END OF FILE****/