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