evalsoc_uart.c 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. #include "evalsoc.h"
  2. #include "evalsoc_uart.h"
  3. int32_t uart_init(UART_TypeDef* uart, uint32_t baudrate)
  4. {
  5. if (__RARELY(uart == NULL)) {
  6. return -1;
  7. }
  8. uart->DIV = SystemCoreClock / baudrate - 1;
  9. uart->TXCTRL |= UART_TXEN;
  10. uart->RXCTRL |= UART_RXEN;
  11. return 0;
  12. }
  13. int32_t uart_config_stopbit(UART_TypeDef* uart, UART_STOP_BIT stopbit)
  14. {
  15. if (__RARELY(uart == NULL)) {
  16. return -1;
  17. }
  18. uint32_t stopval = stopbit;
  19. stopval = (stopbit << UART_TXCTRL_NSTOP_OFS) & UART_TXCTRL_TXCNT_MASK;
  20. uart->TXCTRL &= stopval | (~UART_TXCTRL_TXCNT_MASK);
  21. return 0;
  22. }
  23. int32_t uart_write(UART_TypeDef* uart, uint8_t val)
  24. {
  25. if (__RARELY(uart == NULL)) {
  26. return -1;
  27. }
  28. while (uart->TXFIFO & UART_TXFIFO_FULL);
  29. uart->TXFIFO = val;
  30. return 0;
  31. }
  32. uint8_t uart_read(UART_TypeDef* uart)
  33. {
  34. uint32_t reg;
  35. if (__RARELY(uart == NULL)) {
  36. return -1;
  37. }
  38. do {
  39. reg = uart->RXFIFO;
  40. } while (reg & UART_RXFIFO_EMPTY);
  41. return (uint8_t)(reg & 0xFF);
  42. }
  43. int32_t uart_set_tx_watermark(UART_TypeDef* uart, uint32_t watermark)
  44. {
  45. if (__RARELY(uart == NULL)) {
  46. return -1;
  47. }
  48. watermark = (watermark << UART_TXCTRL_TXCNT_OFS) & UART_TXCTRL_TXCNT_MASK;
  49. uart->TXCTRL &= watermark | (~UART_TXCTRL_TXCNT_MASK);
  50. return 0;
  51. }
  52. int32_t uart_enable_txint(UART_TypeDef* uart)
  53. {
  54. if (__RARELY(uart == NULL)) {
  55. return -1;
  56. }
  57. uart->IE |= UART_IE_TXIE_MASK;
  58. return 0;
  59. }
  60. int32_t uart_disable_txint(UART_TypeDef* uart)
  61. {
  62. if (__RARELY(uart == NULL)) {
  63. return -1;
  64. }
  65. uart->IE &= ~UART_IE_TXIE_MASK;
  66. return 0;
  67. }
  68. int32_t uart_set_rx_watermark(UART_TypeDef* uart, uint32_t watermark)
  69. {
  70. if (__RARELY(uart == NULL)) {
  71. return -1;
  72. }
  73. watermark = (watermark << UART_RXCTRL_RXCNT_OFS) & UART_RXCTRL_RXCNT_MASK;
  74. uart->RXCTRL &= watermark | (~UART_RXCTRL_RXCNT_MASK);
  75. return 0;
  76. }
  77. int32_t uart_enable_rxint(UART_TypeDef* uart)
  78. {
  79. if (__RARELY(uart == NULL)) {
  80. return -1;
  81. }
  82. uart->IE |= UART_IE_RXIE_MASK;
  83. return 0;
  84. }
  85. int32_t uart_disable_rxint(UART_TypeDef* uart)
  86. {
  87. if (__RARELY(uart == NULL)) {
  88. return -1;
  89. }
  90. uart->IE &= ~UART_IE_RXIE_MASK;
  91. return 0;
  92. }
  93. int32_t uart_get_status(UART_TypeDef* uart)
  94. {
  95. if (__RARELY(uart == NULL)) {
  96. return -1;
  97. }
  98. return (uart->IP);
  99. }
  100. int32_t uart_clear_status(UART_TypeDef* uart, uint32_t mask)
  101. {
  102. if (__RARELY(uart == NULL)) {
  103. return -1;
  104. }
  105. uart->IP &= ~mask;
  106. return 0;
  107. }