diff options
author | Dale Rahn <drahn@cvs.openbsd.org> | 2001-03-29 20:02:53 +0000 |
---|---|---|
committer | Dale Rahn <drahn@cvs.openbsd.org> | 2001-03-29 20:02:53 +0000 |
commit | cea7ad0e62e7b069f73136cd695c12af85bdf8bb (patch) | |
tree | c00709d7759a31dc5138c56948dfe28c2fdc1b36 /sys/arch/powerpc | |
parent | a062e81a0b26542cd59f932797405180ec2e3c1a (diff) |
Detect pci bus base more accurately, and save it's size.
Diffstat (limited to 'sys/arch/powerpc')
-rw-r--r-- | sys/arch/powerpc/pci/mpcpcibus.c | 56 |
1 files changed, 52 insertions, 4 deletions
diff --git a/sys/arch/powerpc/pci/mpcpcibus.c b/sys/arch/powerpc/pci/mpcpcibus.c index b156544fa11..d5ef3633b31 100644 --- a/sys/arch/powerpc/pci/mpcpcibus.c +++ b/sys/arch/powerpc/pci/mpcpcibus.c @@ -1,4 +1,4 @@ -/* $OpenBSD: mpcpcibus.c,v 1.23 2001/03/03 05:40:01 drahn Exp $ */ +/* $OpenBSD: mpcpcibus.c,v 1.24 2001/03/29 20:02:52 drahn Exp $ */ /* * Copyright (c) 1997 Per Fogelstrom @@ -187,6 +187,8 @@ mpcpcibrattach(parent, self, aux) int map, node; char *bridge; int of_node = 0; + u_int32_t base; + u_int32_t size; switch(system_type) { case POWER4e: @@ -341,6 +343,11 @@ mpcpcibrattach(parent, self, aux) char compat[32]; u_int32_t addr_offset; u_int32_t data_offset; + struct pci_reserve_mem null_reserve = { + 0, + 0, + 0 + }; int i; int len; int rangelen; @@ -388,6 +395,8 @@ mpcpcibrattach(parent, self, aux) { int found; + unsigned int base = 0; + unsigned int size = 0; /* mac configs */ @@ -409,6 +418,8 @@ mpcpcibrattach(parent, self, aux) if (prange[found].flags == 0x01000000) { sc->sc_iobus_space.bus_base = prange[found].base; + sc->sc_iobus_space.bus_size = + prange[found].size; } /* the mem space ranges @@ -419,12 +430,43 @@ mpcpcibrattach(parent, self, aux) * and all IO and device memory will be in * upper 2G of address space, set to * 0x80000000 + * start with segment 1 not 0, 0 is config. */ - - sc->sc_membus_space.bus_base = 0x80000000; - sc->sc_membus_space.bus_reverse = 1; + for (i = 0; i < rangelen ; i++) + { + if (prange[i].flags == 0x02000000) { + /* find last? */ + printf("\nfound mem %x %x", + prange[i].base, + prange[i].size); + + if (base != 0) { + if ((base + size) == + prange[i].base) + { + size += + prange[i].size; + } else { + base = + prange[i].base; + size = + prange[i].size; + } + } else { + base = prange[i].base; + size = prange[i].size; + } + } + } + sc->sc_membus_space.bus_base = base; + sc->sc_membus_space.bus_size = size; } + printf("membase %x size %x iobase %x size %x\n", + sc->sc_membus_space.bus_base, + sc->sc_membus_space.bus_size, + sc->sc_iobus_space.bus_base, + sc->sc_iobus_space.bus_size); addr_offset = 0; @@ -487,6 +529,10 @@ mpcpcibrattach(parent, self, aux) printf(": %s, Revision 0x%x\n", compat, mpc_cfg_read_1(lcp, MPC106_PCI_REVID)); + +#if 0 + pci_addr_fixup(sc, &lcp->lc_pc, 32, &null_reserve); +#endif } break; @@ -836,7 +882,9 @@ mpc_conf_read(cpv, tag, offset) int daddr = 0; if(offset & 3 || offset < 0 || offset >= 0x100) { +#ifdef DEBUG_CONFIG printf ("pci_conf_read: bad reg %x\n", offset); +#endif /* DEBUG_CONFIG */ return(~0); } |