drv_uart.h 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. /*
  2. * Copyright (c) 2006-2020, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. */
  9. #ifndef __DRV_UART_H__
  10. #define __DRV_UART_H__
  11. #include "riscv_io.h"
  12. /**
  13. * uart ns16550a
  14. * http://byterunner.com/16550.html
  15. */
  16. /* TRANSMIT AND RECEIVE HOLDING REGISTER */
  17. #define UART_RHR 0
  18. #define UART_THR 0
  19. /* INTERRUPT ENABLE REGISTER */
  20. #define UART_IER 1
  21. #define UART_IER_RX_ENABLE (1 << 0)
  22. #define UART_IER_TX_ENABLE (1 << 1)
  23. /* FIFO CONTROL REGISTER */
  24. #define UART_FCR 2
  25. #define UART_FCR_FIFO_ENABLE (1 << 0)
  26. #define UART_FCR_FIFO_CLEAR (3 << 1)
  27. /* INTERRUPT STATUS REGISTER */
  28. #define UART_ISR 2
  29. /* LINE CONTROL REGISTER */
  30. #define UART_LCR 3
  31. #define UART_LCR_EIGHT_BITS (3 << 0)
  32. // special mode to set baud rate
  33. #define UART_LCR_BAUD_LATCH (1 << 7)
  34. /* LINE STATUS REGISTER */
  35. #define UART_LSR 5
  36. // input is waiting to be read from RHR
  37. #define UART_LSR_RX_READY (1 << 0)
  38. // THR can accept another character to send
  39. #define UART_LSR_TX_IDLE (1 << 5)
  40. #define UART_REFERENCE_CLOCK 1843200
  41. #define UART_DEFAULT_BAUDRATE 115200
  42. extern void *uart0_base;
  43. #define write8_uart0(idx, value) __raw_writeb(((rt_uint8_t)value), (void*)((size_t)uart0_base + (idx)))
  44. #define read8_uart0(idx) __raw_readb((void*)((size_t)uart0_base + (idx)))
  45. void rt_hw_uart_start_rx_thread();
  46. int rt_hw_uart_init(void);
  47. void drv_uart_puts(char *str); // for syscall
  48. #endif /* __DRV_UART_H__ */