logo

qmk_firmware

custom branch of QMK firmware git clone https://anongit.hacktivis.me/git/qmk_firmware.git

uart_sio.c (3149B)


  1. // Copyright 2024 Stefan Kerkmann (@KarlK90)
  2. // Copyright 2021 QMK
  3. // SPDX-License-Identifier: GPL-2.0-or-later
  4. #include "uart.h"
  5. #include "gpio.h"
  6. #include "chibios_config.h"
  7. #include <hal.h>
  8. #ifndef UART_DRIVER
  9. # define UART_DRIVER SIOD1
  10. #endif
  11. #ifndef UART_TX_PIN
  12. # define UART_TX_PIN A9
  13. #endif
  14. #ifndef UART_TX_PAL_MODE
  15. # ifdef USE_GPIOV1
  16. # define UART_TX_PAL_MODE PAL_MODE_ALTERNATE_PUSHPULL
  17. # else
  18. # define UART_TX_PAL_MODE 7
  19. # endif
  20. #endif
  21. #ifndef UART_RX_PIN
  22. # define UART_RX_PIN A10
  23. #endif
  24. #ifndef UART_RX_PAL_MODE
  25. # ifdef USE_GPIOV1
  26. # define UART_RX_PAL_MODE PAL_MODE_INPUT
  27. # else
  28. # define UART_RX_PAL_MODE 7
  29. # endif
  30. #endif
  31. #ifndef UART_CTS_PIN
  32. # define UART_CTS_PIN A11
  33. #endif
  34. #ifndef UART_CTS_PAL_MODE
  35. # ifdef USE_GPIOV1
  36. # define UART_CTS_PAL_MODE PAL_MODE_INPUT
  37. # else
  38. # define UART_CTS_PAL_MODE 7
  39. # endif
  40. #endif
  41. #ifndef UART_RTS_PIN
  42. # define UART_RTS_PIN A12
  43. #endif
  44. #ifndef UART_RTS_PAL_MODE
  45. # ifdef USE_GPIOV1
  46. # define UART_RTS_PAL_MODE PAL_MODE_ALTERNATE_PUSHPULL
  47. # else
  48. # define UART_RTS_PAL_MODE 7
  49. # endif
  50. #endif
  51. #ifndef UART_CR1
  52. # define UART_CR1 0
  53. #endif
  54. #ifndef UART_CR2
  55. # define UART_CR2 0
  56. #endif
  57. #ifndef UART_CR3
  58. # define UART_CR3 0
  59. #endif
  60. #if defined(MCU_RP)
  61. // 38400 baud, 8 data bits, 1 stop bit, no parity, no flow control
  62. static SIOConfig sioConfig = {
  63. .baud = SIO_DEFAULT_BITRATE,
  64. .UARTLCR_H = (UART_UARTLCR_H_WLEN_8BITS | UART_UARTLCR_H_FEN),
  65. .UARTCR = 0U,
  66. .UARTIFLS = (UART_UARTIFLS_RXIFLSEL_1_8F | UART_UARTIFLS_TXIFLSEL_1_8E),
  67. .UARTDMACR = 0U,
  68. };
  69. #else
  70. static SIOConfig sioConfig = {
  71. .baud = SIO_DEFAULT_BITRATE,
  72. # if defined(MCU_STM32) && defined(USE_USARTV3)
  73. .presc = USART_PRESC1,
  74. # endif
  75. .cr1 = UART_CR1,
  76. .cr2 = UART_CR2,
  77. .cr3 = UART_CR3,
  78. };
  79. #endif
  80. void uart_init(uint32_t baud) {
  81. static bool is_initialised = false;
  82. if (is_initialised) {
  83. return;
  84. }
  85. is_initialised = true;
  86. sioConfig.baud = baud;
  87. #if defined(USE_GPIOV1)
  88. palSetLineMode(UART_TX_PIN, UART_TX_PAL_MODE);
  89. palSetLineMode(UART_RX_PIN, UART_RX_PAL_MODE);
  90. #else
  91. palSetLineMode(UART_TX_PIN, PAL_MODE_ALTERNATE(UART_TX_PAL_MODE) | PAL_OUTPUT_TYPE_PUSHPULL | PAL_OUTPUT_SPEED_HIGHEST);
  92. palSetLineMode(UART_RX_PIN, PAL_MODE_ALTERNATE(UART_RX_PAL_MODE) | PAL_OUTPUT_TYPE_PUSHPULL | PAL_OUTPUT_SPEED_HIGHEST);
  93. #endif
  94. sioStart(&UART_DRIVER, &sioConfig);
  95. }
  96. void uart_write(uint8_t data) {
  97. chnPutTimeout(&UART_DRIVER, data, TIME_INFINITE);
  98. }
  99. uint8_t uart_read(void) {
  100. msg_t result = chnGetTimeout(&UART_DRIVER, TIME_INFINITE);
  101. if (sioHasRXErrorsX(&UART_DRIVER)) {
  102. sioGetAndClearErrors(&UART_DRIVER);
  103. }
  104. return (uint8_t)result;
  105. }
  106. void uart_transmit(const uint8_t *data, uint16_t length) {
  107. chnWrite(&UART_DRIVER, data, length);
  108. }
  109. void uart_receive(uint8_t *data, uint16_t length) {
  110. chnRead(&UART_DRIVER, data, length);
  111. if (sioHasRXErrorsX(&UART_DRIVER)) {
  112. sioGetAndClearErrors(&UART_DRIVER);
  113. }
  114. }
  115. bool uart_available() {
  116. return !sioIsRXEmptyX(&UART_DRIVER);
  117. }