ls1c_uart.h 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. // 串口相关头文件
  2. #ifndef __OPENLOONGSON_UART_H
  3. #define __OPENLOONGSON_UART_H
  4. #include "ls1c_public.h"
  5. // 串口各寄存器相对基地址的偏移
  6. #define LS1C_UART_DAT_OFFSET (0)
  7. #define LS1C_UART_IER_OFFSET (1)
  8. #define LS1C_UART_IIR_OFFSET (2)
  9. #define LS1C_UART_FCR_OFFSET (2)
  10. #define LS1C_UART_LCR_OFFSET (3)
  11. #define LS1C_UART_MCR_OFFSET (4)
  12. #define LS1C_UART_LSR_OFFSET (5)
  13. #define LS1C_UART_MSR_OFFSET (6)
  14. #define LS1C_UART_LSB_OFFSET (0) // 分频锁存器1
  15. #define LS1C_UART_MSB_OFFSET (1) // 分频锁存器2
  16. /* interrupt enable register */
  17. #define IER_IRxE 0x1 /* 接收有效数据中断使能 */
  18. #define IER_ITxE 0x2 /* 传输保存寄存器为空中断使能 */
  19. #define IER_ILE 0x4 /* 接收器线路状态中断使能 */
  20. #define IER_IME 0x8 /* Modem状态中断使能 */
  21. /* interrupt identification register */
  22. #define IIR_IMASK 0xf /* mask */
  23. #define IIR_RXTOUT 0xc /* receive timeout */
  24. #define IIR_RLS 0x6 /* receive line status */
  25. #define IIR_RXRDY 0x4 /* receive ready */
  26. #define IIR_TXRDY 0x2 /* transmit ready */
  27. #define IIR_NOPEND 0x1 /* nothing */
  28. #define IIR_MLSC 0x0 /* modem status */
  29. #define IIR_FIFO_MASK 0xc0 /* set if FIFOs are enabled */
  30. /* fifo control register */
  31. #define FIFO_ENABLE 0x01 /* enable fifo */
  32. #define FIFO_RCV_RST 0x02 /* reset receive fifo */
  33. #define FIFO_XMT_RST 0x04 /* reset transmit fifo */
  34. #define FIFO_DMA_MODE 0x08 /* enable dma mode */
  35. #define FIFO_TRIGGER_1 0x00 /* trigger at 1 char */
  36. #define FIFO_TRIGGER_4 0x40 /* trigger at 4 chars */
  37. #define FIFO_TRIGGER_8 0x80 /* trigger at 8 chars */
  38. #define FIFO_TRIGGER_14 0xc0 /* trigger at 14 chars */
  39. // 线路控制寄存器
  40. /* character format control register */
  41. #define CFCR_DLAB 0x80 /* divisor latch */
  42. #define CFCR_SBREAK 0x40 /* send break */
  43. #define CFCR_PZERO 0x30 /* zero parity */
  44. #define CFCR_PONE 0x20 /* one parity */
  45. #define CFCR_PEVEN 0x10 /* even parity */
  46. #define CFCR_PODD 0x00 /* odd parity */
  47. #define CFCR_PENAB 0x08 /* parity enable */
  48. #define CFCR_STOPB 0x04 /* 2 stop bits */
  49. #define CFCR_8BITS 0x03 /* 8 data bits */
  50. #define CFCR_7BITS 0x02 /* 7 data bits */
  51. #define CFCR_6BITS 0x01 /* 6 data bits */
  52. #define CFCR_5BITS 0x00 /* 5 data bits */
  53. /* modem control register */
  54. #define MCR_LOOPBACK 0x10 /* loopback */
  55. #define MCR_IENABLE 0x08 /* output 2 = int enable */
  56. #define MCR_DRS 0x04 /* output 1 = xxx */
  57. #define MCR_RTS 0x02 /* enable RTS */
  58. #define MCR_DTR 0x01 /* enable DTR */
  59. /* line status register */
  60. #define LSR_RCV_FIFO 0x80 /* error in receive fifo */
  61. #define LSR_TSRE 0x40 /* transmitter empty */
  62. #define LSR_TXRDY 0x20 /* transmitter ready */
  63. #define LSR_BI 0x10 /* break detected */
  64. #define LSR_FE 0x08 /* framing error */
  65. #define LSR_PE 0x04 /* parity error */
  66. #define LSR_OE 0x02 /* overrun error */
  67. #define LSR_RXRDY 0x01 /* receiver ready */
  68. #define LSR_RCV_MASK 0x1f
  69. // 串口模块编号
  70. typedef enum
  71. {
  72. LS1C_UART00 = 0, // 全功能串口UART0可以分为两个四线串口UART00和UART01
  73. LS1C_UART01,
  74. LS1C_UART1,
  75. LS1C_UART2,
  76. LS1C_UART3,
  77. LS1C_UART4,
  78. LS1C_UART5,
  79. LS1C_UART6,
  80. LS1C_UART7,
  81. LS1C_UART8,
  82. LS1C_UART9,
  83. LS1C_UART10,
  84. LS1C_UART11
  85. }ls1c_uart_t;
  86. // 串口信息
  87. typedef struct
  88. {
  89. ls1c_uart_t UARTx; // 串口模块编号
  90. unsigned int baudrate; // 波特率
  91. BOOL rx_enable; // 是否需要使用串口接收数据(使能接收中断),发送默认使能
  92. }ls1c_uart_info_t;
  93. /*
  94. * 获取指定串口模块的基地址
  95. * @UARTx 串口编号
  96. * @ret 基地址
  97. */
  98. void *uart_get_base(ls1c_uart_t UARTx);
  99. /*
  100. * 初始化指定的串口模块
  101. * @uart_info_p 串口模块信息
  102. */
  103. void uart_init(ls1c_uart_info_t *uart_info_p);
  104. /*
  105. * 初始化串口2
  106. */
  107. void uart2_init(void);
  108. /*
  109. * 在串口2上打印字符串
  110. * @str 待打印的字符串
  111. */
  112. void uart2_print(const char *str);
  113. /*
  114. * 在调试串口打印字符串
  115. * @str 待打印的字符串
  116. */
  117. void uart_debug_print(const char *str);
  118. /*
  119. * 在调试串口打印一个字符
  120. * @ch 待打印的字符
  121. */
  122. void uart_debug_putc(unsigned char ch);
  123. /*
  124. * 把中断号转换为串口号
  125. * @IRQn 中断号
  126. * @ret 串口号
  127. */
  128. ls1c_uart_t uart_irqn_to_uartx(int IRQn);
  129. /*
  130. * 发送一个字节
  131. * @uartx 串口号
  132. * @ch 待发送的字符串
  133. */
  134. void uart_putc(ls1c_uart_t uartx, unsigned char ch);
  135. /*
  136. * 打印一个字符串到指定串口
  137. * @uartx 串口号
  138. * @str 待打印的字符串
  139. */
  140. void uart_print(ls1c_uart_t uartx, const char *str);
  141. #endif