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