summaryrefslogtreecommitdiff
path: root/sys/dev/ic
diff options
context:
space:
mode:
Diffstat (limited to 'sys/dev/ic')
-rw-r--r--sys/dev/ic/re.c50
-rw-r--r--sys/dev/ic/rtl81x9reg.h3
2 files changed, 19 insertions, 34 deletions
diff --git a/sys/dev/ic/re.c b/sys/dev/ic/re.c
index 499fe9bcce5..2c0c3af8973 100644
--- a/sys/dev/ic/re.c
+++ b/sys/dev/ic/re.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: re.c,v 1.105 2009/05/23 09:39:23 jsg Exp $ */
+/* $OpenBSD: re.c,v 1.106 2009/06/03 00:11:19 sthen Exp $ */
/* $FreeBSD: if_re.c,v 1.31 2004/09/04 07:54:05 ru Exp $ */
/*
* Copyright (c) 1997, 1998-2003
@@ -516,44 +516,46 @@ re_iff(struct rl_softc *sc)
{
struct ifnet *ifp = &sc->sc_arpcom.ac_if;
int h = 0;
- u_int32_t hashes[2] = { 0, 0 };
+ u_int32_t hashes[2];
u_int32_t rxfilt;
- int mcnt = 0;
struct arpcom *ac = &sc->sc_arpcom;
struct ether_multi *enm;
struct ether_multistep step;
rxfilt = CSR_READ_4(sc, RL_RXCFG);
- rxfilt &= ~(RL_RXCFG_RX_ALLPHYS | RL_RXCFG_RX_MULTI);
+ rxfilt &= ~(RL_RXCFG_RX_ALLPHYS | RL_RXCFG_RX_BROAD |
+ RL_RXCFG_RX_INDIV | RL_RXCFG_RX_MULTI);
ifp->if_flags &= ~IFF_ALLMULTI;
- if (ifp->if_flags & IFF_PROMISC ||
- ac->ac_multirangecnt > 0) {
- ifp ->if_flags |= IFF_ALLMULTI;
+ /*
+ * Always accept frames destined to our station address.
+ * Always accept broadcast frames.
+ */
+ rxfilt |= RL_RXCFG_RX_INDIV | RL_RXCFG_RX_BROAD;
+
+ if (ifp->if_flags & IFF_PROMISC || ac->ac_multirangecnt > 0) {
+ ifp->if_flags |= IFF_ALLMULTI;
rxfilt |= RL_RXCFG_RX_MULTI;
if (ifp->if_flags & IFF_PROMISC)
rxfilt |= RL_RXCFG_RX_ALLPHYS;
hashes[0] = hashes[1] = 0xFFFFFFFF;
} else {
- /* first, zot all the existing hash bits */
- CSR_WRITE_4(sc, RL_MAR0, 0);
- CSR_WRITE_4(sc, RL_MAR4, 0);
+ rxfilt |= RL_RXCFG_RX_MULTI;
+ /* Program new filter. */
+ bzero(hashes, sizeof(hashes));
- /* now program new ones */
ETHER_FIRST_MULTI(step, ac, enm);
while (enm != NULL) {
h = ether_crc32_be(enm->enm_addrlo,
ETHER_ADDR_LEN) >> 26;
+
if (h < 32)
hashes[0] |= (1 << h);
else
hashes[1] |= (1 << (h - 32));
- mcnt++;
+
ETHER_NEXT_MULTI(step, enm);
}
-
- if (mcnt)
- rxfilt |= RL_RXCFG_RX_MULTI;
}
/*
@@ -1922,7 +1924,6 @@ int
re_init(struct ifnet *ifp)
{
struct rl_softc *sc = ifp->if_softc;
- u_int32_t rxcfg = 0;
u_int16_t cfg;
int s;
union {
@@ -2009,20 +2010,6 @@ re_init(struct ifnet *ifp)
CSR_WRITE_4(sc, RL_RXCFG, RL_RXCFG_CONFIG);
- /* Set the individual bit to receive frames for this host only. */
- rxcfg = CSR_READ_4(sc, RL_RXCFG);
- rxcfg |= RL_RXCFG_RX_INDIV;
-
- /*
- * Set capture broadcast bit to capture broadcast frames.
- */
- if (ifp->if_flags & IFF_BROADCAST)
- rxcfg |= RL_RXCFG_RX_BROAD;
- else
- rxcfg &= ~RL_RXCFG_RX_BROAD;
-
- CSR_WRITE_4(sc, RL_RXCFG, rxcfg);
-
/* Program promiscuous mode and multicast filters. */
re_iff(sc);
@@ -2119,14 +2106,13 @@ re_ioctl(struct ifnet *ifp, u_long command, caddr_t data)
case SIOCSIFFLAGS:
if (ifp->if_flags & IFF_UP) {
if (ifp->if_flags & IFF_RUNNING)
- re_iff(sc);
+ error = ENETRESET;
else
re_init(ifp);
} else {
if (ifp->if_flags & IFF_RUNNING)
re_stop(ifp, 1);
}
- sc->if_flags = ifp->if_flags;
break;
case SIOCGIFMEDIA:
case SIOCSIFMEDIA:
diff --git a/sys/dev/ic/rtl81x9reg.h b/sys/dev/ic/rtl81x9reg.h
index 776c2aa5225..4b85c91a949 100644
--- a/sys/dev/ic/rtl81x9reg.h
+++ b/sys/dev/ic/rtl81x9reg.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: rtl81x9reg.h,v 1.61 2009/06/02 17:27:39 jsg Exp $ */
+/* $OpenBSD: rtl81x9reg.h,v 1.62 2009/06/03 00:11:19 sthen Exp $ */
/*
* Copyright (c) 1997, 1998
@@ -805,7 +805,6 @@ struct rl_softc {
int rl_txthresh;
struct rl_chain_data rl_cdata;
struct timeout sc_tick_tmo;
- int if_flags;
struct rl_list_data rl_ldata;
struct mbuf *rl_head;