drv_uart.c 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212
  1. #include <rtdevice.h>
  2. #include <nrfx_uart.h>
  3. #include "drv_uart.h"
  4. static struct rt_serial_device _serial0_0;
  5. static void uart_event_hander(nrfx_uart_event_t const *p_event,void *p_context);
  6. typedef struct
  7. {
  8. struct rt_serial_device *serial;
  9. nrfx_uart_t uart;
  10. uint32_t rx_pin;
  11. uint32_t tx_pin;
  12. nrfx_uart_event_handler_t event_handler;
  13. } UART_CFG_T;
  14. UART_CFG_T uart0 = {
  15. .uart = NRFX_UART_INSTANCE(0),
  16. #ifdef RT_USING_CONSOLE
  17. .rx_pin = 8,
  18. .tx_pin = 6,
  19. .event_handler = uart_event_hander,
  20. #else
  21. .rx_pin = 19,
  22. .tx_pin = 20
  23. #endif
  24. };
  25. UART_CFG_T *working_cfg = RT_NULL;
  26. static void uart_event_hander(nrfx_uart_event_t const *p_event,void *p_context)
  27. {
  28. if (p_event->type == NRFX_UART_EVT_RX_DONE)
  29. {
  30. rt_hw_serial_isr(working_cfg->serial, RT_SERIAL_EVENT_RX_IND);
  31. }
  32. if (p_event->type == NRFX_UART_EVT_TX_DONE)
  33. {
  34. }
  35. }
  36. static rt_err_t _uart_cfg(struct rt_serial_device *serial, struct serial_configure *cfg)
  37. {
  38. nrfx_uart_config_t config = NRFX_UART_DEFAULT_CONFIG(uart0.tx_pin,uart0.rx_pin);
  39. UART_CFG_T *instance = &uart0;
  40. RT_ASSERT(serial != RT_NULL);
  41. RT_ASSERT(cfg != RT_NULL);
  42. if (serial->parent.user_data != RT_NULL)
  43. {
  44. instance = (UART_CFG_T*)serial->parent.user_data;
  45. }
  46. nrfx_uart_uninit(&(instance->uart));
  47. switch (cfg->baud_rate)
  48. {
  49. case 115200:
  50. config.baudrate = NRF_UART_BAUDRATE_115200;
  51. break;
  52. case 9600:
  53. config.baudrate = NRF_UART_BAUDRATE_9600;
  54. break;
  55. default:
  56. config.baudrate = NRF_UART_BAUDRATE_115200;
  57. break;
  58. }
  59. if (cfg->parity == PARITY_NONE)
  60. {
  61. config.hal_cfg.parity = NRF_UART_PARITY_EXCLUDED;
  62. }
  63. else
  64. {
  65. config.hal_cfg.parity = NRF_UART_PARITY_INCLUDED;
  66. }
  67. config.hal_cfg.hwfc = NRF_UART_HWFC_DISABLED;
  68. config.pselrxd = instance->rx_pin;
  69. config.pseltxd = instance->tx_pin;
  70. nrfx_uart_init(&(instance->uart), &config, instance->event_handler);
  71. nrf_uart_int_enable(instance->uart.p_reg, NRF_UART_INT_MASK_RXDRDY | NRF_UART_INT_MASK_RXTO | NRF_UART_INT_MASK_ERROR);
  72. nrf_uart_int_disable(instance->uart.p_reg, NRF_UART_INT_MASK_TXDRDY);
  73. nrfx_uart_rx_enable(&(instance->uart));
  74. working_cfg = instance;
  75. return RT_EOK;
  76. }
  77. static rt_err_t _uart_ctrl(struct rt_serial_device *serial, int cmd, void *arg)
  78. {
  79. UART_CFG_T *instance = working_cfg;
  80. RT_ASSERT(serial != RT_NULL);
  81. if (serial->parent.user_data != RT_NULL)
  82. {
  83. instance = (UART_CFG_T*)serial->parent.user_data;
  84. }
  85. switch (cmd)
  86. {
  87. /* disable interrupt */
  88. case RT_DEVICE_CTRL_CLR_INT:
  89. break;
  90. /* enable interrupt */
  91. case RT_DEVICE_CTRL_SET_INT:
  92. break;
  93. case RT_DEVICE_CTRL_CUSTOM:
  94. if ((rt_uint32_t)(arg) == UART_CONFIG_BAUD_RATE_9600)
  95. {
  96. instance->serial->config.baud_rate = 9600;
  97. }
  98. else if ((rt_uint32_t)(arg) == UART_CONFIG_BAUD_RATE_115200)
  99. {
  100. instance->serial->config.baud_rate = 115200;
  101. }
  102. _uart_cfg(instance->serial, &(instance->serial->config));
  103. break;
  104. case RT_DEVICE_CTRL_PIN:
  105. if (working_cfg != instance)
  106. {
  107. _uart_cfg(instance->serial, &(instance->serial->config));
  108. }
  109. break;
  110. case RT_DEVICE_POWERSAVE:
  111. nrfx_uart_uninit(&(instance->uart));
  112. break;
  113. case RT_DEVICE_WAKEUP:
  114. _uart_cfg(instance->serial, &(instance->serial->config));
  115. break;
  116. default:
  117. return RT_ERROR;
  118. }
  119. return RT_EOK;
  120. }
  121. static int _uart_putc(struct rt_serial_device *serial, char c)
  122. {
  123. UART_CFG_T *instance = working_cfg;
  124. int rtn = 1;
  125. RT_ASSERT(serial != RT_NULL);
  126. if (serial->parent.user_data != RT_NULL)
  127. {
  128. instance = (UART_CFG_T*)serial->parent.user_data;
  129. }
  130. nrf_uart_event_clear(instance->uart.p_reg, NRF_UART_EVENT_TXDRDY);
  131. nrf_uart_task_trigger(instance->uart.p_reg, NRF_UART_TASK_STARTTX);
  132. nrf_uart_txd_set(instance->uart.p_reg, (uint8_t)c);
  133. while (!nrf_uart_event_check(instance->uart.p_reg, NRF_UART_EVENT_TXDRDY))
  134. {
  135. //wait for TXD send
  136. }
  137. return rtn;
  138. }
  139. /*
  140. @note: this function is invaild ,the cause of the problem is [nrfx_uart.c - line 340]
  141. */
  142. static int _uart_getc(struct rt_serial_device *serial)
  143. {
  144. int ch = -1;
  145. UART_CFG_T *instance = working_cfg;
  146. RT_ASSERT(serial != RT_NULL);
  147. if (serial->parent.user_data != RT_NULL)
  148. {
  149. instance = (UART_CFG_T*)serial->parent.user_data;
  150. }
  151. ch = (int)(nrf_uart_rxd_get(instance->uart.p_reg));
  152. return ch;
  153. }
  154. static struct rt_uart_ops _uart_ops = {
  155. _uart_cfg,
  156. _uart_ctrl,
  157. _uart_putc,
  158. _uart_getc
  159. };
  160. void rt_hw_uart_init(void)
  161. {
  162. struct serial_configure config = RT_SERIAL_CONFIG_DEFAULT;
  163. config.bufsz = RT_SERIAL_RB_BUFSZ;
  164. _serial0_0.config = config;
  165. _serial0_0.ops = &_uart_ops;
  166. uart0.serial = &_serial0_0;
  167. rt_hw_serial_register(&_serial0_0, "uart0", RT_DEVICE_FLAG_RDWR | RT_DEVICE_FLAG_INT_RX, &uart0);
  168. }