gtpcireg.h revision 1.5 1 1.5 kiyohara /* $NetBSD: gtpcireg.h,v 1.5 2010/04/28 13:51:56 kiyohara Exp $ */
2 1.1 matt /*
3 1.5 kiyohara * Copyright (c) 2008, 2009 KIYOHARA Takashi
4 1.1 matt * All rights reserved.
5 1.1 matt *
6 1.1 matt * Redistribution and use in source and binary forms, with or without
7 1.1 matt * modification, are permitted provided that the following conditions
8 1.1 matt * are met:
9 1.1 matt * 1. Redistributions of source code must retain the above copyright
10 1.1 matt * notice, this list of conditions and the following disclaimer.
11 1.1 matt * 2. Redistributions in binary form must reproduce the above copyright
12 1.1 matt * notice, this list of conditions and the following disclaimer in the
13 1.1 matt * documentation and/or other materials provided with the distribution.
14 1.1 matt *
15 1.5 kiyohara * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
16 1.5 kiyohara * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
17 1.5 kiyohara * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
18 1.5 kiyohara * DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT,
19 1.5 kiyohara * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
20 1.5 kiyohara * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
21 1.5 kiyohara * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
22 1.5 kiyohara * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
23 1.5 kiyohara * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
24 1.5 kiyohara * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
25 1.1 matt * POSSIBILITY OF SUCH DAMAGE.
26 1.1 matt */
27 1.1 matt
28 1.5 kiyohara #ifndef _GTPCIREG_H_
29 1.5 kiyohara #define _GTPCIREG_H_
30 1.1 matt
31 1.1 matt
32 1.1 matt /*
33 1.5 kiyohara * PCI Interface Registers
34 1.1 matt */
35 1.5 kiyohara #define GTPCI_SIZE 0x2000
36 1.1 matt
37 1.5 kiyohara #define GTPCI_NINTERFACE 2
38 1.5 kiyohara
39 1.5 kiyohara
40 1.5 kiyohara /* PCI Slave Address Decording Registers */
41 1.5 kiyohara /* BAR Sizes */
42 1.5 kiyohara #define GTPCI_CS0BARS(p) (0x0c08 | ((p) << 7)) /* CSn[0] */
43 1.5 kiyohara #define GTPCI_CS1BARS(p) (0x0d08 | ((p) << 7)) /* CSn[1] */
44 1.5 kiyohara #define GTPCI_CS2BARS(p) (0x0c0c | ((p) << 7)) /* CSn[2] */
45 1.5 kiyohara #define GTPCI_CS3BARS(p) (0x0d0c | ((p) << 7)) /* CSn[3] */
46 1.5 kiyohara #define GTPCI_DCS0BARS(p) (0x0c10 | ((p) << 7)) /* DevCSn[0] */
47 1.5 kiyohara #define GTPCI_DCS1BARS(p) (0x0d10 | ((p) << 7)) /* DevCSn[1] */
48 1.5 kiyohara #define GTPCI_DCS2BARS(p) (0x0d18 | ((p) << 7)) /* DevCSn[2] */
49 1.5 kiyohara #define GTPCI_BCSBARS(p) (0x0d14 | ((p) << 7)) /* Boot CSn */
50 1.5 kiyohara #define GTPCI_P2PM0BARS(p) (0x0d1c | ((p) << 7)) /* P2P Mem0 */
51 1.5 kiyohara #define GTPCI_P2PIOBARS(p) (0x0d24 | ((p) << 7)) /* P2P I/O */
52 1.5 kiyohara #define GTPCI_EROMBARS(p) (0x0d2c | ((p) << 7)) /* Expansion ROM */
53 1.5 kiyohara #define GTPCI_BARSIZE(s) (((s) - 1) & 0xfffff000)
54 1.5 kiyohara #define GTPCI_BARE(p) (0x0c3c | ((p) << 7)) /* Base Addr Reg En */
55 1.5 kiyohara #define GTPCI_BARE_ALLDISABLE 0xffffffff
56 1.5 kiyohara #define GTPCI_BARE_CS0EN (1 << 0)
57 1.5 kiyohara #define GTPCI_BARE_CS1EN (1 << 1)
58 1.5 kiyohara #define GTPCI_BARE_CS2EN (1 << 2)
59 1.5 kiyohara #define GTPCI_BARE_CS3EN (1 << 3)
60 1.5 kiyohara #define GTPCI_BARE_DEVCS0EN (1 << 4)
61 1.5 kiyohara #define GTPCI_BARE_DEVCS1EN (1 << 5)
62 1.5 kiyohara #define GTPCI_BARE_DEVCS2EN (1 << 6)
63 1.5 kiyohara #define GTPCI_BARE_BOOTCSEN (1 << 8)
64 1.5 kiyohara #define GTPCI_BARE_INTMEMEN (1 << 9)
65 1.5 kiyohara #define GTPCI_BARE_INTIOEN (1 << 10)
66 1.5 kiyohara #define GTPCI_BARE_P2PMEM0EN (1 << 11)
67 1.5 kiyohara #define GTPCI_BARE_P2PIO0EN (1 << 13)
68 1.5 kiyohara #define GTPCI_REMAP(a) ((a) & 0xfffff000)
69 1.5 kiyohara /* Base Addr Remaps */
70 1.5 kiyohara #define GTPCI_CS0BAR(p) (0x0c48 | ((p) << 7)) /* CSn[0] */
71 1.5 kiyohara #define GTPCI_CS1BAR(p) (0x0d48 | ((p) << 7)) /* CSn[1] */
72 1.5 kiyohara #define GTPCI_CS2BAR(p) (0x0c4c | ((p) << 7)) /* CSn[2] */
73 1.5 kiyohara #define GTPCI_CS3BAR(p) (0x0d4c | ((p) << 7)) /* CSn[3] */
74 1.5 kiyohara #define GTPCI_DCS0BAR(p) (0x0c50 | ((p) << 7)) /* DevCSn[0] */
75 1.5 kiyohara #define GTPCI_DCS1BAR(p) (0x0d50 | ((p) << 7)) /* DevCSn[1] */
76 1.5 kiyohara #define GTPCI_DCS2BAR(p) (0x0d58 | ((p) << 7)) /* DevCSn[2] */
77 1.5 kiyohara #define GTPCI_BCSBAR(p) (0x0d54 | ((p) << 7)) /* Boot CSn */
78 1.5 kiyohara #define GTPCI_P2PM0BARL(p) (0x0d5c | ((p) << 7)) /* P2P Mem0 (Low) */
79 1.5 kiyohara #define GTPCI_P2PM0BARH(p) (0x0d60 | ((p) << 7)) /* P2P Mem0 (High) */
80 1.5 kiyohara #define GTPCI_P2PIOBAR(p) (0x0d6c | ((p) << 7)) /* P2P I/O */
81 1.5 kiyohara #define GTPCI_EROMBAR(p) (0x0f38 | ((p) << 7)) /* Expresion ROM */
82 1.5 kiyohara #define GTPCI_DRAMBARBS(p) (0x0c1c | ((p) << 7)) /*DRAM BAR Bank Select*/
83 1.5 kiyohara #define GTPCI_ADC(p) (0x0d3c | ((p) << 7)) /* Addr Decode Ctrl */
84 1.5 kiyohara #define GTPCI_ADC_REMAPWRDIS (1 << 0)
85 1.5 kiyohara
86 1.5 kiyohara /* PCI Control Register Map */
87 1.5 kiyohara #define GTPCI_DLLC(p) (0x1d20 | ((p) << 7)) /* PCI DLL Control */
88 1.5 kiyohara #define GTPCI_MPPPC(p) (0x1d1c | ((p) << 7)) /*PCI/MPP Pads Calibrt*/
89 1.5 kiyohara #define GTPCI_C(p) (0x0c00 | ((p) << 7)) /* Command */
90 1.5 kiyohara #define GTPCI_C_MBYTESWAP (1 << 0) /* Master Byte Swap */
91 1.5 kiyohara #define GTPCI_C_MWRCOM (1 << 4) /* Master Wr Combine Enable */
92 1.5 kiyohara #define GTPCI_C_MRDCOM (1 << 5) /* Master Rd Combine Enable */
93 1.5 kiyohara #define GTPCI_C_MWRTRIG (1 << 6) /*Master Write Trigger*/
94 1.5 kiyohara #define GTPCI_C_MRDTRIG (1 << 7) /*Master Read Trigger */
95 1.5 kiyohara #define GTPCI_C_MRDLINE (1 << 8) /* Master Mem Rd Line Enable */
96 1.5 kiyohara #define GTPCI_C_MRDMUL (1 << 9) /* Master Mem Rd Mult Enable */
97 1.5 kiyohara #define GTPCI_C_MWORDSWAP (1 << 10) /* Master Word Swap */
98 1.5 kiyohara #define GTPCI_C_SWORDSWAP (1 << 11) /* Slave Word Swap */
99 1.5 kiyohara #define GTPCI_C_SBYTESWAP (1 << 16) /* Slave Byte Swap */
100 1.5 kiyohara #define GTPCI_C_MDACEN (1 << 17) /* Master DAC Enable */
101 1.5 kiyohara #define GTPCI_C_PERRPROP (1 << 19)/*Pari/ECC Err Propagation En*/
102 1.5 kiyohara #define GTPCI_C_SSWAPEN (1 << 20) /* Slave Swap Enable */
103 1.5 kiyohara #define GTPCI_C_MSWAPEN (1 << 21) /* Master Swap Enable */
104 1.5 kiyohara #define GTPCI_C_SINTSWAP_BYTESWAP (0 << 24)
105 1.5 kiyohara #define GTPCI_C_SINTSWAP_NOSWAP (1 << 24)
106 1.5 kiyohara #define GTPCI_C_SINTSWAP_BOTH (2 << 24)
107 1.5 kiyohara #define GTPCI_C_SINTSWAP_WORDSWAP (3 << 24)
108 1.5 kiyohara #define GTPCI_C_SSBINT (1 << 28)
109 1.5 kiyohara #define GTPCI_C_CPU2PCIORDERING (1 << 29) /* PCI2CPU Ordering En*/
110 1.5 kiyohara #define GTPCI_M(p) (0x0d00 | ((p) << 7)) /* Mode */
111 1.5 kiyohara #define GTPCI_R(p) (0x0c04 | ((p) << 7)) /* Retry */
112 1.5 kiyohara #define GTPCI_DT(p) (0x0d04 | ((p) << 7)) /* Discard Timer */
113 1.5 kiyohara #define GTPCI_MSITT(p) (0x0c38 | ((p) << 7)) /* MSI Trigger Timer */
114 1.5 kiyohara #define GTPCI_AC(p) (0x1d00 | ((p) << 7)) /* Arviter Control */
115 1.5 kiyohara #define GTPCI_AC_BDEN (1 << 0) /* Broken Detection Enable */
116 1.5 kiyohara #define GTPCI_AC_BV(v) ((v) << 3) /* Broken Value */
117 1.5 kiyohara #define GTPCI_AC_PD(v) ((v) << 14) /* Parking Disable */
118 1.5 kiyohara #define GTPCI_AC_EN (1 << 31) /* En Inter Arb Ope */
119 1.5 kiyohara #define GTPCI_P2PC(p) (0x1d14 | ((p) << 7)) /* P2P Configuration */
120 1.5 kiyohara #define GTPCI_P2PC_BUSNUMBER(x) (((x) >> 16) & 0xff)
121 1.5 kiyohara #define GTPCI_P2PC_DEVNUM(x) (((x) >> 24) & 0x1f)
122 1.5 kiyohara #define GTPCI_NPCIAC 6
123 1.5 kiyohara #define GTPCI_ACBL(p, N) (0x1e00 | ((p) << 7) | ((N) << 4))
124 1.5 kiyohara /* Access Control Base N (Low) */
125 1.5 kiyohara #define GTPCI_ACBL_EN (1 << 0)
126 1.5 kiyohara #define GTPCI_ACBL_REQ64 (1 << 1)
127 1.5 kiyohara #define GTPCI_ACBL_SNOOP_MASK (3 << 2)
128 1.5 kiyohara #define GTPCI_ACBL_SNOOP_NONE (0 << 2)
129 1.5 kiyohara #define GTPCI_ACBL_SNOOP_WT (1 << 2)
130 1.5 kiyohara #define GTPCI_ACBL_SNOOP_WB (2 << 2)
131 1.5 kiyohara #define GTPCI_ACBL_ACCPROT (1 << 4)
132 1.5 kiyohara #define GTPCI_ACBL_WRPROT (1 << 5)
133 1.5 kiyohara #define GTPCI_ACBL_PCISWAP_MASK (3 << 6)
134 1.5 kiyohara #define GTPCI_ACBL_PCISWAP_BYTESWAP (0 << 6)
135 1.5 kiyohara #define GTPCI_ACBL_PCISWAP_NOSWAP (1 << 6)
136 1.5 kiyohara #define GTPCI_ACBL_PCISWAP_BOTHSWAP (2 << 6)
137 1.5 kiyohara #define GTPCI_ACBL_PCISWAP_WORDSWAP (3 << 6)
138 1.5 kiyohara #define GTPCI_ACBL_RDMBURST_MASK (3 << 8)
139 1.5 kiyohara #define GTPCI_ACBL_RDMBURST_32BYTE (0 << 8)
140 1.5 kiyohara #define GTPCI_ACBL_RDMBURST_64BYTE (1 << 8)
141 1.5 kiyohara #define GTPCI_ACBL_RDMBURST_128BYTE (2 << 8)
142 1.5 kiyohara #define GTPCI_ACBL_RDSIZE_MASK (3 << 10)
143 1.5 kiyohara #define GTPCI_ACBL_RDSIZE_32BYTE (0 << 10)
144 1.5 kiyohara #define GTPCI_ACBL_RDSIZE_64BYTE (1 << 10)
145 1.5 kiyohara #define GTPCI_ACBL_RDSIZE_128BYTE (2 << 10)
146 1.5 kiyohara #define GTPCI_ACBL_RDSIZE_256BYTE (3 << 10)
147 1.5 kiyohara #define GTPCI_ACBL_BASE(b) ((b) & 0xfffff000)
148 1.5 kiyohara
149 1.5 kiyohara #define GTPCI_GT64260_ACBL_BASE(b) ((b) & 0x00000fff)
150 1.5 kiyohara #define GTPCI_GT64260_ACBL_PREFETCHEN (1 << 12)
151 1.5 kiyohara #define GTPCI_GT64260_ACBL_DREADEN (1 << 13)
152 1.5 kiyohara #define GTPCI_GT64260_ACBL_RDPREFETCH (1 << 16)
153 1.5 kiyohara #define GTPCI_GT64260_ACBL_RDLINEPREFETCH (1 << 17)
154 1.5 kiyohara #define GTPCI_GT64260_ACBL_RDMULPREFETCH (1 << 18)
155 1.5 kiyohara #define GTPCI_GT64260_ACBL_WBURST_MASK (3 << 20)
156 1.5 kiyohara #define GTPCI_GT64260_ACBL_WBURST_4_QW (0 << 20)
157 1.5 kiyohara #define GTPCI_GT64260_ACBL_WBURST_8_QW (1 << 20)
158 1.5 kiyohara #define GTPCI_GT64260_ACBL_WBURST_16_QW (2 << 20)
159 1.5 kiyohara #define PCI_ACCCTLBASEL_PCISwap PCI__EXT(v, 24, 2)
160 1.5 kiyohara #define PCI_ACCCTLBASEL_PCISwap_NoSwap PCI__INS(24, PCI_PCISWAP_NoSwap)
161 1.5 kiyohara #define GTPCI_GT64260_ACBL_PCISWAP_BYTESWAP (0 << 24)
162 1.5 kiyohara #define GTPCI_GT64260_ACBL_PCISWAP_NOSWAP (1 << 24)
163 1.5 kiyohara #define GTPCI_GT64260_ACBL_PCISWAP_BYTEWORDSWAP (3 << 24)
164 1.5 kiyohara #define GTPCI_GT64260_ACBL_PCISWAP_WORDSWAP (3 << 24)
165 1.5 kiyohara #define GTPCI_GT64260_ACBL_ACCPROT (1 << 28)
166 1.5 kiyohara #define GTPCI_GT64260_ACBL_WRPROT (1 << 29)
167 1.5 kiyohara
168 1.5 kiyohara #define GTPCI_ACBH(p, N) (0x1e04 | ((p) << 7) | ((N) << 4))
169 1.5 kiyohara /* Access Control Base N (High) */
170 1.5 kiyohara #define GTPCI_ACS(p, N) (0x1e08 | ((p) << 7) | ((N) << 4))
171 1.5 kiyohara /* Access Ctrl Size N */
172 1.5 kiyohara #define GTPCI_ACS_AGGRWM1 (1 << 4)
173 1.5 kiyohara #define GTPCI_ACS_WRMBURST_MASK (3 << 8)
174 1.5 kiyohara #define GTPCI_ACS_WRMBURST_32BYTE (0 << 8)
175 1.5 kiyohara #define GTPCI_ACS_WRMBURST_64BYTE (1 << 8)
176 1.5 kiyohara #define GTPCI_ACS_WRMBURST_128BYTE (2 << 8)
177 1.5 kiyohara #define GTPCI_ACS_AGGR (1 << 10)
178 1.5 kiyohara #define GTPCI_ACS_PCIOR (1 << 11)
179 1.5 kiyohara #define GTPCI_ACS_SIZE(s) (((s) - 1) & 0xfffff000)
180 1.5 kiyohara
181 1.5 kiyohara /* PCI Configuration Access Register Map */
182 1.5 kiyohara #define GTPCI_CA(p) (0x0cf8 ^ ((p) << 7)) /* Configuration Addr */
183 1.5 kiyohara #define GTPCI_CA_CONFIGEN (1 << 31)
184 1.5 kiyohara #define GTPCI_CD(p) (0x0cfc ^ ((p) << 7)) /* Configuration Data */
185 1.5 kiyohara
186 1.5 kiyohara #define GTPCI_IA(p) (0x0c34 | ((p) << 7) /* Intr Acknowledge */
187 1.5 kiyohara
188 1.5 kiyohara /* PCI Error Report Register Map */
189 1.5 kiyohara #define GTPCI_SERRM(p) (0x0c28 | ((p) << 7) /* SERRn Mask */
190 1.5 kiyohara #define GTPCI_IC(p) (0x0d58 | ((p) << 7) /* Interrupt Cause */
191 1.5 kiyohara #define GTPCI_IM(p) (0x0d5c | ((p) << 7) /* Interrupt Mask */
192 1.5 kiyohara #define GTPCI_EAL(p) (0x0d40 | ((p) << 7) /* Error Addr (Low) */
193 1.5 kiyohara #define GTPCI_EAH(p) (0x0d44 | ((p) << 7) /* Error Addr (High) */
194 1.5 kiyohara #define GTPCI_EC(p) (0x0d50 | ((p) << 7) /* Error Command */
195 1.1 matt
196 1.5 kiyohara /* PCI Configuration, Function 0, Register Map */
197 1.5 kiyohara /* see at dev/pci/pcireg.h from 0x00 to 0x3c. */
198 1.1 matt
199 1.5 kiyohara #define GTPCI_BARLOW_MASK 0xfffff000
200 1.5 kiyohara #define GTPCI_BARLOW_BASE(b) ((b) & GTPCI_BARLOW_MASK)
201 1.1 matt
202 1.5 kiyohara #endif /* _GTPCIREG_H_ */
203