diff options
author | Todd C. Miller <millert@cvs.openbsd.org> | 2004-07-15 12:08:15 +0000 |
---|---|---|
committer | Todd C. Miller <millert@cvs.openbsd.org> | 2004-07-15 12:08:15 +0000 |
commit | c6729b0f74d89eff22b3b29fa464b6d61e2c141e (patch) | |
tree | 9e0c33756d198cd31e72cf3bbbd5a2e112349a79 | |
parent | 7a48c56e460837e8ca1f1bbb8f516916e6e1c4eb (diff) |
Don't send data packets until the interface is in state RUN. This
stops ARP and IPv6 Neighbor Discovery packets from trickling out
the interface before it is time.
Remove dead code from atw_clear_sram.
During scans, initialize the BSSID to ff:ff:ff:ff:ff:ff before
sending the first probe request.
From NetBSD (dyoung)
-rw-r--r-- | sys/dev/ic/atw.c | 28 |
1 files changed, 12 insertions, 16 deletions
diff --git a/sys/dev/ic/atw.c b/sys/dev/ic/atw.c index 4f1b3532fb9..addab3e3c93 100644 --- a/sys/dev/ic/atw.c +++ b/sys/dev/ic/atw.c @@ -1,5 +1,5 @@ -/* $OpenBSD: atw.c,v 1.7 2004/07/15 12:00:31 millert Exp $ */ -/* $NetBSD: atw.c,v 1.39 2004/07/15 05:54:13 dyoung Exp $ */ +/* $OpenBSD: atw.c,v 1.8 2004/07/15 12:08:14 millert Exp $ */ +/* $NetBSD: atw.c,v 1.43 2004/07/15 06:30:12 dyoung Exp $ */ /*- * Copyright (c) 1998, 1999, 2000, 2002, 2003, 2004 The NetBSD Foundation, Inc. @@ -43,7 +43,7 @@ #include <sys/cdefs.h> #if defined(__NetBSD__) -__KERNEL_RCSID(0, "$NetBSD: atw.c,v 1.39 2004/07/15 05:54:13 dyoung Exp $"); +__KERNEL_RCSID(0, "$NetBSD: atw.c,v 1.43 2004/07/15 06:30:12 dyoung Exp $"); #endif #include "bpfilter.h" @@ -890,16 +890,6 @@ atw_reset(struct atw_softc *sc) void atw_clear_sram(struct atw_softc *sc) { -#if 0 - for (addr = 0; addr < 448; addr++) { - ATW_WRITE(sc, ATW_WEPCTL, - ATW_WEPCTL_WR | ATW_WEPCTL_UNKNOWN0 | addr); - DELAY(1000); - ATW_WRITE(sc, ATW_WESK, 0); - DELAY(1000); /* paranoia */ - } - return; -#endif memset(sc->sc_sram, 0, sizeof(sc->sc_sram)); /* XXX not for revision 0x20. */ atw_write_sram(sc, 0, sc->sc_sram, sizeof(sc->sc_sram)); @@ -2371,8 +2361,6 @@ atw_newstate(struct ieee80211com *ic, enum ieee80211_state nstate, int arg) panic("%s: unexpected state IEEE80211_S_INIT\n", __func__); break; case IEEE80211_S_SCAN: - memset(sc->sc_bssid, 0, IEEE80211_ADDR_LEN); - atw_write_bssid(sc); timeout_add(&sc->sc_scan_to, atw_dwelltime * hz / 1000); break; case IEEE80211_S_RUN: @@ -2413,7 +2401,12 @@ atw_newstate(struct ieee80211com *ic, enum ieee80211_state nstate, int arg) else atw_start_beacon(sc, 0); - return (*sc->sc_newstate)(ic, nstate, arg); + error = (*sc->sc_newstate)(ic, nstate, arg); + + if (ostate == IEEE80211_S_INIT && nstate == IEEE80211_S_SCAN) + atw_write_bssid(sc); + + return error; } /* @@ -3350,6 +3343,9 @@ atw_start(struct ifnet *ifp) ni = (struct ieee80211_node *)m0->m_pkthdr.rcvif; m0->m_pkthdr.rcvif = NULL; } else { + /* send no data packets until we are associated */ + if (ic->ic_state != IEEE80211_S_RUN) + break; IFQ_DEQUEUE(&ifp->if_snd, m0); if (m0 == NULL) break; |