1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
|
/*
* Freescale STMP37XX/STMP378X Debug UART driver
*
* Copyright 2008-2009 Freescale Semiconductor, Inc. All Rights Reserved.
* Copyright 2008 Embedded Alley Solutions, Inc All Rights Reserved.
*/
/*
* The code contained herein is licensed under the GNU General Public
* License. You may obtain a copy of the GNU General Public License
* Version 2 or later at the following locations:
*
* http://www.opensource.org/licenses/gpl-license.html
* http://www.gnu.org/copyleft/gpl.html
*/
#ifndef __STMP_DBG_H
#define __STMP_DBG_H
/*
* UART register offsets
*/
#define UART01x_DR 0x00 /* Data read or written */
#define UART01x_RSR 0x04 /* Receive status register */
#define UART01x_ECR 0x04 /* Error clear register (write) */
#define UART010_LCRH 0x08 /* Line control register, MSB */
#define UART010_LCRM 0x0C /* Line control register, */
#define UART010_LCRL 0x10 /* Line control register, LSB */
#define UART010_CR 0x14 /* Control register. */
#define UART01x_FR 0x18 /* Flag register (Read only). */
#define UART010_IIR 0x1C /* Interrupt identification */
#define UART010_ICR 0x1C /* Interrupt clear register */
#define UART01x_ILPR 0x20 /* IrDA low power counter */
#define UART011_IBRD 0x24 /* Integer baud rate divisor */
#define UART011_FBRD 0x28 /* Fractional baud rate divisor */
#define UART011_LCRH 0x2c /* Line control */
#define UART011_CR 0x30 /* Control */
#define UART011_IFLS 0x34 /* Interrupt fifo level select */
#define UART011_IMSC 0x38 /* Interrupt mask */
#define UART011_RIS 0x3c /* Raw */
#define UART011_MIS 0x40 /* Masked */
#define UART011_ICR 0x44 /* Interrupt clear register */
#define UART011_DMACR 0x48 /* DMA control register */
#define UART011_DR_OE (1 << 11)
#define UART011_DR_BE (1 << 10)
#define UART011_DR_PE (1 << 9)
#define UART011_DR_FE (1 << 8)
#define UART01x_RSR_OE 0x08
#define UART01x_RSR_BE 0x04
#define UART01x_RSR_PE 0x02
#define UART01x_RSR_FE 0x01
#define UART011_FR_RI 0x100
#define UART011_FR_TXFE 0x080
#define UART011_FR_RXFF 0x040
#define UART01x_FR_TXFF 0x020
#define UART01x_FR_RXFE 0x010
#define UART01x_FR_BUSY 0x008
#define UART01x_FR_DCD 0x004
#define UART01x_FR_DSR 0x002
#define UART01x_FR_CTS 0x001
#define UART01x_FR_TMSK (UART01x_FR_TXFF + UART01x_FR_BUSY)
#define UART011_CR_CTSEN 0x8000 /* CTS hardware flow control */
#define UART011_CR_RTSEN 0x4000 /* RTS hardware flow control */
#define UART011_CR_OUT2 0x2000 /* OUT2 */
#define UART011_CR_OUT1 0x1000 /* OUT1 */
#define UART011_CR_RTS 0x0800 /* RTS */
#define UART011_CR_DTR 0x0400 /* DTR */
#define UART011_CR_RXE 0x0200 /* receive enable */
#define UART011_CR_TXE 0x0100 /* transmit enable */
#define UART011_CR_LBE 0x0080 /* loopback enable */
#define UART010_CR_RTIE 0x0040
#define UART010_CR_TIE 0x0020
#define UART010_CR_RIE 0x0010
#define UART010_CR_MSIE 0x0008
#define UART01x_CR_IIRLP 0x0004 /* SIR low power mode */
#define UART01x_CR_SIREN 0x0002 /* SIR enable */
#define UART01x_CR_UARTEN 0x0001 /* UART enable */
#define UART011_LCRH_SPS 0x80
#define UART01x_LCRH_WLEN_8 0x60
#define UART01x_LCRH_WLEN_7 0x40
#define UART01x_LCRH_WLEN_6 0x20
#define UART01x_LCRH_WLEN_5 0x00
#define UART01x_LCRH_FEN 0x10
#define UART01x_LCRH_STP2 0x08
#define UART01x_LCRH_EPS 0x04
#define UART01x_LCRH_PEN 0x02
#define UART01x_LCRH_BRK 0x01
#define UART010_IIR_RTIS 0x08
#define UART010_IIR_TIS 0x04
#define UART010_IIR_RIS 0x02
#define UART010_IIR_MIS 0x01
#define UART011_IFLS_RX1_8 (0 << 3)
#define UART011_IFLS_RX2_8 (1 << 3)
#define UART011_IFLS_RX4_8 (2 << 3)
#define UART011_IFLS_RX6_8 (3 << 3)
#define UART011_IFLS_RX7_8 (4 << 3)
#define UART011_IFLS_TX1_8 (0 << 0)
#define UART011_IFLS_TX2_8 (1 << 0)
#define UART011_IFLS_TX4_8 (2 << 0)
#define UART011_IFLS_TX6_8 (3 << 0)
#define UART011_IFLS_TX7_8 (4 << 0)
/* Interrupt masks */
#define UART011_OEIM (1 << 10) /* overrun error */
#define UART011_BEIM (1 << 9) /* break error */
#define UART011_PEIM (1 << 8) /* parity error */
#define UART011_FEIM (1 << 7) /* framing error */
#define UART011_RTIM (1 << 6) /* receive timeout */
#define UART011_TXIM (1 << 5) /* transmit */
#define UART011_RXIM (1 << 4) /* receive */
#define UART011_DSRMIM (1 << 3) /* DSR interrupt mask */
#define UART011_DCDMIM (1 << 2) /* DCD interrupt mask */
#define UART011_CTSMIM (1 << 1) /* CTS interrupt mask */
#define UART011_RIMIM (1 << 0) /* RI interrupt mask */
/* Interrupt statuses */
#define UART011_OEIS (1 << 10) /* overrun error */
#define UART011_BEIS (1 << 9) /* break error */
#define UART011_PEIS (1 << 8) /* parity error */
#define UART011_FEIS (1 << 7) /* framing error */
#define UART011_RTIS (1 << 6) /* receive timeout */
#define UART011_TXIS (1 << 5) /* transmit */
#define UART011_RXIS (1 << 4) /* receive */
#define UART011_DSRMIS (1 << 3) /* DSR */
#define UART011_DCDMIS (1 << 2) /* DCD */
#define UART011_CTSMIS (1 << 1) /* CTS */
#define UART011_RIMIS (1 << 0) /* RI */
/* Interrupt clear masks */
#define UART011_OEIC (1 << 10) /* overrun error */
#define UART011_BEIC (1 << 9) /* break error */
#define UART011_PEIC (1 << 8) /* parity error */
#define UART011_FEIC (1 << 7) /* framing error */
#define UART011_RTIC (1 << 6) /* receive timeout */
#define UART011_TXIC (1 << 5) /* transmit */
#define UART011_RXIC (1 << 4) /* receive */
#define UART011_DSRMIC (1 << 3) /* DSR */
#define UART011_DCDMIC (1 << 2) /* DCD */
#define UART011_CTSMIC (1 << 1) /* CTS */
#define UART011_RIMIC (1 << 0) /* RI */
#define UART011_DMAONERR (1 << 2) /* disable dma on error */
#define UART011_TXDMAE (1 << 1) /* enable transmit dma */
#define UART011_RXDMAE (1 << 0) /* enable receive dma */
#define UART01x_RSR_ANY (UART01x_RSR_OE | UART01x_RSR_BE | \
UART01x_RSR_PE | UART01x_RSR_FE)
#define UART01x_FR_MODEM_ANY (UART01x_FR_DCD | UART01x_FR_DSR | \
UART01x_FR_CTS)
/*
* Access macros for the AMBA UARTs
*/
#define UART_GET_INT_STATUS(p) readb((p)->membase + UART010_IIR)
#define UART_PUT_ICR(p, c) writel((c), (p)->membase + UART010_ICR)
#define UART_GET_FR(p) readb((p)->membase + UART01x_FR)
#define UART_GET_CHAR(p) readb((p)->membase + UART01x_DR)
#define UART_PUT_CHAR(p, c) writel((c), (p)->membase + UART01x_DR)
#define UART_GET_RSR(p) readb((p)->membase + UART01x_RSR)
#define UART_GET_CR(p) readb((p)->membase + UART010_CR)
#define UART_PUT_CR(p, c) writel((c), (p)->membase + UART010_CR)
#define UART_GET_LCRL(p) readb((p)->membase + UART010_LCRL)
#define UART_PUT_LCRL(p, c) writel((c), (p)->membase + UART010_LCRL)
#define UART_GET_LCRM(p) readb((p)->membase + UART010_LCRM)
#define UART_PUT_LCRM(p, c) writel((c), (p)->membase + UART010_LCRM)
#define UART_GET_LCRH(p) readb((p)->membase + UART010_LCRH)
#define UART_PUT_LCRH(p, c) writel((c), (p)->membase + UART010_LCRH)
#define UART_RX_DATA(s) (((s) & UART01x_FR_RXFE) == 0)
#define UART_TX_READY(s) (((s) & UART01x_FR_TXFF) == 0)
#define UART_TX_EMPTY(p) ((UART_GET_FR(p) & UART01x_FR_TMSK) == 0)
#define UART_DUMMY_RSR_RX /*256*/0
#define UART_PORT_SIZE 64
#endif /* STMP_DBG_H */
|