diff options
Diffstat (limited to 'sys/dev/pcmcia/if_malo.c')
-rw-r--r-- | sys/dev/pcmcia/if_malo.c | 71 |
1 files changed, 58 insertions, 13 deletions
diff --git a/sys/dev/pcmcia/if_malo.c b/sys/dev/pcmcia/if_malo.c index fcb4729b031..6b1cadcb0b9 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.33 2007/08/04 12:02:36 mglocker Exp $ */ +/* $OpenBSD: if_malo.c,v 1.34 2007/08/05 00:24:39 mglocker Exp $ */ /* * Copyright (c) 2007 Marcus Glocker <mglocker@openbsd.org> @@ -88,6 +88,7 @@ void cmalo_watchdog(struct ifnet *); int cmalo_tx(struct malo_softc *, struct mbuf *); void cmalo_tx_done(struct malo_softc *); void cmalo_select_network(struct malo_softc *); +void cmalo_reflect_network(struct malo_softc *); void cmalo_hexdump(void *, int); int cmalo_cmd_get_hwspec(struct malo_softc *); @@ -635,8 +636,8 @@ cmalo_init(struct ifnet *ifp) if (ic->ic_opmode != IEEE80211_M_MONITOR) ieee80211_new_state(ic, IEEE80211_S_SCAN, -1); - else - ieee80211_new_state(ic, IEEE80211_S_RUN, -1); + + ieee80211_new_state(ic, IEEE80211_S_RUN, -1); return (0); } @@ -694,23 +695,28 @@ 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); - cmalo_select_network(sc); - if (!sc->sc_aps_num) - /* no AP found */ + if (!sc->sc_aps_num) { + /* no networks found */ + DPRINTF(1, "%s: no networks found!\n", + sc->sc_dev.dv_xname); break; + } + cmalo_select_network(sc); + cmalo_cmd_set_auth(sc); + cmalo_cmd_set_assoc(sc); + break; case IEEE80211_S_AUTH: DPRINTF(1, "%s: newstate is IEEE80211_S_AUTH\n", sc->sc_dev.dv_xname); - cmalo_cmd_set_auth(sc); - /* FALLTHROUGH */ + break; case IEEE80211_S_ASSOC: DPRINTF(1, "%s: newstate is IEEE80211_S_ASSOC\n", sc->sc_dev.dv_xname); - cmalo_cmd_set_assoc(sc); - /* FALLTHROUGH */ + break; case IEEE80211_S_RUN: DPRINTF(1, "%s: newstate is IEEE80211_S_RUN\n", sc->sc_dev.dv_xname); + cmalo_reflect_network(sc); break; default: break; @@ -966,10 +972,28 @@ cmalo_tx_done(struct malo_softc *sc) void cmalo_select_network(struct malo_softc *sc) { + struct ieee80211com *ic = &sc->sc_ic; int i, best_rssi; - /* get AP with best signal strength */ + /* reset last selected network */ sc->sc_aps_best = 0; + + /* get desired network */ + if (ic->ic_des_esslen) { + for (i = 0; i < sc->sc_aps_num; i++) { + if (!strcmp(ic->ic_des_essid, sc->sc_aps[i].ssid)) { + sc->sc_aps_best = i; + DPRINTF(1, "%s: desired network found (%s)\n", + sc->sc_dev.dv_xname, ic->ic_des_essid); + return; + } + } + DPRINTF(1, "%s: desired network not found in scan results " + "(%s)!\n", + sc->sc_dev.dv_xname, ic->ic_des_essid); + } + + /* get network with best signal strength */ best_rssi = sc->sc_aps[0].rssi; for (i = 0; i < sc->sc_aps_num; i++) { if (best_rssi < sc->sc_aps[i].rssi) { @@ -977,9 +1001,30 @@ cmalo_select_network(struct malo_softc *sc) sc->sc_aps_best = i; } } + DPRINTF(1, "%s: best network found (%s)\n", + sc->sc_dev.dv_xname, sc->sc_aps[sc->sc_aps_best].ssid); +} + +void +cmalo_reflect_network(struct malo_softc *sc) +{ + struct ieee80211com *ic = &sc->sc_ic; + uint32_t chan; + + /* reflect active network to our 80211 stack */ + + /* BSSID */ + IEEE80211_ADDR_COPY(ic->ic_bss->ni_bssid, + sc->sc_aps[sc->sc_aps_best].bssid); + + /* SSID */ + ic->ic_bss->ni_esslen = strlen(sc->sc_aps[sc->sc_aps_best].ssid); + bcopy(sc->sc_aps[sc->sc_aps_best].ssid, ic->ic_bss->ni_essid, + ic->ic_bss->ni_esslen); - DPRINTF(1, "best network found is %s\n", - sc->sc_aps[sc->sc_aps_best].ssid); + /* channel */ + chan = letoh32(sc->sc_aps[sc->sc_aps_best].channel); + ic->ic_bss->ni_chan = &ic->ic_channels[chan]; } void |