drv_iic_back.c 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  1. #include "drv_iic_back.h"
  2. #include "nrf_delay.h"
  3. static void IIC_BACK_Start(void)
  4. {
  5. IIC_BACK_SDA_SET;
  6. IIC_BACK_SCL_SET;
  7. nrf_delay_us(5);
  8. IIC_BACK_SDA_CLR;
  9. nrf_delay_us(5);
  10. IIC_BACK_SCL_CLR;
  11. }
  12. static void IIC_BACK_Stop(void)
  13. {
  14. IIC_BACK_SCL_CLR;
  15. IIC_BACK_SDA_CLR;
  16. nrf_delay_us(5);
  17. IIC_BACK_SCL_SET;
  18. IIC_BACK_SDA_SET;
  19. nrf_delay_us(5);
  20. }
  21. static void IIC_BACK_ACK(void)
  22. {
  23. IIC_BACK_SCL_CLR;
  24. nrf_delay_us(1);
  25. IIC_BACK_SDA_CLR;
  26. nrf_delay_us(1);
  27. IIC_BACK_SCL_SET;
  28. nrf_delay_us(1);
  29. IIC_BACK_SCL_CLR;
  30. }
  31. static void IIC_BACK_NoACK(void)
  32. {
  33. IIC_BACK_SCL_CLR;
  34. IIC_BACK_SDA_SET;
  35. nrf_delay_us(1);
  36. IIC_BACK_SCL_SET;
  37. nrf_delay_us(1);
  38. IIC_BACK_SCL_CLR;
  39. }
  40. static bool IIC_BACK_WaitACK(void)
  41. {
  42. uint8_t tim = 0;
  43. // IIC_BACK_SCL_CLR;
  44. IIC_BACK_SDA_SET;
  45. nrf_delay_us(1);
  46. IIC_BACK_SCL_SET;
  47. // nrf_delay_us(1);
  48. while(IIC_BACK_SDA_READ){
  49. if(++tim>=50){
  50. IIC_BACK_Stop();
  51. return false;
  52. }
  53. nrf_delay_us(1);
  54. }
  55. IIC_BACK_SCL_CLR;
  56. return true;
  57. }
  58. static void IIC_BACK_SendByte(uint8_t _byte)
  59. {
  60. uint8_t i = 0;
  61. for (i=0; i<8; i++){
  62. IIC_BACK_SCL_CLR;
  63. nrf_delay_us(5);
  64. if (_byte&0x80) IIC_BACK_SDA_SET;
  65. else IIC_BACK_SDA_CLR;
  66. _byte <<= 1;
  67. IIC_BACK_SCL_SET;
  68. nrf_delay_us(5);
  69. }
  70. IIC_BACK_SCL_CLR;
  71. }
  72. static uint8_t IIC_BACK_RecByte(void)
  73. {
  74. uint8_t i = 0;
  75. uint8_t rec_byte;
  76. IIC_BACK_SDA_SET;
  77. for (i=0; i<8; i++){
  78. rec_byte <<= 1;
  79. IIC_BACK_SCL_CLR;
  80. IIC_BACK_SCL_SET;
  81. if (IIC_BACK_SDA_READ) rec_byte |= 0x01;
  82. }
  83. IIC_BACK_SCL_CLR;
  84. return rec_byte;
  85. }
  86. /********************************************/
  87. bool IIC_BACK_WriteBytes(uint8_t add,uint8_t reg,uint8_t* p,uint8_t len)
  88. {
  89. uint8_t i = 0;
  90. IIC_BACK_Start();
  91. IIC_BACK_SendByte(add);
  92. if(!IIC_BACK_WaitACK()) return false;
  93. IIC_BACK_SendByte(reg);
  94. if(!IIC_BACK_WaitACK()) return false;
  95. for(i=0;i<len;i++){
  96. IIC_BACK_SendByte(p[i]);
  97. if(!IIC_BACK_WaitACK()) return false;
  98. }
  99. IIC_BACK_Stop();
  100. return true;
  101. }
  102. bool IIC_BACK_ReadBytes(uint8_t add,uint8_t reg,uint8_t* p,uint8_t len)
  103. {
  104. uint8_t i = 0;
  105. IIC_BACK_Start();
  106. IIC_BACK_SendByte(add);
  107. if(!IIC_BACK_WaitACK()) return false;
  108. IIC_BACK_SendByte(reg);
  109. if(!IIC_BACK_WaitACK()) return false;
  110. IIC_BACK_Start();
  111. IIC_BACK_SendByte(add+1);
  112. if(!IIC_BACK_WaitACK()) return false;
  113. for(i=0;i<len-1;i++){
  114. p[i] = IIC_BACK_RecByte(); IIC_BACK_ACK();
  115. }
  116. p[i] = IIC_BACK_RecByte(); IIC_BACK_NoACK();
  117. IIC_BACK_Stop();
  118. return true;
  119. }
  120. void IIC_BACK_Init(void)
  121. {
  122. nrf_gpio_cfg(
  123. PIN_BACK_SCL,
  124. NRF_GPIO_PIN_DIR_OUTPUT,
  125. NRF_GPIO_PIN_INPUT_DISCONNECT,
  126. NRF_GPIO_PIN_NOPULL,
  127. NRF_GPIO_PIN_S0S1,
  128. NRF_GPIO_PIN_NOSENSE);
  129. nrf_gpio_cfg_watcher(PIN_BACK_SCL);
  130. nrf_gpio_pin_set(PIN_BACK_SCL);
  131. nrf_gpio_cfg(
  132. PIN_BACK_SDA,
  133. NRF_GPIO_PIN_DIR_OUTPUT,
  134. NRF_GPIO_PIN_INPUT_DISCONNECT,
  135. NRF_GPIO_PIN_NOPULL,
  136. NRF_GPIO_PIN_S0S1,
  137. NRF_GPIO_PIN_NOSENSE);
  138. nrf_gpio_cfg_watcher(PIN_BACK_SDA);
  139. nrf_gpio_pin_set(PIN_BACK_SDA);
  140. }