diff options
Diffstat (limited to 'sys/dev/pcmcia/if_malo.c')
-rw-r--r-- | sys/dev/pcmcia/if_malo.c | 26 |
1 files changed, 17 insertions, 9 deletions
diff --git a/sys/dev/pcmcia/if_malo.c b/sys/dev/pcmcia/if_malo.c index 0df44b9547b..68a2a9e951f 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.40 2007/08/05 16:04:44 mglocker Exp $ */ +/* $OpenBSD: if_malo.c,v 1.41 2007/08/06 14:21:24 mglocker Exp $ */ /* * Copyright (c) 2007 Marcus Glocker <mglocker@openbsd.org> @@ -391,8 +391,10 @@ cmalo_ioctl(struct ifnet *ifp, u_long cmd, caddr_t data) nr->nr_capinfo = sc->sc_net[i].capinfo; nr->nr_flags |= IEEE80211_NODEREQ_AP; - bcopy(nr, (caddr_t)na->na_node + j, - sizeof(struct ieee80211_nodereq)); + if (copyout(nr, (caddr_t)na->na_node + j, + sizeof(struct ieee80211_nodereq))) + break; + j += sizeof(struct ieee80211_nodereq); na->na_nodes++; } @@ -1013,7 +1015,7 @@ void cmalo_reflect_network(struct malo_softc *sc) { struct ieee80211com *ic = &sc->sc_ic; - uint32_t chan; + uint8_t chan; /* reflect active network to our 80211 stack */ @@ -1027,7 +1029,7 @@ cmalo_reflect_network(struct malo_softc *sc) ic->ic_bss->ni_esslen); /* channel */ - chan = letoh32(sc->sc_net[sc->sc_net_cur].channel); + chan = sc->sc_net[sc->sc_net_cur].channel; ic->ic_bss->ni_chan = &ic->ic_channels[chan]; } @@ -1185,7 +1187,7 @@ cmalo_cmd_set_scan(struct malo_softc *sc) htole16(ic->ic_sup_rates[IEEE80211_MODE_11B].rs_nrates); bcopy(ic->ic_sup_rates[IEEE80211_MODE_11B].rs_rates, body_rates->data, ic->ic_sup_rates[IEEE80211_MODE_11B].rs_nrates); - psize += (sizeof(*body_rates) - 1) + body_rates->size; + psize += (sizeof(*body_rates) - 1) + letoh16(body_rates->size); #if 0 body_numprobes = sc->sc_cmd + psize; body_numprobes->type = htole16(MALO_TLV_TYPE_NUMPROBES); @@ -1219,6 +1221,8 @@ cmalo_cmd_rsp_scan(struct malo_softc *sc) body = (struct malo_cmd_body_rsp_scan *)(hdr + 1); + body->bufsize = letoh16(body->bufsize); + DPRINTF(1, "bufsize=%d, APs=%d\n", body->bufsize, body->numofset); sc->sc_net_num = body->numofset; @@ -1226,6 +1230,10 @@ cmalo_cmd_rsp_scan(struct malo_softc *sc) for (i = 0; i < body->numofset; i++) { set = (struct malo_cmd_body_rsp_scan_set *)(sc->sc_cmd + psize); + set->size = letoh16(set->size); + set->beaconintvl = letoh16(set->beaconintvl); + set->capinfo = letoh16(set->capinfo); + DPRINTF(1, "size=%d, bssid=%s, rssi=%d, beaconintvl=%d, " "capinfo=0x%04x\n", set->size, ether_sprintf(set->bssid), set->rssi, @@ -1616,7 +1624,7 @@ cmalo_cmd_set_assoc(struct malo_softc *sc) body_ssid->size = htole16(strlen(sc->sc_net[sc->sc_net_cur].ssid)); bcopy(sc->sc_net[sc->sc_net_cur].ssid, body_ssid->data, body_ssid->size); - psize += (sizeof(*body_ssid) - 1) + body_ssid->size; + psize += (sizeof(*body_ssid) - 1) + letoh16(body_ssid->size); body_phy = sc->sc_cmd + psize; body_phy->type = htole16(MALO_TLV_TYPE_PHY); @@ -1634,14 +1642,14 @@ cmalo_cmd_set_assoc(struct malo_softc *sc) body_rates->size = htole16(strlen(sc->sc_net[sc->sc_net_cur].rates)); bcopy(sc->sc_net[sc->sc_net_cur].rates, body_rates->data, body_rates->size); - psize += (sizeof(*body_rates) - 1) + body_rates->size; + psize += (sizeof(*body_rates) - 1) + letoh16(body_rates->size); /* hack to correct FW's wrong generated rates-element-id */ body_passeid = sc->sc_cmd + psize; body_passeid->type = htole16(MALO_TLV_TYPE_PASSEID); body_passeid->size = body_rates->size; bcopy(body_rates->data, body_passeid->data, body_rates->size); - psize += (sizeof(*body_passeid) - 1) + body_passeid->size; + psize += (sizeof(*body_passeid) - 1) + letoh16(body_passeid->size); hdr->size = htole16(psize - sizeof(*hdr)); |