summaryrefslogtreecommitdiff
path: root/sys/dev/pci/if_ti.c
diff options
context:
space:
mode:
Diffstat (limited to 'sys/dev/pci/if_ti.c')
-rw-r--r--sys/dev/pci/if_ti.c275
1 files changed, 132 insertions, 143 deletions
diff --git a/sys/dev/pci/if_ti.c b/sys/dev/pci/if_ti.c
index d158c06a822..99c2aee2b0a 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.2 1999/08/03 00:55:44 ho Exp $ */
+/* $OpenBSD: if_ti.c,v 1.3 1999/09/26 03:22:40 jason Exp $ */
/*
* Copyright (c) 1997, 1998, 1999
@@ -31,7 +31,7 @@
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
* THE POSSIBILITY OF SUCH DAMAGE.
*
- * $FreeBSD: if_ti.c,v 1.9 1999/07/06 19:23:29 des Exp $
+ * $FreeBSD: src/sys/pci/if_ti.c,v 1.24 1999/09/23 03:32:54 wpaul Exp $
*/
/*
@@ -130,69 +130,66 @@
#define bootverbose 1
-static int ti_probe __P((struct device *, void *, void *));
-static void ti_attach __P((struct device *, struct device *, void *));
-
-static void ti_txeof __P((struct ti_softc *));
-static void ti_rxeof __P((struct ti_softc *));
-
-static void ti_stats_update __P((struct ti_softc *));
-static int ti_encap __P((struct ti_softc *, struct mbuf *,
- u_int32_t *));
-
-static int ti_intr __P((void *));
-static void ti_start __P((struct ifnet *));
-static int ti_ioctl __P((struct ifnet *, u_long, caddr_t));
-static void ti_init __P((void *));
-static void ti_init2 __P((struct ti_softc *));
-static void ti_stop __P((struct ti_softc *));
-static void ti_watchdog __P((struct ifnet *));
-static void ti_shutdown __P((void *));
-static int ti_ifmedia_upd __P((struct ifnet *));
-static void ti_ifmedia_sts __P((struct ifnet *, struct ifmediareq *));
-
-static u_int32_t ti_eeprom_putbyte __P((struct ti_softc *, int));
-static u_int8_t ti_eeprom_getbyte __P((struct ti_softc *,
- int, u_int8_t *));
-static int ti_read_eeprom __P((struct ti_softc *, caddr_t, int, int));
-
-static void ti_add_mcast __P((struct ti_softc *, struct ether_addr *));
-static void ti_del_mcast __P((struct ti_softc *, struct ether_addr *));
-static void ti_setmulti __P((struct ti_softc *));
-
-static void ti_mem __P((struct ti_softc *, u_int32_t,
- u_int32_t, caddr_t));
-static void ti_loadfw __P((struct ti_softc *));
-static void ti_cmd __P((struct ti_softc *, struct ti_cmd_desc *));
-static void ti_cmd_ext __P((struct ti_softc *, struct ti_cmd_desc *,
- caddr_t, int));
-static void ti_handle_events __P((struct ti_softc *));
-static int ti_alloc_jumbo_mem __P((struct ti_softc *));
-static void *ti_jalloc __P((struct ti_softc *));
-static void ti_jfree __P((caddr_t, u_int));
+int ti_probe __P((struct device *, void *, void *));
+void ti_attach __P((struct device *, struct device *, void *));
+
+void ti_txeof __P((struct ti_softc *));
+void ti_rxeof __P((struct ti_softc *));
+
+void ti_stats_update __P((struct ti_softc *));
+int ti_encap __P((struct ti_softc *, struct mbuf *, u_int32_t *));
+
+int ti_intr __P((void *));
+void ti_start __P((struct ifnet *));
+int ti_ioctl __P((struct ifnet *, u_long, caddr_t));
+void ti_init __P((void *));
+void ti_init2 __P((struct ti_softc *));
+void ti_stop __P((struct ti_softc *));
+void ti_watchdog __P((struct ifnet *));
+void ti_shutdown __P((void *));
+int ti_ifmedia_upd __P((struct ifnet *));
+void ti_ifmedia_sts __P((struct ifnet *, struct ifmediareq *));
+
+u_int32_t ti_eeprom_putbyte __P((struct ti_softc *, int));
+u_int8_t ti_eeprom_getbyte __P((struct ti_softc *, int, u_int8_t *));
+int ti_read_eeprom __P((struct ti_softc *, caddr_t, int, int));
+
+void ti_add_mcast __P((struct ti_softc *, struct ether_addr *));
+void ti_del_mcast __P((struct ti_softc *, struct ether_addr *));
+void ti_setmulti __P((struct ti_softc *));
+
+void ti_mem __P((struct ti_softc *, u_int32_t, u_int32_t, caddr_t));
+void ti_loadfw __P((struct ti_softc *));
+void ti_cmd __P((struct ti_softc *, struct ti_cmd_desc *));
+void ti_cmd_ext __P((struct ti_softc *, struct ti_cmd_desc *,
+ caddr_t, int));
+void ti_handle_events __P((struct ti_softc *));
+int ti_alloc_jumbo_mem __P((struct ti_softc *));
+void *ti_jalloc __P((struct ti_softc *));
+void ti_jfree __P((caddr_t, u_int));
#if 0
-static void ti_jref __P((caddr_t, u_int));
+void ti_jref __P((caddr_t, u_int));
#endif
-static int ti_newbuf_std __P((struct ti_softc *, int, struct mbuf *));
-static int ti_newbuf_mini __P((struct ti_softc *, int, struct mbuf *));
-static int ti_newbuf_jumbo __P((struct ti_softc *, int, struct mbuf *));
-static int ti_init_rx_ring_std __P((struct ti_softc *));
-static void ti_free_rx_ring_std __P((struct ti_softc *));
-static int ti_init_rx_ring_jumbo __P((struct ti_softc *));
-static void ti_free_rx_ring_jumbo __P((struct ti_softc *));
-static int ti_init_rx_ring_mini __P((struct ti_softc *));
-static void ti_free_rx_ring_mini __P((struct ti_softc *));
-static void ti_free_tx_ring __P((struct ti_softc *));
-static int ti_init_tx_ring __P((struct ti_softc *));
-
-static int ti_64bitslot_war __P((struct ti_softc *));
-static int ti_chipinit __P((struct ti_softc *));
-static int ti_gibinit __P((struct ti_softc *));
+int ti_newbuf_std __P((struct ti_softc *, int, struct mbuf *));
+int ti_newbuf_mini __P((struct ti_softc *, int, struct mbuf *));
+int ti_newbuf_jumbo __P((struct ti_softc *, int, struct mbuf *));
+int ti_init_rx_ring_std __P((struct ti_softc *));
+void ti_free_rx_ring_std __P((struct ti_softc *));
+int ti_init_rx_ring_jumbo __P((struct ti_softc *));
+void ti_free_rx_ring_jumbo __P((struct ti_softc *));
+int ti_init_rx_ring_mini __P((struct ti_softc *));
+void ti_free_rx_ring_mini __P((struct ti_softc *));
+void ti_free_tx_ring __P((struct ti_softc *));
+int ti_init_tx_ring __P((struct ti_softc *));
+
+int ti_64bitslot_war __P((struct ti_softc *));
+int ti_chipinit __P((struct ti_softc *));
+int ti_gibinit __P((struct ti_softc *));
/*
* Send an instruction or address to the EEPROM, check for ACK.
*/
-static u_int32_t ti_eeprom_putbyte(sc, byte)
+u_int32_t ti_eeprom_putbyte(sc, byte)
struct ti_softc *sc;
int byte;
{
@@ -238,7 +235,7 @@ static 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.
*/
-static u_int8_t ti_eeprom_getbyte(sc, addr, dest)
+u_int8_t ti_eeprom_getbyte(sc, addr, dest)
struct ti_softc *sc;
int addr;
u_int8_t *dest;
@@ -312,7 +309,7 @@ static u_int8_t ti_eeprom_getbyte(sc, addr, dest)
/*
* Read a sequence of bytes from the EEPROM.
*/
-static int ti_read_eeprom(sc, dest, off, cnt)
+int ti_read_eeprom(sc, dest, off, cnt)
struct ti_softc *sc;
caddr_t dest;
int off;
@@ -335,7 +332,7 @@ static int ti_read_eeprom(sc, dest, off, cnt)
* NIC memory access function. Can be used to either clear a section
* of NIC local memory or (if buf is non-NULL) copy data into it.
*/
-static void ti_mem(sc, addr, len, buf)
+void ti_mem(sc, addr, len, buf)
struct ti_softc *sc;
u_int32_t addr, len;
caddr_t buf;
@@ -345,12 +342,7 @@ static void ti_mem(sc, addr, len, buf)
segptr = addr;
cnt = len;
-#ifdef __i386__
ti_winbase = (caddr_t)(sc->ti_bhandle + TI_WINDOW);
-#endif
-#ifdef __alpha__
- ti_winbase = (caddr_t)(sc->ti_vhandle + TI_WINDOW);
-#endif
ptr = buf;
while(cnt) {
@@ -379,7 +371,7 @@ static void ti_mem(sc, addr, len, buf)
* is acceptable and see if we want the firmware for the Tigon 1 or
* Tigon 2.
*/
-static void ti_loadfw(sc)
+void ti_loadfw(sc)
struct ti_softc *sc;
{
switch(sc->ti_hwrev) {
@@ -437,7 +429,7 @@ static void ti_loadfw(sc)
/*
* Send the NIC a command via the command ring.
*/
-static void ti_cmd(sc, cmd)
+void ti_cmd(sc, cmd)
struct ti_softc *sc;
struct ti_cmd_desc *cmd;
{
@@ -459,7 +451,7 @@ static void ti_cmd(sc, cmd)
* Send the NIC an extended command. The 'len' parameter specifies the
* number of command slots to include after the initial command.
*/
-static void ti_cmd_ext(sc, cmd, arg, len)
+void ti_cmd_ext(sc, cmd, arg, len)
struct ti_softc *sc;
struct ti_cmd_desc *cmd;
caddr_t arg;
@@ -488,7 +480,7 @@ static void ti_cmd_ext(sc, cmd, arg, len)
/*
* Handle events that have triggered interrupts.
*/
-static void ti_handle_events(sc)
+void ti_handle_events(sc)
struct ti_softc *sc;
{
struct ti_event_desc *e;
@@ -567,7 +559,7 @@ static void ti_handle_events(sc)
* be tuned by changing a #define in if_tireg.h.
*/
-static int ti_alloc_jumbo_mem(sc)
+int ti_alloc_jumbo_mem(sc)
struct ti_softc *sc;
{
caddr_t ptr;
@@ -628,7 +620,7 @@ static int ti_alloc_jumbo_mem(sc)
/*
* Allocate a jumbo buffer.
*/
-static void *ti_jalloc(sc)
+void *ti_jalloc(sc)
struct ti_softc *sc;
{
struct ti_jpool_entry *entry;
@@ -652,7 +644,7 @@ static void *ti_jalloc(sc)
* get used much because our jumbo buffers don't get passed around
* too much, but it's implemented for correctness.
*/
-static void ti_jref(buf, size)
+void ti_jref(buf, size)
caddr_t buf;
u_int size;
{
@@ -667,7 +659,7 @@ static void ti_jref(buf, size)
if (sc == NULL)
panic("ti_jref: can't find softc pointer!");
- if (size != TI_JUMBO_FRAMELEN - ETHER_ALIGN)
+ if (size != TI_JUMBO_FRAMELEN)
panic("ti_jref: adjusting refcount of buf of wrong size!");
/* calculate the slot this buffer belongs to */
@@ -690,7 +682,7 @@ static void ti_jref(buf, size)
/*
* Release a jumbo buffer.
*/
-static void ti_jfree(buf, size)
+void ti_jfree(buf, size)
caddr_t buf;
u_int size;
{
@@ -706,7 +698,7 @@ static void ti_jfree(buf, size)
if (sc == NULL)
panic("ti_jfree: can't find softc pointer!");
- if (size != TI_JUMBO_FRAMELEN - ETHER_ALIGN)
+ if (size != TI_JUMBO_FRAMELEN)
panic("ti_jfree: freeing buffer of wrong size!");
/* calculate the slot this buffer belongs to */
@@ -738,7 +730,7 @@ static void ti_jfree(buf, size)
/*
* Intialize a standard receive ring descriptor.
*/
-static int ti_newbuf_std(sc, i, m)
+int ti_newbuf_std(sc, i, m)
struct ti_softc *sc;
int i;
struct mbuf *m;
@@ -746,9 +738,7 @@ static int ti_newbuf_std(sc, i, m)
struct mbuf *m_new = NULL;
struct ti_rx_desc *r;
- if (m != NULL) {
- m_new = m;
- } else {
+ if (m == NULL) {
MGETHDR(m_new, M_DONTWAIT, MT_DATA);
if (m_new == NULL) {
printf("%s: mbuf allocation failed "
@@ -758,11 +748,16 @@ static int ti_newbuf_std(sc, i, m)
MCLGET(m_new, M_DONTWAIT);
if (!(m_new->m_flags & M_EXT)) {
- printf("sc->sc_dv.dv_xname: cluster allocation failed "
+ printf("%s: cluster allocation failed "
"-- packet dropped!\n", sc->sc_dv.dv_xname);
m_freem(m_new);
return(ENOBUFS);
}
+ m_new->m_len = m_new->m_pkthdr.len = MCLBYTES;
+ } else {
+ m_new = m;
+ m_new->m_len = m_new->m_pkthdr.len = MCLBYTES;
+ m_new->m_data = m_new->m_ext.ext_buf;
}
m_adj(m_new, ETHER_ALIGN);
@@ -775,7 +770,7 @@ static int ti_newbuf_std(sc, i, m)
#else
r->ti_flags = 0;
#endif
- r->ti_len = MCLBYTES - ETHER_ALIGN;
+ r->ti_len = MCLBYTES;
r->ti_idx = i;
return(0);
@@ -785,7 +780,7 @@ static int ti_newbuf_std(sc, i, m)
* Intialize a mini receive ring descriptor. This only applies to
* the Tigon 2.
*/
-static int ti_newbuf_mini(sc, i, m)
+int ti_newbuf_mini(sc, i, m)
struct ti_softc *sc;
int i;
struct mbuf *m;
@@ -793,16 +788,20 @@ static int ti_newbuf_mini(sc, i, m)
struct mbuf *m_new = NULL;
struct ti_rx_desc *r;
- if (m != NULL) {
- m_new = m;
- } else {
+ if (m == NULL) {
MGETHDR(m_new, M_DONTWAIT, MT_DATA);
if (m_new == NULL) {
printf("%s: mbuf allocation failed "
"-- packet dropped!\n", sc->sc_dv.dv_xname);
return(ENOBUFS);
}
+ m_new->m_len = m_new->m_pkthdr.len = MHLEN;
+ } else {
+ m_new = m;
+ m_new->m_data = m_new->m_pktdat;
+ m_new->m_len = m_new->m_pkthdr.len = MHLEN;
}
+
m_adj(m_new, ETHER_ALIGN);
r = &sc->ti_rdata->ti_rx_mini_ring[i];
sc->ti_cdata.ti_rx_mini_chain[i] = m_new;
@@ -812,7 +811,7 @@ static int ti_newbuf_mini(sc, i, m)
#ifdef TI_CSUM_OFFLOAD
r->ti_flags |= TI_BDFLAG_TCP_UDP_CKSUM|TI_BDFLAG_IP_CKSUM;
#endif
- r->ti_len = MHLEN - ETHER_ALIGN;
+ r->ti_len = m_new->m_len;
r->ti_idx = i;
return(0);
@@ -822,7 +821,7 @@ static int ti_newbuf_mini(sc, i, m)
* Initialize a jumbo receive ring descriptor. This allocates
* a jumbo buffer from the pool managed internally by the driver.
*/
-static int ti_newbuf_jumbo(sc, i, m)
+int ti_newbuf_jumbo(sc, i, m)
struct ti_softc *sc;
int i;
struct mbuf *m;
@@ -830,9 +829,7 @@ static int ti_newbuf_jumbo(sc, i, m)
struct mbuf *m_new = NULL;
struct ti_rx_desc *r;
- if (m != NULL) {
- m_new = m;
- } else {
+ if (m == NULL) {
caddr_t *buf = NULL;
/* Allocate the mbuf. */
@@ -854,15 +851,20 @@ static int ti_newbuf_jumbo(sc, i, m)
/* Attach the buffer to the mbuf. */
m_new->m_data = m_new->m_ext.ext_buf = (void *)buf;
- m_new->m_data += ETHER_ALIGN;
m_new->m_flags |= M_EXT;
- m_new->m_ext.ext_size = TI_JUMBO_FRAMELEN - ETHER_ALIGN;
+ m_new->m_len = m_new->m_pkthdr.len =
+ m_new->m_ext.ext_size = TI_JUMBO_FRAMELEN;
m_new->m_ext.ext_free = ti_jfree;
#if 0
m_new->m_ext.ext_ref = ti_jref;
#endif
+ } else {
+ m_new = m;
+ m_new->m_data = m_new->m_ext.ext_buf;
+ m_new->m_ext.ext_size = TI_JUMBO_FRAMELEN;
}
+ m_adj(m_new, ETHER_ALIGN);
/* Set up the descriptor. */
r = &sc->ti_rdata->ti_rx_jumbo_ring[i];
sc->ti_cdata.ti_rx_jumbo_chain[i] = m_new;
@@ -872,7 +874,7 @@ static int ti_newbuf_jumbo(sc, i, m)
#ifdef TI_CSUM_OFFLOAD
r->ti_flags |= TI_BDFLAG_TCP_UDP_CKSUM|TI_BDFLAG_IP_CKSUM;
#endif
- r->ti_len = TI_JUMBO_FRAMELEN - ETHER_ALIGN;
+ r->ti_len = m_new->m_len;
r->ti_idx = i;
return(0);
@@ -884,7 +886,7 @@ static int ti_newbuf_jumbo(sc, i, m)
* 256 ring entries and hope that our CPU is fast enough to keep up with
* the NIC.
*/
-static int ti_init_rx_ring_std(sc)
+int ti_init_rx_ring_std(sc)
struct ti_softc *sc;
{
register int i;
@@ -901,7 +903,7 @@ static int ti_init_rx_ring_std(sc)
return(0);
}
-static void ti_free_rx_ring_std(sc)
+void ti_free_rx_ring_std(sc)
struct ti_softc *sc;
{
register int i;
@@ -918,7 +920,7 @@ static void ti_free_rx_ring_std(sc)
return;
}
-static int ti_init_rx_ring_jumbo(sc)
+int ti_init_rx_ring_jumbo(sc)
struct ti_softc *sc;
{
register int i;
@@ -935,7 +937,7 @@ static int ti_init_rx_ring_jumbo(sc)
return(0);
}
-static void ti_free_rx_ring_jumbo(sc)
+void ti_free_rx_ring_jumbo(sc)
struct ti_softc *sc;
{
register int i;
@@ -952,7 +954,7 @@ static void ti_free_rx_ring_jumbo(sc)
return;
}
-static int ti_init_rx_ring_mini(sc)
+int ti_init_rx_ring_mini(sc)
struct ti_softc *sc;
{
register int i;
@@ -968,7 +970,7 @@ static int ti_init_rx_ring_mini(sc)
return(0);
}
-static void ti_free_rx_ring_mini(sc)
+void ti_free_rx_ring_mini(sc)
struct ti_softc *sc;
{
register int i;
@@ -985,7 +987,7 @@ static void ti_free_rx_ring_mini(sc)
return;
}
-static void ti_free_tx_ring(sc)
+void ti_free_tx_ring(sc)
struct ti_softc *sc;
{
register int i;
@@ -1005,7 +1007,7 @@ static void ti_free_tx_ring(sc)
return;
}
-static int ti_init_tx_ring(sc)
+int ti_init_tx_ring(sc)
struct ti_softc *sc;
{
sc->ti_txcnt = 0;
@@ -1091,7 +1093,7 @@ void ti_del_mcast(sc, addr)
* state so we know what addresses have been programmed into the NIC at
* any given time.
*/
-static void ti_setmulti(sc)
+void ti_setmulti(sc)
struct ti_softc *sc;
{
struct ifnet *ifp;
@@ -1148,7 +1150,7 @@ static void ti_setmulti(sc)
* 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.
*/
-static int ti_64bitslot_war(sc)
+int ti_64bitslot_war(sc)
struct ti_softc *sc;
{
if (!(CSR_READ_4(sc, TI_PCI_STATE) & TI_PCISTATE_32BIT_BUS)) {
@@ -1173,7 +1175,7 @@ static int ti_64bitslot_war(sc)
* Do endian, PCI and DMA initialization. Also check the on-board ROM
* self-test results.
*/
-static int ti_chipinit(sc)
+int ti_chipinit(sc)
struct ti_softc *sc;
{
u_int32_t cacheline;
@@ -1316,7 +1318,7 @@ static int ti_chipinit(sc)
* Initialize the general information block and firmware, and
* start the CPU(s) running.
*/
-static int ti_gibinit(sc)
+int ti_gibinit(sc)
struct ti_softc *sc;
{
struct ti_rcb *rcb;
@@ -1351,14 +1353,8 @@ static int ti_gibinit(sc)
/* Set up the command ring and producer mailbox. */
rcb = &sc->ti_rdata->ti_info.ti_cmd_rcb;
-#ifdef __i386__
sc->ti_rdata->ti_cmd_ring =
(struct ti_cmd_desc *)(sc->ti_bhandle + TI_GCR_CMDRING);
-#endif
-#ifdef __alpha__
- sc->ti_rdata->ti_cmd_ring =
- (struct ti_cmd_desc *)(sc->ti_vhandle + TI_GCR_CMDRING);
-#endif
TI_HOSTADDR(rcb->ti_hostaddr) = TI_GCR_NIC_ADDR(TI_GCR_CMDRING);
rcb->ti_flags = 0;
rcb->ti_max_len = 0;
@@ -1393,7 +1389,7 @@ static int ti_gibinit(sc)
rcb = &sc->ti_rdata->ti_info.ti_jumbo_rx_rcb;
TI_HOSTADDR(rcb->ti_hostaddr) =
vtophys(&sc->ti_rdata->ti_rx_jumbo_ring);
- rcb->ti_max_len = TI_JUMBO_FRAMELEN - ETHER_ALIGN;
+ rcb->ti_max_len = TI_JUMBO_FRAMELEN;
rcb->ti_flags = 0;
#ifdef TI_CSUM_OFFLOAD
rcb->ti_flags |= TI_RCB_FLAG_TCP_UDP_CKSUM|TI_RCB_FLAG_IP_CKSUM;
@@ -1410,7 +1406,7 @@ static int ti_gibinit(sc)
rcb = &sc->ti_rdata->ti_info.ti_mini_rx_rcb;
TI_HOSTADDR(rcb->ti_hostaddr) =
vtophys(&sc->ti_rdata->ti_rx_mini_ring);
- rcb->ti_max_len = MHLEN;
+ rcb->ti_max_len = MHLEN - ETHER_ALIGN;
if (sc->ti_hwrev == TI_HWREV_TIGON)
rcb->ti_flags = TI_RCB_FLAG_RING_DISABLED;
else
@@ -1444,14 +1440,8 @@ static int ti_gibinit(sc)
*/
CSR_WRITE_4(sc, TI_WINBASE, TI_TX_RING_BASE);
if (sc->ti_hwrev == TI_HWREV_TIGON) {
-#ifdef __i386__
sc->ti_rdata->ti_tx_ring_nic =
(struct ti_tx_desc *)(sc->ti_bhandle + TI_WINDOW);
-#endif
-#ifdef __alpha__
- sc->ti_rdata->ti_tx_ring_nic =
- (struct ti_tx_desc *)(sc->ti_vhandle + TI_WINDOW);
-#endif
}
bzero((char *)sc->ti_rdata->ti_tx_ring,
TI_TX_RING_CNT * sizeof(struct ti_tx_desc));
@@ -1498,7 +1488,7 @@ static int ti_gibinit(sc)
* Probe for a Tigon chip. Check the PCI vendor and device IDs
* against our list and return its name if we find a match.
*/
-static int
+int
ti_probe(parent, match, aux)
struct device *parent;
void *match;
@@ -1526,7 +1516,7 @@ ti_probe(parent, match, aux)
}
-static void
+void
ti_attach(parent, self, aux)
struct device *parent, *self;
void *aux;
@@ -1574,9 +1564,9 @@ ti_attach(parent, self, aux)
goto fail;
}
intrstr = pci_intr_string(pc, ih);
- sc->sc_ih = pci_intr_establish(pc, ih, IPL_NET, ti_intr, sc,
+ sc->ti_intrhand = pci_intr_establish(pc, ih, IPL_NET, ti_intr, sc,
self->dv_xname);
- if (sc->sc_ih == NULL) {
+ if (sc->ti_intrhand == NULL) {
printf(": couldn't establish interrupt");
if (intrstr != NULL)
printf(" at %s", intrstr);
@@ -1621,19 +1611,18 @@ ti_attach(parent, self, aux)
/* Allocate the general information block and ring buffers. */
#ifndef UVM
- sc->ti_rdata_ptr = (caddr_t) vm_page_alloc_contig(
+ sc->ti_rdata = (struct ti_ring_data *) vm_page_alloc_contig(
sizeof(struct ti_ring_data), 0x100000, 0xffffffff, PAGE_SIZE);
#else
- sc->ti_rdata_ptr = (caddr_t) uvm_pagealloc_contig(
+ sc->ti_rdata = (struct ti_ring_data *) uvm_pagealloc_contig(
sizeof(struct ti_ring_data), 0x100000, 0xffffffff, PAGE_SIZE);
#endif
- if (sc->ti_rdata_ptr == NULL) {
+ if (sc->ti_rdata == NULL) {
printf("%s: no memory for list buffers!\n", sc->sc_dv.dv_xname);
goto fail;
}
- sc->ti_rdata = (struct ti_ring_data *)sc->ti_rdata_ptr;
bzero(sc->ti_rdata, sizeof(struct ti_ring_data));
/* Try to allocate memory for jumbo buffers. */
@@ -1704,7 +1693,7 @@ fail:
* 3) the frame is from the standard receive ring
*/
-static void ti_rxeof(sc)
+void ti_rxeof(sc)
struct ti_softc *sc;
{
struct ifnet *ifp;
@@ -1830,7 +1819,7 @@ static void ti_rxeof(sc)
return;
}
-static void ti_txeof(sc)
+void ti_txeof(sc)
struct ti_softc *sc;
{
struct ti_tx_desc *cur_tx = NULL;
@@ -1879,7 +1868,7 @@ static void ti_txeof(sc)
return;
}
-static int ti_intr(xsc)
+int ti_intr(xsc)
void *xsc;
{
struct ti_softc *sc;
@@ -1920,7 +1909,7 @@ static int ti_intr(xsc)
return (claimed);
}
-static void ti_stats_update(sc)
+void ti_stats_update(sc)
struct ti_softc *sc;
{
struct ifnet *ifp;
@@ -1941,7 +1930,7 @@ static void ti_stats_update(sc)
* Encapsulate an mbuf chain in the tx ring by coupling the mbuf data
* pointers to descriptors.
*/
-static int ti_encap(sc, m_head, txidx)
+int ti_encap(sc, m_head, txidx)
struct ti_softc *sc;
struct mbuf *m_head;
u_int32_t *txidx;
@@ -2032,7 +2021,7 @@ static int ti_encap(sc, m_head, txidx)
* Main transmit routine. To avoid having to do mbuf copies, we put pointers
* to the mbuf data regions directly in the transmit descriptors.
*/
-static void ti_start(ifp)
+void ti_start(ifp)
struct ifnet *ifp;
{
struct ti_softc *sc;
@@ -2080,7 +2069,7 @@ static void ti_start(ifp)
return;
}
-static void ti_init(xsc)
+void ti_init(xsc)
void *xsc;
{
struct ti_softc *sc = xsc;
@@ -2103,7 +2092,7 @@ static void ti_init(xsc)
return;
}
-static void ti_init2(sc)
+void ti_init2(sc)
struct ti_softc *sc;
{
struct ti_cmd_desc cmd;
@@ -2191,7 +2180,7 @@ static void ti_init2(sc)
/*
* Set media options.
*/
-static int ti_ifmedia_upd(ifp)
+int ti_ifmedia_upd(ifp)
struct ifnet *ifp;
{
struct ti_softc *sc;
@@ -2247,7 +2236,7 @@ static int ti_ifmedia_upd(ifp)
/*
* Report current media status.
*/
-static void ti_ifmedia_sts(ifp, ifmr)
+void ti_ifmedia_sts(ifp, ifmr)
struct ifnet *ifp;
struct ifmediareq *ifmr;
{
@@ -2281,7 +2270,7 @@ static void ti_ifmedia_sts(ifp, ifmr)
return;
}
-static int ti_ioctl(ifp, command, data)
+int ti_ioctl(ifp, command, data)
struct ifnet *ifp;
u_long command;
caddr_t data;
@@ -2365,7 +2354,7 @@ static int ti_ioctl(ifp, command, data)
return(error);
}
-static void ti_watchdog(ifp)
+void ti_watchdog(ifp)
struct ifnet *ifp;
{
struct ti_softc *sc;
@@ -2385,7 +2374,7 @@ static void ti_watchdog(ifp)
* Stop the adapter and free any mbufs allocated to the
* RX and TX lists.
*/
-static void ti_stop(sc)
+void ti_stop(sc)
struct ti_softc *sc;
{
struct ifnet *ifp;
@@ -2431,7 +2420,7 @@ static void ti_stop(sc)
* Stop all chip I/O so that the kernel's probe routines don't
* get confused by errant DMAs when rebooting.
*/
-static void ti_shutdown(xsc)
+void ti_shutdown(xsc)
void *xsc;
{
struct ti_softc *sc;