i2c_config.h 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  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. * 2024-12-18 shelton first version
  9. */
  10. #ifndef __I2C_CONFIG_H__
  11. #define __I2C_CONFIG_H__
  12. #include <rtthread.h>
  13. #include "dma_config.h"
  14. #ifdef __cplusplus
  15. extern "C" {
  16. #endif
  17. #define HWI2C_OWN_ADDRESS 0x0
  18. #define I2C1_EVT_IRQHandler I2C1_EVT_IRQHandler
  19. #define I2C1_ERR_IRQHandler I2C1_ERR_IRQHandler
  20. #define I2C2_EVT_IRQHandler I2C2_EVT_IRQHandler
  21. #define I2C2_ERR_IRQHandler I2C2_ERR_IRQHandler
  22. #define I2C3_EVT_IRQHandler I2C3_EVT_IRQHandler
  23. #define I2C3_ERR_IRQHandler I2C3_ERR_IRQHandler
  24. #ifdef BSP_USING_HARD_I2C1
  25. #define I2C1_CONFIG \
  26. { \
  27. .i2c_x = I2C1, \
  28. .i2c_name = "hwi2c1", \
  29. .timing = 0x01F03333, \
  30. .ev_irqn = I2C1_EVT_IRQn, \
  31. .er_irqn = I2C1_ERR_IRQn, \
  32. }
  33. #endif /* BSP_USING_HARD_I2C1 */
  34. #ifdef BSP_I2C1_RX_USING_DMA
  35. #define I2C1_RX_DMA_CONFIG \
  36. { \
  37. .dma_channel = I2C1_RX_DMA_CHANNEL, \
  38. .dma_clock = I2C1_RX_DMA_CLOCK, \
  39. .dma_irqn = I2C1_RX_DMA_IRQ, \
  40. .dmamux_channel = I2C1_RX_DMA_MUX_CHANNEL, \
  41. .request_id = I2C1_RX_DMA_REQ_ID, \
  42. }
  43. #endif /* BSP_I2C1_RX_USING_DMA */
  44. #ifdef BSP_I2C1_TX_USING_DMA
  45. #define I2C1_TX_DMA_CONFIG \
  46. { \
  47. .dma_channel = I2C1_TX_DMA_CHANNEL, \
  48. .dma_clock = I2C1_TX_DMA_CLOCK, \
  49. .dma_irqn = I2C1_TX_DMA_IRQ, \
  50. .dmamux_channel = I2C1_TX_DMA_MUX_CHANNEL, \
  51. .request_id = I2C1_TX_DMA_REQ_ID, \
  52. }
  53. #endif /* BSP_I2C1_TX_USING_DMA */
  54. #ifdef BSP_USING_HARD_I2C2
  55. #define I2C2_CONFIG \
  56. { \
  57. .i2c_x = I2C2, \
  58. .i2c_name = "hwi2c2", \
  59. .timing = 0x01F03333, \
  60. .ev_irqn = I2C2_EVT_IRQn, \
  61. .er_irqn = I2C2_ERR_IRQn, \
  62. }
  63. #endif /* BSP_USING_HARD_I2C2 */
  64. #ifdef BSP_I2C2_RX_USING_DMA
  65. #define I2C2_RX_DMA_CONFIG \
  66. { \
  67. .dma_channel = I2C2_RX_DMA_CHANNEL, \
  68. .dma_clock = I2C2_RX_DMA_CLOCK, \
  69. .dma_irqn = I2C2_RX_DMA_IRQ, \
  70. .dmamux_channel = I2C2_RX_DMA_MUX_CHANNEL, \
  71. .request_id = I2C2_RX_DMA_REQ_ID, \
  72. }
  73. #endif /* BSP_I2C2_RX_USING_DMA */
  74. #ifdef BSP_I2C2_TX_USING_DMA
  75. #define I2C2_TX_DMA_CONFIG \
  76. { \
  77. .dma_channel = I2C2_TX_DMA_CHANNEL, \
  78. .dma_clock = I2C2_TX_DMA_CLOCK, \
  79. .dma_irqn = I2C2_TX_DMA_IRQ, \
  80. .dmamux_channel = I2C2_TX_DMA_MUX_CHANNEL, \
  81. .request_id = I2C2_TX_DMA_REQ_ID, \
  82. }
  83. #endif /* BSP_I2C2_TX_USING_DMA */
  84. #ifdef BSP_USING_HARD_I2C3
  85. #define I2C3_CONFIG \
  86. { \
  87. .i2c_x = I2C3, \
  88. .i2c_name = "hwi2c3", \
  89. .timing = 0x01F03333, \
  90. .ev_irqn = I2C3_EVT_IRQn, \
  91. .er_irqn = I2C3_ERR_IRQn, \
  92. }
  93. #endif /* BSP_USING_HARD_I2C3 */
  94. #ifdef BSP_I2C3_RX_USING_DMA
  95. #define I2C3_RX_DMA_CONFIG \
  96. { \
  97. .dma_channel = I2C3_RX_DMA_CHANNEL, \
  98. .dma_clock = I2C3_RX_DMA_CLOCK, \
  99. .dma_irqn = I2C3_RX_DMA_IRQ, \
  100. .dmamux_channel = I2C3_RX_DMA_MUX_CHANNEL, \
  101. .request_id = I2C3_RX_DMA_REQ_ID, \
  102. }
  103. #endif /* BSP_I2C3_RX_USING_DMA */
  104. #ifdef BSP_I2C3_TX_USING_DMA
  105. #define I2C3_TX_DMA_CONFIG \
  106. { \
  107. .dma_channel = I2C3_TX_DMA_CHANNEL, \
  108. .dma_clock = I2C3_TX_DMA_CLOCK, \
  109. .dma_irqn = I2C3_TX_DMA_IRQ, \
  110. .dmamux_channel = I2C3_TX_DMA_MUX_CHANNEL, \
  111. .request_id = I2C3_TX_DMA_REQ_ID, \
  112. }
  113. #endif /* BSP_I2C3_TX_USING_DMA */
  114. #ifdef __cplusplus
  115. }
  116. #endif
  117. #endif /*__I2C_CONFIG_H__ */