diff options
author | Brad Smith <brad@cvs.openbsd.org> | 2005-07-03 02:04:16 +0000 |
---|---|---|
committer | Brad Smith <brad@cvs.openbsd.org> | 2005-07-03 02:04:16 +0000 |
commit | cb65c0cabdd2e67e1ec15ed3dc6355cdd72e6c13 (patch) | |
tree | 3e330bf402c498b3cec0d2ec63aed8acd7e4ac60 /sys | |
parent | f16442fd58c46fe957b9e0e09e37635123c668c8 (diff) |
- when printing the "unsupported chip revision" message also print the
chip revision.
- allow VLAN-sized frames even when not using hardware VLAN support. From FreeBSD
- disestablish PCI interrupt on failure to attach.
- allow reception of Jumbo frames by default. Based on a diff sent to me a long time
ago by mcbride@
Diffstat (limited to 'sys')
-rw-r--r-- | sys/dev/pci/if_ti.c | 37 | ||||
-rw-r--r-- | sys/dev/pci/if_tireg.h | 9 |
2 files changed, 28 insertions, 18 deletions
diff --git a/sys/dev/pci/if_ti.c b/sys/dev/pci/if_ti.c index f9aa332e281..d7155aa34a3 100644 --- a/sys/dev/pci/if_ti.c +++ b/sys/dev/pci/if_ti.c @@ -1,4 +1,4 @@ -/* $OpenBSD: if_ti.c,v 1.61 2005/07/02 23:10:11 brad Exp $ */ +/* $OpenBSD: if_ti.c,v 1.62 2005/07/03 02:04:15 brad Exp $ */ /* * Copyright (c) 1997, 1998, 1999 @@ -1242,6 +1242,7 @@ int ti_chipinit(sc) { u_int32_t cacheline; u_int32_t pci_writemax = 0; + u_int32_t chip_rev; /* Initialize link to down state. */ sc->ti_linkstat = TI_EV_CODE_LINK_DOWN; @@ -1266,7 +1267,8 @@ int ti_chipinit(sc) TI_SETBIT(sc, TI_CPU_STATE, TI_CPUSTATE_HALT); /* Figure out the hardware revision. */ - switch(CSR_READ_4(sc, TI_MISC_HOST_CTL) & TI_MHC_CHIP_REV_MASK) { + chip_rev = CSR_READ_4(sc, TI_MISC_HOST_CTL) & TI_MHC_CHIP_REV_MASK; + switch(chip_rev) { case TI_REV_TIGON_I: sc->ti_hwrev = TI_HWREV_TIGON; break; @@ -1274,14 +1276,16 @@ int ti_chipinit(sc) sc->ti_hwrev = TI_HWREV_TIGON_II; break; default: - printf("%s: unsupported chip revision\n", sc->sc_dv.dv_xname); + printf("\n"); + printf("%s: unsupported chip revision: %x\n", + chip_rev, sc->sc_dv.dv_xname); return(ENODEV); } /* Do special setup for Tigon 2. */ if (sc->ti_hwrev == TI_HWREV_TIGON_II) { TI_SETBIT(sc, TI_CPU_CTL_B, TI_CPUSTATE_HALT); - TI_SETBIT(sc, TI_MISC_LOCAL_CTL, TI_MLC_SRAM_BANK_256K); + TI_SETBIT(sc, TI_MISC_LOCAL_CTL, TI_MLC_SRAM_BANK_512K); TI_SETBIT(sc, TI_MISC_CONF, TI_MCR_SRAM_SYNCHRONOUS); } @@ -1730,14 +1734,16 @@ ti_attach(parent, self, aux) ifp->if_ioctl = ti_ioctl; ifp->if_start = ti_start; ifp->if_watchdog = ti_watchdog; -#if NVLAN >0 - ifp->if_capabilities |= IFCAP_VLAN_MTU | IFCAP_VLAN_HWTAGGING; -#endif - IFQ_SET_MAXLEN(&ifp->if_snd, TI_TX_RING_CNT - 1); IFQ_SET_READY(&ifp->if_snd); bcopy(sc->sc_dv.dv_xname, ifp->if_xname, IFNAMSIZ); + ifp->if_capabilities = IFCAP_VLAN_MTU; + +#if NVLAN > 0 + ifp->if_capabilities |= IFCAP_VLAN_HWTAGGING; +#endif + /* Set up ifmedia support. */ ifmedia_init(&sc->ifmedia, IFM_IMASK, ti_ifmedia_upd, ti_ifmedia_sts); if (sc->ti_copper) { @@ -1776,6 +1782,9 @@ ti_attach(parent, self, aux) shutdownhook_establish(ti_shutdown, sc); fail: + if (sc->ti_intrhand != NULL) + pci_intr_disestablish(pc, sc->ti_intrhand); + splx(s); return; @@ -2362,8 +2371,7 @@ void ti_init2(sc) /* Specify MTU and interface index. */ CSR_WRITE_4(sc, TI_GCR_IFINDEX, sc->sc_dv.dv_unit); - CSR_WRITE_4(sc, TI_GCR_IFMTU, ifp->if_mtu + - ETHER_HDR_LEN + ETHER_CRC_LEN); + CSR_WRITE_4(sc, TI_GCR_IFMTU, ETHERMTU_JUMBO + ETHER_VLAN_ENCAP_LEN); TI_DO_CMD(TI_CMD_UPDATE_GENCOM, 0, 0); /* Load our MAC address. */ @@ -2395,8 +2403,7 @@ void ti_init2(sc) panic("not enough mbufs for rx ring"); /* Init jumbo RX ring. */ - if (ifp->if_mtu > ETHER_MAX_LEN) - ti_init_rx_ring_jumbo(sc); + ti_init_rx_ring_jumbo(sc); /* * If this is a Tigon 2, we can also configure the @@ -2584,12 +2591,10 @@ int ti_ioctl(ifp, command, data) } break; case SIOCSIFMTU: - if (ifr->ifr_mtu < ETHERMIN || ifr->ifr_mtu > ETHERMTU_JUMBO) { + if (ifr->ifr_mtu < ETHERMIN || ifr->ifr_mtu > ETHERMTU_JUMBO) error = EINVAL; - } else { + else if (ifp->if_mtu != ifr->ifr_mtu) ifp->if_mtu = ifr->ifr_mtu; - ti_init(sc); - } break; case SIOCSIFFLAGS: if (ifp->if_flags & IFF_UP) { diff --git a/sys/dev/pci/if_tireg.h b/sys/dev/pci/if_tireg.h index 876e357c126..ab8d38226be 100644 --- a/sys/dev/pci/if_tireg.h +++ b/sys/dev/pci/if_tireg.h @@ -1,4 +1,4 @@ -/* $OpenBSD: if_tireg.h,v 1.17 2005/05/27 00:15:21 pvalchev Exp $ */ +/* $OpenBSD: if_tireg.h,v 1.18 2005/07/03 02:04:15 brad Exp $ */ /* * Copyright (c) 1997, 1998, 1999 @@ -108,7 +108,6 @@ * Miscelaneous Local Control register. */ #define TI_MLC_EE_WRITE_ENB 0x00000010 -#define TI_MLC_SRAM_BANK_256K 0x00000200 #define TI_MLC_SRAM_BANK_SIZE 0x00000300 /* Tigon 2 only */ #define TI_MLC_LOCALADDR_21 0x00004000 #define TI_MLC_LOCALADDR_22 0x00008000 @@ -118,6 +117,12 @@ #define TI_MLC_EE_DOUT 0x00400000 #define TI_MLC_EE_DIN 0x00800000 +/* Possible memory sizes. */ +#define TI_MLC_SRAM_BANK_DISA 0x00000000 +#define TI_MLC_SRAM_BANK_1024K 0x00000100 +#define TI_MLC_SRAM_BANK_512K 0x00000200 +#define TI_MLC_SRAM_BANK_256K 0x00000300 + /* * Offset of MAC address inside EEPROM. */ |