diff options
-rw-r--r-- | sys/dev/pci/pccbb.c | 63 | ||||
-rw-r--r-- | sys/dev/pci/pccbbvar.h | 8 |
2 files changed, 7 insertions, 64 deletions
diff --git a/sys/dev/pci/pccbb.c b/sys/dev/pci/pccbb.c index e7987f620a1..04cda441090 100644 --- a/sys/dev/pci/pccbb.c +++ b/sys/dev/pci/pccbb.c @@ -1,4 +1,4 @@ -/* $OpenBSD: pccbb.c,v 1.66 2009/07/21 20:59:45 miod Exp $ */ +/* $OpenBSD: pccbb.c,v 1.67 2009/07/25 11:27:26 kettenis Exp $ */ /* $NetBSD: pccbb.c,v 1.96 2004/03/28 09:49:31 nakayama Exp $ */ /* @@ -363,10 +363,6 @@ pccbb_shutdown(void *arg) DPRINTF(("%s: shutdown\n", sc->sc_dev.dv_xname)); - /* Nothing for us to do if we didn't map any registers. */ - if ((sc->sc_flags & CBB_MEMHMAPPED) == 0) - return; - /* turn off power */ pccbb_power((cardbus_chipset_tag_t)sc, CARDBUS_VCC_0V | CARDBUS_VPP_0V); @@ -407,8 +403,6 @@ pccbbattach(struct device *parent, struct device *self, void *aux) sc->sc_rbus_iot = rbus_pccbb_parent_io(self, pa); sc->sc_rbus_memt = rbus_pccbb_parent_mem(self, pa); - sc->sc_flags &= ~CBB_MEMHMAPPED; - /* * MAP socket registers and ExCA registers on memory-space * When no valid address is set on socket base registers (on pci @@ -416,42 +410,14 @@ pccbbattach(struct device *parent, struct device *self, void *aux) */ sock_base = pci_conf_read(pc, pa->pa_tag, PCI_SOCKBASE); - if (PCI_MAPREG_MEM_ADDR(sock_base) >= 0x100000 && - PCI_MAPREG_MEM_ADDR(sock_base) != 0xfffffff0) { - /* The address must be valid. */ - if (pci_mapreg_map(pa, PCI_SOCKBASE, PCI_MAPREG_TYPE_MEM, 0, - &sc->sc_base_memt, &sc->sc_base_memh, &sockbase, NULL, 0)) - { - printf("%s: can't map socket base address 0x%x\n", - sc->sc_dev.dv_xname, sock_base); - /* - * I think it's funny: socket base registers must be - * mapped on memory space, but ... - */ - if (pci_mapreg_map(pa, PCI_SOCKBASE, - PCI_MAPREG_TYPE_IO, 0, &sc->sc_base_memt, - &sc->sc_base_memh, &sockbase, NULL, 0)) { - printf("%s: can't map socket base address" - " 0x%lx: io mode\n", sc->sc_dev.dv_xname, - sockbase); - /* give up... allocate reg space via rbus. */ - pci_conf_write(pc, pa->pa_tag, PCI_SOCKBASE, 0); - } else - sc->sc_flags |= CBB_MEMHMAPPED; - } else { - DPRINTF(("%s: socket base address 0x%lx\n", - sc->sc_dev.dv_xname, sockbase)); - sc->sc_flags |= CBB_MEMHMAPPED; - } + if (pci_mapreg_map(pa, PCI_SOCKBASE, PCI_MAPREG_TYPE_MEM, 0, + &sc->sc_base_memt, &sc->sc_base_memh, &sockbase, NULL, 0)) { + printf("can't map registers\n"); + return; } - sc->sc_mem_start = 0; /* XXX */ - sc->sc_mem_end = 0xffffffff; /* XXX */ - busreg = pci_conf_read(pc, pa->pa_tag, PCI_BUSNUM); - /* pccbb_machdep.c end */ - #if defined CBB_DEBUG { static char *intrname[5] = { "NON", "A", "B", "C", "D" }; @@ -515,7 +481,7 @@ pccbbattach(struct device *parent, struct device *self, void *aux) /* Disable legacy register mapping. */ switch (sc->sc_chipset) { - case CB_RX5C46X: /* fallthrough */ + case CB_RX5C46X: #if 0 /* The RX5C47X-series requires writes to the PCI_LEGACY register. */ case CB_RX5C47X: @@ -561,29 +527,12 @@ pccbb_pci_callback(struct device *self) bus_space_tag_t base_memt; bus_space_handle_t base_memh; u_int32_t maskreg; - bus_addr_t sockbase; struct cbslot_attach_args cba; struct pcmciabus_attach_args paa; struct cardslot_attach_args caa; struct cardslot_softc *csc; u_int32_t sockstat; - if (!(sc->sc_flags & CBB_MEMHMAPPED)) { - /* The socket registers aren't mapped correctly. */ - if (rbus_space_alloc(sc->sc_rbus_memt, 0, 0x1000, 0x0fff, - (sc->sc_chipset == CB_RX5C47X - || sc->sc_chipset == CB_TI113X) ? 0x10000 : 0x1000, - 0, &sockbase, &sc->sc_base_memh)) { - return; - } - sc->sc_base_memt = sc->sc_memt; - pci_conf_write(pc, sc->sc_tag, PCI_SOCKBASE, sockbase); - DPRINTF(("%s: CardBus register address 0x%lx -> 0x%x\n", - sc->sc_dev.dv_xname, sockbase, pci_conf_read(pc, sc->sc_tag, - PCI_SOCKBASE))); - sc->sc_flags |= CBB_MEMHMAPPED; - } - base_memt = sc->sc_base_memt; /* socket regs memory tag */ base_memh = sc->sc_base_memh; /* socket regs memory handle */ diff --git a/sys/dev/pci/pccbbvar.h b/sys/dev/pci/pccbbvar.h index 5b973be8dfc..9d5db19c8c8 100644 --- a/sys/dev/pci/pccbbvar.h +++ b/sys/dev/pci/pccbbvar.h @@ -1,4 +1,4 @@ -/* $OpenBSD: pccbbvar.h,v 1.13 2007/11/30 08:12:00 miod Exp $ */ +/* $OpenBSD: pccbbvar.h,v 1.14 2009/07/25 11:27:26 kettenis Exp $ */ /* $NetBSD: pccbbvar.h,v 1.13 2000/06/08 10:28:29 haya Exp $ */ /* * Copyright (c) 1999 HAYAKAWA Koichi. All rights reserved. @@ -137,7 +137,6 @@ struct pccbb_softc { #define CBB_INSERTING 0x01000000 #define CBB_16BITCARD 0x04 #define CBB_32BITCARD 0x08 -#define CBB_MEMHMAPPED 0x02000000 pci_chipset_tag_t sc_pc; pcitag_t sc_tag; @@ -145,11 +144,6 @@ struct pccbb_softc { int sc_chipset; /* chipset id */ int sc_ints_on; - bus_addr_t sc_mem_start; /* CardBus/PCMCIA memory start */ - bus_addr_t sc_mem_end; /* CardBus/PCMCIA memory end */ - bus_addr_t sc_io_start; /* CardBus/PCMCIA io start */ - bus_addr_t sc_io_end; /* CardBus/PCMCIA io end */ - pcireg_t sc_sockbase; /* Socket base register */ pcireg_t sc_busnum; /* bus number */ |