drv_uarte.c 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327
  1. /*
  2. * Copyright (c) 2006-2022, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2020-04-28 xckhmf Modify for <nrfx>
  9. * 2020-10-31 xckhmf Support for UART1
  10. *
  11. */
  12. #include <rtdevice.h>
  13. #include <nrfx_uarte.h>
  14. #include "drv_uart.h"
  15. #ifdef BSP_USING_UART
  16. #if defined(BSP_USING_UART0) || defined(BSP_USING_UART1)|| defined(BSP_USING_UART2)|| defined(BSP_USING_UART3)
  17. typedef struct
  18. {
  19. struct rt_serial_device *serial;
  20. nrfx_uarte_t uarte_instance;
  21. uint8_t rx_length;
  22. uint8_t tx_buffer[1];
  23. uint8_t rx_buffer[1];
  24. bool isInit;
  25. uint32_t rx_pin;
  26. uint32_t tx_pin;
  27. } drv_uart_cb_t;
  28. #ifdef BSP_USING_UART0
  29. static struct rt_serial_device m_serial_0;
  30. drv_uart_cb_t m_uarte0_cb = {
  31. .uarte_instance = NRFX_UARTE_INSTANCE(0),
  32. .rx_length = 0,
  33. .rx_pin = BSP_UART0_RX_PIN,
  34. .tx_pin = BSP_UART0_TX_PIN,
  35. .isInit = false
  36. };
  37. #endif /* BSP_USING_UART0 */
  38. #ifdef BSP_USING_UART1
  39. static struct rt_serial_device m_serial_1;
  40. drv_uart_cb_t m_uarte1_cb = {
  41. .uarte_instance = NRFX_UARTE_INSTANCE(1),
  42. .rx_length = 0,
  43. .rx_pin = BSP_UART1_RX_PIN,
  44. .tx_pin = BSP_UART1_TX_PIN,
  45. .isInit = false
  46. };
  47. #endif /* BSP_USING_UART1 */
  48. #ifdef BSP_USING_UART2
  49. static struct rt_serial_device m_serial_2;
  50. drv_uart_cb_t m_uarte2_cb = {
  51. .uarte_instance = NRFX_UARTE_INSTANCE(2),
  52. .rx_length = 0,
  53. .rx_pin = BSP_UART2_RX_PIN,
  54. .tx_pin = BSP_UART2_TX_PIN,
  55. .isInit = false
  56. };
  57. #endif /* BSP_USING_UART2 */
  58. #ifdef BSP_USING_UART3
  59. static struct rt_serial_device m_serial_3;
  60. drv_uart_cb_t m_uarte3_cb = {
  61. .uarte_instance = NRFX_UARTE_INSTANCE(3),
  62. .rx_length = 0,
  63. .rx_pin = BSP_UART3_RX_PIN,
  64. .tx_pin = BSP_UART3_TX_PIN,
  65. .isInit = false
  66. };
  67. #endif /* BSP_USING_UART3 */
  68. static void uarte_evt_handler(nrfx_uarte_event_t const * p_event,
  69. void * p_context)
  70. {
  71. drv_uart_cb_t *p_cb = RT_NULL;
  72. p_cb = (drv_uart_cb_t*)p_context;
  73. switch (p_event->type)
  74. {
  75. case NRFX_UARTE_EVT_RX_DONE:
  76. p_cb->rx_length = p_event->data.rxtx.bytes;
  77. if(p_cb->serial->parent.open_flag&RT_DEVICE_FLAG_INT_RX)
  78. {
  79. rt_hw_serial_isr(p_cb->serial, RT_SERIAL_EVENT_RX_IND);
  80. }
  81. (void)nrfx_uarte_rx(&(p_cb->uarte_instance), p_cb->rx_buffer, 1);
  82. break;
  83. case NRFX_UARTE_EVT_ERROR:
  84. (void)nrfx_uarte_rx(&(p_cb->uarte_instance), p_cb->rx_buffer, 1);
  85. break;
  86. case NRFX_UARTE_EVT_TX_DONE:
  87. if(p_cb->serial->parent.open_flag&RT_DEVICE_FLAG_INT_TX)
  88. {
  89. rt_hw_serial_isr(p_cb->serial, RT_SERIAL_EVENT_TX_DONE);
  90. }
  91. break;
  92. default:
  93. break;
  94. }
  95. }
  96. static rt_err_t _uart_cfg(struct rt_serial_device *serial, struct serial_configure *cfg)
  97. {
  98. nrfx_uarte_config_t config = NRFX_UARTE_DEFAULT_CONFIG(NRF_UARTE_PSEL_DISCONNECTED,\
  99. NRF_UARTE_PSEL_DISCONNECTED);
  100. drv_uart_cb_t *p_cb = RT_NULL;
  101. RT_ASSERT(serial != RT_NULL);
  102. RT_ASSERT(cfg != RT_NULL);
  103. if (serial->parent.user_data == RT_NULL)
  104. {
  105. return -RT_ERROR;
  106. }
  107. p_cb = (drv_uart_cb_t*)serial->parent.user_data;
  108. if(p_cb->isInit)
  109. {
  110. nrfx_uarte_uninit(&(p_cb->uarte_instance));
  111. p_cb->isInit = false;
  112. }
  113. switch (cfg->baud_rate)
  114. {
  115. case BAUD_RATE_2400:
  116. config.baudrate = NRF_UARTE_BAUDRATE_2400;
  117. break;
  118. case BAUD_RATE_4800:
  119. config.baudrate = NRF_UARTE_BAUDRATE_4800;
  120. break;
  121. case BAUD_RATE_9600:
  122. config.baudrate = NRF_UARTE_BAUDRATE_9600;
  123. break;
  124. case BAUD_RATE_19200:
  125. config.baudrate = NRF_UARTE_BAUDRATE_19200;
  126. break;
  127. case BAUD_RATE_38400:
  128. config.baudrate = NRF_UARTE_BAUDRATE_38400;
  129. break;
  130. case BAUD_RATE_57600:
  131. config.baudrate = NRF_UARTE_BAUDRATE_57600;
  132. break;
  133. case BAUD_RATE_115200:
  134. config.baudrate = NRF_UARTE_BAUDRATE_115200;
  135. break;
  136. case BAUD_RATE_230400:
  137. config.baudrate = NRF_UARTE_BAUDRATE_230400;
  138. break;
  139. case BAUD_RATE_460800:
  140. config.baudrate = NRF_UARTE_BAUDRATE_460800;
  141. break;
  142. case BAUD_RATE_921600:
  143. config.baudrate = NRF_UARTE_BAUDRATE_921600;
  144. break;
  145. #if defined(SOC_NRF5340)
  146. case 1000000:
  147. config.baudrate = NRF_UARTE_BAUDRATE_1000000;
  148. break;
  149. #endif /* SOC_NRF5340*/
  150. case BAUD_RATE_2000000:
  151. case BAUD_RATE_3000000:
  152. return -RT_EINVAL;
  153. default:
  154. config.baudrate = NRF_UARTE_BAUDRATE_115200;
  155. break;
  156. }
  157. config.hal_cfg.parity = (cfg->parity == PARITY_NONE)?\
  158. NRF_UARTE_PARITY_EXCLUDED:NRF_UARTE_PARITY_INCLUDED;
  159. config.hal_cfg.hwfc = NRF_UARTE_HWFC_DISABLED;
  160. config.pselrxd = p_cb->rx_pin;
  161. config.pseltxd = p_cb->tx_pin;
  162. config.p_context = (void *)p_cb;
  163. nrfx_uarte_init(&(p_cb->uarte_instance),(nrfx_uarte_config_t const *)&config,uarte_evt_handler);
  164. nrfx_uarte_rx(&(p_cb->uarte_instance),p_cb->rx_buffer,1);
  165. p_cb->isInit = true;
  166. return RT_EOK;
  167. }
  168. static rt_err_t _uart_ctrl(struct rt_serial_device *serial, int cmd, void *arg)
  169. {
  170. drv_uart_cb_t *p_cb = RT_NULL;
  171. RT_ASSERT(serial != RT_NULL);
  172. if (serial->parent.user_data == RT_NULL)
  173. {
  174. return -RT_ERROR;
  175. }
  176. p_cb = (drv_uart_cb_t*)serial->parent.user_data;
  177. switch (cmd)
  178. {
  179. /* disable interrupt */
  180. case RT_DEVICE_CTRL_CLR_INT:
  181. break;
  182. /* enable interrupt */
  183. case RT_DEVICE_CTRL_SET_INT:
  184. break;
  185. case RT_DEVICE_CTRL_CUSTOM:
  186. if ((rt_uint32_t)(arg) == UART_CONFIG_BAUD_RATE_9600)
  187. {
  188. p_cb->serial->config.baud_rate = 9600;
  189. }
  190. else if ((rt_uint32_t)(arg) == UART_CONFIG_BAUD_RATE_115200)
  191. {
  192. p_cb->serial->config.baud_rate = 115200;
  193. }
  194. _uart_cfg(serial, &(serial->config));
  195. break;
  196. case RT_DEVICE_CTRL_PIN:
  197. _uart_cfg(serial, &(serial->config));
  198. break;
  199. case RT_DEVICE_POWERSAVE:
  200. if(p_cb->isInit)
  201. {
  202. nrfx_uarte_uninit(&(p_cb->uarte_instance));
  203. p_cb->isInit = false;
  204. }
  205. break;
  206. case RT_DEVICE_WAKEUP:
  207. _uart_cfg(serial, &(serial->config));
  208. break;
  209. default:
  210. return -RT_ERROR;
  211. }
  212. return RT_EOK;
  213. }
  214. static int _uart_putc(struct rt_serial_device *serial, char c)
  215. {
  216. drv_uart_cb_t *p_cb = RT_NULL;
  217. int rtn = -1;
  218. RT_ASSERT(serial != RT_NULL);
  219. if (serial->parent.user_data != RT_NULL)
  220. {
  221. p_cb = (drv_uart_cb_t*)serial->parent.user_data;
  222. }
  223. p_cb->tx_buffer[0] = c;
  224. nrfx_uarte_tx(&(p_cb->uarte_instance),p_cb->tx_buffer,1);
  225. if(!(serial->parent.open_flag&RT_DEVICE_FLAG_INT_TX))
  226. {
  227. while(nrfx_uarte_tx_in_progress(&(p_cb->uarte_instance)))
  228. {
  229. }
  230. }
  231. return rtn;
  232. }
  233. static int _uart_getc(struct rt_serial_device *serial)
  234. {
  235. int ch = -1;
  236. drv_uart_cb_t *p_cb = RT_NULL;
  237. RT_ASSERT(serial != RT_NULL);
  238. if (serial->parent.user_data != RT_NULL)
  239. {
  240. p_cb = (drv_uart_cb_t*)serial->parent.user_data;
  241. }
  242. if(p_cb->rx_length)
  243. {
  244. ch = p_cb->rx_buffer[0];
  245. p_cb->rx_length--;
  246. }
  247. return ch;
  248. }
  249. static struct rt_uart_ops _uart_ops = {
  250. _uart_cfg,
  251. _uart_ctrl,
  252. _uart_putc,
  253. _uart_getc
  254. };
  255. int rt_hw_uart_init(void)
  256. {
  257. struct serial_configure config = RT_SERIAL_CONFIG_DEFAULT;
  258. #ifdef BSP_USING_UART0
  259. m_serial_0.config = config;
  260. #if defined(SOC_NRF5340)
  261. m_serial_0.config.baud_rate = 1000000;
  262. #endif /* SOC_NRF5340*/
  263. m_serial_0.ops = &_uart_ops;
  264. m_uarte0_cb.serial = &m_serial_0;
  265. rt_hw_serial_register(&m_serial_0, "uart0", \
  266. RT_DEVICE_FLAG_RDWR | RT_DEVICE_FLAG_INT_RX | RT_DEVICE_FLAG_DMA_RX | RT_DEVICE_FLAG_DMA_TX , &m_uarte0_cb);
  267. #endif /* BSP_USING_UART0 */
  268. #ifdef BSP_USING_UART1
  269. m_serial_1.config = config;
  270. m_serial_1.ops = &_uart_ops;
  271. m_uarte1_cb.serial = &m_serial_1;
  272. rt_hw_serial_register(&m_serial_1, "uart1", \
  273. RT_DEVICE_FLAG_RDWR | RT_DEVICE_FLAG_INT_RX |RT_DEVICE_FLAG_INT_TX | RT_DEVICE_FLAG_DMA_RX | RT_DEVICE_FLAG_DMA_TX, &m_uarte1_cb);
  274. #endif /* BSP_USING_UART1 */
  275. #ifdef BSP_USING_UART2
  276. m_serial_2.config = config;
  277. m_serial_2.ops = &_uart_ops;
  278. m_uarte2_cb.serial = &m_serial_2;
  279. rt_hw_serial_register(&m_serial_2, "uart2", \
  280. RT_DEVICE_FLAG_RDWR | RT_DEVICE_FLAG_INT_RX |RT_DEVICE_FLAG_INT_TX | RT_DEVICE_FLAG_DMA_RX | RT_DEVICE_FLAG_DMA_TX, &m_uarte2_cb);
  281. #endif /* BSP_USING_UART2 */
  282. #ifdef BSP_USING_UART3
  283. m_serial_3.config = config;
  284. m_serial_3.ops = &_uart_ops;
  285. m_uarte3_cb.serial = &m_serial_3;
  286. rt_hw_serial_register(&m_serial_3, "uart3", \
  287. RT_DEVICE_FLAG_RDWR | RT_DEVICE_FLAG_INT_RX |RT_DEVICE_FLAG_INT_TX | RT_DEVICE_FLAG_DMA_RX | RT_DEVICE_FLAG_DMA_TX, &m_uarte3_cb);
  288. #endif /* BSP_USING_UART3 */
  289. return RT_EOK;
  290. }
  291. #endif /* defined(BSP_USING_UART0) || defined(BSP_USING_UART1) */
  292. #endif /* BSP_USING_UART */