xref: /netbsd-src/sys/arch/shark/ofw/vlpci.h (revision f1871fd136c809cfc13df2b3cba76a3cd9bcf6a4)
1*f1871fd1Sflxd /* $NetBSD: vlpci.h,v 1.1 2017/04/18 14:11:42 flxd Exp $ */
2*f1871fd1Sflxd 
3*f1871fd1Sflxd /*-
4*f1871fd1Sflxd  * Copyright (c) 2017, Felix Deichmann
5*f1871fd1Sflxd  * All rights reserved.
6*f1871fd1Sflxd  *
7*f1871fd1Sflxd  * Redistribution and use in source and binary forms, with or without
8*f1871fd1Sflxd  * modification, are permitted provided that the following conditions
9*f1871fd1Sflxd  * are met:
10*f1871fd1Sflxd  * 1. Redistributions of source code must retain the above copyright
11*f1871fd1Sflxd  *    notice, this list of conditions and the following disclaimer.
12*f1871fd1Sflxd  * 2. Redistributions in binary form must reproduce the above copyright
13*f1871fd1Sflxd  *    notice, this list of conditions and the following disclaimer in the
14*f1871fd1Sflxd  *    documentation and/or other materials provided with the distribution.
15*f1871fd1Sflxd  *
16*f1871fd1Sflxd  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
17*f1871fd1Sflxd  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
18*f1871fd1Sflxd  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
19*f1871fd1Sflxd  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
20*f1871fd1Sflxd  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
21*f1871fd1Sflxd  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
22*f1871fd1Sflxd  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
23*f1871fd1Sflxd  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
24*f1871fd1Sflxd  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
25*f1871fd1Sflxd  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
26*f1871fd1Sflxd  * POSSIBILITY OF SUCH DAMAGE.
27*f1871fd1Sflxd  */
28*f1871fd1Sflxd 
29*f1871fd1Sflxd #ifndef _VLPCI_H
30*f1871fd1Sflxd #define _VLPCI_H
31*f1871fd1Sflxd 
32*f1871fd1Sflxd #include <sys/param.h>
33*f1871fd1Sflxd #include <sys/cdefs.h>
34*f1871fd1Sflxd #include <sys/bitops.h>
35*f1871fd1Sflxd 
36*f1871fd1Sflxd /*
37*f1871fd1Sflxd  * VT82C505 register definitions according to:
38*f1871fd1Sflxd  *
39*f1871fd1Sflxd  * VIA Technologies, Inc. "Configuration Registers of VT82C505-F", December
40*f1871fd1Sflxd  * 1994. Application Note AN-025B.
41*f1871fd1Sflxd  *
42*f1871fd1Sflxd  * VIA Technologies, Inc. "VIA VT82C505 Pentium/486 VL to PCI BRIDGE", May 1994.
43*f1871fd1Sflxd  * Datasheet.
44*f1871fd1Sflxd  */
45*f1871fd1Sflxd 
46*f1871fd1Sflxd #define VLPCI_INTREG_BASE			0xa8
47*f1871fd1Sflxd #define VLPCI_INTREG_IDX_OFF			0
48*f1871fd1Sflxd #define VLPCI_INTREG_DATA_OFF			1
49*f1871fd1Sflxd #define VLPCI_INTREG_SZ				2
50*f1871fd1Sflxd 
51*f1871fd1Sflxd #define VLPCI_CFGREG_BASE			0xcf8
52*f1871fd1Sflxd #define VLPCI_CFGREG_ADDR_OFF			0
53*f1871fd1Sflxd #define VLPCI_CFGREG_DATA_OFF			4
54*f1871fd1Sflxd #define VLPCI_CFGREG_SZ				8
55*f1871fd1Sflxd 
56*f1871fd1Sflxd #define VLPCI_DIP_SW_REG			0x80
57*f1871fd1Sflxd #define VLPCI_DIP_SW_PCLK_CCLK			__BIT(7)
58*f1871fd1Sflxd #define VLPCI_DIP_SW_SYNC_CLK			__BIT(6)
59*f1871fd1Sflxd #define VLPCI_DIP_SW_IRQ14_15_PIN		__BIT(5)
60*f1871fd1Sflxd #define VLPCI_DIP_SW_BLAST_PIN			__BIT(4)
61*f1871fd1Sflxd #define VLPCI_DIP_SW_STRAP			__BITS(7, 4)
62*f1871fd1Sflxd #define VLPCI_DIP_SW_REV_ID			__BITS(3, 0)
63*f1871fd1Sflxd #define VLPCI_DIP_SW_REV_ID_D			0x1
64*f1871fd1Sflxd #define VLPCI_DIP_SW_REV_ID_E			0x2
65*f1871fd1Sflxd #define VLPCI_DIP_SW_REV_ID_F			0x3
66*f1871fd1Sflxd 
67*f1871fd1Sflxd #define VLPCI_OBD_MEM_SZ_REG			0x81
68*f1871fd1Sflxd 
69*f1871fd1Sflxd #define VLPCI_BUF_CTL_REG			0x82
70*f1871fd1Sflxd #define VLPCI_BUF_CTL_CPU2PCI_WR_BUF		__BIT(7)
71*f1871fd1Sflxd #define VLPCI_BUF_CTL_PCI2CPU_WR_BUF		__BIT(6)
72*f1871fd1Sflxd #define VLPCI_BUF_CTL_CPU2PCI_PREF_BUF		__BIT(5)
73*f1871fd1Sflxd #define VLPCI_BUF_CTL_PCI2CPU_PREF_BUF		__BIT(4)
74*f1871fd1Sflxd #define VLPCI_BUF_CTL_PCI_DYN_ACC_DEC		__BIT(3)
75*f1871fd1Sflxd #define VLPCI_BUF_CTL_BST_B4_LST_BRDY		__BIT(2)
76*f1871fd1Sflxd #define VLPCI_BUF_CTL_OBD_MEM_WR_BST		__BIT(1)
77*f1871fd1Sflxd #define VLPCI_BUF_CTL_OBD_MEM_RD_BST		__BIT(0)
78*f1871fd1Sflxd 
79*f1871fd1Sflxd #define VLPCI_VL_TIM_REG			0x83
80*f1871fd1Sflxd #define VLPCI_VL_TIM_CPU2VL_WR_0WS		__BIT(7)
81*f1871fd1Sflxd #define VLPCI_VL_TIM_LDEV_2ND_T2		__BIT(6)
82*f1871fd1Sflxd #define VLPCI_VL_TIM_TRDY2LRDY_BYP		__BIT(5)	/* AN-025B */
83*f1871fd1Sflxd #define VLPCI_VL_TIM_TRDY2LRDY_RESYNC		__BIT(5)	/* DS */
84*f1871fd1Sflxd #define VLPCI_VL_TIM_RDYRTN2TRDY_BYP		__BIT(4)	/* AN-025B */
85*f1871fd1Sflxd #define VLPCI_VL_TIM_RDYRTN2TRDY_RESYNC		__BIT(4)	/* DS */
86*f1871fd1Sflxd #define VLPCI_VL_TIM_OBD_MEM_1ST_DAT		__BIT(3)
87*f1871fd1Sflxd #define VLPCI_VL_TIM_CPU2PCI_WR_BST		__BIT(2)
88*f1871fd1Sflxd #define VLPCI_VL_TIM_PADS_DIS			__BIT(1)
89*f1871fd1Sflxd #define VLPCI_VL_TIM_TST_MODE			__BIT(0)
90*f1871fd1Sflxd 
91*f1871fd1Sflxd #define VLPCI_PCI_TIM_REG			0x84
92*f1871fd1Sflxd #define VLPCI_PCI_TIM_SLV_LOCK			__BIT(7)
93*f1871fd1Sflxd #define VLPCI_PCI_TIM_RTY_CNT_64		__BIT(6)
94*f1871fd1Sflxd #define VLPCI_PCI_TIM_RTY_DEADL_ERR_REP		__BIT(5)
95*f1871fd1Sflxd #define VLPCI_PCI_TIM_RTY_STS_OCCU		__BIT(4)
96*f1871fd1Sflxd #define VLPCI_PCI_TIM_CPU2PCI_FAST_B2B		__BIT(3)
97*f1871fd1Sflxd #define VLPCI_PCI_TIM_FAST_FRAME		__BIT(2)
98*f1871fd1Sflxd #define VLPCI_PCI_TIM_DEVSEL_DEC		__BITS(1, 0)
99*f1871fd1Sflxd #define VLPCI_PCI_TIM_DEVSEL_DEC_SUBTR		0x3
100*f1871fd1Sflxd #define VLPCI_PCI_TIM_DEVSEL_DEC_SLOW		0x2
101*f1871fd1Sflxd #define VLPCI_PCI_TIM_DEVSEL_DEC_MDM		0x1
102*f1871fd1Sflxd #define VLPCI_PCI_TIM_DEVSEL_DEC_FAST		0x0
103*f1871fd1Sflxd 
104*f1871fd1Sflxd #define VLPCI_PCI_ARB_REG			0x85
105*f1871fd1Sflxd #define VLPCI_PCI_ARB_FAIR			__BIT(7)
106*f1871fd1Sflxd #define VLPCI_PCI_ARB_FRAME			__BIT(6)
107*f1871fd1Sflxd #define VLPCI_PCI_ARB_CPU_TIM_SLT		__BITS(5, 4)
108*f1871fd1Sflxd #define VLPCI_PCI_ARB_CPU_TIM_SLT_32CLK		0x3
109*f1871fd1Sflxd #define VLPCI_PCI_ARB_CPU_TIM_SLT_16CLK		0x2
110*f1871fd1Sflxd #define VLPCI_PCI_ARB_CPU_TIM_SLT_8CLK		0x1
111*f1871fd1Sflxd #define VLPCI_PCI_ARB_CPU_TIM_SLT_4CLK		0x0
112*f1871fd1Sflxd #define VLPCI_PCI_ARB_PCI_MST_TMO		__BITS(3, 0)
113*f1871fd1Sflxd #define VLPCI_PCI_ARB_PCI_MST_TMO_DIS		0x0
114*f1871fd1Sflxd #define VLPCI_PCI_ARB_PCI_MST_TMO_1X32CLK	0x1
115*f1871fd1Sflxd #define VLPCI_PCI_ARB_PCI_MST_TMO_2X32CLK	0x2
116*f1871fd1Sflxd #define VLPCI_PCI_ARB_PCI_MST_TMO_3X32CLK	0x3
117*f1871fd1Sflxd #define VLPCI_PCI_ARB_PCI_MST_TMO_4X32CLK	0x4
118*f1871fd1Sflxd #define VLPCI_PCI_ARB_PCI_MST_TMO_5X32CLK	0x5
119*f1871fd1Sflxd #define VLPCI_PCI_ARB_PCI_MST_TMO_6X32CLK	0x6
120*f1871fd1Sflxd #define VLPCI_PCI_ARB_PCI_MST_TMO_7X32CLK	0x7
121*f1871fd1Sflxd #define VLPCI_PCI_ARB_PCI_MST_TMO_8X32CLK	0x8
122*f1871fd1Sflxd #define VLPCI_PCI_ARB_PCI_MST_TMO_9X32CLK	0x9
123*f1871fd1Sflxd #define VLPCI_PCI_ARB_PCI_MST_TMO_10X32CLK	0xa
124*f1871fd1Sflxd #define VLPCI_PCI_ARB_PCI_MST_TMO_11X32CLK	0xb
125*f1871fd1Sflxd #define VLPCI_PCI_ARB_PCI_MST_TMO_12X32CLK	0xc
126*f1871fd1Sflxd #define VLPCI_PCI_ARB_PCI_MST_TMO_13X32CLK	0xd
127*f1871fd1Sflxd #define VLPCI_PCI_ARB_PCI_MST_TMO_14X32CLK	0xe
128*f1871fd1Sflxd #define VLPCI_PCI_ARB_PCI_MST_TMO_15X32CLK	0xf
129*f1871fd1Sflxd 
130*f1871fd1Sflxd #define VLPCI_CFG_MISC_CTL_REG			0x86
131*f1871fd1Sflxd #define VLPCI_CFG_MISC_CTL_PCI_CFG_MECHN_2	__BIT(7)
132*f1871fd1Sflxd #define VLPCI_CFG_MISC_CTL_INT_CTL		__BITS(5, 6)
133*f1871fd1Sflxd #define VLPCI_CFG_MISC_CTL_INT_CTL_TRSP		0x0
134*f1871fd1Sflxd #define VLPCI_CFG_MISC_CTL_INT_CTL_CONV_INTL	0x1
135*f1871fd1Sflxd #define VLPCI_CFG_MISC_CTL_INT_CTL_TRSP_INV	0x2
136*f1871fd1Sflxd #define VLPCI_CFG_MISC_CTL_INT_CTL_CONV		0x3
137*f1871fd1Sflxd #define VLPCI_CFG_MISC_CTL_TST_MODE		__BIT(4)
138*f1871fd1Sflxd #define VLPCI_CFG_MISC_CTL_SERR_NMI		__BIT(3)
139*f1871fd1Sflxd #define VLPCI_CFG_MISC_CTL_SERR_STS		__BIT(2)
140*f1871fd1Sflxd #define VLPCI_CFG_MISC_CTL_PCI_MST_BRK_TMR	__BIT(1)
141*f1871fd1Sflxd #define VLPCI_CFG_MISC_CTL_LREQI_LGNTO_PIN	__BIT(0)
142*f1871fd1Sflxd 
143*f1871fd1Sflxd #define VLPCI_PCI_WND_NO_1			1
144*f1871fd1Sflxd #define VLPCI_PCI_WND_NO_2			2
145*f1871fd1Sflxd #define VLPCI_PCI_WND_NO_3			3
146*f1871fd1Sflxd 
147*f1871fd1Sflxd #define VLPCI_PCI_WND_HIADDR_REG(no)		(0x87 + 3 * ((no) - 1))
148*f1871fd1Sflxd #define VLPCI_PCI_WND_HIADDR_IO(x)		(((x) >> 8) & 0xff)
149*f1871fd1Sflxd #define VLPCI_PCI_WND_HIADDR_MEM(x)		(((x) >> 24) & 0xff)
150*f1871fd1Sflxd 
151*f1871fd1Sflxd #define VLPCI_PCI_WND_LOADDR_REG(no)		(0x88 + 3 * ((no) - 1))
152*f1871fd1Sflxd #define VLPCI_PCI_WND_LOADDR_IO(x)		(((x) >> 0) & 0xff)
153*f1871fd1Sflxd #define VLPCI_PCI_WND_LOADDR_MEM(x)		(((x) >> 16) & 0xff)
154*f1871fd1Sflxd 
155*f1871fd1Sflxd /*
156*f1871fd1Sflxd  * Window attributes differ significantly between AN-025B (PCI windows only,
157*f1871fd1Sflxd  * memory and I/O) and DS (PCI and VL windows, memory only).
158*f1871fd1Sflxd  */
159*f1871fd1Sflxd #define VLPCI_PCI_WND_ATTR_REG(no)		(0x89 + 3 * ((no) - 1))
160*f1871fd1Sflxd #define VLPCI_PCI_WND_ATTR_ENA			__BIT(7)	/* AN-025B */
161*f1871fd1Sflxd #define VLPCI_PCI_WND_ATTR_PCI			__BIT(7)	/* DS */
162*f1871fd1Sflxd #define VLPCI_PCI_WND_ATTR_WR_BUF		__BIT(6)
163*f1871fd1Sflxd #define VLPCI_PCI_WND_ATTR_IO			__BIT(5)	/* AN-025B */
164*f1871fd1Sflxd #define VLPCI_PCI_WND_ATTR_VL			__BIT(5)	/* DS */
165*f1871fd1Sflxd #define VLPCI_PCI_WND_ATTR_SZ			__BITS(4, 2)
166*f1871fd1Sflxd /* I/O size only present in AN-025B. */
167*f1871fd1Sflxd #define VLPCI_PCI_WND_ATTR_SZ_IO_4		0x0
168*f1871fd1Sflxd #define VLPCI_PCI_WND_ATTR_SZ_IO_8		0x1
169*f1871fd1Sflxd #define VLPCI_PCI_WND_ATTR_SZ_IO_16		0x2
170*f1871fd1Sflxd #define VLPCI_PCI_WND_ATTR_SZ_IO_32		0x3
171*f1871fd1Sflxd #define VLPCI_PCI_WND_ATTR_SZ_IO_64		0x4
172*f1871fd1Sflxd #define VLPCI_PCI_WND_ATTR_SZ_IO_128		0x5
173*f1871fd1Sflxd #define VLPCI_PCI_WND_ATTR_SZ_IO_256		0x6
174*f1871fd1Sflxd #define VLPCI_PCI_WND_ATTR_SZ_IO_512		0x7
175*f1871fd1Sflxd #define VLPCI_PCI_WND_ATTR_SZ_IO(b)		ilog2((b) >> 2)
176*f1871fd1Sflxd #define VLPCI_PCI_WND_ATTR_SZ_MEM_64K		0x0
177*f1871fd1Sflxd #define VLPCI_PCI_WND_ATTR_SZ_MEM_128K		0x1
178*f1871fd1Sflxd #define VLPCI_PCI_WND_ATTR_SZ_MEM_256K		0x2
179*f1871fd1Sflxd #define VLPCI_PCI_WND_ATTR_SZ_MEM_512K		0x3
180*f1871fd1Sflxd #define VLPCI_PCI_WND_ATTR_SZ_MEM_1M		0x4
181*f1871fd1Sflxd #define VLPCI_PCI_WND_ATTR_SZ_MEM_2M		0x5
182*f1871fd1Sflxd #define VLPCI_PCI_WND_ATTR_SZ_MEM_4M		0x6
183*f1871fd1Sflxd #define VLPCI_PCI_WND_ATTR_SZ_MEM_8M		0x7
184*f1871fd1Sflxd #define VLPCI_PCI_WND_ATTR_SZ_MEM(b)		ilog2((b) >> 16)
185*f1871fd1Sflxd 
186*f1871fd1Sflxd #define VLPCI_INT_CTL_REG(int)			(0x90 + (int) / 8)
187*f1871fd1Sflxd #define VLPCI_INT_CTL_ENA(int)			__BIT((int) % 8 + 3)
188*f1871fd1Sflxd #define VLPCI_INT_CTL_INT2IRQ(int)		__BITS((int) % 8 + 2, (int) % 8)
189*f1871fd1Sflxd #define VLPCI_INT_CTL_INTB			12
190*f1871fd1Sflxd #define VLPCI_INT_CTL_INTA			8
191*f1871fd1Sflxd #define VLPCI_INT_CTL_INTD			4
192*f1871fd1Sflxd #define VLPCI_INT_CTL_INTC			0
193*f1871fd1Sflxd #define VLPCI_INT_CTL_IRQ_NONE			0x0
194*f1871fd1Sflxd #define VLPCI_INT_CTL_IRQ5			0x1
195*f1871fd1Sflxd #define VLPCI_INT_CTL_IRQ9			0x2
196*f1871fd1Sflxd #define VLPCI_INT_CTL_IRQ10			0x3
197*f1871fd1Sflxd #define VLPCI_INT_CTL_IRQ11			0x4
198*f1871fd1Sflxd #define VLPCI_INT_CTL_IRQ14			0x5
199*f1871fd1Sflxd #define VLPCI_INT_CTL_IRQ15			0x6
200*f1871fd1Sflxd #define VLPCI_INT_CTL_IRQ(irq)			\
201*f1871fd1Sflxd     (((irq) == 5) ? VLPCI_INT_CTL_IRQ5 :	\
202*f1871fd1Sflxd     ((irq) == 9) ? VLPCI_INT_CTL_IRQ9 :		\
203*f1871fd1Sflxd     ((irq) == 10) ? VLPCI_INT_CTL_IRQ10 :	\
204*f1871fd1Sflxd     ((irq) == 11) ? VLPCI_INT_CTL_IRQ11 :	\
205*f1871fd1Sflxd     ((irq) == 14) ? VLPCI_INT_CTL_IRQ14 :	\
206*f1871fd1Sflxd     ((irq) == 15) ? VLPCI_INT_CTL_IRQ15 :	\
207*f1871fd1Sflxd     VLPCI_INT_CTL_IRQ_NONE)
208*f1871fd1Sflxd 
209*f1871fd1Sflxd #define VLPCI_ACC_ISA_CYC_REG			0x92
210*f1871fd1Sflxd #define VLPCI_ACC_ISA_CYC_A0000			__BIT(7)
211*f1871fd1Sflxd #define VLPCI_ACC_ISA_CYC_B0000			__BIT(6)
212*f1871fd1Sflxd #define VLPCI_ACC_ISA_CYC_C0000			__BIT(5)
213*f1871fd1Sflxd #define VLPCI_ACC_ISA_CYC_C8000			__BIT(4)
214*f1871fd1Sflxd #define VLPCI_ACC_ISA_CYC_D0000			__BIT(3)
215*f1871fd1Sflxd #define VLPCI_ACC_ISA_CYC_D8000			__BIT(2)
216*f1871fd1Sflxd #define VLPCI_ACC_ISA_CYC_E0000			__BIT(1)
217*f1871fd1Sflxd #define VLPCI_ACC_ISA_CYC_E8000			__BIT(0)
218*f1871fd1Sflxd /* F0000h to FFFFFh is always accelerated ISA cycle. */
219*f1871fd1Sflxd 
220*f1871fd1Sflxd #define VLPCI_MISC_CTL_REG			0x93
221*f1871fd1Sflxd #define VLPCI_MISC_CTL_HIADDR			(__BITS(7, 6) | __BIT(4))
222*f1871fd1Sflxd #define VLPCI_MISC_CTL_HIADDR_CA26_ABV		0x0	/* 0b00x0 */
223*f1871fd1Sflxd #define VLPCI_MISC_CTL_HIADDR_CA27_ABV		0x4	/* 0b01x0 */
224*f1871fd1Sflxd #define VLPCI_MISC_CTL_HIADDR_CA28_ABV		0x8	/* 0b10x0 */
225*f1871fd1Sflxd #define VLPCI_MISC_CTL_HIADDR_CA29_ABV		0xc	/* 0b11x0 */
226*f1871fd1Sflxd #define VLPCI_MISC_CTL_HIADDR_CA30_ABV		0x1	/* 0b00x1 */
227*f1871fd1Sflxd #define VLPCI_MISC_CTL_HIADDR_CA31_ABV		0x5	/* 0b01x1 */
228*f1871fd1Sflxd #define VLPCI_MISC_CTL_HIADDR_DIS		0xd	/* 0b11x1 */
229*f1871fd1Sflxd #define VLPCI_MISC_CTL_IOCHCK_PIN		__BIT(5)
230*f1871fd1Sflxd #define VLPCI_MISC_CTL_2ND_VL_IDE		__BIT(3)
231*f1871fd1Sflxd #define VLPCI_MISC_CTL_1ST_VL_IDE		__BIT(2)
232*f1871fd1Sflxd #define VLPCI_MISC_CTL_OBD_IO_ACC_ISA		__BIT(0)
233*f1871fd1Sflxd 
234*f1871fd1Sflxd #define VLPCI_ACC_PCI_64K_WND_REG		0x94
235*f1871fd1Sflxd #define VLPCI_ACC_PCI_64K_WND_A0000		__BIT(7)
236*f1871fd1Sflxd #define VLPCI_ACC_PCI_64K_WND_B0000		__BIT(6)
237*f1871fd1Sflxd #define VLPCI_ACC_PCI_64K_WND_C0000		__BIT(5)
238*f1871fd1Sflxd #define VLPCI_ACC_PCI_64K_WND_C8000		__BIT(4)
239*f1871fd1Sflxd #define VLPCI_ACC_PCI_64K_WND_D0000		__BIT(3)
240*f1871fd1Sflxd #define VLPCI_ACC_PCI_64K_WND_D8000		__BIT(2)
241*f1871fd1Sflxd #define VLPCI_ACC_PCI_64K_WND_E0000		__BIT(1)
242*f1871fd1Sflxd #define VLPCI_ACC_PCI_64K_WND_E8000		__BIT(0)
243*f1871fd1Sflxd 
244*f1871fd1Sflxd #define VLPCI_ACC_PCI_32K_WND_REG		0x95
245*f1871fd1Sflxd #define VLPCI_ACC_PCI_32K_WND_A0000		__BIT(7)
246*f1871fd1Sflxd #define VLPCI_ACC_PCI_32K_WND_A8000		__BIT(6)
247*f1871fd1Sflxd #define VLPCI_ACC_PCI_32K_WND_B0000		__BIT(5)
248*f1871fd1Sflxd #define VLPCI_ACC_PCI_32K_WND_B8000		__BIT(4)
249*f1871fd1Sflxd 
250*f1871fd1Sflxd #define VLPCI_MISC_1_REG			0x96
251*f1871fd1Sflxd #define VLPCI_MISC_1_DYN_DEC_MEM_WR		__BIT(7)
252*f1871fd1Sflxd #define VLPCI_MISC_1_RTY_TMO_ACTION		__BIT(6)
253*f1871fd1Sflxd #define VLPCI_MISC_1_DYN_DEC_DIS		__BIT(5)
254*f1871fd1Sflxd #define VLPCI_MISC_1_LOCAL_PIN			__BIT(4)
255*f1871fd1Sflxd #define VLPCI_MISC_1_COMPAT_ISA_BOFF		__BIT(3)
256*f1871fd1Sflxd #define VLPCI_MISC_1_IRQ_IDLE_LOW		__BIT(2)
257*f1871fd1Sflxd #define VLPCI_MISC_1_PCI_MST_1WS_WR		__BIT(1)
258*f1871fd1Sflxd #define VLPCI_MISC_1_PCI_SLV_1WS_BST_WR		__BIT(0)
259*f1871fd1Sflxd 
260*f1871fd1Sflxd /* Individual INT[ABCD] mode control from VT82C505-E on. */
261*f1871fd1Sflxd #define VLPCI_IRQ_MODE_REG			0x97
262*f1871fd1Sflxd #define VLPCI_IRQ_MODE_CTL(i)			__BITS((i) + 1, (i))
263*f1871fd1Sflxd #define VLPCI_IRQ_MODE_CTL_INTA			6
264*f1871fd1Sflxd #define VLPCI_IRQ_MODE_CTL_INTB			4
265*f1871fd1Sflxd #define VLPCI_IRQ_MODE_CTL_INTC			2
266*f1871fd1Sflxd #define VLPCI_IRQ_MODE_CTL_INTD			0
267*f1871fd1Sflxd 
268*f1871fd1Sflxd #define VLPCI_OBD_MEM_EADDR_REG			0x98
269*f1871fd1Sflxd #define VLPCI_OBD_MEM_EADDR_CA32_CA28		__BITS(4, 0)
270*f1871fd1Sflxd 
271*f1871fd1Sflxd #define VLPCI_MISC_2_REG			0x99
272*f1871fd1Sflxd #define VLPCI_MISC_2_BYTE_MRG			__BIT(7)
273*f1871fd1Sflxd #define VLPCI_MISC_2_ENH_BYTE_MRG		__BIT(6)
274*f1871fd1Sflxd #define VLPCI_MISC_2_DYN_PCI_BST		__BIT(5)
275*f1871fd1Sflxd #define VLPCI_MISC_2_RTY_FAIL_POP_1_DAT		__BIT(4)
276*f1871fd1Sflxd #define VLPCI_MISC_2_2WAY_DYN_DEC		__BIT(3)
277*f1871fd1Sflxd #define VLPCI_MISC_2_ISAREQ_1CLK_DLY		__BIT(1)
278*f1871fd1Sflxd #define VLPCI_MISC_2_ADS_1CLK_DLY		__BIT(0)
279*f1871fd1Sflxd 
280*f1871fd1Sflxd #endif /* !defined(_VLPCI_H) */
281