summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/dev/pci/if_ti.c499
1 files changed, 211 insertions, 288 deletions
diff --git a/sys/dev/pci/if_ti.c b/sys/dev/pci/if_ti.c
index 3e364596fbd..7ba1866fb02 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.71 2005/07/30 04:25:00 brad Exp $ */
+/* $OpenBSD: if_ti.c,v 1.72 2005/10/09 05:38:00 brad Exp $ */
/*
* Copyright (c) 1997, 1998, 1999
@@ -123,15 +123,17 @@
#include <dev/pci/if_tireg.h>
#include <dev/pci/if_tivar.h>
-#ifdef M_HWCKSUM
-/*#define TI_CSUM_OFFLOAD*/
-#endif
-
-#define bootverbose 1
-
int ti_probe(struct device *, void *, void *);
void ti_attach(struct device *, struct device *, void *);
+struct cfattach ti_ca = {
+ sizeof(struct ti_softc), ti_probe, ti_attach
+};
+
+struct cfdriver ti_cd = {
+ 0, "ti", DV_IFNET
+};
+
void ti_txeof_tigon1(struct ti_softc *);
void ti_txeof_tigon2(struct ti_softc *);
void ti_rxeof(struct ti_softc *);
@@ -186,12 +188,21 @@ int ti_64bitslot_war(struct ti_softc *);
int ti_chipinit(struct ti_softc *);
int ti_gibinit(struct ti_softc *);
+const struct pci_matchid ti_devices[] = {
+ { PCI_VENDOR_NETGEAR, PCI_PRODUCT_NETGEAR_GA620 },
+ { PCI_VENDOR_NETGEAR, PCI_PRODUCT_NETGEAR_GA620T },
+ { PCI_VENDOR_ALTEON, PCI_PRODUCT_ALTEON_ACENIC },
+ { PCI_VENDOR_ALTEON, PCI_PRODUCT_ALTEON_ACENICT },
+ { PCI_VENDOR_3COM, PCI_PRODUCT_3COM_3C985 },
+ { PCI_VENDOR_SGI, PCI_PRODUCT_SGI_TIGON },
+ { PCI_VENDOR_DEC, PCI_PRODUCT_DEC_PN9000SX },
+};
+
/*
* Send an instruction or address to the EEPROM, check for ACK.
*/
-u_int32_t ti_eeprom_putbyte(sc, byte)
- struct ti_softc *sc;
- int byte;
+u_int32_t
+ti_eeprom_putbyte(struct ti_softc *sc, int byte)
{
int i, ack = 0;
@@ -227,7 +238,7 @@ u_int32_t ti_eeprom_putbyte(sc, byte)
ack = CSR_READ_4(sc, TI_MISC_LOCAL_CTL) & TI_MLC_EE_DIN;
TI_CLRBIT(sc, TI_MISC_LOCAL_CTL, TI_MLC_EE_CLK);
- return(ack);
+ return (ack);
}
/*
@@ -235,10 +246,8 @@ u_int32_t ti_eeprom_putbyte(sc, byte)
* We have to send two address bytes since the EEPROM can hold
* more than 256 bytes of data.
*/
-u_int8_t ti_eeprom_getbyte(sc, addr, dest)
- struct ti_softc *sc;
- int addr;
- u_int8_t *dest;
+u_int8_t
+ti_eeprom_getbyte(struct ti_softc *sc, int addr, u_int8_t *dest)
{
int i;
u_int8_t byte = 0;
@@ -251,7 +260,7 @@ u_int8_t ti_eeprom_getbyte(sc, addr, dest)
if (ti_eeprom_putbyte(sc, EEPROM_CTL_WRITE)) {
printf("%s: failed to send write command, status: %x\n",
sc->sc_dv.dv_xname, CSR_READ_4(sc, TI_MISC_LOCAL_CTL));
- return(1);
+ return (1);
}
/*
@@ -260,7 +269,7 @@ u_int8_t ti_eeprom_getbyte(sc, addr, dest)
if (ti_eeprom_putbyte(sc, (addr >> 8) & 0xFF)) {
printf("%s: failed to send address, status: %x\n",
sc->sc_dv.dv_xname, CSR_READ_4(sc, TI_MISC_LOCAL_CTL));
- return(1);
+ return (1);
}
/*
* Send second byte address of byte we want to read.
@@ -268,7 +277,7 @@ u_int8_t ti_eeprom_getbyte(sc, addr, dest)
if (ti_eeprom_putbyte(sc, addr & 0xFF)) {
printf("%s: failed to send address, status: %x\n",
sc->sc_dv.dv_xname, CSR_READ_4(sc, TI_MISC_LOCAL_CTL));
- return(1);
+ return (1);
}
EEPROM_STOP;
@@ -279,7 +288,7 @@ u_int8_t ti_eeprom_getbyte(sc, addr, dest)
if (ti_eeprom_putbyte(sc, EEPROM_CTL_READ)) {
printf("%s: failed to send read command, status: %x\n",
sc->sc_dv.dv_xname, CSR_READ_4(sc, TI_MISC_LOCAL_CTL));
- return(1);
+ return (1);
}
/*
@@ -303,17 +312,14 @@ u_int8_t ti_eeprom_getbyte(sc, addr, dest)
*dest = byte;
- return(0);
+ return (0);
}
/*
* Read a sequence of bytes from the EEPROM.
*/
-int ti_read_eeprom(sc, dest, off, cnt)
- struct ti_softc *sc;
- caddr_t dest;
- int off;
- int cnt;
+int
+ti_read_eeprom(struct ti_softc *sc, caddr_t dest, int off, int cnt)
{
int err = 0, i;
u_int8_t byte = 0;
@@ -325,17 +331,15 @@ int ti_read_eeprom(sc, dest, off, cnt)
*(dest + i) = byte;
}
- return(err ? 1 : 0);
+ return (err ? 1 : 0);
}
/*
* NIC memory read function.
* Can be used to copy data from NIC local memory.
*/
-void ti_mem_read(sc, addr, len, buf)
- struct ti_softc *sc;
- u_int32_t addr, len;
- void *buf;
+void
+ti_mem_read(struct ti_softc *sc, u_int32_t addr, u_int32_t len, void *buf)
{
int segptr, segsize, cnt;
caddr_t ptr;
@@ -363,10 +367,9 @@ void ti_mem_read(sc, addr, len, buf)
* NIC memory write function.
* Can be used to copy data into NIC local memory.
*/
-void ti_mem_write(sc, addr, len, buf)
- struct ti_softc *sc;
- u_int32_t addr, len;
- const void *buf;
+void
+ti_mem_write(struct ti_softc *sc, u_int32_t addr, u_int32_t len,
+ const void *buf)
{
int segptr, segsize, cnt;
const char *ptr;
@@ -394,9 +397,8 @@ void ti_mem_write(sc, addr, len, buf)
* NIC memory write function.
* Can be used to clear a section of NIC local memory.
*/
-void ti_mem_set(sc, addr, len)
- struct ti_softc *sc;
- u_int32_t addr, len;
+void
+ti_mem_set(struct ti_softc *sc, u_int32_t addr, u_int32_t len)
{
int segptr, segsize, cnt;
@@ -421,8 +423,8 @@ void ti_mem_set(sc, addr, len)
* is acceptable and see if we want the firmware for the Tigon 1 or
* Tigon 2.
*/
-void ti_loadfw(sc)
- struct ti_softc *sc;
+void
+ti_loadfw(struct ti_softc *sc)
{
struct tigon_firmware *tf;
u_char *buf = NULL;
@@ -473,9 +475,8 @@ void ti_loadfw(sc)
/*
* Send the NIC a command via the command ring.
*/
-void ti_cmd(sc, cmd)
- struct ti_softc *sc;
- struct ti_cmd_desc *cmd;
+void
+ti_cmd(struct ti_softc *sc, struct ti_cmd_desc *cmd)
{
u_int32_t index;
@@ -484,19 +485,15 @@ void ti_cmd(sc, cmd)
TI_INC(index, TI_CMD_RING_CNT);
CSR_WRITE_4(sc, TI_MB_CMDPROD_IDX, index);
sc->ti_cmd_saved_prodidx = index;
-
- return;
}
/*
* Send the NIC an extended command. The 'len' parameter specifies the
* number of command slots to include after the initial command.
*/
-void ti_cmd_ext(sc, cmd, arg, len)
- struct ti_softc *sc;
- struct ti_cmd_desc *cmd;
- caddr_t arg;
- int len;
+void
+ti_cmd_ext(struct ti_softc *sc, struct ti_cmd_desc *cmd, caddr_t arg,
+ int len)
{
u_int32_t index;
int i;
@@ -511,15 +508,13 @@ void ti_cmd_ext(sc, cmd, arg, len)
}
CSR_WRITE_4(sc, TI_MB_CMDPROD_IDX, index);
sc->ti_cmd_saved_prodidx = index;
-
- return;
}
/*
* Handle events that have triggered interrupts.
*/
-void ti_handle_events(sc)
- struct ti_softc *sc;
+void
+ti_handle_events(struct ti_softc *sc)
{
struct ti_event_desc *e;
@@ -562,8 +557,6 @@ void ti_handle_events(sc)
TI_INC(sc->ti_ev_saved_considx, TI_EVENT_RING_CNT);
CSR_WRITE_4(sc, TI_GCR_EVENTCONS_IDX, sc->ti_ev_saved_considx);
}
-
- return;
}
/*
@@ -589,8 +582,8 @@ void ti_handle_events(sc)
* be tuned by changing a #define in if_tireg.h.
*/
-int ti_alloc_jumbo_mem(sc)
- struct ti_softc *sc;
+int
+ti_alloc_jumbo_mem(struct ti_softc *sc)
{
caddr_t ptr, kva;
bus_dma_segment_t seg;
@@ -676,15 +669,15 @@ out:
break;
}
}
-
+
return (error);
}
/*
* Allocate a jumbo buffer.
*/
-void *ti_jalloc(sc)
- struct ti_softc *sc;
+void *
+ti_jalloc(struct ti_softc *sc)
{
struct ti_jpool_entry *entry;
@@ -696,17 +689,14 @@ void *ti_jalloc(sc)
SLIST_REMOVE_HEAD(&sc->ti_jfree_listhead, jpool_entries);
SLIST_INSERT_HEAD(&sc->ti_jinuse_listhead, entry, jpool_entries);
sc->ti_cdata.ti_jslots[entry->slot].ti_inuse = 1;
- return(sc->ti_cdata.ti_jslots[entry->slot].ti_buf);
+ return (sc->ti_cdata.ti_jslots[entry->slot].ti_buf);
}
/*
* Release a jumbo buffer.
*/
void
-ti_jfree(buf, size, arg)
- caddr_t buf;
- u_int size;
- void *arg;
+ti_jfree(caddr_t buf, u_int size, void *arg)
{
struct ti_softc *sc;
int i;
@@ -741,11 +731,9 @@ ti_jfree(buf, size, arg)
/*
* Intialize a standard receive ring descriptor.
*/
-int ti_newbuf_std(sc, i, m, dmamap)
- struct ti_softc *sc;
- int i;
- struct mbuf *m;
- bus_dmamap_t dmamap;
+int
+ti_newbuf_std(struct ti_softc *sc, int i, struct mbuf *m,
+ bus_dmamap_t dmamap)
{
struct mbuf *m_new = NULL;
struct ti_rx_desc *r;
@@ -757,7 +745,7 @@ int ti_newbuf_std(sc, i, m, dmamap)
0, BUS_DMA_NOWAIT, &dmamap)) {
printf("%s: can't create recv map\n",
sc->sc_dv.dv_xname);
- return(ENOMEM);
+ return (ENOMEM);
}
} else if (m == NULL)
bus_dmamap_unload(sc->sc_dmatag, dmamap);
@@ -767,12 +755,12 @@ int ti_newbuf_std(sc, i, m, dmamap)
if (m == NULL) {
MGETHDR(m_new, M_DONTWAIT, MT_DATA);
if (m_new == NULL)
- return(ENOBUFS);
+ return (ENOBUFS);
MCLGET(m_new, M_DONTWAIT);
if (!(m_new->m_flags & M_EXT)) {
m_freem(m_new);
- return(ENOBUFS);
+ return (ENOBUFS);
}
m_new->m_len = m_new->m_pkthdr.len = MCLBYTES;
@@ -780,9 +768,14 @@ int ti_newbuf_std(sc, i, m, dmamap)
if (bus_dmamap_load_mbuf(sc->sc_dmatag, dmamap, m_new,
BUS_DMA_NOWAIT))
- return(ENOBUFS);
+ return (ENOBUFS);
} else {
+ /*
+ * We're re-using a previously allocated mbuf;
+ * be sure to re-init pointers and lengths to
+ * default values.
+ */
m_new = m;
m_new->m_len = m_new->m_pkthdr.len = MCLBYTES;
m_new->m_data = m_new->m_ext.ext_buf;
@@ -800,20 +793,18 @@ int ti_newbuf_std(sc, i, m, dmamap)
if ((dmamap->dm_segs[0].ds_addr & ~(MCLBYTES - 1)) !=
((dmamap->dm_segs[0].ds_addr + dmamap->dm_segs[0].ds_len - 1) &
~(MCLBYTES - 1)))
- panic("overwritten!!!");
+ panic("%s: overwritten!!!", sc->sc_dv.dv_xname);
- return(0);
+ return (0);
}
/*
* Intialize a mini receive ring descriptor. This only applies to
* the Tigon 2.
*/
-int ti_newbuf_mini(sc, i, m, dmamap)
- struct ti_softc *sc;
- int i;
- struct mbuf *m;
- bus_dmamap_t dmamap;
+int
+ti_newbuf_mini(struct ti_softc *sc, int i, struct mbuf *m,
+ bus_dmamap_t dmamap)
{
struct mbuf *m_new = NULL;
struct ti_rx_desc *r;
@@ -825,7 +816,7 @@ int ti_newbuf_mini(sc, i, m, dmamap)
0, BUS_DMA_NOWAIT, &dmamap)) {
printf("%s: can't create recv map\n",
sc->sc_dv.dv_xname);
- return(ENOMEM);
+ return (ENOMEM);
}
} else if (m == NULL)
bus_dmamap_unload(sc->sc_dmatag, dmamap);
@@ -835,15 +826,20 @@ int ti_newbuf_mini(sc, i, m, dmamap)
if (m == NULL) {
MGETHDR(m_new, M_DONTWAIT, MT_DATA);
if (m_new == NULL)
- return(ENOBUFS);
+ return (ENOBUFS);
m_new->m_len = m_new->m_pkthdr.len = MHLEN;
m_adj(m_new, ETHER_ALIGN);
if (bus_dmamap_load_mbuf(sc->sc_dmatag, dmamap, m_new,
BUS_DMA_NOWAIT))
- return(ENOBUFS);
+ return (ENOBUFS);
} else {
+ /*
+ * We're re-using a previously allocated mbuf;
+ * be sure to re-init pointers and lengths to
+ * default values.
+ */
m_new = m;
m_new->m_data = m_new->m_pktdat;
m_new->m_len = m_new->m_pkthdr.len = MHLEN;
@@ -857,17 +853,15 @@ int ti_newbuf_mini(sc, i, m, dmamap)
r->ti_len = dmamap->dm_segs[0].ds_len;
r->ti_idx = i;
- return(0);
+ return (0);
}
/*
* Initialize a jumbo receive ring descriptor. This allocates
* a jumbo buffer from the pool managed internally by the driver.
*/
-int ti_newbuf_jumbo(sc, i, m)
- struct ti_softc *sc;
- int i;
- struct mbuf *m;
+int
+ti_newbuf_jumbo(struct ti_softc *sc, int i, struct mbuf *m)
{
struct mbuf *m_new = NULL;
struct ti_rx_desc *r;
@@ -878,19 +872,24 @@ int ti_newbuf_jumbo(sc, i, m)
/* Allocate the mbuf. */
MGETHDR(m_new, M_DONTWAIT, MT_DATA);
if (m_new == NULL)
- return(ENOBUFS);
+ return (ENOBUFS);
/* Allocate the jumbo buffer */
buf = ti_jalloc(sc);
if (buf == NULL) {
m_freem(m_new);
- return(ENOBUFS);
+ return (ENOBUFS);
}
/* Attach the buffer to the mbuf. */
m_new->m_len = m_new->m_pkthdr.len = ETHER_MAX_LEN_JUMBO;
MEXTADD(m_new, buf, ETHER_MAX_LEN_JUMBO, 0, ti_jfree, sc);
} else {
+ /*
+ * We're re-using a previously allocated mbuf;
+ * be sure to re-init pointers and lengths to
+ * default values.
+ */
m_new = m;
m_new->m_data = m_new->m_ext.ext_buf;
m_new->m_ext.ext_size = ETHER_MAX_LEN_JUMBO;
@@ -906,7 +905,7 @@ int ti_newbuf_jumbo(sc, i, m)
r->ti_len = m_new->m_len;
r->ti_idx = i;
- return(0);
+ return (0);
}
/*
@@ -915,25 +914,25 @@ int ti_newbuf_jumbo(sc, i, m)
* 256 ring entries and hope that our CPU is fast enough to keep up with
* the NIC.
*/
-int ti_init_rx_ring_std(sc)
- struct ti_softc *sc;
+int
+ti_init_rx_ring_std(struct ti_softc *sc)
{
int i;
struct ti_cmd_desc cmd;
for (i = 0; i < TI_SSLOTS; i++) {
if (ti_newbuf_std(sc, i, NULL, 0) == ENOBUFS)
- return(ENOBUFS);
+ return (ENOBUFS);
}
TI_UPDATE_STDPROD(sc, i - 1);
sc->ti_std = i - 1;
- return(0);
+ return (0);
}
-void ti_free_rx_ring_std(sc)
- struct ti_softc *sc;
+void
+ti_free_rx_ring_std(struct ti_softc *sc)
{
int i;
@@ -948,29 +947,27 @@ void ti_free_rx_ring_std(sc)
bzero((char *)&sc->ti_rdata->ti_rx_std_ring[i],
sizeof(struct ti_rx_desc));
}
-
- return;
}
-int ti_init_rx_ring_jumbo(sc)
- struct ti_softc *sc;
+int
+ti_init_rx_ring_jumbo(struct ti_softc *sc)
{
int i;
struct ti_cmd_desc cmd;
for (i = 0; i < TI_JUMBO_RX_RING_CNT; i++) {
if (ti_newbuf_jumbo(sc, i, NULL) == ENOBUFS)
- return(ENOBUFS);
+ return (ENOBUFS);
};
TI_UPDATE_JUMBOPROD(sc, i - 1);
sc->ti_jumbo = i - 1;
- return(0);
+ return (0);
}
-void ti_free_rx_ring_jumbo(sc)
- struct ti_softc *sc;
+void
+ti_free_rx_ring_jumbo(struct ti_softc *sc)
{
int i;
@@ -982,28 +979,26 @@ void ti_free_rx_ring_jumbo(sc)
bzero((char *)&sc->ti_rdata->ti_rx_jumbo_ring[i],
sizeof(struct ti_rx_desc));
}
-
- return;
}
-int ti_init_rx_ring_mini(sc)
- struct ti_softc *sc;
+int
+ti_init_rx_ring_mini(struct ti_softc *sc)
{
int i;
for (i = 0; i < TI_MSLOTS; i++) {
if (ti_newbuf_mini(sc, i, NULL, 0) == ENOBUFS)
- return(ENOBUFS);
+ return (ENOBUFS);
};
TI_UPDATE_MINIPROD(sc, i - 1);
sc->ti_mini = i - 1;
- return(0);
+ return (0);
}
-void ti_free_rx_ring_mini(sc)
- struct ti_softc *sc;
+void
+ti_free_rx_ring_mini(struct ti_softc *sc)
{
int i;
@@ -1018,12 +1013,10 @@ void ti_free_rx_ring_mini(sc)
bzero((char *)&sc->ti_rdata->ti_rx_mini_ring[i],
sizeof(struct ti_rx_desc));
}
-
- return;
}
-void ti_free_tx_ring(sc)
- struct ti_softc *sc;
+void
+ti_free_tx_ring(struct ti_softc *sc)
{
int i;
struct ti_txmap_entry *entry;
@@ -1048,12 +1041,10 @@ void ti_free_tx_ring(sc)
bus_dmamap_destroy(sc->sc_dmatag, entry->dmamap);
free(entry, M_DEVBUF);
}
-
- return;
}
-int ti_init_tx_ring(sc)
- struct ti_softc *sc;
+int
+ti_init_tx_ring(struct ti_softc *sc)
{
int i;
bus_dmamap_t dmamap;
@@ -1066,8 +1057,8 @@ int ti_init_tx_ring(sc)
SLIST_INIT(&sc->ti_tx_map_listhead);
for (i = 0; i < TI_TX_RING_CNT; i++) {
if (bus_dmamap_create(sc->sc_dmatag, ETHER_MAX_LEN_JUMBO,
- TI_NTXSEG, ETHER_MAX_LEN_JUMBO, 0, BUS_DMA_NOWAIT, &dmamap))
- return(ENOBUFS);
+ TI_NTXSEG, MCLBYTES, 0, BUS_DMA_NOWAIT, &dmamap))
+ return (ENOBUFS);
entry = malloc(sizeof(*entry), M_DEVBUF, M_NOWAIT);
if (!entry) {
@@ -1078,7 +1069,7 @@ int ti_init_tx_ring(sc)
SLIST_INSERT_HEAD(&sc->ti_tx_map_listhead, entry, link);
}
- return(0);
+ return (0);
}
/*
@@ -1086,9 +1077,8 @@ int ti_init_tx_ring(sc)
* but we have to support the old way too so that Tigon 1 cards will
* work.
*/
-void ti_add_mcast(sc, addr)
- struct ti_softc *sc;
- struct ether_addr *addr;
+void
+ti_add_mcast(struct ti_softc *sc, struct ether_addr *addr)
{
struct ti_cmd_desc cmd;
u_int16_t *m;
@@ -1111,13 +1101,10 @@ void ti_add_mcast(sc, addr)
printf("%s: unknown hwrev\n", sc->sc_dv.dv_xname);
break;
}
-
- return;
}
-void ti_del_mcast(sc, addr)
- struct ti_softc *sc;
- struct ether_addr *addr;
+void
+ti_del_mcast(struct ti_softc *sc, struct ether_addr *addr)
{
struct ti_cmd_desc cmd;
u_int16_t *m;
@@ -1140,8 +1127,6 @@ void ti_del_mcast(sc, addr)
printf("%s: unknown hwrev\n", sc->sc_dv.dv_xname);
break;
}
-
- return;
}
/*
@@ -1158,8 +1143,8 @@ void ti_del_mcast(sc, addr)
* state so we know what addresses have been programmed into the NIC at
* any given time.
*/
-void ti_setmulti(sc)
- struct ti_softc *sc;
+void
+ti_setmulti(struct ti_softc *sc)
{
struct ifnet *ifp;
struct arpcom *ac = &sc->arpcom;
@@ -1212,8 +1197,6 @@ allmulti:
/* Re-enable interrupts. */
CSR_WRITE_4(sc, TI_MB_HOSTINTR, intrs);
-
- return;
}
/*
@@ -1222,8 +1205,8 @@ allmulti:
* around it on the Tigon 2 by setting a bit in the PCI state register,
* but for the Tigon 1 we must give up and abort the interface attach.
*/
-int ti_64bitslot_war(sc)
- struct ti_softc *sc;
+int
+ti_64bitslot_war(struct ti_softc *sc)
{
if (!(CSR_READ_4(sc, TI_PCI_STATE) & TI_PCISTATE_32BIT_BUS)) {
CSR_WRITE_4(sc, 0x600, 0);
@@ -1231,24 +1214,24 @@ int ti_64bitslot_war(sc)
CSR_WRITE_4(sc, 0x600, 0x5555AAAA);
if (CSR_READ_4(sc, 0x604) == 0x5555AAAA) {
if (sc->ti_hwrev == TI_HWREV_TIGON)
- return(EINVAL);
+ return (EINVAL);
else {
TI_SETBIT(sc, TI_PCI_STATE,
TI_PCISTATE_32BIT_BUS);
- return(0);
+ return (0);
}
}
}
- return(0);
+ return (0);
}
/*
* Do endian, PCI and DMA initialization. Also check the on-board ROM
* self-test results.
*/
-int ti_chipinit(sc)
- struct ti_softc *sc;
+int
+ti_chipinit(struct ti_softc *sc)
{
u_int32_t cacheline;
u_int32_t pci_writemax = 0;
@@ -1270,7 +1253,7 @@ int ti_chipinit(sc)
if (CSR_READ_4(sc, TI_CPU_STATE) & TI_CPUSTATE_ROMFAIL) {
printf("%s: board self-diagnostics failed!\n",
sc->sc_dv.dv_xname);
- return(ENODEV);
+ return (ENODEV);
}
/* Halt the CPU. */
@@ -1289,7 +1272,7 @@ int ti_chipinit(sc)
printf("\n");
printf("%s: unsupported chip revision: %x\n",
chip_rev, sc->sc_dv.dv_xname);
- return(ENODEV);
+ return (ENODEV);
}
/* Do special setup for Tigon 2. */
@@ -1329,10 +1312,6 @@ int ti_chipinit(sc)
break;
default:
/* Disable PCI memory write and invalidate. */
- if (bootverbose)
- printf("%s: cache line size %d not "
- "supported; disabling PCI MWI\n",
- sc->sc_dv.dv_xname, cacheline);
CSR_WRITE_4(sc, TI_PCI_CMDSTAT, CSR_READ_4(sc,
TI_PCI_CMDSTAT) & ~PCI_COMMAND_INVALIDATE_ENABLE);
break;
@@ -1384,18 +1363,18 @@ int ti_chipinit(sc)
if (ti_64bitslot_war(sc)) {
printf("%s: bios thinks we're in a 64 bit slot, "
"but we aren't", sc->sc_dv.dv_xname);
- return(EINVAL);
+ return (EINVAL);
}
- return(0);
+ return (0);
}
/*
* Initialize the general information block and firmware, and
* start the CPU(s) running.
*/
-int ti_gibinit(sc)
- struct ti_softc *sc;
+int
+ti_gibinit(struct ti_softc *sc)
{
struct ti_rcb *rcb;
int i;
@@ -1538,64 +1517,43 @@ int ti_gibinit(sc)
/* Start CPU. */
TI_CLRBIT(sc, TI_CPU_STATE, (TI_CPUSTATE_HALT|TI_CPUSTATE_STEP));
- return(0);
+ return (0);
}
-const struct pci_matchid ti_devices[] = {
- { PCI_VENDOR_NETGEAR, PCI_PRODUCT_NETGEAR_GA620 },
- { PCI_VENDOR_NETGEAR, PCI_PRODUCT_NETGEAR_GA620T },
- { PCI_VENDOR_ALTEON, PCI_PRODUCT_ALTEON_ACENIC },
- { PCI_VENDOR_ALTEON, PCI_PRODUCT_ALTEON_ACENICT },
- { PCI_VENDOR_3COM, PCI_PRODUCT_3COM_3C985 },
- { PCI_VENDOR_SGI, PCI_PRODUCT_SGI_TIGON },
- { PCI_VENDOR_DEC, PCI_PRODUCT_DEC_PN9000SX },
-};
-
/*
* Probe for a Tigon chip. Check the PCI vendor and device IDs
* against our list and return its name if we find a match.
*/
int
-ti_probe(parent, match, aux)
- struct device *parent;
- void *match;
- void *aux;
+ti_probe(struct device *parent, void *match, void *aux)
{
return (pci_matchbyid((struct pci_attach_args *)aux, ti_devices,
sizeof(ti_devices)/sizeof(ti_devices[0])));
}
-
void
-ti_attach(parent, self, aux)
- struct device *parent, *self;
- void *aux;
+ti_attach(struct device *parent, struct device *self, void *aux)
{
struct ti_softc *sc = (struct ti_softc *)self;
struct pci_attach_args *pa = aux;
pci_chipset_tag_t pc = pa->pa_pc;
pci_intr_handle_t ih;
const char *intrstr = NULL;
+ bus_size_t size;
bus_dma_segment_t seg;
- int s, rseg;
- u_int32_t command;
+ int rseg;
struct ifnet *ifp;
caddr_t kva;
- s = splimp();
-
/*
* Map control/status registers.
*/
- command = pci_conf_read(pa->pa_pc, pa->pa_tag, PCI_COMMAND_STATUS_REG);
- command |= PCI_COMMAND_MEM_ENABLE;
- pci_conf_write(pa->pa_pc, pa->pa_tag, PCI_COMMAND_STATUS_REG, command);
- command = pci_conf_read(pa->pa_pc, pa->pa_tag, PCI_COMMAND_STATUS_REG);
- if (pci_mapreg_map(pa, TI_PCI_LOMEM, PCI_MAPREG_TYPE_MEM, 0,
- &sc->ti_btag, &sc->ti_bhandle, NULL, NULL, 0)) {
+ if (pci_mapreg_map(pa, TI_PCI_LOMEM,
+ PCI_MAPREG_TYPE_MEM | PCI_MAPREG_MEM_TYPE_32BIT, 0,
+ &sc->ti_btag, &sc->ti_bhandle, NULL, &size, 0)) {
printf(": can't map mem space\n");
- goto fail_1;
+ return;
}
if (pci_intr_map(pa, &ih)) {
@@ -1615,7 +1573,7 @@ ti_attach(parent, self, aux)
if (ti_chipinit(sc)) {
printf("%s: chip initialization failed\n", sc->sc_dv.dv_xname);
- goto fail;
+ goto fail_2;
}
/* Zero out the NIC's on-board SRAM. */
@@ -1624,7 +1582,7 @@ ti_attach(parent, self, aux)
/* Init again -- zeroing memory may have clobbered some registers. */
if (ti_chipinit(sc)) {
printf("%s: chip initialization failed\n", sc->sc_dv.dv_xname);
- goto fail;
+ goto fail_2;
}
/*
@@ -1639,13 +1597,13 @@ ti_attach(parent, self, aux)
printf("%s: failed to read station address\n",
sc->sc_dv.dv_xname);
free(sc, M_DEVBUF);
- goto fail;
+ goto fail_2;
}
/*
* A Tigon chip was detected. Inform the world.
*/
- printf(": %s address %s\n", intrstr,
+ printf(": %s, address %s\n", intrstr,
ether_sprintf(sc->arpcom.ac_enaddr));
/* Allocate the general information block and ring buffers. */
@@ -1653,31 +1611,23 @@ ti_attach(parent, self, aux)
if (bus_dmamem_alloc(sc->sc_dmatag, sizeof(struct ti_ring_data),
PAGE_SIZE, 0, &seg, 1, &rseg, BUS_DMA_NOWAIT)) {
printf("%s: can't alloc rx buffers\n", sc->sc_dv.dv_xname);
- goto fail;
+ goto fail_2;
}
if (bus_dmamem_map(sc->sc_dmatag, &seg, rseg,
sizeof(struct ti_ring_data), &kva, BUS_DMA_NOWAIT)) {
printf("%s: can't map dma buffers (%d bytes)\n",
sc->sc_dv.dv_xname, sizeof(struct ti_ring_data));
- bus_dmamem_free(sc->sc_dmatag, &seg, rseg);
- goto fail;
+ goto fail_3;
}
if (bus_dmamap_create(sc->sc_dmatag, sizeof(struct ti_ring_data), 1,
sizeof(struct ti_ring_data), 0, BUS_DMA_NOWAIT,
&sc->ti_ring_map)) {
printf("%s: can't create dma map\n", sc->sc_dv.dv_xname);
- bus_dmamem_unmap(sc->sc_dmatag, kva,
- sizeof(struct ti_ring_data));
- bus_dmamem_free(sc->sc_dmatag, &seg, rseg);
- goto fail;
+ goto fail_4;
}
if (bus_dmamap_load(sc->sc_dmatag, sc->ti_ring_map, kva,
sizeof(struct ti_ring_data), NULL, BUS_DMA_NOWAIT)) {
- bus_dmamap_destroy(sc->sc_dmatag, sc->ti_ring_map);
- bus_dmamem_unmap(sc->sc_dmatag, kva,
- sizeof(struct ti_ring_data));
- bus_dmamem_free(sc->sc_dmatag, &seg, rseg);
- goto fail;
+ goto fail_5;
}
sc->ti_rdata = (struct ti_ring_data *)kva;
bzero(sc->ti_rdata, sizeof(struct ti_ring_data));
@@ -1686,7 +1636,7 @@ ti_attach(parent, self, aux)
if (ti_alloc_jumbo_mem(sc)) {
printf("%s: jumbo buffer allocation failed\n",
sc->sc_dv.dv_xname);
- goto fail;
+ goto fail_5;
}
/*
@@ -1767,11 +1717,21 @@ ti_attach(parent, self, aux)
shutdownhook_establish(ti_shutdown, sc);
return;
-fail:
+fail_5:
+ bus_dmamap_destroy(sc->sc_dmatag, sc->ti_ring_map);
+
+fail_4:
+ bus_dmamem_unmap(sc->sc_dmatag, kva,
+ sizeof(struct ti_ring_data));
+
+fail_3:
+ bus_dmamem_free(sc->sc_dmatag, &seg, rseg);
+
+fail_2:
pci_intr_disestablish(pc, sc->ti_intrhand);
fail_1:
- splx(s);
+ bus_space_unmap(sc->ti_btag, sc->ti_bhandle, size);
}
/*
@@ -1785,8 +1745,8 @@ fail_1:
* 3) the frame is from the standard receive ring
*/
-void ti_rxeof(sc)
- struct ti_softc *sc;
+void
+ti_rxeof(struct ti_softc *sc)
{
struct ifnet *ifp;
struct ti_cmd_desc cmd;
@@ -1897,12 +1857,10 @@ void ti_rxeof(sc)
TI_UPDATE_STDPROD(sc, sc->ti_std);
TI_UPDATE_MINIPROD(sc, sc->ti_mini);
TI_UPDATE_JUMBOPROD(sc, sc->ti_jumbo);
-
- return;
}
-void ti_txeof_tigon1(sc)
- struct ti_softc *sc;
+void
+ti_txeof_tigon1(struct ti_softc *sc)
{
struct ifnet *ifp;
struct ti_txmap_entry *entry;
@@ -1948,12 +1906,10 @@ void ti_txeof_tigon1(sc)
if (!active)
ifp->if_flags &= ~IFF_OACTIVE;
-
- return;
}
-void ti_txeof_tigon2(sc)
- struct ti_softc *sc;
+void
+ti_txeof_tigon2(struct ti_softc *sc)
{
struct ti_tx_desc *cur_tx = NULL;
struct ifnet *ifp;
@@ -1994,12 +1950,10 @@ void ti_txeof_tigon2(sc)
if (cur_tx != NULL)
ifp->if_flags &= ~IFF_OACTIVE;
-
- return;
}
-int ti_intr(xsc)
- void *xsc;
+int
+ti_intr(void *xsc)
{
struct ti_softc *sc;
struct ifnet *ifp;
@@ -2037,8 +1991,8 @@ int ti_intr(xsc)
return (1);
}
-void ti_stats_update(sc)
- struct ti_softc *sc;
+void
+ti_stats_update(struct ti_softc *sc)
{
struct ifnet *ifp;
struct ti_stats *stats = &sc->ti_rdata->ti_info.ti_stats;
@@ -2057,13 +2011,11 @@ void ti_stats_update(sc)
}
/*
- * Encapsulate an mbuf chain in the tx ring by coupling the mbuf data
+ * Encapsulate an mbuf chain in the tx ring by coupling the mbuf data
* pointers to descriptors.
*/
-int ti_encap_tigon1(sc, m_head, txidx)
- struct ti_softc *sc;
- struct mbuf *m_head;
- u_int32_t *txidx;
+int
+ti_encap_tigon1(struct ti_softc *sc, struct mbuf *m_head, u_int32_t *txidx)
{
u_int32_t frag, cur, cnt = 0;
struct ti_txmap_entry *entry;
@@ -2080,7 +2032,7 @@ int ti_encap_tigon1(sc, m_head, txidx)
entry = SLIST_FIRST(&sc->ti_tx_map_listhead);
if (entry == NULL)
- return ENOBUFS;
+ return (ENOBUFS);
txmap = entry->dmamap;
cur = frag = *txidx;
@@ -2092,7 +2044,7 @@ int ti_encap_tigon1(sc, m_head, txidx)
*/
if (bus_dmamap_load_mbuf(sc->sc_dmatag, txmap, m_head,
BUS_DMA_NOWAIT))
- return(ENOBUFS);
+ return (ENOBUFS);
for (i = 0; i < txmap->dm_nsegs; i++) {
if (sc->ti_cdata.ti_tx_chain[frag] != NULL)
@@ -2119,14 +2071,14 @@ int ti_encap_tigon1(sc, m_head, txidx)
* of the end of the ring.
*/
if ((TI_TX_RING_CNT - (sc->ti_txcnt + cnt)) < 16)
- return(ENOBUFS);
+ return (ENOBUFS);
cur = frag;
TI_INC(frag, TI_TX_RING_CNT);
cnt++;
}
if (frag == sc->ti_tx_saved_considx)
- return(ENOBUFS);
+ return (ENOBUFS);
txdesc.ti_flags |= TI_BDFLAG_END;
ti_mem_write(sc, TI_TX_RING_BASE + cur * sizeof(txdesc),
@@ -2142,17 +2094,15 @@ int ti_encap_tigon1(sc, m_head, txidx)
*txidx = frag;
- return(0);
+ return (0);
}
/*
- * Encapsulate an mbuf chain in the tx ring by coupling the mbuf data
+ * Encapsulate an mbuf chain in the tx ring by coupling the mbuf data
* pointers to descriptors.
*/
-int ti_encap_tigon2(sc, m_head, txidx)
- struct ti_softc *sc;
- struct mbuf *m_head;
- u_int32_t *txidx;
+int
+ti_encap_tigon2(struct ti_softc *sc, struct mbuf *m_head, u_int32_t *txidx)
{
struct ti_tx_desc *f = NULL;
u_int32_t frag, cur, cnt = 0;
@@ -2169,7 +2119,7 @@ int ti_encap_tigon2(sc, m_head, txidx)
entry = SLIST_FIRST(&sc->ti_tx_map_listhead);
if (entry == NULL)
- return ENOBUFS;
+ return (ENOBUFS);
txmap = entry->dmamap;
cur = frag = *txidx;
@@ -2181,7 +2131,7 @@ int ti_encap_tigon2(sc, m_head, txidx)
*/
if (bus_dmamap_load_mbuf(sc->sc_dmatag, txmap, m_head,
BUS_DMA_NOWAIT))
- return(ENOBUFS);
+ return (ENOBUFS);
for (i = 0; i < txmap->dm_nsegs; i++) {
f = &sc->ti_rdata->ti_tx_ring[frag];
@@ -2228,15 +2178,15 @@ int ti_encap_tigon2(sc, m_head, txidx)
*txidx = frag;
- return(0);
+ return (0);
}
/*
* Main transmit routine. To avoid having to do mbuf copies, we put pointers
* to the mbuf data regions directly in the transmit descriptors.
*/
-void ti_start(ifp)
- struct ifnet *ifp;
+void
+ti_start(struct ifnet *ifp)
{
struct ti_softc *sc;
struct mbuf *m_head = NULL;
@@ -2290,17 +2240,15 @@ void ti_start(ifp)
* Set a timeout in case the chip goes out to lunch.
*/
ifp->if_timer = 5;
-
- return;
}
-void ti_init(xsc)
- void *xsc;
+void
+ti_init(void *xsc)
{
struct ti_softc *sc = xsc;
int s;
- s = splimp();
+ s = splnet();
/* Cancel pending I/O and flush buffers. */
ti_stop(sc);
@@ -2313,12 +2261,10 @@ void ti_init(xsc)
}
splx(s);
-
- return;
}
-void ti_init2(sc)
- struct ti_softc *sc;
+void
+ti_init2(struct ti_softc *sc)
{
struct ti_cmd_desc cmd;
struct ifnet *ifp;
@@ -2398,15 +2344,13 @@ void ti_init2(sc)
ifm->ifm_media = ifm->ifm_cur->ifm_media;
ti_ifmedia_upd(ifp);
ifm->ifm_media = tmp;
-
- return;
}
/*
* Set media options.
*/
-int ti_ifmedia_upd(ifp)
- struct ifnet *ifp;
+int
+ti_ifmedia_upd(struct ifnet *ifp)
{
struct ti_softc *sc;
struct ifmedia *ifm;
@@ -2462,15 +2406,14 @@ int ti_ifmedia_upd(ifp)
break;
}
- return(0);
+ return (0);
}
/*
* Report current media status.
*/
-void ti_ifmedia_sts(ifp, ifmr)
- struct ifnet *ifp;
- struct ifmediareq *ifmr;
+void
+ti_ifmedia_sts(struct ifnet *ifp, struct ifmediareq *ifmr)
{
struct ti_softc *sc;
u_int32_t media = 0;
@@ -2513,14 +2456,10 @@ void ti_ifmedia_sts(ifp, ifmr)
if (media & TI_LNK_HALF_DUPLEX)
ifmr->ifm_active |= IFM_HDX;
}
-
- return;
}
-int ti_ioctl(ifp, command, data)
- struct ifnet *ifp;
- u_long command;
- caddr_t data;
+int
+ti_ioctl(struct ifnet *ifp, u_long command, caddr_t data)
{
struct ti_softc *sc = ifp->if_softc;
struct ifreq *ifr = (struct ifreq *)data;
@@ -2528,7 +2467,7 @@ int ti_ioctl(ifp, command, data)
int s, error = 0;
struct ti_cmd_desc cmd;
- s = splimp();
+ s = splnet();
if ((error = ether_ioctl(ifp, &sc->arpcom, command, data)) > 0) {
splx(s);
@@ -2584,7 +2523,6 @@ int ti_ioctl(ifp, command, data)
}
}
sc->ti_if_flags = ifp->if_flags;
- error = 0;
break;
case SIOCADDMULTI:
case SIOCDELMULTI:
@@ -2608,12 +2546,11 @@ int ti_ioctl(ifp, command, data)
}
splx(s);
-
- return(error);
+ return (error);
}
-void ti_watchdog(ifp)
- struct ifnet *ifp;
+void
+ti_watchdog(struct ifnet *ifp)
{
struct ti_softc *sc;
@@ -2624,16 +2561,14 @@ void ti_watchdog(ifp)
ti_init(sc);
ifp->if_oerrors++;
-
- return;
}
/*
* Stop the adapter and free any mbufs allocated to the
* RX and TX lists.
*/
-void ti_stop(sc)
- struct ti_softc *sc;
+void
+ti_stop(struct ti_softc *sc)
{
struct ifnet *ifp;
struct ti_cmd_desc cmd;
@@ -2670,30 +2605,18 @@ void ti_stop(sc)
sc->ti_return_prodidx.ti_idx = 0;
sc->ti_tx_considx.ti_idx = 0;
sc->ti_tx_saved_considx = TI_TXCONS_UNSET;
-
- return;
}
/*
* Stop all chip I/O so that the kernel's probe routines don't
* get confused by errant DMAs when rebooting.
*/
-void ti_shutdown(xsc)
- void *xsc;
+void
+ti_shutdown(void *xsc)
{
struct ti_softc *sc;
sc = xsc;
ti_chipinit(sc);
-
- return;
}
-
-struct cfattach ti_ca = {
- sizeof(struct ti_softc), ti_probe, ti_attach
-};
-
-struct cfdriver ti_cd = {
- 0, "ti", DV_IFNET
-};