diff options
author | Marcus Glocker <mglocker@cvs.openbsd.org> | 2007-02-24 23:05:05 +0000 |
---|---|---|
committer | Marcus Glocker <mglocker@cvs.openbsd.org> | 2007-02-24 23:05:05 +0000 |
commit | 580cb8acd3312b1a12ff95f27f5417f975292863 (patch) | |
tree | dd9dea86fe57ea66c8fa69f1653cdf0e4c22900d | |
parent | 927e7acd301e5d8d9836e39ba782f84551cadbab (diff) |
Get correct chip revision and also get chip package.
-rw-r--r-- | sys/dev/ic/bcw.c | 49 | ||||
-rw-r--r-- | sys/dev/ic/bcwvar.h | 7 | ||||
-rw-r--r-- | sys/dev/pci/if_bcw_pci.c | 3 |
3 files changed, 31 insertions, 28 deletions
diff --git a/sys/dev/ic/bcw.c b/sys/dev/ic/bcw.c index e789815c1e0..a74db9bab45 100644 --- a/sys/dev/ic/bcw.c +++ b/sys/dev/ic/bcw.c @@ -1,4 +1,4 @@ -/* $OpenBSD: bcw.c,v 1.56 2007/02/24 11:59:33 mglocker Exp $ */ +/* $OpenBSD: bcw.c,v 1.57 2007/02/24 23:05:04 mglocker Exp $ */ /* * Copyright (c) 2006 Jon Simola <jsimola@gmail.com> @@ -743,13 +743,15 @@ bcw_attach(struct bcw_softc *sc) sc->sc_havecommon = 1; /* XXX do early init of sc_core[0] here */ sbval = BCW_READ(sc, BCW_CORE_COMMON_CHIPID); - sc->sc_chipid = (sbval & 0x0000ffff); - sc->sc_chiprev = - ((sbval & 0x00007000) >> 8 | (sbval & 0x0000000f)); - if ((sc->sc_chiprev == 4) || (sc->sc_chiprev >= 6)) + sc->sc_chip_id = (sbval & 0x0000ffff); + sc->sc_chip_rev = (sbval & 0x000f0000) >> 16; + sc->sc_chip_package = (sbval & 0x00f00000) >> 20; + //sc->sc_chip_rev = + // ((sbval & 0x00007000) >> 8 | (sbval & 0x0000000f)); + if ((sc->sc_chip_rev == 4) || (sc->sc_chip_rev >= 6)) sc->sc_numcores = (sbval & 0x0f000000) >> 24; else - switch (sc->sc_chipid) { + switch (sc->sc_chip_id) { case 0x4710: case 0x4610: case 0x4704: @@ -785,7 +787,7 @@ bcw_attach(struct bcw_softc *sc) case 0x4713: case 0x4714: case 0x4715: - sc->sc_chipid = 0x4710; + sc->sc_chip_id = 0x4710; sc->sc_numcores = 9; break; case 0x4610: @@ -794,34 +796,35 @@ bcw_attach(struct bcw_softc *sc) case 0x4613: case 0x4614: case 0x4615: - sc->sc_chipid = 0x4610; + sc->sc_chip_id = 0x4610; sc->sc_numcores = 9; break; case 0x4402: case 0x4403: - sc->sc_chipid = 0x4402; + sc->sc_chip_id = 0x4402; sc->sc_numcores = 3; break; case 0x4305: case 0x4306: case 0x4307: - sc->sc_chipid = 0x4307; + sc->sc_chip_id = 0x4307; sc->sc_numcores = 5; break; case 0x4301: - sc->sc_chipid = 0x4301; + sc->sc_chip_id = 0x4301; sc->sc_numcores = 5; break; default: - sc->sc_chipid = sc->sc_prodid; + sc->sc_chip_id = sc->sc_prodid; /* Set to max */ sc->sc_numcores = BCW_MAX_CORES; } /* end of switch */ } /* End of if/else */ - DPRINTF(("%s: ChipID=0x%x, ChipRev=0x%x, NumCores=%d\n", - sc->sc_dev.dv_xname, sc->sc_chipid, - sc->sc_chiprev, sc->sc_numcores)); + DPRINTF(("%s: ChipID=0x%x, ChipRev=0x%x, ChipPkg=0x%x, NumCores=%d\n", + sc->sc_dev.dv_xname, + sc->sc_chip_id, sc->sc_chip_rev, sc->sc_chip_package, + sc->sc_numcores)); /* Reset and Identify each core */ for (i = 0; i < sc->sc_numcores; i++) { @@ -919,14 +922,14 @@ bcw_attach(struct bcw_softc *sc) * Radio registers, and requires seperate 16bit reads from the low * and the high data addresses. */ - if (sc->sc_chipid != 0x4317) { + if (sc->sc_chip_id != 0x4317) { BCW_WRITE16(sc, BCW_RADIO_CONTROL, BCW_RADIO_ID); sbval = BCW_READ16(sc, BCW_RADIO_DATAHIGH); sbval <<= 16; BCW_WRITE16(sc, BCW_RADIO_CONTROL, BCW_RADIO_ID); sc->sc_radio_mnf = sbval | BCW_READ16(sc, BCW_RADIO_DATALOW); } else { - switch (sc->sc_chiprev) { + switch (sc->sc_chip_rev) { case 0: sc->sc_radio_mnf = 0x3205017F; break; @@ -1703,8 +1706,8 @@ bcw_init(struct ifnet *ifp) bcw_radio_on(sc); BCW_WRITE16(sc, 0x03e6, 0); - if ((error = bcw_phy_init(sc))) - return (error); + //if ((error = bcw_phy_init(sc))) + // return (error); return (0); @@ -2587,7 +2590,7 @@ bcw_powercontrol_crystal_off(struct bcw_softc *sc) uint32_t sbval; /* XXX Return if radio is hardware disabled */ - if (sc->sc_chiprev < 5) + if (sc->sc_chip_rev < 5) return; if ((sc->sc_boardflags & BCW_BF_XTAL) == BCW_BF_XTAL) return; @@ -3050,7 +3053,7 @@ bcw_gpio_init(struct bcw_softc *sc) mask = 0x0000001f; set = 0x0000000f; - if (sc->sc_chipid == 0x4301) { + if (sc->sc_chip_id == 0x4301) { mask |= 0x0060; set |= 0x0060; } @@ -3066,7 +3069,7 @@ bcw_gpio_init(struct bcw_softc *sc) mask |= 0x0200; set |= 0x0200; } - if (sc->sc_chiprev >= 2) + if (sc->sc_chip_rev >= 2) mask |= 0x0010; /* FIXME this is redundant */ BCW_WRITE(sc, BCW_GPIO_CTRL, (BCW_READ(sc, BCW_GPIO_CTRL) & mask) | @@ -3215,7 +3218,7 @@ bcw_phy_initg(struct bcw_softc *sc) if (sc->sc_radio_rev == 8) bcw_phy_write16(sc, 0x0805, 0x3230); bcw_phy_init_pctl(sc); - if (sc->sc_chipid == 0x4306 && sc->sc_chiprev == 2) { + if (sc->sc_chip_id == 0x4306 && sc->sc_chip_rev == 2) { bcw_phy_write16(sc, 0x0429, bcw_phy_read16(sc, 0x0429) & 0xbfff); bcw_phy_write16(sc, 0x04c3, bcw_phy_read16(sc, 0x04c3) & diff --git a/sys/dev/ic/bcwvar.h b/sys/dev/ic/bcwvar.h index 063afd0164b..de52210453f 100644 --- a/sys/dev/ic/bcwvar.h +++ b/sys/dev/ic/bcwvar.h @@ -1,4 +1,4 @@ -/* $OpenBSD: bcwvar.h,v 1.22 2007/02/24 11:59:33 mglocker Exp $ */ +/* $OpenBSD: bcwvar.h,v 1.23 2007/02/24 23:05:04 mglocker Exp $ */ /* * Copyright (c) 2006 Jon Simola <jsimola@gmail.com> @@ -223,8 +223,9 @@ struct bcw_softc { int sc_txsnext; /* next available tx slot */ struct timeout sc_timeout; /* Break these out into seperate structs */ - uint16_t sc_chipid; /* Chip ID */ - uint16_t sc_chiprev; /* Chip Revision */ + uint16_t sc_chip_id; /* Chip ID */ + uint16_t sc_chip_rev; /* Chip Revision */ + uint16_t sc_chip_package; /* Chip Package */ uint16_t sc_prodid; /* Product ID */ struct bcw_core sc_core[BCW_MAX_CORES]; // struct bcw_radio radio[BCW_RADIO_MAX]; diff --git a/sys/dev/pci/if_bcw_pci.c b/sys/dev/pci/if_bcw_pci.c index b3c9b5cfdb1..86071e6284b 100644 --- a/sys/dev/pci/if_bcw_pci.c +++ b/sys/dev/pci/if_bcw_pci.c @@ -1,4 +1,4 @@ -/* $OpenBSD: if_bcw_pci.c,v 1.8 2007/01/03 10:01:34 mglocker Exp $ */ +/* $OpenBSD: if_bcw_pci.c,v 1.9 2007/02/24 23:05:04 mglocker Exp $ */ /* * Copyright (c) 2006 Jon Simola <jsimola@gmail.com> @@ -223,7 +223,6 @@ bcw_pci_attach(struct device *parent, struct device *self, void *aux) /* * Get some PCI based info into the softc */ - sc->sc_chiprev = PCI_REVISION(pa->pa_class); sc->sc_prodid = PCI_PRODUCT(pa->pa_id); /* |