diff options
author | briggs <briggs@cvs.openbsd.org> | 1997-04-25 03:29:16 +0000 |
---|---|---|
committer | briggs <briggs@cvs.openbsd.org> | 1997-04-25 03:29:16 +0000 |
commit | 8a75bc7b41e91cc976a36a12871ac843109f52ac (patch) | |
tree | 3624ce5be6fe1d78f7f67e0ed3ee13f1a1cad27c /sys/arch/mac68k/dev | |
parent | f92382202f6b017156ef0abbc7977fe8922301ca (diff) |
A couple of performance improvements from Denny Gentry <denny1@home.com>
Diffstat (limited to 'sys/arch/mac68k/dev')
-rw-r--r-- | sys/arch/mac68k/dev/if_sn.c | 33 | ||||
-rw-r--r-- | sys/arch/mac68k/dev/if_snvar.h | 21 |
2 files changed, 33 insertions, 21 deletions
diff --git a/sys/arch/mac68k/dev/if_sn.c b/sys/arch/mac68k/dev/if_sn.c index 3bd38797bf8..e65ad212d58 100644 --- a/sys/arch/mac68k/dev/if_sn.c +++ b/sys/arch/mac68k/dev/if_sn.c @@ -1,5 +1,5 @@ /* $NetBSD: if_sn.c,v 1.7 1997/03/20 17:47:51 scottr Exp $ */ -/* $OpenBSD: if_sn.c,v 1.21 1997/04/18 11:58:34 briggs Exp $ */ +/* $OpenBSD: if_sn.c,v 1.22 1997/04/25 03:29:15 briggs Exp $ */ /* * National Semiconductor SONIC Driver @@ -176,14 +176,6 @@ snsetup(sc) p = (unsigned char *)SOALIGN(sc, p); - for (i = 0; i < NRDA; i++) { - sc->p_rda[i] = (void *) p; - sc->v_rda[i] = kvtop(p); - p += RXPKT_SIZE(sc); - } - - p = (unsigned char *)SOALIGN(sc, p); - for (i = 0; i < NTDA; i++) { struct mtd *mtdp = &sc->mtda[i]; mtdp->mtd_txp = (void *)p; @@ -195,17 +187,34 @@ snsetup(sc) if ((p - pp) > NBPG) { printf ("%s: sizeof RRA (%ld) + CDA (%ld) +" - "RDA (%ld) + TDA (%ld) > NBPG (%d). Punt!\n", + "TDA (%ld) > NBPG (%d). Punt!\n", sc->sc_dev.dv_xname, (ulong)sc->p_cda - (ulong)sc->p_rra[0], - (ulong)sc->p_rda[0] - (ulong)sc->p_cda, - (ulong)sc->mtda[0].mtd_txp - (ulong)sc->p_rda[0], + (ulong)sc->mtda[0].mtd_txp - (ulong)sc->p_cda, (ulong)p - (ulong)sc->mtda[0].mtd_txp, NBPG); return(1); } p = pp + NBPG; + pp = p; + + if ((NRDA * RXPKT_SIZE(sc)) > NBPG) { + printf ("%s: sizeof NRDA (%d) > NBPG (%d). Punt!\n", + sc->sc_dev.dv_xname, + NRDA * RXPKT_SIZE(sc), NBPG); + return (1); + } + + for (i = 0; i < NRDA; i++) { + sc->p_rda[i] = (void *) p; + sc->v_rda[i] = kvtop(p); + p += RXPKT_SIZE(sc); + } + + p = (unsigned char *)SOALIGN(sc, p); + + p = pp + NBPG; for (i = 0; i < NRBA; i++) { sc->rbuf[i] = (caddr_t) p; diff --git a/sys/arch/mac68k/dev/if_snvar.h b/sys/arch/mac68k/dev/if_snvar.h index 5f3bd9bf5b2..9d0abe3bd83 100644 --- a/sys/arch/mac68k/dev/if_snvar.h +++ b/sys/arch/mac68k/dev/if_snvar.h @@ -1,4 +1,4 @@ -/* $OpenBSD: if_snvar.h,v 1.6 1997/04/23 00:28:22 gene Exp $ */ +/* $OpenBSD: if_snvar.h,v 1.7 1997/04/25 03:29:14 briggs Exp $ */ /* * Copyright (c) 1991 Algorithmics Ltd (http://www.algor.co.uk) @@ -40,19 +40,22 @@ /* * buffer sizes in 32 bit mode - * 1 TXpkt is 4 hdr words + (3 * FRAGMAX) + 1 link word - * FRAGMAX == 16 => 54 words == 216 bytes + * 1 TXpkt is 4 hdr words + (3 * FRAGMAX) + 1 link word == 23 words == 92 bytes * * 1 RxPkt is 7 words == 28 bytes * 1 Rda is 4 words == 16 bytes + * + * The CDA is 17 words == 68 bytes + * + * total space in page 0 = NTDA * 92 + NRRA * 16 + NRDA * 28 + 68 */ #define NRBA 8 /* # receive buffers < NRRA */ #define RBAMASK (NRBA-1) -#define NRDA NRBA*4 -#define NTDA 4 /* # transmit descriptors */ -#define NRRA 32 /* # receive resource descriptors */ -#define RRAMASK (NRRA-1) /* the reason why it must be power of two */ +#define NRDA 146 +#define NTDA 8 /* # transmit descriptors */ +#define NRRA 16 /* # receive resource descriptors */ +#define RRAMASK (NRRA-1) /* the reason why NRRA must be power of two */ #define FCSSIZE 4 /* size of FCS appended to packets */ @@ -66,10 +69,10 @@ /* * transmit buffer area */ -#define NTXB 10 /* Number of xmit buffers */ +#define NTXB NTDA /* Number of xmit buffers */ #define TXBSIZE 1536 /* 6*2^8 -- the same size as the 8390 TXBUF */ -#define SN_NPAGES 1 + 8 + 5 +#define SN_NPAGES 2 + 8 + 4 /* * Statistics collected over time |