summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDavid Gwynne <dlg@cvs.openbsd.org>2004-12-05 12:26:00 +0000
committerDavid Gwynne <dlg@cvs.openbsd.org>2004-12-05 12:26:00 +0000
commit9d45bdb773f34e8300dd2a5b58fa35819cf8b3a6 (patch)
treeb9027e68b62540a18b99d24c0ec30610b0bfc44e
parent642d50184ea693d04f4a7316e1b0e4b56513583d (diff)
do a scan for networks when net80211 thinks we should rather than doing it
only when we bring the interface up.
-rw-r--r--sys/dev/usb/if_atu.c127
-rw-r--r--sys/dev/usb/if_atureg.h10
2 files changed, 90 insertions, 47 deletions
diff --git a/sys/dev/usb/if_atu.c b/sys/dev/usb/if_atu.c
index 3a5cc051b41..9b68b82179d 100644
--- a/sys/dev/usb/if_atu.c
+++ b/sys/dev/usb/if_atu.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_atu.c,v 1.37 2004/12/05 04:51:47 dlg Exp $ */
+/* $OpenBSD: if_atu.c,v 1.38 2004/12/05 12:25:59 dlg Exp $ */
/*
* Copyright (c) 2003, 2004
* Daan Vreeken <Danovitsch@Vitsch.net>. All rights reserved.
@@ -173,6 +173,7 @@ void atu_xfer_list_free(struct atu_softc *sc, struct atu_chain *ch,
void atu_print_a_bunch_of_debug_things(struct atu_softc *sc);
int atu_set_wepkey(struct atu_softc *sc, int nr, u_int8_t *key, int len);
+void atu_task(void *);
int atu_newstate(struct ieee80211com *, enum ieee80211_state, int);
int atu_tx_start(struct atu_softc *, struct ieee80211_node *,
struct atu_chain *, struct mbuf *);
@@ -1119,6 +1120,56 @@ atu_media_status(struct ifnet *ifp, struct ifmediareq *req)
ieee80211_media_status(ifp, req);
}
+void
+atu_task(void *arg)
+{
+ struct atu_softc *sc = (struct atu_softc *)arg;
+ struct ieee80211com *ic = &sc->sc_ic;
+ struct ifnet *ifp = &ic->ic_if;
+ usbd_status err;
+ int s;
+
+ DPRINTFN(10, ("%s: atu_task\n", USBDEVNAME(sc->atu_dev)));
+
+ if (sc->atu_dying)
+ return;
+
+ switch (sc->sc_cmd) {
+ case ATU_C_SCAN:
+
+ err = atu_start_scan(sc);
+ if (err) {
+ DPRINTFN(1, ("%s: atu_init: couldn't start scan!\n",
+ USBDEVNAME(sc->atu_dev)));
+ return;
+ }
+
+ err = atu_wait_completion(sc, CMD_START_SCAN, NULL);
+ if (err) {
+ DPRINTF(("%s: atu_init: error waiting for scan\n",
+ USBDEVNAME(sc->atu_dev)));
+ return;
+ }
+
+ DPRINTF(("%s: ==========================> END OF SCAN!\n",
+ USBDEVNAME(sc->atu_dev)));
+
+ ifp->if_flags |= IFF_DEBUG;
+
+ s = splnet();
+ /* ieee80211_next_scan(ifp); */
+ ieee80211_end_scan(ifp);
+ splx(s);
+
+ DPRINTF(("%s: ----------------------======> END OF SCAN2!\n",
+ USBDEVNAME(sc->atu_dev)));
+ break;
+
+ case ATU_C_JOIN:
+ atu_join(sc, ic->ic_bss);
+ }
+}
+
int
atu_newstate(struct ieee80211com *ic, enum ieee80211_state nstate, int arg)
{
@@ -1129,16 +1180,32 @@ atu_newstate(struct ieee80211com *ic, enum ieee80211_state nstate, int arg)
DPRINTFN(10, ("%s: atu_newstate: %s -> %s\n", USBDEVNAME(sc->atu_dev),
ieee80211_state_name[ostate], ieee80211_state_name[nstate]));
- if ((ostate == IEEE80211_S_SCAN) && ((nstate == IEEE80211_S_AUTH) ||
- (nstate == IEEE80211_S_RUN))) {
-
- /*
- * The BSSID has changed. Join it first before net80211 starts
- * sending packets...
- */
-
- atu_join(sc, ic->ic_bss);
+ switch (nstate) {
+ case IEEE80211_S_SCAN:
+ memcpy(ic->ic_chan_scan, ic->ic_chan_active,
+ sizeof(ic->ic_chan_active));
+ ieee80211_free_allnodes(ic);
+
+ /* tell the event thread that we want a scan */
+ sc->sc_cmd = ATU_C_SCAN;
+ usb_add_task(sc->atu_udev, &sc->sc_task);
+
+ /* handle this ourselves */
+ ic->ic_state = nstate;
+ return (0);
+
+ case IEEE80211_S_AUTH:
+ case IEEE80211_S_RUN:
+ if (ostate == IEEE80211_S_SCAN) {
+ sc->sc_cmd = ATU_C_JOIN;
+ usb_add_task(sc->atu_udev, &sc->sc_task);
+ }
+ break;
+ default:
+ /* nothing to do */
+ break;
}
+
return (*sc->sc_newstate)(ic, nstate, arg);
}
@@ -1316,7 +1383,7 @@ USB_ATTACH(atu)
for (i = 1; i <= 14; i++) {
ic->ic_channels[i].ic_flags = IEEE80211_CHAN_B |
- IEEE80211_F_ASCAN;
+ IEEE80211_CHAN_PASSIVE;
ic->ic_channels[i].ic_freq = ieee80211_ieee2mhz(i,
ic->ic_channels[i].ic_flags);
}
@@ -1343,6 +1410,8 @@ USB_ATTACH(atu)
/* setup ifmedia interface */
ieee80211_media_init(ifp, atu_media_change, atu_media_status);
+ usb_init_task(&sc->sc_task, atu_task, sc);
+
sc->atu_dying = 0;
USB_ATTACH_SUCCESS_RETURN;
@@ -1362,6 +1431,8 @@ USB_DETACH(atu)
usbd_abort_pipe(sc->atu_ep[ATU_ENDPT_TX]);
if (sc->atu_ep[ATU_ENDPT_RX] != NULL)
usbd_abort_pipe(sc->atu_ep[ATU_ENDPT_RX]);
+
+ usb_rem_task(sc->atu_udev, &sc->sc_task);
return(0);
}
@@ -1988,40 +2059,6 @@ atu_init(struct ifnet *ifp)
}
splx(s);
- err = atu_start_scan(sc);
- if (err) {
- DPRINTFN(1, ("%s: atu_init: couldn't start scan!\n",
- USBDEVNAME(sc->atu_dev)));
- return(EIO);
- }
-
- /* Start a timer to check when the scan is done */
- /* timeout_add(&sc->atu_scan_timer, (1000 * hz) / 1000); */
- /*
- * Hmmm... sleeping in a timeout handler crashes the system :)
- * let's just wait here for the scan to finish
- */
-
- err = atu_wait_completion(sc, CMD_START_SCAN, NULL);
- if (err) {
- DPRINTF(("%s: atu_init: error waiting for scan\n",
- USBDEVNAME(sc->atu_dev)));
- return(err);
- }
-
- DPRINTF(("%s: ==========================> END OF SCAN!\n",
- USBDEVNAME(sc->atu_dev)));
-
- ifp->if_flags |= IFF_DEBUG;
-
- s = splnet();
- /* ieee80211_next_scan(ifp); */
- ieee80211_end_scan(ifp);
- splx(s);
-
- DPRINTF(("%s: ----------------------======> END OF SCAN2!\n",
- USBDEVNAME(sc->atu_dev)));
-
return 0;
}
diff --git a/sys/dev/usb/if_atureg.h b/sys/dev/usb/if_atureg.h
index ce2b5c8fcca..5d675fe8d1b 100644
--- a/sys/dev/usb/if_atureg.h
+++ b/sys/dev/usb/if_atureg.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_atureg.h,v 1.14 2004/12/05 01:51:20 dlg Exp $ */
+/* $OpenBSD: if_atureg.h,v 1.15 2004/12/05 12:25:59 dlg Exp $ */
/*
* Copyright (c) 2003
* Daan Vreeken <Danovitsch@Vitsch.net>. All rights reserved.
@@ -32,7 +32,7 @@
*
*/
-/* $ATUWI: $Id: if_atureg.h,v 1.14 2004/12/05 01:51:20 dlg Exp $ */
+/* $ATUWI: $Id: if_atureg.h,v 1.15 2004/12/05 12:25:59 dlg Exp $ */
/************ driver options ************/
@@ -258,6 +258,12 @@ struct atu_softc {
int (*sc_newstate)(struct ieee80211com *,
enum ieee80211_state, int);
+ int sc_cmd;
+#define ATU_C_NONE 0
+#define ATU_C_SCAN 1
+#define ATU_C_JOIN 2
+ struct usb_task sc_task;
+
usbd_device_handle atu_udev;
usbd_interface_handle atu_iface;
struct ifmedia atu_media;