summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/arch/sgi/xbow/xbridge.c40
1 files changed, 27 insertions, 13 deletions
diff --git a/sys/arch/sgi/xbow/xbridge.c b/sys/arch/sgi/xbow/xbridge.c
index f0ef4c2be6e..5a5cbdcb6cb 100644
--- a/sys/arch/sgi/xbow/xbridge.c
+++ b/sys/arch/sgi/xbow/xbridge.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: xbridge.c,v 1.46 2009/08/22 02:54:51 mk Exp $ */
+/* $OpenBSD: xbridge.c,v 1.47 2009/10/07 04:19:30 miod Exp $ */
/*
* Copyright (c) 2008, 2009 Miodrag Vallat.
@@ -507,6 +507,12 @@ xbridge_attach_bus(struct xbridge_softc *sc, uint busno, bus_space_tag_t regt)
pba.pba_dmat = xb->xb_dmat;
pba.pba_ioex = xb->xb_ioex;
pba.pba_memex = xb->xb_memex;
+#ifdef DEBUG
+ if (xb->xb_ioex != NULL)
+ extent_print(xb->xb_ioex);
+ if (xb->xb_memex != NULL)
+ extent_print(xb->xb_memex);
+#endif
pba.pba_pc = &xb->xb_pc;
pba.pba_domain = pci_ndomains++;
pba.pba_bus = 0;
@@ -1964,8 +1970,12 @@ xbridge_setup(struct xbridge_bus *xb)
*/
for (dev = 0; dev < xb->xb_nslots; dev++) {
- pa = xb->xb_regh + BRIDGE_PCI_CFG_SPACE +
- (dev << 12) + PCI_ID_REG;
+ if (ISSET(xb->xb_flags, XF_PIC))
+ pa = xb->xb_regh + BRIDGE_PCI_CFG_SPACE +
+ ((dev + 1) << 12) + PCI_ID_REG;
+ else
+ pa = xb->xb_regh + BRIDGE_PCI_CFG_SPACE +
+ (dev << 12) + PCI_ID_REG;
if (guarded_read_4(pa, &xb->xb_devices[dev].id) != 0)
xb->xb_devices[dev].id =
PCI_ID_CODE(PCI_VENDOR_INVALID, 0xffff);
@@ -2156,6 +2166,11 @@ xbridge_resource_setup(struct xbridge_bus *xb)
* Configure all regular PCI devices.
*/
+#ifdef DEBUG
+ for (dev = 0; dev < xb->xb_nslots; dev++)
+ printf("device %d: devio %08x\n",
+ dev, xbridge_read_reg(xb, BRIDGE_DEVICE(dev)));
+#endif
nppb = npccbb = 0;
for (dev = 0; dev < xb->xb_nslots; dev++) {
id = xb->xb_devices[dev].id;
@@ -2192,10 +2207,8 @@ xbridge_resource_setup(struct xbridge_bus *xb)
*/
devio = xbridge_read_reg(xb, BRIDGE_DEVICE(dev));
-#ifdef DEBUG
- printf("device %d: devio %08x\n", dev, devio);
-#endif
- if (id != PCI_ID_CODE(PCI_VENDOR_SGI, PCI_PRODUCT_SGI_IOC3))
+ if (id != PCI_ID_CODE(PCI_VENDOR_SGI, PCI_PRODUCT_SGI_IOC3) &&
+ id != PCI_ID_CODE(PCI_VENDOR_SGI, PCI_PRODUCT_SGI_IOC4))
need_setup = 1;
else
need_setup = xb->xb_devio_skew !=
@@ -2212,6 +2225,7 @@ xbridge_resource_setup(struct xbridge_bus *xb)
devio |= BRIDGE_DEVICE_SWAP_PMU;
devio |= BRIDGE_DEVICE_SWAP_DIR;
if (id == PCI_ID_CODE(PCI_VENDOR_SGI, PCI_PRODUCT_SGI_IOC3) ||
+ id == PCI_ID_CODE(PCI_VENDOR_SGI, PCI_PRODUCT_SGI_IOC4) ||
id == PCI_ID_CODE(PCI_VENDOR_SGI, PCI_PRODUCT_SGI_RAD1))
devio &=
~(BRIDGE_DEVICE_SWAP_DIR | BRIDGE_DEVICE_SWAP_PMU);
@@ -2325,8 +2339,8 @@ xbridge_extent_setup(struct xbridge_bus *xb)
bus_addr_t start, end;
uint32_t devio;
- snprintf(xb->xb_ioexname, sizeof(xb->xb_ioexname), "%s_io",
- DEVNAME(xb));
+ snprintf(xb->xb_ioexname, sizeof(xb->xb_ioexname), "%s_io%d",
+ DEVNAME(xb), xb->xb_busno);
xb->xb_ioex = extent_create(xb->xb_ioexname, 0, 0xffffffff,
M_DEVBUF, NULL, 0, EX_NOWAIT | EX_FILLED);
@@ -2374,8 +2388,8 @@ xbridge_extent_setup(struct xbridge_bus *xb)
}
}
- snprintf(xb->xb_memexname, sizeof(xb->xb_memexname), "%s_mem",
- DEVNAME(xb));
+ snprintf(xb->xb_memexname, sizeof(xb->xb_memexname), "%s_mem%d",
+ DEVNAME(xb), xb->xb_busno);
xb->xb_memex = extent_create(xb->xb_memexname, 0, 0xffffffff,
M_DEVBUF, NULL, 0, EX_NOWAIT | EX_FILLED);
@@ -2703,8 +2717,8 @@ xbridge_resource_manage(struct xbridge_bus *xb, pcitag_t tag,
* ARCS but can be reinitialized as we see fit).
*/
#ifdef DEBUG
- printf("bar %02x type %d base %p size %p",
- reg, type, base, size);
+ printf("tag %04x bar %02x type %d base %p size %p",
+ tag, reg, type, base, size);
#endif
switch (type) {
case PCI_MAPREG_TYPE_MEM | PCI_MAPREG_MEM_TYPE_64BIT: