drv_spi.h 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414
  1. /*
  2. * Copyright (c) 2006-2021, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2018-02-08 RT-Thread the first version
  9. */
  10. #ifndef __DRV_SPI_H__
  11. #define __DRV_SPI_H__
  12. #ifdef __cplusplus
  13. extern "C" {
  14. #endif
  15. /********************** private ************************************/
  16. #define SPI0_BASE_ADDR (0x01C05000)
  17. #define SPI1_BASE_ADDR (0x01C06000)
  18. /**
  19. * @brief Serial Peripheral Interface
  20. */
  21. typedef struct
  22. {
  23. volatile rt_uint32_t VER; /* SPI Version number Register, Address offset: 0x00 */
  24. volatile rt_uint32_t CTRL; /* SPI Global Control Register, Address offset: 0x04 */
  25. volatile rt_uint32_t TCTRL; /* SPI Transfer Control Register, Address offset: 0x08 */
  26. volatile rt_uint32_t RESERVED1[1]; /* Reserved, 0x0C */
  27. volatile rt_uint32_t IER; /* SPI Interrupt Control Register, Address offset: 0x10 */
  28. volatile rt_uint32_t STA; /* SPI Interrupt Status Register, Address offset: 0x14 */
  29. volatile rt_uint32_t FCTL; /* SPI FIFO Control Register, Address offset: 0x18 */
  30. volatile rt_uint32_t FST; /* SPI FIFO Status Register, Address offset: 0x1C */
  31. volatile rt_uint32_t WAIT; /* SPI Wait Clock Counter Register, Address offset: 0x20 */
  32. volatile rt_uint32_t CCTR; /* SPI Clock Rate Control Register, Address offset: 0x24 */
  33. volatile rt_uint32_t RESERVED2[2]; /* Reserved, 0x28-0x2C */
  34. volatile rt_uint32_t BC; /* SPI Master mode Burst Control Register, Address offset: 0x30 */
  35. volatile rt_uint32_t TC; /* SPI Master mode Transmit Counter Register, Address offset: 0x34 */
  36. volatile rt_uint32_t BCC; /* SPI Burst Control Register, Address offset: 0x38 */
  37. volatile rt_uint32_t RESERVED3[19]; /* Reserved, 0x3C-0x84 */
  38. volatile rt_uint32_t NDMA_MODE_CTRL; /* SPI Nomal DMA Mode Control Regist Address offset: 0x88 */
  39. volatile rt_uint32_t RESERVED4[93]; /* Reserved, 0x8C-0x1FC */
  40. volatile rt_uint32_t TXD; /* SPI TX Date Register, Address offset: 0x200 */
  41. volatile rt_uint32_t RESERVED5[63]; /* Reserved, 0x204-0x2FC */
  42. volatile rt_uint32_t RXD; /* SPI RX Date Register, Address offset: 0x300 */
  43. } SPI_T;
  44. /*
  45. * @brief SPI Global Control Register
  46. */
  47. #define SPI_CTRL_RST_SHIFT (31)
  48. #define SPI_CTRL_RST_MASK (0x1U << SPI_CTRL_RST_SHIFT)
  49. #define SPI_CTRL_TP_EN_SHIFT (7)
  50. #define SPI_CTRL_TP_EN_MASK (0x1U << SPI_CTRL_TP_EN_SHIFT)
  51. #define SPI_CTRL_MODE_SHIFT (1)
  52. #define SPI_CTRL_MODE_MASK (0x1U << SPI_CTRL_MODE_SHIFT)
  53. typedef enum
  54. {
  55. SPI_CTRL_MODE_SLAVE = 0 << SPI_CTRL_MODE_SHIFT,
  56. SPI_CTRL_MODE_MASTER = 1 << SPI_CTRL_MODE_SHIFT
  57. } SPI_CTRL_Mode;
  58. #define SPI_CTRL_EN_SHIFT (0)
  59. #define SPI_CTRL_EN_MASK (0x1U << SPI_CTRL_EN_SHIFT)
  60. typedef enum
  61. {
  62. SPI_CTRL_EN_DISABLE = 0 << SPI_CTRL_EN_SHIFT,
  63. SPI_CTRL_EN_ENABLE = 1 << SPI_CTRL_EN_SHIFT
  64. } SPI_CTRL_En;
  65. /*
  66. * @brief SPI Transfer Control Register
  67. */
  68. #define SPI_TCTRL_XCH_SHIFT (31)
  69. #define SPI_TCTRL_XCH_MASK (0x1U << SPI_TCTRL_XCH_SHIFT)
  70. typedef enum
  71. {
  72. SPI_TCTRL_XCH_IDLE = 0 << SPI_TCTRL_XCH_SHIFT,
  73. SPI_TCTRL_XCH_START = 1 << SPI_TCTRL_XCH_SHIFT
  74. } SPI_TCTRL_Xch;
  75. #define SPI_TCTRL_SDDM_SHIFT (14)
  76. #define SPI_TCTRL_SDDM_MASK (0x0U << SPI_TCTRL_SDDM_SHIFT)
  77. typedef enum
  78. {
  79. SPI_TCTRL_SDDM_SEND_NODELAY = 0 << SPI_TCTRL_SDDM_SHIFT,
  80. SPI_TCTRL_SDDM_SEND_DELAY = 1 << SPI_TCTRL_SDDM_SHIFT
  81. } SPI_TCTRL_Sddm;
  82. #define SPI_TCTRL_SDM_SHIFT (13)
  83. #define SPI_TCTRL_SDM_MASK (0x1U << SPI_TCTRL_SDM_SHIFT)
  84. typedef enum
  85. {
  86. SPI_TCTRL_SDM_SAMPLE_NODELAY = 1 << SPI_TCTRL_SDM_SHIFT,
  87. SPI_TCTRL_SDM_SAMPLE_DELAY = 0 << SPI_TCTRL_SDM_SHIFT
  88. } SPI_TCTRL_Sdm;
  89. #define SPI_TCTRL_FBS_SHIFT (12)
  90. #define SPI_TCTRL_FBS_MASK (0x1U << SPI_TCTRL_FBS_SHIFT)
  91. typedef enum
  92. {
  93. SPI_TCTRL_FBS_MSB = 0 << SPI_TCTRL_FBS_SHIFT,
  94. SPI_TCTRL_FBS_LSB = 1 << SPI_TCTRL_FBS_SHIFT
  95. } SPI_TCTRL_Fbs;
  96. #define SPI_TCTRL_SDC_SHIFT (11)
  97. #define SPI_TCTRL_SDC_MASK (0x1U << SPI_TCTRL_SDC_SHIFT)
  98. #define SPI_TCTRL_RPSM_SHIFT (10)
  99. #define SPI_TCTRL_RPSM_MASK (0x1U << SPI_TCTRL_RPSM_SHIFT)
  100. #define SPI_TCTRL_DDB_SHIFT (9)
  101. #define SPI_TCTRL_DDB_MASK (0x1U << SPI_TCTRL_DDB_SHIFT)
  102. #define SPI_TCTRL_DHB_SHIFT (8)
  103. #define SPI_TCTRL_DHB_MASK (0x1U << SPI_TCTRL_DHB_SHIFT)
  104. typedef enum
  105. {
  106. SPI_TCTRL_DHB_FULL_DUPLEX = 0 << SPI_TCTRL_DHB_SHIFT,
  107. SPI_TCTRL_DHB_HALF_DUPLEX = 1 << SPI_TCTRL_DHB_SHIFT
  108. } SPI_TCTRL_DHB_Duplex;
  109. #define SPI_TCTRL_SS_LEVEL_SHIFT (7)
  110. #define SPI_TCTRL_SS_LEVEL_MASK (0x1U << SPI_TCTRL_SS_LEVEL_SHIFT)
  111. #define SPI_TCTRL_SS_OWNER_SHIFT (6)
  112. #define SPI_TCTRL_SS_OWNER_MASK (0x1U << SPI_TCTRL_SS_OWNER_SHIFT)
  113. typedef enum
  114. {
  115. SPI_TCTRL_SS_OWNER_CONTROLLER = 0 << SPI_TCTRL_SS_OWNER_SHIFT,
  116. SPI_TCTRL_SS_OWNER_SOFTWARE = 1 << SPI_TCTRL_SS_OWNER_SHIFT
  117. } SPI_TCTRL_SS_OWNER;
  118. #define SPI_TCTRL_SS_SEL_SHIFT (4)
  119. #define SPI_TCTRL_SS_SEL_MASK (0x3U << SPI_TCTRL_SS_SEL_SHIFT)
  120. typedef enum
  121. {
  122. SPI_TCTRL_SS_SEL_SS0 = 0 << SPI_TCTRL_SS_SEL_SHIFT,
  123. SPI_TCTRL_SS_SEL_SS1 = 1 << SPI_TCTRL_SS_SEL_SHIFT,
  124. SPI_TCTRL_SS_SEL_SS2 = 2 << SPI_TCTRL_SS_SEL_SHIFT,
  125. SPI_TCTRL_SS_SEL_SS3 = 3 << SPI_TCTRL_SS_SEL_SHIFT
  126. } SPI_TCTRL_SS_Sel;
  127. #define SPI_TCTRL_SS_CTL_SHIFT (3)
  128. #define SPI_TCTRL_SS_CTL_MASK (0x1U << SPI_TCTRL_SS_CTL_SHIFT)
  129. #define SPI_TCTRL_SPOL_SHIFT (2)
  130. #define SPI_TCTRL_SPOL_MASK (0x1U << SPI_TCTRL_SPOL_SHIFT)
  131. #define SPI_TCTRL_CPOL_SHIFT (1)
  132. #define SPI_TCTRL_CPOL_MASK (0x1U << SPI_TCTRL_CPOL_SHIFT)
  133. typedef enum
  134. {
  135. SPI_TCTRL_CPOL_HIGH = 0 << SPI_TCTRL_CPOL_SHIFT,
  136. SPI_TCTRL_CPOL_LOW = 1 << SPI_TCTRL_CPOL_SHIFT
  137. } SPI_TCTRL_Cpol;
  138. #define SPI_TCTRL_CPHA_SHIFT (0)
  139. #define SPI_TCTRL_CPHA_MASK (0x1U << SPI_TCTRL_CPHA_SHIFT)
  140. typedef enum
  141. {
  142. SPI_TCTRL_CPHA_PHASE0 = 0 << SPI_TCTRL_CPHA_SHIFT,
  143. SPI_TCTRL_CPHA_PHASE1 = 1 << SPI_TCTRL_CPHA_SHIFT
  144. } SPI_TCTRL_Cpha;
  145. typedef enum
  146. {
  147. SPI_SCLK_Mode0 = 0 << SPI_TCTRL_CPHA_SHIFT,
  148. SPI_SCLK_Mode1 = 1 << SPI_TCTRL_CPHA_SHIFT,
  149. SPI_SCLK_Mode2 = 2 << SPI_TCTRL_CPHA_SHIFT,
  150. SPI_SCLK_Mode3 = 3 << SPI_TCTRL_CPHA_SHIFT
  151. } SPI_SCLK_Mode;
  152. /*
  153. * @brief SPI Interrupt Control Register
  154. */
  155. #define SPI_IER_SS_INT_EN_SHIFT (13)
  156. #define SPI_IER_SS_INT_EN_MASK (0x1U << SPI_IER_SS_INT_EN_SHIFT)
  157. #define SPI_IER_TC_INT_EN_SHIFT (12)
  158. #define SPI_IER_TC_INT_EN_MASK (0x1U << SPI_IER_TC_INT_EN_SHIFT)
  159. #define SPI_IER_TF_UDR_INT_EN_SHIFT (11)
  160. #define SPI_IER_TF_UDR_INT_EN_MASK (0x1U << SPI_IER_TF_UDR_INT_EN_SHIFT)
  161. #define SPI_IER_TF_OVF_INT_EN_SHIFT (10)
  162. #define SPI_IER_TF_OVF_INT_EN_MASK (0x1U << SPI_IER_TF_OVF_INT_EN_SHIFT)
  163. #define SPI_IER_RF_UDR_INT_EN_SHIFT (9)
  164. #define SPI_IER_RF_UDR_INT_EN_MASK (0x1U << SPI_IER_RF_UDR_INT_EN_SHIFT)
  165. #define SPI_IER_RF_OVF_INT_EN_SHIFT (8)
  166. #define SPI_IER_RF_OVF_INT_EN_MASK (0x1U << SPI_IER_RF_OVF_INT_EN_SHIFT)
  167. #define SPI_IER_TF_FUL_INT_EN_SHIFT (6)
  168. #define SPI_IER_TF_FUL_INT_EN_MASK (0x1U << SPI_IER_TF_FUL_INT_EN_SHIFT)
  169. #define SPI_IER_TX_EMP_INT_EN_SHIFT (5)
  170. #define SPI_IER_TX_EMP_INT_EN_MASK (0x1U << SPI_IER_TX_EMP_INT_EN_SHIFT)
  171. #define SPI_IER_TX_ERQ_INT_EN_SHIFT (4)
  172. #define SPI_IER_TX_ERQ_INT_EN_MASK (0x1U << SPI_IER_TX_ERQ_INT_EN_SHIFT)
  173. #define SPI_IER_RF_FUL_INT_EN_SHIFT (2)
  174. #define SPI_IER_RF_FUL_INT_EN_MASK (0x1U << SPI_IER_RF_FUL_INT_EN_SHIFT)
  175. #define SPI_IER_RX_EMP_INT_EN_SHIFT (1)
  176. #define SPI_IER_RX_EMP_INT_EN_MASK (0x1U << SPI_IER_RX_EMP_INT_EN_SHIFT)
  177. #define SPI_IER_RF_RDY_INT_EN_SHIFT (0)
  178. #define SPI_IER_RF_RDY_INT_EN_MASK (0x1U << SPI_IER_RF_RDY_INT_EN_SHIFT)
  179. /*
  180. * @brief SPI Interrupt Status Register
  181. */
  182. #define SPI_STA_SSI_SHIFT (13)
  183. #define SPI_STA_SSI_MASK (0x1U << SPI_STA_SSI_SHIFT)
  184. #define SPI_STA_TC_SHIFT (12)
  185. #define SPI_STA_TC_MASK (0x1U << SPI_STA_TC_SHIFT)
  186. #define SPI_STA_TF_UDF_SHIFT (11)
  187. #define SPI_STA_TF_UDF_MASK (0x1U << SPI_STA_TF_UDF_SHIFT)
  188. #define SPI_STA_TF_OVF_SHIFT (10)
  189. #define SPI_STA_TF_OVF_MASK (0x1U << SPI_STA_TF_OVF_SHIFT)
  190. #define SPI_STA_RX_UDF_SHIFT (9)
  191. #define SPI_STA_RX_UDF_MASK (0x1U << SPI_STA_RX_UDF_SHIFT)
  192. #define SPI_STA_RX_OVF_SHIFT (8)
  193. #define SPI_STA_RX_OVF_MASK (0x1U << SPI_STA_RX_OVF_SHIFT)
  194. #define SPI_STA_TX_FULL_SHIFT (6)
  195. #define SPI_STA_TX_FULL_MASK (0x1U << SPI_STA_TX_FULL_SHIFT)
  196. #define SPI_STA_TX_EMP_SHIFT (5)
  197. #define SPI_STA_TX_EMP_MASK (0x1U << SPI_STA_TX_EMP_SHIFT)
  198. #define SPI_STA_TX_READY_SHIFT (4)
  199. #define SPI_STA_TX_READY_MASK (0x1U << SPI_STA_TX_READY_SHIFT)
  200. #define SPI_STA_RX_FULL_SHIFT (2)
  201. #define SPI_STA_RX_FULL_MASK (0x1U << SPI_STA_RX_FULL_SHIFT)
  202. #define SPI_STA_RX_EMP_SHIFT (1)
  203. #define SPI_STA_RX_EMP_MASK (0x1U << SPI_STA_RX_EMP_SHIFT)
  204. #define SPI_STA_RX_RDY_SHIFT (0)
  205. #define SPI_STA_RX_RDY_MASK (0x1U << SPI_STA_RX_RDY_SHIFT)
  206. /*
  207. * @brief SPI FIFO Control Register
  208. */
  209. #define SPI_FCTL_TF_RST_SHIFT (31)
  210. #define SPI_FCTL_TF_RST_MASK (0x1U << SPI_FCTL_TF_RST_SHIFT)
  211. #define SPI_FCTL_TF_TEST_EN_SHIFT (30)
  212. #define SPI_FCTL_TF_TEST_EN_MASK (0x1U << SPI_FCTL_TF_TEST_EN_SHIFT)
  213. #define SPI_FCTL_TF_DRQ_EN_SHIFT (24)
  214. #define SPI_FCTL_TF_DRQ_EN_MASK (0x1U << SPI_FCTL_TF_DRQ_EN_SHIFT)
  215. #define SPI_FCTL_TF_DRQ_EN_BIT HAL_BIT(24)
  216. #define SPI_FCTL_TX_TRIG_LEVEL_SHIFT (16)
  217. #define SPI_FCTL_TX_TRIG_LEVEL_MASK (0xFFU << SPI_FCTL_TX_TRIG_LEVEL_SHIFT)
  218. #define SPI_FCTL_RF_RST_SHIFT (15)
  219. #define SPI_FCTL_RF_RST_MASK (0x1U << SPI_FCTL_RF_RST_SHIFT)
  220. #define SPI_FCTL_RF_TEST_SHIFT (14)
  221. #define SPI_FCTL_RF_TEST_MASK (0x1U << SPI_FCTL_RF_TEST_SHIFT)
  222. #define SPI_FCTL_RF_DRQ_EN_SHIFT (8)
  223. #define SPI_FCTL_RF_DRQ_EN_MASK (0x1U << SPI_FCTL_RF_DRQ_EN_SHIFT)
  224. #define SPI_FCTL_RX_TRIG_LEVEL_SHIFT (0)
  225. #define SPI_FCTL_RX_TRIG_LEVEL_MASK (0xFFU << SPI_FCTL_RX_TRIG_LEVEL_SHIFT)
  226. /*
  227. * @brief SPI FIFO Status Registe
  228. */
  229. #define SPI_FST_TB_WR_SHIFT (31)
  230. #define SPI_FST_TB_WR_MASK (0x1U << SPI_FST_TB_WR_SHIFT)
  231. #define SPI_FST_TB_CNT_SHIFT (28)
  232. #define SPI_FST_TB_CNT_MASK (0x7U << SPI_FST_TB_CNT_SHIFT)
  233. #define SPI_FST_TF_CNT_SHIFT (16)
  234. #define SPI_FST_TF_CNT_MASK (0xFFU << SPI_FST_TF_CNT_SHIFT)
  235. #define SPI_FST_RB_WR_SHIFT (15)
  236. #define SPI_FST_RB_WR_MASK (0x1U << SPI_FST_RB_WR_SHIFT)
  237. #define SPI_FST_RB_CNT_SHIFT (12)
  238. #define SPI_FST_RB_CNT_MASK (0x7U << SPI_FST_RB_CNT_SHIFT)
  239. #define SPI_FST_RF_CNT_SHIFT (0)
  240. #define SPI_FST_RF_CNT_MASK (0xFFU << SPI_FST_RF_CNT_SHIFT)
  241. /*
  242. * @brief SPI Wait Clock Counter Register
  243. */
  244. #define SPI_WAIT_SWC_SHIFT (16)
  245. #define SPI_WAIT_SWC_MASK (0xFU << SPI_WAIT_SWC_SHIFT)
  246. #define SPI_WAIT_WCC_SHIFT (0)
  247. #define SPI_WAIT_WCC_MASK (0xFFFFU << SPI_WAIT_WCC_SHIFT)
  248. /*
  249. * @brief SPI Clock Rate Control Register
  250. */
  251. #define SPI_CCTR_DRS_SHIFT (12)
  252. #define SPI_CCTR_DRS_MASK (0x1U << SPI_CCTR_DRS_SHIFT)
  253. typedef enum
  254. {
  255. SPI_CCTR_DRS_type_divRate1 = 0 << SPI_CCTR_DRS_SHIFT,
  256. SPI_CCTR_DRS_type_divRate2 = 1 << SPI_CCTR_DRS_SHIFT
  257. } SPI_CCTR_DRS_type;
  258. #define SPI_CCTR_CDR1_SHIFT (8)
  259. #define SPI_CCTR_CDR1_MASK (0xFU << SPI_CCTR_CDR1_SHIFT)
  260. #define SPI_CCTR_CDR2_SHIFT (0)
  261. #define SPI_CCTR_CDR2_MASK (0xFFU << SPI_CCTR_CDR2_SHIFT)
  262. /*
  263. * @brief SPI Master mode Burst Control Register
  264. */
  265. #define SPI_BC_MBC_SHIFT (0)
  266. #define SPI_BC_MBC_MASK (0xFFFFFFU << SPI_BC_MBC_SHIFT)
  267. /*
  268. * @brief SPI Master mode Transmit Counter Register
  269. */
  270. #define SPI_TC_MWTC_SHIFT (0)
  271. #define SPI_TC_MWTC_MASK (0xFFFFFFU << SPI_TC_MWTC_SHIFT)
  272. /*
  273. * @brief SPI Burst Control Register
  274. */
  275. #define SPI_BCC_DRM_SHIFT (28)
  276. #define SPI_BCC_DRM_MASK (0x1U << SPI_BCC_DRM_SHIFT)
  277. #define SPI_BCC_DBC_SHIFT (24)
  278. #define SPI_BCC_DBC_MASK (0xFU << SPI_BCC_DBC_SHIFT)
  279. #define SPI_BCC_STC_SHIFT (0)
  280. #define SPI_BCC_STC_MASK (0xFFFFFFU << SPI_BCC_STC_SHIFT)
  281. /*
  282. * @brief SPI Nomal DMA Mode Control Regist
  283. */
  284. #define SPI_NDMA_MODE_CTRL_SHIFT (0)
  285. #define SPI_NDMA_MODE_CTRL_MASK (0xFFU << SPI_NDMA_MODE_CTRL_SHIFT)
  286. /*
  287. * @brief SPI TX Date Register
  288. */
  289. #define SPI_TXD_SHIFT (0)
  290. #define SPI_TXD_MASK (0xFFFFFFFFU << SPI_TXD_SHIFT)
  291. /*
  292. * @brief SPI RX Date Register
  293. */
  294. #define SPI_RXD_SHIFT (0)
  295. #define SPI_RXD_MASK (0xFFFFFFFFU << SPI_RXD_SHIFT)
  296. /* other */
  297. #define SPI_FIFO_SIZE (64)
  298. #define SPI_MAX_WAIT_MS (2000)
  299. #define SPI_SOURCE_CLK (24 * 1000 * 1000)
  300. /* io ops */
  301. #define HAL_BIT(pos) (1U << (pos))
  302. #define HAL_SET_BIT(reg, mask) ((reg) |= (mask))
  303. #define HAL_CLR_BIT(reg, mask) ((reg) &= ~(mask))
  304. #define HAL_GET_BIT(reg, mask) ((reg) & (mask))
  305. #define HAL_GET_BIT_VAL(reg, shift, vmask) (((reg) >> (shift)) & (vmask))
  306. #define HAL_MODIFY_REG(reg, clr_mask, set_mask) \
  307. ((reg) = (((reg) & (~(clr_mask))) | (set_mask)))
  308. /* access LSBs of a 32-bit register (little endian only) */
  309. #define HAL_REG_32BIT(reg_addr) (*((volatile rt_uint32_t *)(reg_addr)))
  310. #define HAL_REG_16BIT(reg_addr) (*((volatile rt_uint16_t *)(reg_addr)))
  311. #define HAL_REG_8BIT(reg_addr) (*((volatile rt_uint8_t *)(reg_addr)))
  312. #define HAL_WAIT_FOREVER OS_WAIT_FOREVER
  313. #define HAL_ARRAY_SIZE(a) (sizeof((a)) / sizeof((a)[0]))
  314. struct tina_spi
  315. {
  316. SPI_T *spi;
  317. unsigned int spi_gate;
  318. struct rt_spi_bus *spi_bus;
  319. };
  320. struct tina_spi_cs
  321. {
  322. SPI_TCTRL_SS_Sel cs;
  323. };
  324. /* public function */
  325. rt_err_t r6_spi_bus_register(SPI_T *spi, const char *spi_bus_name);
  326. #ifdef __cplusplus
  327. }
  328. #endif
  329. #endif //