plcomreg.h revision 1.3 1 1.3 skrll /* $NetBSD: plcomreg.h,v 1.3 2012/05/14 19:40:06 skrll Exp $ */
2 1.1 rearnsha
3 1.1 rearnsha /*-
4 1.1 rearnsha * Copyright (c) 2001 ARM Ltd
5 1.1 rearnsha * All rights reserved.
6 1.1 rearnsha *
7 1.1 rearnsha * Redistribution and use in source and binary forms, with or without
8 1.1 rearnsha * modification, are permitted provided that the following conditions
9 1.1 rearnsha * are met:
10 1.1 rearnsha * 1. Redistributions of source code must retain the above copyright
11 1.1 rearnsha * notice, this list of conditions and the following disclaimer.
12 1.1 rearnsha * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 rearnsha * notice, this list of conditions and the following disclaimer in the
14 1.1 rearnsha * documentation and/or other materials provided with the distribution.
15 1.1 rearnsha * 3. The name of the company may not be used to endorse or promote
16 1.1 rearnsha * products derived from this software without specific prior written
17 1.1 rearnsha * permission.
18 1.1 rearnsha *
19 1.1 rearnsha * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
20 1.1 rearnsha * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
21 1.1 rearnsha * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
22 1.1 rearnsha * IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
23 1.1 rearnsha * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
24 1.1 rearnsha * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
25 1.1 rearnsha * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
26 1.1 rearnsha * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
27 1.1 rearnsha * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
28 1.1 rearnsha * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
29 1.1 rearnsha * SUCH DAMAGE.
30 1.1 rearnsha */
31 1.1 rearnsha
32 1.1 rearnsha
33 1.1 rearnsha #define PLCOM_FREQ 1843200 /* 16-bit baud rate divisor */
34 1.1 rearnsha #define PLCOM_TOLERANCE 30 /* baud rate tolerance, in 0.1% units */
35 1.1 rearnsha
36 1.1 rearnsha /* control register */
37 1.3 skrll #define PL011_CR_CTSEN 0x8000 /* CTS HW flow control enable */
38 1.3 skrll #define PL011_CR_RTSEN 0x4000 /* RTS HW flow control enable */
39 1.3 skrll #define PL011_CR_OUT2 0x2000 /* Complement of UART Out2 MSR */
40 1.3 skrll #define PL011_CR_OUT1 0x1000 /* Complement of UART Out1 MSR */
41 1.3 skrll #define PL011_CR_RTS 0x0800 /* Request to send */
42 1.3 skrll #define PL011_CR_DTR 0x0400 /* Data transmit Ready */
43 1.3 skrll #define PL011_CR_RXE 0x0200 /* Receive enable */
44 1.3 skrll #define PL011_CR_TXE 0x0100 /* Transmit enable */
45 1.3 skrll #define PL01X_CR_LBE 0x0080 /* Loopback enable */
46 1.3 skrll #define PL010_CR_RTIE 0x0040 /* Receive timeout interrupt enable */
47 1.3 skrll #define PL010_CR_TIE 0x0020 /* Transmit interrupt enable */
48 1.3 skrll #define PL010_CR_RIE 0x0010 /* Receive interrrupt enable */
49 1.3 skrll #define PL010_CR_MSIE 0x0008 /* Modem status interrupt enable */
50 1.3 skrll #define PL01X_CR_SIRLP 0x0004 /* IrDA SIR Low power mode */
51 1.3 skrll #define PL01X_CR_SIREN 0x0002 /* SIR Enable */
52 1.3 skrll #define PL01X_CR_UARTEN 0x0001 /* Uart enable */
53 1.1 rearnsha
54 1.1 rearnsha /* interrupt identification register */
55 1.3 skrll #define PL010_IIR_IMASK 0x0f
56 1.3 skrll #define PL010_IIR_RTIS 0x08
57 1.3 skrll #define PL010_IIR_TIS 0x04
58 1.3 skrll #define PL010_IIR_RIS 0x02
59 1.3 skrll #define PL010_IIR_MIS 0x01
60 1.1 rearnsha
61 1.1 rearnsha /* line control register */
62 1.3 skrll #define PL011_LCR_SPS 0x80 /* Stick parity select */
63 1.3 skrll #define PL01X_LCR_WLEN 0x60 /* Mask of size bits */
64 1.3 skrll #define PL01X_LCR_8BITS 0x60 /* 8 bits per serial word */
65 1.3 skrll #define PL01X_LCR_7BITS 0x40 /* 7 bits */
66 1.3 skrll #define PL01X_LCR_6BITS 0x20 /* 6 bits */
67 1.3 skrll #define PL01X_LCR_5BITS 0x00 /* 5 bits */
68 1.3 skrll #define PL01X_LCR_FEN 0x10 /* FIFO enable */
69 1.3 skrll #define PL01X_LCR_STP2 0x08 /* 2 stop bits per serial word */
70 1.3 skrll #define PL01X_LCR_EPS 0x04 /* Even parity select */
71 1.3 skrll #define PL01X_LCR_PEN 0x02 /* Parity enable */
72 1.3 skrll #define PL01X_LCR_PEVEN (PL01X_LCR_PEN | PL01X_LCR_EPS)
73 1.3 skrll #define PL01X_LCR_PODD PL01X_LCR_PEN
74 1.3 skrll #define PL01X_LCR_PNONE 0x00 /* No parity */
75 1.3 skrll #define PL01X_LCR_BRK 0x01 /* Break Control */
76 1.1 rearnsha
77 1.1 rearnsha /* modem control register */
78 1.3 skrll #define PL01X_MCR_RTS 0x02 /* Request To Send */
79 1.3 skrll #define PL01X_MCR_DTR 0x01 /* Data Terminal Ready */
80 1.1 rearnsha
81 1.1 rearnsha /* receive status register */
82 1.3 skrll #define PL01X_RSR_OE 0x08 /* Overrun Error */
83 1.3 skrll #define PL01X_RSR_BE 0x04 /* Break */
84 1.3 skrll #define PL01X_RSR_PE 0x02 /* Parity Error */
85 1.3 skrll #define PL01X_RSR_FE 0x01 /* Framing Error */
86 1.3 skrll #define PL01X_RSR_ERROR (PL01X_RSR_OE | PL01X_RSR_BE | PL01X_RSR_PE | PL01X_RSR_FE)
87 1.1 rearnsha
88 1.1 rearnsha /* flag register */
89 1.3 skrll #define PL01X_FR_RI 0x100 /* Ring Indicator */
90 1.3 skrll #define PL01X_FR_TXFE 0x080 /* Transmit fifo empty */
91 1.3 skrll #define PL01X_FR_RXFF 0x040 /* Recive fifo full */
92 1.3 skrll #define PL01X_FR_TXFF 0x020 /* Transmit fifo full */
93 1.3 skrll #define PL01X_FR_RXFE 0x010 /* Receive fifo empty */
94 1.3 skrll #define PL01X_FR_BUSY 0x008 /* Uart Busy */
95 1.3 skrll #define PL01X_FR_DCD 0x004 /* Data carrier detect */
96 1.3 skrll #define PL01X_FR_DSR 0x002 /* Data set ready */
97 1.3 skrll #define PL01X_FR_CTS 0x001 /* Clear to send */
98 1.1 rearnsha
99 1.1 rearnsha /* modem status register */
100 1.1 rearnsha /* All deltas are from the last read of the MSR. */
101 1.3 skrll #define PL01X_MSR_DCD PL01X_FR_DCD
102 1.3 skrll #define PL01X_MSR_DSR PL01X_FR_DSR
103 1.3 skrll #define PL01X_MSR_CTS PL01X_FR_CTS
104 1.3 skrll
105 1.3 skrll /* All interrupt status/clear registers */
106 1.3 skrll #define PL011_INT_OE 0x400
107 1.3 skrll #define PL011_INT_BE 0x200
108 1.3 skrll #define PL011_INT_PE 0x100
109 1.3 skrll #define PL011_INT_FE 0x080
110 1.3 skrll #define PL011_INT_RT 0x040
111 1.3 skrll #define PL011_INT_TX 0x020
112 1.3 skrll #define PL011_INT_RX 0x010
113 1.3 skrll #define PL011_INT_DSR 0x008
114 1.3 skrll #define PL011_INT_DCD 0x004
115 1.3 skrll #define PL011_INT_CTS 0x002
116 1.3 skrll #define PL011_INT_RIR 0x001
117 1.3 skrll
118 1.3 skrll /* DMA control registers */
119 1.3 skrll #define PL011_DMA_ONERR 0x4
120 1.3 skrll #define PL011_DMA_TXE 0x2
121 1.3 skrll #define PL011_DMA_RXE 0x1
122 1.1 rearnsha
123 1.1 rearnsha /* Register offsets */
124 1.2 bsh #define plcom_dr 0x00
125 1.2 bsh #define plcom_rsr 0x04
126 1.2 bsh #define plcom_ecr 0x04
127 1.2 bsh #define plcom_lcr 0x08
128 1.2 bsh #define plcom_dlbh 0x0c
129 1.2 bsh #define plcom_dlbl 0x10
130 1.2 bsh #define plcom_cr 0x14
131 1.2 bsh #define plcom_fr 0x18
132 1.2 bsh #define plcom_iir 0x1c
133 1.2 bsh #define plcom_icr 0x1c
134 1.2 bsh #define plcom_ilpr 0x20
135 1.1 rearnsha
136 1.1 rearnsha /* IFPGA specific */
137 1.2 bsh #define PLCOM_UART_SIZE 0x24
138