summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMarcus Glocker <mglocker@cvs.openbsd.org>2007-08-01 11:30:23 +0000
committerMarcus Glocker <mglocker@cvs.openbsd.org>2007-08-01 11:30:23 +0000
commit64bfef78395e38d5dbb0390ea6577ebee20d1d9b (patch)
treed5e183fd3f33828493178249b4b7e22aa14a2aa0
parent0cc4b12ba72bbc3c7a0d3f999caeddb9a94057e6 (diff)
Improve state switching and fix some debug output.
-rw-r--r--sys/dev/pcmcia/if_malo.c35
-rw-r--r--sys/dev/pcmcia/if_malovar.h3
2 files changed, 26 insertions, 12 deletions
diff --git a/sys/dev/pcmcia/if_malo.c b/sys/dev/pcmcia/if_malo.c
index f0fb584250c..2dea5c9c840 100644
--- a/sys/dev/pcmcia/if_malo.c
+++ b/sys/dev/pcmcia/if_malo.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_malo.c,v 1.28 2007/07/31 23:19:40 mglocker Exp $ */
+/* $OpenBSD: if_malo.c,v 1.29 2007/08/01 11:30:22 mglocker Exp $ */
/*
* Copyright (c) 2007 Marcus Glocker <mglocker@openbsd.org>
@@ -632,11 +632,9 @@ cmalo_init(struct ifnet *ifp)
ifp->if_flags |= IFF_RUNNING;
ifp->if_flags &= ~IFF_OACTIVE;
- if (ic->ic_opmode != IEEE80211_M_MONITOR) {
+ if (ic->ic_opmode != IEEE80211_M_MONITOR)
ieee80211_new_state(ic, IEEE80211_S_SCAN, -1);
- ieee80211_new_state(ic, IEEE80211_S_AUTH, -1);
- ieee80211_new_state(ic, IEEE80211_S_RUN, -1);
- } else
+ else
ieee80211_new_state(ic, IEEE80211_S_RUN, -1);
return (0);
@@ -679,6 +677,12 @@ int
cmalo_newstate(struct ieee80211com *ic, enum ieee80211_state nstate, int arg)
{
struct malo_softc *sc = ic->ic_if.if_softc;
+ enum ieee80211_state ostate;
+
+ ostate = ic->ic_state;
+
+ if (ostate == nstate)
+ goto out;
switch (nstate) {
case IEEE80211_S_INIT:
@@ -689,19 +693,18 @@ cmalo_newstate(struct ieee80211com *ic, enum ieee80211_state nstate, int arg)
DPRINTF(1, "%s: newstate is IEEE80211_S_SCAN\n",
sc->sc_dev.dv_xname);
cmalo_cmd_set_scan(sc);
- break;
+ cmalo_select_network(sc);
+ if (!sc->sc_aps_num)
+ /* no AP found */
+ break;
case IEEE80211_S_AUTH:
DPRINTF(1, "%s: newstate is IEEE80211_S_AUTH\n",
sc->sc_dev.dv_xname);
- if (sc->sc_aps_num == 0)
- break;
- cmalo_select_network(sc);
cmalo_cmd_set_auth(sc);
case IEEE80211_S_ASSOC:
DPRINTF(1, "%s: newstate is IEEE80211_S_ASSOC\n",
sc->sc_dev.dv_xname);
cmalo_cmd_set_assoc(sc);
- break;
case IEEE80211_S_RUN:
DPRINTF(1, "%s: newstate is IEEE80211_S_RUN\n",
sc->sc_dev.dv_xname);
@@ -710,6 +713,7 @@ cmalo_newstate(struct ieee80211com *ic, enum ieee80211_state nstate, int arg)
break;
}
+out:
return (sc->sc_newstate(ic, nstate, arg));
}
@@ -976,7 +980,7 @@ cmalo_hexdump(void *buf, int len)
#ifdef CMALO_DEBUG
int i;
- if (cmalo_d <= 2) {
+ if (cmalo_d >= 2) {
for (i = 0; i < len; i++) {
if (i % 16 == 0)
printf("%s%5i:", i ? "\n" : "", i);
@@ -1725,6 +1729,10 @@ cmalo_cmd_response(struct malo_softc *sc)
}
hdr->cmd &= ~MALO_CMD_RESP;
+ /* association cmd response is special */
+ if (hdr->cmd == 0x0012)
+ hdr->cmd = MALO_CMD_ASSOC;
+
/* to which command does the response belong */
switch (hdr->cmd) {
case MALO_CMD_HWSPEC:
@@ -1775,6 +1783,11 @@ cmalo_cmd_response(struct malo_softc *sc)
DPRINTF(1, "%s: got macctrl cmd response\n",
sc->sc_dev.dv_xname);
break;
+ case MALO_CMD_ASSOC:
+ /* do nothing */
+ DPRINTF(1, "%s: got assoc cmd response\n",
+ sc->sc_dev.dv_xname);
+ break;
case MALO_CMD_80211D:
/* do nothing */
DPRINTF(1, "%s: got 80211d cmd response\n",
diff --git a/sys/dev/pcmcia/if_malovar.h b/sys/dev/pcmcia/if_malovar.h
index e82f056d081..66c27df890a 100644
--- a/sys/dev/pcmcia/if_malovar.h
+++ b/sys/dev/pcmcia/if_malovar.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_malovar.h,v 1.16 2007/07/31 23:19:40 mglocker Exp $ */
+/* $OpenBSD: if_malovar.h,v 1.17 2007/08/01 11:30:22 mglocker Exp $ */
/*
* Copyright (c) 2007 Marcus Glocker <mglocker@openbsd.org>
@@ -315,4 +315,5 @@ struct malo_softc {
int sc_aps_num;
int sc_aps_best;
struct malo_aps sc_aps[12];
+ struct timeout sc_scan_to;
};