yc11xx_iic.c 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204
  1. #include "yc11xx_iic.h"
  2. #define IS_IIC_TXLen(TxLen) (TxLen != 0)
  3. #define IS_IIC_RXLen(RxLen) (RxLen != 0)
  4. #define IS_IICD_CLOCKSPEED(CLOCKSPEED) ((CLOCKSPEED>=IICD_CLOCKSPEED1MHZ) && (CLOCKSPEED<=IICD_CLOCKSPEED200KHZ))
  5. typedef struct
  6. {
  7. uint8_t Ctrl;
  8. uint8_t Scll;
  9. uint8_t Sclh;
  10. uint8_t Stsu;
  11. uint8_t Sthd;
  12. uint8_t Sosu;
  13. uint8_t Dtsu;
  14. uint8_t Dthd;
  15. uint16_t TxLen;
  16. uint16_t TxAddr;
  17. uint16_t RxAddr;
  18. uint16_t RxLen;
  19. }I2C_RegDef;
  20. void I2C_Init(I2C_InitTypeDef* I2C_InitStruct)
  21. {
  22. #define AUTO_DMA_AFTER_RW_BIT 0
  23. #define RESTART_BETWEEN_WR_BIT 1
  24. #define SELECT_RAM_BIT 2
  25. #define IICD_CTRL_VAL ((1<<AUTO_DMA_AFTER_RW_BIT)|\
  26. (1<<RESTART_BETWEEN_WR_BIT)|\
  27. (1<<SELECT_RAM_BIT))
  28. I2C_RegDef* I2cAdr = NULL;
  29. uint16_t* Ptr = NULL;
  30. /*check parameter*/
  31. _ASSERT(I2C_InitStruct != NULL);
  32. _ASSERT(IS_IICD_CLOCKSPEED(I2C_InitStruct->I2C_ClockSpeed));
  33. _ASSERT(IS_IIC_TXLen(I2C_InitStruct->I2C_TXLen));
  34. _ASSERT(IS_IIC_RXLen(I2C_InitStruct->I2C_RXLen));
  35. I2cAdr = (I2C_RegDef*)(reg_map(CORE_IICD_CTRL));
  36. HW_REG_8BIT((uint32_t)&I2cAdr->Ctrl, IICD_CTRL_VAL);
  37. /*set iic clock speed*/
  38. I2cAdr->Scll = I2C_InitStruct->I2C_ClockSpeed-1;
  39. I2cAdr->Sclh = I2C_InitStruct->I2C_ClockSpeed;
  40. I2cAdr->Stsu = I2C_InitStruct->I2C_ClockSpeed;
  41. I2cAdr->Sthd = I2C_InitStruct->I2C_ClockSpeed;
  42. I2cAdr->Sosu = I2C_InitStruct->I2C_ClockSpeed;
  43. I2cAdr->Dtsu = I2C_InitStruct->I2C_ClockSpeed-1;
  44. /*set iic tx buff*/
  45. Ptr = malloc(I2C_InitStruct->I2C_TXLen);
  46. HW_REG_16BIT((uint32_t)&I2cAdr->TxAddr, (uint32_t)Ptr);
  47. _ASSERT(Ptr != NULL);
  48. HW_REG_16BIT((uint32_t)&I2cAdr->TxLen, 0);
  49. Ptr = NULL;
  50. /*set iic rx buff*/
  51. Ptr = malloc(I2C_InitStruct->I2C_RXLen);
  52. HW_REG_16BIT((uint32_t)&I2cAdr->RxAddr,(uint32_t) Ptr);
  53. _ASSERT(Ptr != NULL);
  54. HW_REG_16BIT((uint32_t)&I2cAdr->RxLen, 0);
  55. Ptr = NULL;
  56. }
  57. void I2C_DeInit(void)
  58. {
  59. I2C_RegDef* I2cAdr = NULL;
  60. I2cAdr = (I2C_RegDef *)(reg_map(CORE_IICD_CTRL));
  61. free((void *)((uint32_t)I2cAdr->RxAddr));
  62. free((void *)((uint32_t)I2cAdr->TxAddr));
  63. }
  64. #define START_IIC_DMA 0x04
  65. #define CHECK_IIC_DMA_DONE 0x20
  66. #define IIC_TXLEN_4BYTES 4
  67. #define IIC_TXLEN_3BYTES 3
  68. #define IIC_TXLEN_2BYTES 2
  69. void I2C_SendData(uint32_t DevAddr, uint32_t RegAddr, uint16_t Data)
  70. {
  71. I2C_RegDef* I2cAdr = NULL;
  72. uint8_t * I2cTxPtr = NULL;
  73. //_ASSERT(IS_I2C_REGADDR(RegAddr));
  74. I2cAdr = (I2C_RegDef *)(reg_map(CORE_IICD_CTRL));
  75. I2cTxPtr = (uint8_t *) reg_map_m0(HR_REG_16BIT((uint32_t)&I2cAdr->TxAddr));
  76. DevAddr = DevAddr<<0x01;
  77. *I2cTxPtr++ = DevAddr & 0xff;
  78. if(IS_I2C_REGADDR16BITS(RegAddr)) {
  79. *I2cTxPtr++ = RegAddr>> 8;
  80. *I2cTxPtr++ = RegAddr & 0xff;
  81. *I2cTxPtr++ = Data & 0xff;
  82. HW_REG_16BIT((uint32_t )&I2cAdr->TxLen, IIC_TXLEN_4BYTES);
  83. }else {
  84. *I2cTxPtr++ = RegAddr & 0xff;
  85. *I2cTxPtr++ = Data & 0xff;
  86. HW_REG_16BIT((uint32_t )&I2cAdr->TxLen, IIC_TXLEN_3BYTES);
  87. }
  88. HW_REG_16BIT((uint32_t)&I2cAdr->RxLen, 0);
  89. HWRITE(CORE_DMA_START,START_IIC_DMA);
  90. while(!(HREAD(CORE_DMA_STATUS) & (CHECK_IIC_DMA_DONE)));
  91. }
  92. uint32_t I2C_ReceiveData(uint32_t DevAddr, uint32_t RegAddr)
  93. {
  94. I2C_RegDef* I2cAdr = NULL;
  95. uint8_t * I2cTxPtr = NULL;
  96. uint8_t * I2cRxPtr = NULL;
  97. _ASSERT(IS_I2C_REGADDR(RegAddr));
  98. I2cAdr = (I2C_RegDef *)(reg_map(CORE_IICD_CTRL));
  99. I2cTxPtr = (uint8_t *) reg_map_m0(HR_REG_16BIT((uint32_t)&I2cAdr->TxAddr));
  100. I2cRxPtr = (uint8_t *) reg_map_m0(HR_REG_16BIT((uint32_t)&I2cAdr->RxAddr));
  101. DevAddr = DevAddr<<0x01;
  102. *I2cTxPtr++ = DevAddr & 0xff;
  103. if(IS_I2C_REGADDR16BITS(RegAddr)) {
  104. *I2cTxPtr++ = RegAddr >> 8;
  105. *I2cTxPtr++ = RegAddr & 0xff;
  106. *I2cTxPtr++ = DevAddr | 0x01;
  107. HW_REG_16BIT((uint32_t)&I2cAdr->TxLen,IIC_TXLEN_4BYTES);
  108. }else {
  109. *I2cTxPtr++ = RegAddr & 0xff;
  110. *I2cTxPtr++ = DevAddr | 0x01;
  111. HW_REG_16BIT((uint32_t)&I2cAdr->TxLen, IIC_TXLEN_3BYTES);
  112. }
  113. HW_REG_16BIT((uint32_t )&I2cAdr->RxLen, 3);
  114. HWRITE(CORE_DMA_START, START_IIC_DMA);
  115. while(!(HREAD(CORE_DMA_STATUS) & (CHECK_IIC_DMA_DONE)));
  116. return (uint32_t)( *I2cRxPtr);
  117. }
  118. void I2C_ReadDatatoBuff(uint32_t DevAddr,
  119. uint32_t RegAddr,
  120. uint8_t *RxBuff,
  121. uint16_t RxLen)
  122. {
  123. I2C_RegDef * I2cAdr = NULL;
  124. uint8_t * I2cTxPtr = NULL;
  125. uint8_t * I2cRxPtr = NULL;
  126. _ASSERT(IS_I2C_REGADDR(RegAddr));
  127. _ASSERT(IS_IIC_RXLen(RxLen));
  128. I2cAdr = (I2C_RegDef *)(reg_map(CORE_IICD_CTRL));
  129. I2cTxPtr = (uint8_t *)reg_map_m0(HR_REG_16BIT((uint32_t)&I2cAdr->TxAddr));
  130. I2cRxPtr = (uint8_t *)reg_map_m0(HR_REG_16BIT((uint32_t)&I2cAdr->RxAddr));
  131. DevAddr = DevAddr<<0x01;
  132. *I2cTxPtr++ = DevAddr & 0xff;
  133. if(IS_I2C_REGADDR16BITS(RegAddr)) {
  134. *I2cTxPtr++ = RegAddr >> 8;
  135. *I2cTxPtr++ = RegAddr & 0xff;
  136. *I2cTxPtr++ = DevAddr | 0x01;
  137. HW_REG_16BIT((uint32_t)&I2cAdr->TxLen, IIC_TXLEN_4BYTES);
  138. }else {
  139. *I2cTxPtr++ = RegAddr & 0xff;
  140. *I2cTxPtr++ = DevAddr | 0x01;
  141. HW_REG_16BIT((uint32_t)&I2cAdr->TxLen, IIC_TXLEN_3BYTES);
  142. }
  143. HW_REG_16BIT((uint32_t )&I2cAdr->RxLen, RxLen);
  144. HWRITE(CORE_DMA_START, START_IIC_DMA);
  145. while(!(HREAD(CORE_DMA_STATUS) & (CHECK_IIC_DMA_DONE)));
  146. memcpy(RxBuff, I2cRxPtr, RxLen);
  147. }
  148. void I2C_SendDataFromBuff(uint32_t DevAddr,
  149. uint32_t RegAddr,
  150. uint8_t *TxBuff,
  151. uint16_t TxLen)
  152. {
  153. I2C_RegDef * I2cAdr = NULL;
  154. uint8_t * I2cTxPtr = NULL;
  155. _ASSERT(IS_I2C_REGADDR(RegAddr));
  156. _ASSERT(IS_IIC_TXLen(TxLen));
  157. I2cAdr = (I2C_RegDef *)(reg_map(CORE_IICD_CTRL));
  158. I2cTxPtr = (uint8_t *)reg_map_m0(HR_REG_16BIT((uint32_t)&I2cAdr->TxAddr));
  159. DevAddr = DevAddr<<0x01;
  160. *I2cTxPtr++ = DevAddr & 0xff;
  161. if(IS_I2C_REGADDR16BITS(RegAddr)) {
  162. *I2cTxPtr++ = RegAddr >> 8;
  163. *I2cTxPtr++ = RegAddr & 0xff;
  164. memcpy(I2cTxPtr, TxBuff, TxLen);
  165. HW_REG_16BIT((uint32_t )&I2cAdr->TxLen, TxLen+IIC_TXLEN_3BYTES);
  166. }else {
  167. *I2cTxPtr++ = RegAddr & 0xff;
  168. memcpy(I2cTxPtr, TxBuff, TxLen);
  169. HW_REG_16BIT((uint32_t )&I2cAdr->TxLen, TxLen+IIC_TXLEN_2BYTES);
  170. }
  171. HW_REG_16BIT((uint32_t)&I2cAdr->RxLen, 0);
  172. HWRITE(CORE_DMA_START, START_IIC_DMA);
  173. while(!(HREAD(CORE_DMA_STATUS) & (CHECK_IIC_DMA_DONE)));
  174. }