2 * PIC32 Integrated Serial Driver.
4 * Copyright (C) 2015 Microchip Technology, Inc.
7 * Sorin-Andrei Pistirica <andrei.pistirica@microchip.com>
9 * Licensed under GPLv2 or later.
11 #ifndef __DT_PIC32_UART_H__
12 #define __DT_PIC32_UART_H__
14 #define PIC32_UART_DFLT_BRATE (9600)
15 #define PIC32_UART_TX_FIFO_DEPTH (8)
16 #define PIC32_UART_RX_FIFO_DEPTH (8)
18 #define PIC32_UART_MODE 0x00
19 #define PIC32_UART_STA 0x10
20 #define PIC32_UART_TX 0x20
21 #define PIC32_UART_RX 0x30
22 #define PIC32_UART_BRG 0x40
24 struct pic32_console_opt {
31 /* struct pic32_sport - pic32 serial port descriptor
32 * @port: uart port descriptor
34 * @irq_fault: virtual fault interrupt number
35 * @irqflags_fault: flags related to fault irq
36 * @irq_fault_name: irq fault name
37 * @irq_rx: virtual rx interrupt number
38 * @irqflags_rx: flags related to rx irq
39 * @irq_rx_name: irq rx name
40 * @irq_tx: virtual tx interrupt number
41 * @irqflags_tx: : flags related to tx irq
42 * @irq_tx_name: irq tx name
43 * @cts_gpio: clear to send gpio
44 * @dev: device descriptor
47 struct uart_port port;
48 struct pic32_console_opt opt;
53 const char *irq_fault_name;
56 const char *irq_rx_name;
59 const char *irq_tx_name;
70 #define to_pic32_sport(c) container_of(c, struct pic32_sport, port)
71 #define pic32_get_port(sport) (&sport->port)
72 #define pic32_get_opt(sport) (&sport->opt)
73 #define tx_irq_enabled(sport) (sport->enable_tx_irq)
75 static inline void pic32_uart_writel(struct pic32_sport *sport,
78 struct uart_port *port = pic32_get_port(sport);
80 __raw_writel(val, port->membase + reg);
83 static inline u32 pic32_uart_readl(struct pic32_sport *sport, u32 reg)
85 struct uart_port *port = pic32_get_port(sport);
87 return __raw_readl(port->membase + reg);
90 /* pic32 uart mode register bits */
91 #define PIC32_UART_MODE_ON BIT(15)
92 #define PIC32_UART_MODE_FRZ BIT(14)
93 #define PIC32_UART_MODE_SIDL BIT(13)
94 #define PIC32_UART_MODE_IREN BIT(12)
95 #define PIC32_UART_MODE_RTSMD BIT(11)
96 #define PIC32_UART_MODE_RESV1 BIT(10)
97 #define PIC32_UART_MODE_UEN1 BIT(9)
98 #define PIC32_UART_MODE_UEN0 BIT(8)
99 #define PIC32_UART_MODE_WAKE BIT(7)
100 #define PIC32_UART_MODE_LPBK BIT(6)
101 #define PIC32_UART_MODE_ABAUD BIT(5)
102 #define PIC32_UART_MODE_RXINV BIT(4)
103 #define PIC32_UART_MODE_BRGH BIT(3)
104 #define PIC32_UART_MODE_PDSEL1 BIT(2)
105 #define PIC32_UART_MODE_PDSEL0 BIT(1)
106 #define PIC32_UART_MODE_STSEL BIT(0)
108 /* pic32 uart status register bits */
109 #define PIC32_UART_STA_UTXISEL1 BIT(15)
110 #define PIC32_UART_STA_UTXISEL0 BIT(14)
111 #define PIC32_UART_STA_UTXINV BIT(13)
112 #define PIC32_UART_STA_URXEN BIT(12)
113 #define PIC32_UART_STA_UTXBRK BIT(11)
114 #define PIC32_UART_STA_UTXEN BIT(10)
115 #define PIC32_UART_STA_UTXBF BIT(9)
116 #define PIC32_UART_STA_TRMT BIT(8)
117 #define PIC32_UART_STA_URXISEL1 BIT(7)
118 #define PIC32_UART_STA_URXISEL0 BIT(6)
119 #define PIC32_UART_STA_ADDEN BIT(5)
120 #define PIC32_UART_STA_RIDLE BIT(4)
121 #define PIC32_UART_STA_PERR BIT(3)
122 #define PIC32_UART_STA_FERR BIT(2)
123 #define PIC32_UART_STA_OERR BIT(1)
124 #define PIC32_UART_STA_URXDA BIT(0)
126 #endif /* __DT_PIC32_UART_H__ */