diff options
author | Claudio Jeker <claudio@cvs.openbsd.org> | 2015-09-11 13:35:16 +0000 |
---|---|---|
committer | Claudio Jeker <claudio@cvs.openbsd.org> | 2015-09-11 13:35:16 +0000 |
commit | 121bf16df48d00dae7bb102ceab608a735aac61b (patch) | |
tree | 50940aae2486acd703cf84a820744de6400da26d /sys/dev/pci | |
parent | ace20f11631f3fcbcb750e9acdc6324c539a1cb9 (diff) |
Remove the unfinished che(4) driver for Chelsio 10G cards. I lost interest
fixing this long ago.
Diffstat (limited to 'sys/dev/pci')
-rw-r--r-- | sys/dev/pci/files.pci | 9 | ||||
-rw-r--r-- | sys/dev/pci/if_che.c | 874 |
2 files changed, 1 insertions, 882 deletions
diff --git a/sys/dev/pci/files.pci b/sys/dev/pci/files.pci index 5410a10258d..1cef9349ab4 100644 --- a/sys/dev/pci/files.pci +++ b/sys/dev/pci/files.pci @@ -1,4 +1,4 @@ -# $OpenBSD: files.pci,v 1.318 2015/06/19 11:12:24 jmatthew Exp $ +# $OpenBSD: files.pci,v 1.319 2015/09/11 13:35:15 claudio Exp $ # $NetBSD: files.pci,v 1.20 1996/09/24 17:47:15 christos Exp $ # # Config file and device description for machine-independent PCI code. @@ -381,13 +381,6 @@ device tht: ether, ifnet, ifmedia, firmload attach tht at thtc file dev/pci/if_tht.c thtc | tht -# Chelsio 10Gb Ethernet -device cheg {} -attach cheg at pci -device che: ether, ifnet, ifmedia, firmload -attach che at cheg -file dev/pci/if_che.c cheg | che - # Myricom Myri-10G Ethernet device myx: ether, ifnet, ifmedia attach myx at pci diff --git a/sys/dev/pci/if_che.c b/sys/dev/pci/if_che.c deleted file mode 100644 index c79a145ecf5..00000000000 --- a/sys/dev/pci/if_che.c +++ /dev/null @@ -1,874 +0,0 @@ -/* $OpenBSD: if_che.c,v 1.12 2014/12/28 14:20:37 jsg Exp $ */ - -/* - * Copyright (c) 2007 Claudio Jeker <claudio@openbsd.org> - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -#include "bpfilter.h" - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/sockio.h> -#include <sys/mbuf.h> -#include <sys/kernel.h> -#include <sys/socket.h> -#include <sys/malloc.h> -#include <sys/device.h> - -#include <machine/bus.h> - -#include <dev/pci/pcireg.h> -#include <dev/pci/pcivar.h> -#include <dev/pci/pcidevs.h> - -#include <net/if.h> -#include <net/if_dl.h> -#include <net/if_media.h> -#include <net/if_types.h> - -#if NBPFILTER > 0 -#include <net/bpf.h> -#endif - -#include <netinet/in.h> -#include <netinet/if_ether.h> - -#include <dev/mii/mii.h> -#include <dev/mii/miivar.h> - -/* registers & defines */ - -#define CHE_PCI_BAR 0x10 -#define CHE_PCI_CAP_ID_VPD 0x03 -#define CHE_PCI_VPD_DATA 0x4 -#define CHE_PCI_F_VPD_ADDR 0x80000000 -#define CHE_PCI_VPD_BASE 0xc00 - -#define CHE_REG_T3DBG_GPIO_EN 0xd0 -#define CHE_T3DBG_F_GPIO11_OEN 0x08000000 -#define CHE_T3DBG_F_GPIO10_OEN 0x04000000 -#define CHE_T3DBG_F_GPIO9_OEN 0x02000000 -#define CHE_T3DBG_F_GPIO8_OEN 0x01000000 -#define CHE_T3DBG_F_GPIO7_OEN 0x00800000 -#define CHE_T3DBG_F_GPIO6_OEN 0x00400000 -#define CHE_T3DBG_F_GPIO5_OEN 0x00200000 -#define CHE_T3DBG_F_GPIO4_OEN 0x00100000 -#define CHE_T3DBG_F_GPIO3_OEN 0x00080000 -#define CHE_T3DBG_F_GPIO2_OEN 0x00040000 -#define CHE_T3DBG_F_GPIO1_OEN 0x00020000 -#define CHE_T3DBG_F_GPIO0_OEN 0x00010000 -#define CHE_T3DBG_F_GPIO11_OUT_VAL 0x00000800 -#define CHE_T3DBG_F_GPIO10_OUT_VAL 0x00000400 -#define CHE_T3DBG_F_GPIO9_OUT_VAL 0x00000200 -#define CHE_T3DBG_F_GPIO8_OUT_VAL 0x00000100 -#define CHE_T3DBG_F_GPIO7_OUT_VAL 0x00000080 -#define CHE_T3DBG_F_GPIO6_OUT_VAL 0x00000040 -#define CHE_T3DBG_F_GPIO5_OUT_VAL 0x00000020 -#define CHE_T3DBG_F_GPIO4_OUT_VAL 0x00000010 -#define CHE_T3DBG_F_GPIO3_OUT_VAL 0x00000008 -#define CHE_T3DBG_F_GPIO2_OUT_VAL 0x00000004 -#define CHE_T3DBG_F_GPIO1_OUT_VAL 0x00000002 -#define CHE_T3DBG_F_GPIO0_OUT_VAL 0x00000001 -#define CHE_REG_I2C_CFG 0x6a0 -#define CHE_I2C_CLKDIV(_x) ((_x) & 0xfff) -#define CHE_REG_MI1_CFG 0x6b0 -#define CHE_REG_MI1_ADDR 0x6b4 -#define CHE_REG_MI1_DATA 0x6b8 -#define CHE_REG_MI1_OP 0x6bc -#define CHE_MI1_F_BUSY (1U << 31) -#define CHE_MI1_F_ST 0x8 -#define CHE_MI1_F_PREEN 0x4 -#define CHE_MI1_F_MDIINV 0x2 -#define CHE_MI1_F_MDIEN 0x1 -#define CHE_MI1_CLKDIV(_x) ((_x) << 5) -#define CHE_MI1_PHYADDR(_x) ((_x) << 5) -#define CHE_MI1_OP(_x) ((_x) & 0x3) -#define CHE_REG_PL_RST 0x6f0 -#define CHE_RST_F_CRSTWRM 0x2 -#define CHE_RST_F_CRSTWRMMODE 0x1 -#define CHE_REG_PL_REV 0x6f4 -#define CHE_REG_XGM_PORT_CFG 0x8b8 -#define CHE_XGMAC0_0_BASE_ADDR 0x800 -#define CHE_XGMAC0_1_BASE_ADDR 0xa00 -#define CHE_XGM_REG(_r, _i) \ - ((_r) + (_i) * (CHE_XGMAC0_1_BASE_ADDR - CHE_XGMAC0_0_BASE_ADDR)) -#define CHE_XGM_PORTSPEED(_x) ((_x) << 1) -#define CHE_XGM_F_ENRGMII 0x1 -#define CHE_XGM_F_CLKDIVRESET 0x8 - -/* serial flash and firmware definitions */ -#define CHE_REG_SF_DATA 0x6d8 -#define CHE_REG_SF_OP 0x6dc -#define CHE_SF_SEC_SIZE (64 * 1024) /* serial flash sector size */ -#define CHE_SF_SIZE (8 * CHE_SF_SEC_SIZE) /* serial flash size */ -#define CHE_SF_PROG_PAGE 2 -#define CHE_SF_WR_DISABLE 4 -#define CHE_SF_RD_STATUS 5 /* read status register */ -#define CHE_SF_WR_ENABLE 6 -#define CHE_SF_RD_DATA 11 -#define CHE_SF_SEC_ERASE 216 -#define CHE_SF_F_BUSY (1U << 31) -#define CHE_SF_F_OP 0x1 -#define CHE_SF_CONT(_x) ((_x) << 3) -#define CHE_SF_BYTECNT_MASK 0x3 -#define CHE_SF_BYTECNT(_x) (((_x) & CHE_SF_BYTECNT_MASK) << 1) - -#define FW_FLASH_BOOT_ADDR 0x70000 /* start address of FW in flash */ -#define FW_VERS_ADDR 0x77ffc /* flash address holding FW version */ -#define FW_VERS_TYPE_N3 0 -#define FW_VERS_TYPE_T3 1 -#define FW_VERS_TYPE(_x) (((_x) >> 28) & 0xf) -#define FW_VERS_MAJOR(_x) (((_x) >> 16) & 0xfff) -#define FW_VERS_MINOR(_x) (((_x) >> 8) & 0xff) -#define FW_VERS_MICRO(_x) ((_x) & 0xff) - -/* Partial EEPROM Vital Product Data structure. */ -struct che_vpd { - u_int8_t id_tag; - u_int8_t id_len[2]; - u_int8_t id_data[16]; - u_int8_t vpdr_tag; - u_int8_t vpdr_len[2]; - u_int8_t pn_name[2]; /* part number */ - u_int8_t pn_len; - u_int8_t pn_data[16]; - u_int8_t ec_name[2]; /* EC level */ - u_int8_t ec_len; - u_int8_t ec_data[16]; - u_int8_t sn_name[2]; /* serial number */ - u_int8_t sn_len; - u_int8_t sn_data[16]; - u_int8_t na_name[2]; /* MAC address base */ - u_int8_t na_len; - u_int8_t na_data[12]; - u_int8_t cclk_name[2]; /* core clock */ - u_int8_t cclk_len; - u_int8_t cclk_data[6]; - u_int8_t mclk_name[2]; /* mem clock */ - u_int8_t mclk_len; - u_int8_t mclk_data[6]; - u_int8_t uclk_name[2]; /* uP clock */ - u_int8_t uclk_len; - u_int8_t uclk_data[6]; - u_int8_t mdc_name[2]; /* MDIO clock */ - u_int8_t mdc_len; - u_int8_t mdc_data[6]; - u_int8_t mt_name[2]; /* mem timing */ - u_int8_t mt_len; - u_int8_t mt_data[2]; - u_int8_t xaui0cfg_name[2]; /* XAUI0 config */ - u_int8_t xaui0cfg_len; - u_int8_t xaui0cfg_data[6]; - u_int8_t xaui1cfg_name[2]; /* XAUI1 config */ - u_int8_t xaui1cfg_len; - u_int8_t xaui1cfg_data[6]; - u_int8_t port0_name[2]; /* PHY0 */ - u_int8_t port0_len; - u_int8_t port0_data[2]; - u_int8_t port1_name[2]; /* PHY1 */ - u_int8_t port1_len; - u_int8_t port1_data[2]; - u_int8_t port2_name[2]; /* PHY2 */ - u_int8_t port2_len; - u_int8_t port2_data[2]; - u_int8_t port3_name[2]; /* PHY3 */ - u_int8_t port3_len; - u_int8_t port3_data[2]; - u_int8_t rv_name[2]; /* csum */ - u_int8_t rv_len; - u_int8_t rv_data[1]; - u_int8_t pad[4]; /* for multiple-of-4 sizing */ -} __packed; - - -#define DEVNAME(_sc) ((_sc)->sc_dev.dv_xname) - -/* the pci controller */ - -struct cheg_softc { - struct device sc_dev; - - bus_dma_tag_t sc_dmat; - - bus_space_tag_t sc_memt; - bus_space_handle_t sc_memh; - bus_size_t sc_mems; - - u_int32_t sc_rev; /* card revision */ - u_int32_t sc_cclk; /* core clock */ - u_int32_t sc_mdc; /* mdio clock */ - - pci_vendor_id_t sc_product; -}; - -int cheg_match(struct device *, void *, void *); -void cheg_attach(struct device *, struct device *, void *); -int cheg_print(void *, const char *); - -struct cfattach cheg_ca = { - sizeof(struct cheg_softc), - cheg_match, - cheg_attach -}; - -struct cfdriver cheg_cd = { - NULL, "cheg", DV_DULL -}; - -/* glue between the controller and the port */ - -struct che_attach_args { - struct pci_attach_args *caa_pa; - pci_intr_handle_t caa_ih; - int caa_port; - u_int8_t caa_lladdr[ETHER_ADDR_LEN]; -}; - -/* che itself */ - -struct che_softc { - struct device sc_dev; - struct arpcom sc_ac; - struct mii_data sc_mii; - - struct cheg_softc *sc_cheg; - void *sc_ih; - int sc_port; -}; - -int che_match(struct device *, void *, void *); -void che_attach(struct device *, struct device *, void *); - -struct cfattach che_ca = { - sizeof(struct che_softc), - che_match, - che_attach -}; - -struct cfdriver che_cd = { - NULL, "che", DV_IFNET -}; - -int che_write_flash_reg(struct cheg_softc *, size_t, int, - u_int32_t); -int che_read_flash_reg(struct cheg_softc *, size_t, int, - u_int32_t *); -int che_read_flash_multi4(struct cheg_softc *, u_int, u_int32_t *, - size_t); -int che_read_eeprom(struct cheg_softc *, struct pci_attach_args *, - pcireg_t, pcireg_t *); -int che_get_vpd(struct cheg_softc *, struct pci_attach_args *, - void *, size_t); -void che_conv_lladdr(char *, u_int8_t *); -u_int32_t che_conv_num(char *, size_t); -void che_reset(struct cheg_softc *); -int che_ioctl(struct ifnet *, u_long, caddr_t); -void che_watchdog(struct ifnet *); -void che_start(struct ifnet *); - -/* ifmedia & mii helper functions */ -int che_ifmedia_upd(struct ifnet *); -void che_ifmedia_sts(struct ifnet *, struct ifmediareq *); -int che_miibus_readreg(struct device *, int, int); -void che_miibus_writereg(struct device *, int, int, int); -int che_miibus_ind_readreg(struct device *, int, int); -void che_miibus_ind_writereg(struct device *, int, int, int); -void che_miibus_statchg(struct device *); - -/* bus_space wrappers */ -u_int32_t che_read(struct cheg_softc *, bus_size_t); -void che_write(struct cheg_softc *, bus_size_t, u_int32_t); -int che_waitfor(struct cheg_softc *, bus_size_t, u_int32_t, int); - -/* HW low-level functions */ -void che_hw_init(struct cheg_softc *); - -/* cheg */ -struct cheg_device { - pci_vendor_id_t cd_vendor; - pci_vendor_id_t cd_product; - u_int cd_nports; -}; - -const struct cheg_device *cheg_lookup(struct pci_attach_args *); - -const struct cheg_device che_devices[] = { - { PCI_VENDOR_CHELSIO, PCI_PRODUCT_CHELSIO_PE9000, 2 }, - { PCI_VENDOR_CHELSIO, PCI_PRODUCT_CHELSIO_T302E, 2 }, - { PCI_VENDOR_CHELSIO, PCI_PRODUCT_CHELSIO_T302X, 2 }, - { PCI_VENDOR_CHELSIO, PCI_PRODUCT_CHELSIO_T310E, 1 }, - { PCI_VENDOR_CHELSIO, PCI_PRODUCT_CHELSIO_T310X, 1 }, - { PCI_VENDOR_CHELSIO, PCI_PRODUCT_CHELSIO_T320E, 2 }, - { PCI_VENDOR_CHELSIO, PCI_PRODUCT_CHELSIO_T320X, 2 }, - { PCI_VENDOR_CHELSIO, PCI_PRODUCT_CHELSIO_T3B02, 2 }, - { PCI_VENDOR_CHELSIO, PCI_PRODUCT_CHELSIO_T3B10, 1 }, - { PCI_VENDOR_CHELSIO, PCI_PRODUCT_CHELSIO_T3B20, 2 } -}; - -const struct cheg_device * -cheg_lookup(struct pci_attach_args *pa) -{ - int i; - const struct cheg_device *cd; - - for (i = 0; i < nitems(che_devices); i++) { - cd = &che_devices[i]; - if (cd->cd_vendor == PCI_VENDOR(pa->pa_id) && - cd->cd_product == PCI_PRODUCT(pa->pa_id)) - return (cd); - } - - return (NULL); -} - -int -cheg_match(struct device *parent, void *match, void *aux) -{ - struct pci_attach_args *pa = aux; - - if (cheg_lookup(pa) != NULL) - return (1); - - return (0); -} - -void -cheg_attach(struct device *parent, struct device *self, void *aux) -{ - struct cheg_softc *sc = (struct cheg_softc *)self; - struct pci_attach_args *pa = aux; - const struct cheg_device *cd; - struct che_attach_args caa; - struct che_vpd vpd; - pcireg_t memtype; - u_int32_t vers; - u_int i; - - bzero(&caa, sizeof(caa)); - cd = cheg_lookup(pa); - - sc->sc_dmat = pa->pa_dmat; - - memtype = pci_mapreg_type(pa->pa_pc, pa->pa_tag, CHE_PCI_BAR); - if (pci_mapreg_map(pa, CHE_PCI_BAR, memtype, 0, &sc->sc_memt, - &sc->sc_memh, NULL, &sc->sc_mems, 0) != 0) { - printf(": unable to map host registers\n"); - return; - } - - if (pci_intr_map(pa, &caa.caa_ih) != 0) { - printf(": unable to map interrupt\n"); - goto unmap; - } - - sc->sc_rev = che_read(sc, CHE_REG_PL_REV); - - /* reset the beast */ - che_reset(sc); - - if (che_read_flash_multi4(sc, FW_VERS_ADDR, &vers, 1) != 0) { - printf(": unable to read flash version\n"); - goto unmap; - } - - if (che_get_vpd(sc, pa, &vpd, sizeof(vpd)/sizeof(u_int32_t)) != 0) { - printf(": unable to get vital product data\n"); - goto unmap; - } - - printf(": %s revision %d firmware %s-%d.%d.%d\n", - pci_intr_string(pa->pa_pc, caa.caa_ih), sc->sc_rev, - FW_VERS_TYPE(vers) ? "T" : "N", - FW_VERS_MAJOR(vers), FW_VERS_MINOR(vers), FW_VERS_MICRO(vers)); - - sc->sc_product = PCI_PRODUCT(pa->pa_id); - sc->sc_cclk = che_conv_num(vpd.cclk_data, sizeof(vpd.cclk_data)); - sc->sc_mdc = che_conv_num(vpd.mdc_data, sizeof(vpd.mdc_data)); - - che_hw_init(sc); - - caa.caa_pa = pa; - che_conv_lladdr(vpd.na_data, caa.caa_lladdr); - - for (i = 0; i < cd->cd_nports; i++) { - caa.caa_port = i; - - config_found(self, &caa, cheg_print); - - /* - * The VPD EEPROM stores only the base Ethernet address for the - * card. The last octet is increased by one for every additional - * port. - */ - caa.caa_lladdr[5] += 1; - } - - return; - -unmap: - bus_space_unmap(sc->sc_memt, sc->sc_memh, sc->sc_mems); - sc->sc_mems = 0; -} - -int -cheg_print(void *aux, const char *pnp) -{ - struct che_attach_args *caa = aux; - - if (pnp != NULL) - printf("\"%s\" at %s", che_cd.cd_name, pnp); - - printf(" port %d", caa->caa_port); - - return (UNCONF); -} - -int -che_match(struct device *parent, void *match, void *aux) -{ - return (1); -} - -void -che_attach(struct device *parent, struct device *self, void *aux) -{ - struct cheg_softc *gsc = (struct cheg_softc *)parent; - struct che_softc *sc = (struct che_softc *)self; - struct che_attach_args *caa = aux; - struct ifnet *ifp; - - sc->sc_cheg = gsc; - - sc->sc_port = caa->caa_port; - bcopy(caa->caa_lladdr, sc->sc_ac.ac_enaddr, ETHER_ADDR_LEN); - - printf(": address %s\n", ether_sprintf(sc->sc_ac.ac_enaddr)); - - ifp = &sc->sc_ac.ac_if; - ifp->if_softc = sc; - ifp->if_flags = IFF_BROADCAST | IFF_SIMPLEX | IFF_MULTICAST; - ifp->if_ioctl = che_ioctl; - ifp->if_start = che_start; - ifp->if_watchdog = che_watchdog; - ifp->if_hardmtu = MCLBYTES - ETHER_HDR_LEN - ETHER_CRC_LEN; /* XXX */ - strlcpy(ifp->if_xname, DEVNAME(sc), IFNAMSIZ); - IFQ_SET_MAXLEN(&ifp->if_snd, 400); - IFQ_SET_READY(&ifp->if_snd); - - ifmedia_init(&sc->sc_mii.mii_media, 0, - che_ifmedia_upd, che_ifmedia_sts); - - sc->sc_mii.mii_ifp = ifp; - sc->sc_mii.mii_readreg = che_miibus_ind_readreg; - sc->sc_mii.mii_writereg = che_miibus_ind_writereg; - sc->sc_mii.mii_statchg = che_miibus_statchg; - - mii_attach(self, &sc->sc_mii, 0xffffffff, MII_PHY_ANY, - MII_OFFSET_ANY, MIIF_DOPAUSE | MIIF_HAVEFIBER); - - if (LIST_FIRST(&sc->sc_mii.mii_phys) == NULL) { - printf("%s: no PHY found!\n", sc->sc_dev.dv_xname); - ifmedia_add(&sc->sc_mii.mii_media, IFM_ETHER|IFM_MANUAL, - 0, NULL); - ifmedia_set(&sc->sc_mii.mii_media, IFM_ETHER|IFM_MANUAL); - } else - ifmedia_set(&sc->sc_mii.mii_media, IFM_ETHER|IFM_AUTO); - - if_attach(ifp); - ether_ifattach(ifp); - - return; -} - -int -che_write_flash_reg(struct cheg_softc *sc, size_t bcnt, int cont, u_int32_t v) -{ - if (che_read(sc, CHE_REG_SF_OP) & CHE_SF_F_BUSY) - return (EBUSY); - - che_write(sc, CHE_REG_SF_DATA, v); - che_write(sc, CHE_REG_SF_OP, CHE_SF_CONT(cont) | - CHE_SF_BYTECNT(bcnt - 1) | CHE_SF_F_OP); - - return (che_waitfor(sc, CHE_REG_SF_OP, CHE_SF_F_BUSY, 5)); -} - -int -che_read_flash_reg(struct cheg_softc *sc, size_t bcnt, int cont, u_int32_t *vp) -{ - if (che_read(sc, CHE_REG_SF_OP) & CHE_SF_F_BUSY) - return (EBUSY); - - che_write(sc, CHE_REG_SF_OP, CHE_SF_CONT(cont) | - CHE_SF_BYTECNT(bcnt - 1)); - - if (che_waitfor(sc, CHE_REG_SF_OP, CHE_SF_F_BUSY, 5)) - return (EAGAIN); - - *vp = che_read(sc, CHE_REG_SF_DATA); - return (0); -} - -int -che_read_flash_multi4(struct cheg_softc *sc, u_int addr, u_int32_t *datap, - size_t count) -{ - int rv; - - if (addr + count * sizeof(u_int32_t) > CHE_SF_SIZE || (addr & 3)) - panic("%s: che_read_flash_multi4 bad params", DEVNAME(sc)); - - addr = swap32(addr) | CHE_SF_RD_DATA; - - if ((rv = che_write_flash_reg(sc, 4, 1, addr))) - return (rv); - if ((rv = che_read_flash_reg(sc, 1, 1, datap))) - return (rv); - - while (count) { - if ((rv = che_read_flash_reg(sc, 4, count > 1, datap))) - return (rv); - count--; - datap++; - } - return (0); -} - -int -che_read_eeprom(struct cheg_softc *sc, struct pci_attach_args *pa, - pcireg_t addr, pcireg_t *dp) -{ - pcireg_t rv, base; - int i = 4; - - if (!pci_get_capability(pa->pa_pc, pa->pa_tag, CHE_PCI_CAP_ID_VPD, - &base, NULL)) { - printf("%s: VPD EEPROM not found\n", DEVNAME(sc)); - return EIO; - } - - addr <<= 16; - pci_conf_write(pa->pa_pc, pa->pa_tag, base, addr); - - while(i--) { - delay(10); - rv = pci_conf_read(pa->pa_pc, pa->pa_tag, base); - if (rv & CHE_PCI_F_VPD_ADDR) - break; - } - if (!(rv & CHE_PCI_F_VPD_ADDR)) { - printf("%s: reading EEPROM address 0x%x failed\n", - DEVNAME(sc), addr); - return EIO; - } - - *dp = pci_conf_read(pa->pa_pc, pa->pa_tag, base + CHE_PCI_VPD_DATA); - return (0); -} - -int -che_get_vpd(struct cheg_softc *sc, struct pci_attach_args *pa, - void *vpd, size_t dwords) -{ - pcireg_t dw0, *dw = vpd; - int i; - u_int16_t addr; - - /* - * Card information is normally at CHE_PCI_VPD_BASE but some early - * cards had it at 0. - */ - if (che_read_eeprom(sc, pa, CHE_PCI_VPD_BASE, &dw0)) - return (1); - - /* we compare the id_tag which is least significant byte */ - addr = ((dw0 & 0xff) == 0x82) ? CHE_PCI_VPD_BASE : 0; - - for (i = 0; i < dwords; i++) { - if (che_read_eeprom(sc, pa, addr + i * 4, &dw[i])) - return (1); - } - - return (0); -} - -/* - * VPD mac addr is stored as ASCII string so we need to convert it to a - * sane representation form. - */ -void -che_conv_lladdr(char *mac, u_int8_t *lladdr) -{ - int i; - u_int8_t digit; - - bzero(lladdr, ETHER_ADDR_LEN); - - for (i = 0; i < ETHER_ADDR_LEN * 2; i++) { - if (mac[i] >= '0' && mac[i] <= '9') - digit = mac[i] - '0'; - else if (mac[i] >= 'A' && mac[i] <= 'F') - digit = mac[i] - 'A' + 10; - else if (mac[i] >= 'a' && mac[i] <= 'f') - digit = mac[i] - 'a' + 10; - - if ((i & 1) == 0) - digit <<= 4; - - lladdr[i/2] |= digit; - } -} - -u_int32_t -che_conv_num(char *num, size_t len) -{ - size_t i; - u_int32_t n = 0; - - for (i = 0; i < len; i++) { - if (num[i] >= '0' && num[i] <= '9') - n = 10 * n + (num[i] - '0'); - else - break; - } - return (n); -} - -void -che_reset(struct cheg_softc *sc) -{ - che_write(sc, CHE_REG_PL_RST, CHE_RST_F_CRSTWRM | - CHE_RST_F_CRSTWRMMODE); - - /* Give the card some time to boot */ - delay(500); -} - -int -che_ioctl(struct ifnet *ifp, u_long cmd, caddr_t addr) -{ - return (EIO); -} - -void -che_watchdog(struct ifnet *ifp) -{ - /* XXX */ -} - -void -che_start(struct ifnet *ifp) -{ - /* XXX */ -} - -int -che_ifmedia_upd(struct ifnet *ifp) -{ - struct che_softc *sc = ifp->if_softc; - - mii_mediachg(&sc->sc_mii); - return (0); -} - -void -che_ifmedia_sts(struct ifnet *ifp, struct ifmediareq *ifmr) -{ - struct che_softc *sc = ifp->if_softc; - - mii_pollstat(&sc->sc_mii); - ifmr->ifm_active = sc->sc_mii.mii_media_active; - ifmr->ifm_status = sc->sc_mii.mii_media_status; -} - -int -che_miibus_readreg(struct device *dev, int phy, int reg) -{ - struct che_softc *sc = (struct che_softc *)dev; - u_int32_t addr = CHE_MI1_PHYADDR(phy) | reg; - - che_write(sc->sc_cheg, CHE_REG_MI1_ADDR, addr); - che_write(sc->sc_cheg, CHE_REG_MI1_OP, CHE_MI1_OP(2)); - - if (che_waitfor(sc->sc_cheg, CHE_REG_MI1_OP, CHE_MI1_F_BUSY, 20)) - return (0); - - return ((int)che_read(sc->sc_cheg, CHE_REG_MI1_DATA)); -} - -void -che_miibus_writereg(struct device *dev, int phy, int reg, int val) -{ - struct che_softc *sc = (struct che_softc *)dev; - u_int32_t addr = CHE_MI1_PHYADDR(phy) | reg; - - che_write(sc->sc_cheg, CHE_REG_MI1_ADDR, addr); - che_write(sc->sc_cheg, CHE_REG_MI1_DATA, val); - che_write(sc->sc_cheg, CHE_REG_MI1_OP, CHE_MI1_OP(1)); - che_waitfor(sc->sc_cheg, CHE_REG_MI1_OP, CHE_MI1_F_BUSY, 20); -} - -int -che_miibus_ind_readreg(struct device *dev, int phy, int reg) -{ - struct che_softc *sc = (struct che_softc *)dev; - - che_write(sc->sc_cheg, CHE_REG_MI1_ADDR, CHE_MI1_PHYADDR(phy)); - che_write(sc->sc_cheg, CHE_REG_MI1_DATA, reg); - che_write(sc->sc_cheg, CHE_REG_MI1_OP, CHE_MI1_OP(0)); - - if (che_waitfor(sc->sc_cheg, CHE_REG_MI1_OP, CHE_MI1_F_BUSY, 20)) - return (0); - - che_write(sc->sc_cheg, CHE_REG_MI1_OP, CHE_MI1_OP(3)); - - if (che_waitfor(sc->sc_cheg, CHE_REG_MI1_OP, CHE_MI1_F_BUSY, 20)) - return (0); - - return ((int)che_read(sc->sc_cheg, CHE_REG_MI1_DATA)); -} - -void -che_miibus_ind_writereg(struct device *dev, int phy, int reg, int val) -{ - struct che_softc *sc = (struct che_softc *)dev; - - che_write(sc->sc_cheg, CHE_REG_MI1_ADDR, CHE_MI1_PHYADDR(phy)); - che_write(sc->sc_cheg, CHE_REG_MI1_DATA, reg); - che_write(sc->sc_cheg, CHE_REG_MI1_OP, CHE_MI1_OP(0)); - - if (che_waitfor(sc->sc_cheg, CHE_REG_MI1_OP, CHE_MI1_F_BUSY, 20)) - return; - - che_write(sc->sc_cheg, CHE_REG_MI1_DATA, val); - che_write(sc->sc_cheg, CHE_REG_MI1_OP, CHE_MI1_OP(1)); - - che_waitfor(sc->sc_cheg, CHE_REG_MI1_OP, CHE_MI1_F_BUSY, 20); -} - -void -che_miibus_statchg(struct device *dev) -{ - struct che_softc *sc = (struct che_softc *)dev; - //struct mii_data *mii = &sc->sc_mii; - - printf("%s: che_miibus_statchg\n", DEVNAME(sc)); -} - -u_int32_t -che_read(struct cheg_softc *sc, bus_size_t r) -{ - bus_space_barrier(sc->sc_memt, sc->sc_memh, r, 4, - BUS_SPACE_BARRIER_READ); - return (bus_space_read_4(sc->sc_memt, sc->sc_memh, r)); -} - -void -che_write(struct cheg_softc *sc, bus_size_t r, u_int32_t v) -{ - bus_space_write_4(sc->sc_memt, sc->sc_memh, r, v); - bus_space_barrier(sc->sc_memt, sc->sc_memh, r, 4, - BUS_SPACE_BARRIER_WRITE); -} - -int -che_waitfor(struct cheg_softc *sc, bus_size_t r, u_int32_t mask, int tries) -{ - u_int32_t v; - int i; - - for (i = 0; i < tries; i++) { - v = che_read(sc, r); - if ((v & mask) == 0) - return (0); - delay(10); - } - return (EAGAIN); -} - -void -che_hw_init(struct cheg_softc *sc) -{ - u_int32_t mi1_reg; - u_int32_t i2c_reg; - u_int32_t gpio_reg; - u_int32_t port_reg; - - mi1_reg = CHE_MI1_F_PREEN | - CHE_MI1_CLKDIV(sc->sc_cclk / (2 * sc->sc_mdc) - 1); - - i2c_reg = CHE_I2C_CLKDIV(sc->sc_cclk / 80 - 1); /* 80KHz */ - - gpio_reg = CHE_T3DBG_F_GPIO0_OEN | CHE_T3DBG_F_GPIO0_OUT_VAL; - - switch (sc->sc_product) { - case PCI_PRODUCT_CHELSIO_PE9000: - gpio_reg |= CHE_T3DBG_F_GPIO2_OEN | CHE_T3DBG_F_GPIO2_OUT_VAL | - CHE_T3DBG_F_GPIO4_OEN | CHE_T3DBG_F_GPIO4_OUT_VAL; - port_reg = CHE_XGM_PORTSPEED(2); - break; - case PCI_PRODUCT_CHELSIO_T302E: - case PCI_PRODUCT_CHELSIO_T302X: - case PCI_PRODUCT_CHELSIO_T3B02: - gpio_reg |= CHE_T3DBG_F_GPIO2_OEN | CHE_T3DBG_F_GPIO2_OUT_VAL | - CHE_T3DBG_F_GPIO4_OEN | CHE_T3DBG_F_GPIO4_OUT_VAL; - port_reg = CHE_XGM_PORTSPEED(2); - break; - case PCI_PRODUCT_CHELSIO_T310E: - case PCI_PRODUCT_CHELSIO_T310X: - case PCI_PRODUCT_CHELSIO_T3B10: - mi1_reg |= CHE_MI1_F_ST; - gpio_reg |= CHE_T3DBG_F_GPIO1_OEN | CHE_T3DBG_F_GPIO1_OUT_VAL | - CHE_T3DBG_F_GPIO6_OEN | CHE_T3DBG_F_GPIO6_OUT_VAL | - CHE_T3DBG_F_GPIO7_OEN | - CHE_T3DBG_F_GPIO10_OEN | CHE_T3DBG_F_GPIO10_OUT_VAL; - port_reg = CHE_XGM_PORTSPEED(3); - port_reg |= CHE_XGM_F_ENRGMII; - break; - case PCI_PRODUCT_CHELSIO_T320X: - case PCI_PRODUCT_CHELSIO_T320E: - case PCI_PRODUCT_CHELSIO_T3B20: - mi1_reg |= CHE_MI1_F_ST; - gpio_reg |= CHE_T3DBG_F_GPIO1_OEN | CHE_T3DBG_F_GPIO1_OUT_VAL | - CHE_T3DBG_F_GPIO2_OEN | - CHE_T3DBG_F_GPIO4_OEN | - CHE_T3DBG_F_GPIO5_OEN | CHE_T3DBG_F_GPIO5_OUT_VAL | - CHE_T3DBG_F_GPIO6_OEN | CHE_T3DBG_F_GPIO6_OUT_VAL | - CHE_T3DBG_F_GPIO7_OEN | - CHE_T3DBG_F_GPIO10_OEN | CHE_T3DBG_F_GPIO10_OUT_VAL | - CHE_T3DBG_F_GPIO11_OEN; - port_reg = CHE_XGM_PORTSPEED(3); - port_reg |= CHE_XGM_F_ENRGMII; - break; - } - - if (sc->sc_rev == 0) - port_reg |= CHE_XGM_F_ENRGMII; - - /* write all registers */ - che_write(sc, CHE_REG_MI1_CFG, mi1_reg); - che_write(sc, CHE_REG_I2C_CFG, i2c_reg); - che_write(sc, CHE_REG_T3DBG_GPIO_EN, gpio_reg); - - che_write(sc, CHE_REG_XGM_PORT_CFG, port_reg); - (void)che_read(sc, CHE_REG_XGM_PORT_CFG); - - port_reg |= CHE_XGM_F_CLKDIVRESET; - - che_write(sc, CHE_REG_XGM_PORT_CFG, port_reg); - (void)che_read(sc, CHE_REG_XGM_PORT_CFG); - che_write(sc, CHE_XGM_REG(CHE_REG_XGM_PORT_CFG, 1), port_reg); - (void)che_read(sc, CHE_REG_XGM_PORT_CFG); -} |