furi_hal_i2c.h 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205
  1. /**
  2. * @file furi_hal_i2c.h
  3. * I2C HAL API
  4. */
  5. #pragma once
  6. #include <stdbool.h>
  7. #include <stdint.h>
  8. #include <furi_hal_i2c_config.h>
  9. #ifdef __cplusplus
  10. extern "C" {
  11. #endif
  12. /** Init I2C
  13. */
  14. void furi_hal_i2c_init();
  15. /** Acquire i2c bus handle
  16. *
  17. * @return Instance of FuriHalI2cBus
  18. */
  19. void furi_hal_i2c_acquire(FuriHalI2cBusHandle* handle);
  20. /** Release i2c bus handle
  21. *
  22. * @param bus instance of FuriHalI2cBus aquired in `furi_hal_i2c_acquire`
  23. */
  24. void furi_hal_i2c_release(FuriHalI2cBusHandle* handle);
  25. /** Perform I2C tx transfer
  26. *
  27. * @param handle pointer to FuriHalI2cBusHandle instance
  28. * @param address I2C slave address
  29. * @param data pointer to data buffer
  30. * @param size size of data buffer
  31. * @param timeout timeout in ticks
  32. *
  33. * @return true on successful transfer, false otherwise
  34. */
  35. bool furi_hal_i2c_tx(
  36. FuriHalI2cBusHandle* handle,
  37. const uint8_t address,
  38. const uint8_t* data,
  39. const uint8_t size,
  40. uint32_t timeout);
  41. /** Perform I2C rx transfer
  42. *
  43. * @param handle pointer to FuriHalI2cBusHandle instance
  44. * @param address I2C slave address
  45. * @param data pointer to data buffer
  46. * @param size size of data buffer
  47. * @param timeout timeout in ticks
  48. *
  49. * @return true on successful transfer, false otherwise
  50. */
  51. bool furi_hal_i2c_rx(
  52. FuriHalI2cBusHandle* handle,
  53. const uint8_t address,
  54. uint8_t* data,
  55. const uint8_t size,
  56. uint32_t timeout);
  57. /** Perform I2C tx and rx transfers
  58. *
  59. * @param handle pointer to FuriHalI2cBusHandle instance
  60. * @param address I2C slave address
  61. * @param tx_data pointer to tx data buffer
  62. * @param tx_size size of tx data buffer
  63. * @param rx_data pointer to rx data buffer
  64. * @param rx_size size of rx data buffer
  65. * @param timeout timeout in ticks
  66. *
  67. * @return true on successful transfer, false otherwise
  68. */
  69. bool furi_hal_i2c_trx(
  70. FuriHalI2cBusHandle* handle,
  71. const uint8_t address,
  72. const uint8_t* tx_data,
  73. const uint8_t tx_size,
  74. uint8_t* rx_data,
  75. const uint8_t rx_size,
  76. uint32_t timeout);
  77. /** Check if I2C device presents on bus
  78. *
  79. * @param handle pointer to FuriHalI2cBusHandle instance
  80. * @param i2c_addr I2C slave address
  81. * @param timeout timeout in ticks
  82. *
  83. * @return true if device present and is ready, false otherwise
  84. */
  85. bool furi_hal_i2c_is_device_ready(FuriHalI2cBusHandle* handle, uint8_t i2c_addr, uint32_t timeout);
  86. /** Perform I2C device register read (8-bit)
  87. *
  88. * @param handle pointer to FuriHalI2cBusHandle instance
  89. * @param i2c_addr I2C slave address
  90. * @param reg_addr register address
  91. * @param data pointer to register value
  92. * @param timeout timeout in ticks
  93. *
  94. * @return true on successful transfer, false otherwise
  95. */
  96. bool furi_hal_i2c_read_reg_8(
  97. FuriHalI2cBusHandle* handle,
  98. uint8_t i2c_addr,
  99. uint8_t reg_addr,
  100. uint8_t* data,
  101. uint32_t timeout);
  102. /** Perform I2C device register read (16-bit)
  103. *
  104. * @param handle pointer to FuriHalI2cBusHandle instance
  105. * @param i2c_addr I2C slave address
  106. * @param reg_addr register address
  107. * @param data pointer to register value
  108. * @param timeout timeout in ticks
  109. *
  110. * @return true on successful transfer, false otherwise
  111. */
  112. bool furi_hal_i2c_read_reg_16(
  113. FuriHalI2cBusHandle* handle,
  114. uint8_t i2c_addr,
  115. uint8_t reg_addr,
  116. uint16_t* data,
  117. uint32_t timeout);
  118. /** Perform I2C device memory read
  119. *
  120. * @param handle pointer to FuriHalI2cBusHandle instance
  121. * @param i2c_addr I2C slave address
  122. * @param mem_addr memory start address
  123. * @param data pointer to data buffer
  124. * @param len size of data buffer
  125. * @param timeout timeout in ticks
  126. *
  127. * @return true on successful transfer, false otherwise
  128. */
  129. bool furi_hal_i2c_read_mem(
  130. FuriHalI2cBusHandle* handle,
  131. uint8_t i2c_addr,
  132. uint8_t mem_addr,
  133. uint8_t* data,
  134. uint8_t len,
  135. uint32_t timeout);
  136. /** Perform I2C device register write (8-bit)
  137. *
  138. * @param handle pointer to FuriHalI2cBusHandle instance
  139. * @param i2c_addr I2C slave address
  140. * @param reg_addr register address
  141. * @param data register value
  142. * @param timeout timeout in ticks
  143. *
  144. * @return true on successful transfer, false otherwise
  145. */
  146. bool furi_hal_i2c_write_reg_8(
  147. FuriHalI2cBusHandle* handle,
  148. uint8_t i2c_addr,
  149. uint8_t reg_addr,
  150. uint8_t data,
  151. uint32_t timeout);
  152. /** Perform I2C device register write (16-bit)
  153. *
  154. * @param handle pointer to FuriHalI2cBusHandle instance
  155. * @param i2c_addr I2C slave address
  156. * @param reg_addr register address
  157. * @param data register value
  158. * @param timeout timeout in ticks
  159. *
  160. * @return true on successful transfer, false otherwise
  161. */
  162. bool furi_hal_i2c_write_reg_16(
  163. FuriHalI2cBusHandle* handle,
  164. uint8_t i2c_addr,
  165. uint8_t reg_addr,
  166. uint16_t data,
  167. uint32_t timeout);
  168. /** Perform I2C device memory
  169. *
  170. * @param handle pointer to FuriHalI2cBusHandle instance
  171. * @param i2c_addr I2C slave address
  172. * @param mem_addr memory start address
  173. * @param data pointer to data buffer
  174. * @param len size of data buffer
  175. * @param timeout timeout in ticks
  176. *
  177. * @return true on successful transfer, false otherwise
  178. */
  179. bool furi_hal_i2c_write_mem(
  180. FuriHalI2cBusHandle* handle,
  181. uint8_t i2c_addr,
  182. uint8_t mem_addr,
  183. uint8_t* data,
  184. uint8_t len,
  185. uint32_t timeout);
  186. #ifdef __cplusplus
  187. }
  188. #endif