Lines Matching full:local

18 	local_info_t *local;  in hostap_get_wireless_stats()  local
22 local = iface->local; in hostap_get_wireless_stats()
28 wstats = &local->wstats; in hostap_get_wireless_stats()
32 local->comm_tallies.rx_discards_wep_undecryptable; in hostap_get_wireless_stats()
34 local->comm_tallies.rx_fcs_errors + in hostap_get_wireless_stats()
35 local->comm_tallies.rx_discards_no_buffer + in hostap_get_wireless_stats()
36 local->comm_tallies.tx_discards_wrong_sa; in hostap_get_wireless_stats()
39 local->comm_tallies.tx_retry_limit_exceeded; in hostap_get_wireless_stats()
41 local->comm_tallies.rx_message_in_bad_msg_fragments; in hostap_get_wireless_stats()
43 if (local->iw_mode != IW_MODE_MASTER && in hostap_get_wireless_stats()
44 local->iw_mode != IW_MODE_REPEAT) { in hostap_get_wireless_stats()
61 wstats->qual.qual = local->comms_qual; in hostap_get_wireless_stats()
62 wstats->qual.level = local->avg_signal; in hostap_get_wireless_stats()
63 wstats->qual.noise = local->avg_noise; in hostap_get_wireless_stats()
78 local_info_t *local; in prism2_get_datarates() local
84 local = iface->local; in prism2_get_datarates()
86 len = local->func->get_rid(dev, HFA384X_RID_SUPPORTEDDATARATES, buf, in prism2_get_datarates()
128 local_info_t *local; in prism2_ioctl_siwencode() local
133 local = iface->local; in prism2_ioctl_siwencode()
137 i = local->crypt_info.tx_keyidx; in prism2_ioctl_siwencode()
143 crypt = &local->crypt_info.crypt[i]; in prism2_ioctl_siwencode()
147 lib80211_crypt_delayed_deinit(&local->crypt_info, crypt); in prism2_ioctl_siwencode()
154 lib80211_crypt_delayed_deinit(&local->crypt_info, crypt); in prism2_ioctl_siwencode()
191 if (j != i && local->crypt_info.crypt[j]) { in prism2_ioctl_siwencode()
197 local->crypt_info.tx_keyidx = i; in prism2_ioctl_siwencode()
200 local->crypt_info.tx_keyidx = i; in prism2_ioctl_siwencode()
204 local->open_wep = erq->flags & IW_ENCODE_OPEN; in prism2_ioctl_siwencode()
206 if (hostap_set_encryption(local)) { in prism2_ioctl_siwencode()
216 if (local->iw_mode != IW_MODE_INFRA && local->func->reset_port(dev)) { in prism2_ioctl_siwencode()
230 local_info_t *local; in prism2_ioctl_giwencode() local
236 local = iface->local; in prism2_ioctl_giwencode()
240 i = local->crypt_info.tx_keyidx; in prism2_ioctl_giwencode()
246 crypt = local->crypt_info.crypt[i]; in prism2_ioctl_giwencode()
268 if (local->func->get_rid(dev, HFA384X_RID_CNFWEPFLAGS, &val, 2, 1) < 0) in prism2_ioctl_giwencode()
290 local_info_t *local; in hostap_set_rate() local
294 local = iface->local; in hostap_set_rate()
296 basic_rates = local->basic_rates & local->tx_rate_control; in hostap_set_rate()
297 if (!basic_rates || basic_rates != local->basic_rates) { in hostap_set_rate()
302 basic_rates = local->tx_rate_control; in hostap_set_rate()
304 local->basic_rates = basic_rates; in hostap_set_rate()
312 local->tx_rate_control) || in hostap_set_rate()
314 local->tx_rate_control) || in hostap_set_rate()
315 local->func->reset_port(dev)); in hostap_set_rate()
320 dev->name, local->tx_rate_control); in hostap_set_rate()
325 hostap_update_rates(local); in hostap_set_rate()
336 local_info_t *local; in prism2_ioctl_siwrate() local
339 local = iface->local; in prism2_ioctl_siwrate()
344 local->tx_rate_control = HFA384X_RATES_11MBPS; in prism2_ioctl_siwrate()
347 local->tx_rate_control = HFA384X_RATES_5MBPS; in prism2_ioctl_siwrate()
350 local->tx_rate_control = HFA384X_RATES_2MBPS; in prism2_ioctl_siwrate()
353 local->tx_rate_control = HFA384X_RATES_1MBPS; in prism2_ioctl_siwrate()
356 local->tx_rate_control = HFA384X_RATES_1MBPS | in prism2_ioctl_siwrate()
364 local->tx_rate_control = HFA384X_RATES_1MBPS | in prism2_ioctl_siwrate()
369 local->tx_rate_control = HFA384X_RATES_1MBPS | in prism2_ioctl_siwrate()
373 local->tx_rate_control = HFA384X_RATES_1MBPS | in prism2_ioctl_siwrate()
377 local->tx_rate_control = HFA384X_RATES_1MBPS; in prism2_ioctl_siwrate()
380 local->tx_rate_control = HFA384X_RATES_1MBPS | in prism2_ioctl_siwrate()
397 local_info_t *local; in prism2_ioctl_giwrate() local
401 local = iface->local; in prism2_ioctl_giwrate()
403 if (local->func->get_rid(dev, HFA384X_RID_TXRATECONTROL, &val, 2, 1) < in prism2_ioctl_giwrate()
412 if (local->iw_mode == IW_MODE_MASTER && local->ap != NULL && in prism2_ioctl_giwrate()
413 !local->fw_tx_rate_control) { in prism2_ioctl_giwrate()
417 rrq->value = local->ap->last_tx_rate > 0 ? in prism2_ioctl_giwrate()
418 local->ap->last_tx_rate * 100000 : 11000000; in prism2_ioctl_giwrate()
422 if (local->func->get_rid(dev, HFA384X_RID_CURRENTTXRATE, &val, 2, 1) < in prism2_ioctl_giwrate()
455 local_info_t *local; in prism2_ioctl_siwsens() local
458 local = iface->local; in prism2_ioctl_siwsens()
465 local->func->reset_port(dev)) in prism2_ioctl_siwsens()
476 local_info_t *local; in prism2_ioctl_giwsens() local
480 local = iface->local; in prism2_ioctl_giwsens()
483 if (local->func->get_rid(dev, HFA384X_RID_CNFSYSTEMSCALE, &val, 2, 1) < in prism2_ioctl_giwsens()
500 local_info_t *local; in prism2_ioctl_giwaplist() local
505 local = iface->local; in prism2_ioctl_giwaplist()
507 if (local->iw_mode != IW_MODE_MASTER) { in prism2_ioctl_giwaplist()
523 data->length = prism2_ap_get_sta_qual(local, addr, qual, IW_MAX_AP, 1); in prism2_ioctl_giwaplist()
541 local_info_t *local; in prism2_ioctl_siwrts() local
545 local = iface->local; in prism2_ioctl_siwrts()
554 if (local->func->set_rid(dev, HFA384X_RID_RTSTHRESHOLD, &val, 2) || in prism2_ioctl_siwrts()
555 local->func->reset_port(dev)) in prism2_ioctl_siwrts()
558 local->rts_threshold = rts->value; in prism2_ioctl_siwrts()
568 local_info_t *local; in prism2_ioctl_giwrts() local
572 local = iface->local; in prism2_ioctl_giwrts()
574 if (local->func->get_rid(dev, HFA384X_RID_RTSTHRESHOLD, &val, 2, 1) < in prism2_ioctl_giwrts()
591 local_info_t *local; in prism2_ioctl_siwfrag() local
595 local = iface->local; in prism2_ioctl_siwfrag()
604 local->fragm_threshold = rts->value & ~0x1; in prism2_ioctl_siwfrag()
605 if (local->func->set_rid(dev, HFA384X_RID_FRAGMENTATIONTHRESHOLD, &val, in prism2_ioctl_siwfrag()
607 || local->func->reset_port(dev)) in prism2_ioctl_siwfrag()
618 local_info_t *local; in prism2_ioctl_giwfrag() local
622 local = iface->local; in prism2_ioctl_giwfrag()
624 if (local->func->get_rid(dev, HFA384X_RID_FRAGMENTATIONTHRESHOLD, in prism2_ioctl_giwfrag()
640 local_info_t *local; in hostap_join_ap() local
647 local = iface->local; in hostap_join_ap()
649 memcpy(req.bssid, local->preferred_ap, ETH_ALEN); in hostap_join_ap()
652 spin_lock_irqsave(&local->lock, flags); in hostap_join_ap()
653 for (i = 0; i < local->last_scan_results_count; i++) { in hostap_join_ap()
654 if (!local->last_scan_results) in hostap_join_ap()
656 entry = &local->last_scan_results[i]; in hostap_join_ap()
657 if (memcmp(local->preferred_ap, entry->bssid, ETH_ALEN) == 0) { in hostap_join_ap()
662 spin_unlock_irqrestore(&local->lock, flags); in hostap_join_ap()
664 if (local->func->set_rid(dev, HFA384X_RID_JOINREQUEST, &req, in hostap_join_ap()
667 dev->name, local->preferred_ap); in hostap_join_ap()
672 dev->name, local->preferred_ap); in hostap_join_ap()
687 local_info_t *local; in prism2_ioctl_siwap()
690 local = iface->local; in prism2_ioctl_siwap()
692 memcpy(local->preferred_ap, &ap_addr->sa_data, ETH_ALEN); in prism2_ioctl_siwap()
694 if (local->host_roaming == 1 && local->iw_mode == IW_MODE_INFRA) { in prism2_ioctl_siwap()
699 if (local->func->set_rid(dev, HFA384X_RID_SCANREQUEST, in prism2_ioctl_siwap()
705 } else if (local->host_roaming == 2 && in prism2_ioctl_siwap()
706 local->iw_mode == IW_MODE_INFRA) { in prism2_ioctl_siwap()
724 local_info_t *local; in prism2_ioctl_giwap() local
727 local = iface->local; in prism2_ioctl_giwap()
735 memcpy(&ap_addr->sa_data, local->assoc_ap_addr, ETH_ALEN); in prism2_ioctl_giwap()
741 if (local->func->get_rid(dev, HFA384X_RID_CURRENTBSSID, in prism2_ioctl_giwap()
745 /* local->bssid is also updated in LinkStatus handler when in in prism2_ioctl_giwap()
747 memcpy(local->bssid, &ap_addr->sa_data, ETH_ALEN); in prism2_ioctl_giwap()
760 local_info_t *local; in prism2_ioctl_siwnickn() local
763 local = iface->local; in prism2_ioctl_siwnickn()
765 memset(local->name, 0, sizeof(local->name)); in prism2_ioctl_siwnickn()
766 memcpy(local->name, nickname, data->length); in prism2_ioctl_siwnickn()
767 local->name_set = 1; in prism2_ioctl_siwnickn()
769 if (hostap_set_string(dev, HFA384X_RID_CNFOWNNAME, local->name) || in prism2_ioctl_siwnickn()
770 local->func->reset_port(dev)) in prism2_ioctl_siwnickn()
781 local_info_t *local; in prism2_ioctl_giwnickn() local
787 local = iface->local; in prism2_ioctl_giwnickn()
789 len = local->func->get_rid(dev, HFA384X_RID_CNFOWNNAME, in prism2_ioctl_giwnickn()
808 local_info_t *local; in prism2_ioctl_siwfreq() local
811 local = iface->local; in prism2_ioctl_siwfreq()
829 !(local->channel_mask & (1 << (freq->m - 1)))) in prism2_ioctl_siwfreq()
832 local->channel = freq->m; /* channel is used in prism2_setup_rids() */ in prism2_ioctl_siwfreq()
833 if (hostap_set_word(dev, HFA384X_RID_CNFOWNCHANNEL, local->channel) || in prism2_ioctl_siwfreq()
834 local->func->reset_port(dev)) in prism2_ioctl_siwfreq()
845 local_info_t *local; in prism2_ioctl_giwfreq() local
849 local = iface->local; in prism2_ioctl_giwfreq()
851 if (local->func->get_rid(dev, HFA384X_RID_CURRENTCHANNEL, &val, 2, 1) < in prism2_ioctl_giwfreq()
866 static void hostap_monitor_set_type(local_info_t *local) in hostap_monitor_set_type() argument
868 struct net_device *dev = local->ddev; in hostap_monitor_set_type()
873 if (local->monitor_type == PRISM2_MONITOR_PRISM || in hostap_monitor_set_type()
874 local->monitor_type == PRISM2_MONITOR_CAPHDR) { in hostap_monitor_set_type()
876 } else if (local->monitor_type == PRISM2_MONITOR_RADIOTAP) { in hostap_monitor_set_type()
889 local_info_t *local; in prism2_ioctl_siwessid() local
892 local = iface->local; in prism2_ioctl_siwessid()
900 if (local->iw_mode == IW_MODE_MASTER && ssid[0] == '\0') { in prism2_ioctl_siwessid()
908 memcpy(local->essid, ssid, data->length); in prism2_ioctl_siwessid()
909 local->essid[data->length] = '\0'; in prism2_ioctl_siwessid()
911 if ((!local->fw_ap && in prism2_ioctl_siwessid()
912 hostap_set_string(dev, HFA384X_RID_CNFDESIREDSSID, local->essid)) in prism2_ioctl_siwessid()
913 || hostap_set_string(dev, HFA384X_RID_CNFOWNSSID, local->essid) || in prism2_ioctl_siwessid()
914 local->func->reset_port(dev)) in prism2_ioctl_siwessid()
925 local_info_t *local; in prism2_ioctl_giwessid() local
929 local = iface->local; in prism2_ioctl_giwessid()
935 if (local->iw_mode == IW_MODE_MASTER) { in prism2_ioctl_giwessid()
936 data->length = strlen(local->essid); in prism2_ioctl_giwessid()
937 memcpy(essid, local->essid, IW_ESSID_MAX_SIZE); in prism2_ioctl_giwessid()
942 len = local->func->get_rid(dev, HFA384X_RID_CURRENTSSID, in prism2_ioctl_giwessid()
961 local_info_t *local; in prism2_ioctl_giwrange() local
968 local = iface->local; in prism2_ioctl_giwrange()
978 if (local->iw_mode == IW_MODE_INFRA || local->iw_mode == IW_MODE_ADHOC) in prism2_ioctl_giwrange()
1002 if (local->channel_mask & (1 << i)) { in prism2_ioctl_giwrange()
1013 if (local->sta_fw_ver >= PRISM2_FW_VER(1,3,1)) { in prism2_ioctl_giwrange()
1070 if (local->sta_fw_ver >= PRISM2_FW_VER(1,3,1)) in prism2_ioctl_giwrange()
1077 static int hostap_monitor_mode_enable(local_info_t *local) in hostap_monitor_mode_enable() argument
1079 struct net_device *dev = local->dev; in hostap_monitor_mode_enable()
1082 hostap_monitor_set_type(local); in hostap_monitor_mode_enable()
1101 if (local->func->reset_port(dev) || in hostap_monitor_mode_enable()
1102 local->func->cmd(dev, HFA384X_CMDCODE_TEST | in hostap_monitor_mode_enable()
1113 static int hostap_monitor_mode_disable(local_info_t *local) in hostap_monitor_mode_disable() argument
1115 struct net_device *dev = local->ddev; in hostap_monitor_mode_disable()
1123 if (local->func->cmd(dev, HFA384X_CMDCODE_TEST | in hostap_monitor_mode_disable()
1127 return hostap_set_encryption(local); in hostap_monitor_mode_disable()
1136 local_info_t *local; in prism2_ioctl_siwmode() local
1140 local = iface->local; in prism2_ioctl_siwmode()
1152 if (*mode == local->iw_mode) in prism2_ioctl_siwmode()
1155 if (*mode == IW_MODE_MASTER && local->essid[0] == '\0') { in prism2_ioctl_siwmode()
1161 if (local->iw_mode == IW_MODE_MONITOR) in prism2_ioctl_siwmode()
1162 hostap_monitor_mode_disable(local); in prism2_ioctl_siwmode()
1164 if ((local->iw_mode == IW_MODE_ADHOC || in prism2_ioctl_siwmode()
1165 local->iw_mode == IW_MODE_MONITOR) && *mode == IW_MODE_MASTER) { in prism2_ioctl_siwmode()
1174 "%d -> %d\n", dev->name, local->iw_mode, *mode); in prism2_ioctl_siwmode()
1175 local->iw_mode = *mode; in prism2_ioctl_siwmode()
1177 if (local->iw_mode == IW_MODE_MONITOR) in prism2_ioctl_siwmode()
1178 hostap_monitor_mode_enable(local); in prism2_ioctl_siwmode()
1179 else if (local->iw_mode == IW_MODE_MASTER && !local->host_encrypt && in prism2_ioctl_siwmode()
1180 !local->fw_encrypt_ok) { in prism2_ioctl_siwmode()
1184 local->host_encrypt = 1; in prism2_ioctl_siwmode()
1188 hostap_get_porttype(local))) in prism2_ioctl_siwmode()
1191 if (local->func->reset_port(dev)) in prism2_ioctl_siwmode()
1193 if (double_reset && local->func->reset_port(dev)) in prism2_ioctl_siwmode()
1196 if (local->iw_mode != IW_MODE_INFRA && local->iw_mode != IW_MODE_ADHOC) in prism2_ioctl_siwmode()
1200 netif_carrier_on(local->dev); in prism2_ioctl_siwmode()
1201 netif_carrier_on(local->ddev); in prism2_ioctl_siwmode()
1212 local_info_t *local; in prism2_ioctl_giwmode() local
1215 local = iface->local; in prism2_ioctl_giwmode()
1225 *mode = local->iw_mode; in prism2_ioctl_giwmode()
1299 local_info_t *local; in prism2_ioctl_giwpower()
1303 local = iface->local; in prism2_ioctl_giwpower()
1305 if (local->func->get_rid(dev, HFA384X_RID_CNFPMENABLED, &enable, 2, 1) in prism2_ioctl_giwpower()
1318 if (local->func->get_rid(dev, in prism2_ioctl_giwpower()
1327 if (local->func->get_rid(dev, HFA384X_RID_CNFMAXSLEEPDURATION, in prism2_ioctl_giwpower()
1335 if (local->func->get_rid(dev, HFA384X_RID_CNFMULTICASTRECEIVE, &mcast, in prism2_ioctl_giwpower()
1354 local_info_t *local; in prism2_ioctl_siwretry() local
1357 local = iface->local; in prism2_ioctl_siwretry()
1368 local->manual_retry_count = -1; in prism2_ioctl_siwretry()
1369 local->tx_control &= ~HFA384X_TX_CTRL_ALT_RTRY; in prism2_ioctl_siwretry()
1379 local->manual_retry_count = rrq->value; in prism2_ioctl_siwretry()
1380 local->tx_control |= HFA384X_TX_CTRL_ALT_RTRY; in prism2_ioctl_siwretry()
1415 local_info_t *local; in prism2_ioctl_giwretry() local
1419 local = iface->local; in prism2_ioctl_giwretry()
1421 if (local->func->get_rid(dev, HFA384X_RID_SHORTRETRYLIMIT, &shortretry, in prism2_ioctl_giwretry()
1423 local->func->get_rid(dev, HFA384X_RID_LONGRETRYLIMIT, &longretry, in prism2_ioctl_giwretry()
1425 local->func->get_rid(dev, HFA384X_RID_MAXTRANSMITLIFETIME, in prism2_ioctl_giwretry()
1435 if (local->manual_retry_count >= 0) { in prism2_ioctl_giwretry()
1437 if (local->func->get_rid(dev, in prism2_ioctl_giwretry()
1442 rrq->value = local->manual_retry_count; in prism2_ioctl_giwretry()
1509 local_info_t *local; in prism2_ioctl_siwtxpow() local
1517 local = iface->local; in prism2_ioctl_siwtxpow()
1520 if (local->txpower_type != PRISM2_TXPOWER_OFF) { in prism2_ioctl_siwtxpow()
1522 ret = local->func->cmd(dev, HFA384X_CMDCODE_WRITEMIF, in prism2_ioctl_siwtxpow()
1527 local->txpower_type = PRISM2_TXPOWER_OFF; in prism2_ioctl_siwtxpow()
1532 if (local->txpower_type == PRISM2_TXPOWER_OFF) { in prism2_ioctl_siwtxpow()
1534 ret = local->func->cmd(dev, HFA384X_CMDCODE_WRITEMIF, in prism2_ioctl_siwtxpow()
1538 local->txpower_type = PRISM2_TXPOWER_UNKNOWN; in prism2_ioctl_siwtxpow()
1542 if (!rrq->fixed && local->txpower_type != PRISM2_TXPOWER_AUTO) { in prism2_ioctl_siwtxpow()
1545 local->func->cmd(dev, HFA384X_CMDCODE_TEST | in prism2_ioctl_siwtxpow()
1547 local->txpower_type = PRISM2_TXPOWER_AUTO; in prism2_ioctl_siwtxpow()
1551 if (local->txpower_type != PRISM2_TXPOWER_FIXED) { in prism2_ioctl_siwtxpow()
1554 local->func->cmd(dev, HFA384X_CMDCODE_TEST | in prism2_ioctl_siwtxpow()
1556 local->txpower_type = PRISM2_TXPOWER_FIXED; in prism2_ioctl_siwtxpow()
1572 local->txpower = rrq->value; in prism2_ioctl_siwtxpow()
1573 val = prism2_txpower_dBm_to_hfa386x(local->txpower); in prism2_ioctl_siwtxpow()
1574 if (local->func->cmd(dev, HFA384X_CMDCODE_WRITEMIF, in prism2_ioctl_siwtxpow()
1591 local_info_t *local; in prism2_ioctl_giwtxpow() local
1595 local = iface->local; in prism2_ioctl_giwtxpow()
1601 if (local->txpower_type == PRISM2_TXPOWER_AUTO) { in prism2_ioctl_giwtxpow()
1602 if (local->func->cmd(dev, HFA384X_CMDCODE_READMIF, in prism2_ioctl_giwtxpow()
1610 } else if (local->txpower_type == PRISM2_TXPOWER_OFF) { in prism2_ioctl_giwtxpow()
1613 } else if (local->txpower_type == PRISM2_TXPOWER_FIXED) { in prism2_ioctl_giwtxpow()
1614 rrq->value = local->txpower; in prism2_ioctl_giwtxpow()
1618 local->txpower_type); in prism2_ioctl_giwtxpow()
1636 local_info_t *local; in prism2_request_hostscan() local
1640 local = iface->local; in prism2_request_hostscan()
1643 scan_req.channel_list = cpu_to_le16(local->channel_mask & in prism2_request_hostscan()
1644 local->scan_channel_mask); in prism2_request_hostscan()
1653 if (local->func->set_rid(dev, HFA384X_RID_HOSTSCAN, &scan_req, in prism2_request_hostscan()
1665 local_info_t *local; in prism2_request_scan() local
1670 local = iface->local; in prism2_request_scan()
1673 scan_req.channel_list = cpu_to_le16(local->channel_mask & in prism2_request_scan()
1674 local->scan_channel_mask); in prism2_request_scan()
1686 if (!local->host_roaming) in prism2_request_scan()
1690 if (local->func->set_rid(dev, HFA384X_RID_SCANREQUEST, &scan_req, in prism2_request_scan()
1696 if (!local->host_roaming) in prism2_request_scan()
1725 local_info_t *local; in prism2_ioctl_siwscan() local
1731 local = iface->local; in prism2_ioctl_siwscan()
1736 if (local->iw_mode == IW_MODE_MASTER) { in prism2_ioctl_siwscan()
1737 /* In master mode, we just return the results of our local in prism2_ioctl_siwscan()
1744 if (!local->dev_enabled) in prism2_ioctl_siwscan()
1752 ((local->iw_mode != IW_MODE_INFRA && in prism2_ioctl_siwscan()
1753 local->iw_mode != IW_MODE_ADHOC) || in prism2_ioctl_siwscan()
1754 (local->sta_fw_ver < PRISM2_FW_VER(1,3,1)))) in prism2_ioctl_siwscan()
1758 if (local->sta_fw_ver >= PRISM2_FW_VER(1,3,1)) in prism2_ioctl_siwscan()
1764 local->scan_timestamp = jiffies; in prism2_ioctl_siwscan()
1773 static char * __prism2_translate_scan(local_info_t *local, in __prism2_translate_scan() argument
1854 if (local->last_scan_type == PRISM2_HOSTSCAN) { in __prism2_translate_scan()
1917 if (local->last_scan_type == PRISM2_HOSTSCAN && in __prism2_translate_scan()
1951 static inline int prism2_translate_scan(local_info_t *local, in prism2_translate_scan() argument
1961 spin_lock_bh(&local->lock); in prism2_translate_scan()
1963 list_for_each(ptr, &local->bss_list) { in prism2_translate_scan()
1969 hostscan = local->last_scan_type == PRISM2_HOSTSCAN; in prism2_translate_scan()
1970 for (entry = 0; entry < local->last_scan_results_count; entry++) { in prism2_translate_scan()
1972 scan = &local->last_scan_results[entry]; in prism2_translate_scan()
1977 list_for_each(ptr, &local->bss_list) { in prism2_translate_scan()
1983 local, info, scan, bss, current_ev, in prism2_translate_scan()
1990 local, info, scan, NULL, current_ev, end_buf); in prism2_translate_scan()
1995 spin_unlock_bh(&local->lock); in prism2_translate_scan()
2001 * of BSSes in scan results. Extend this limit by using local BSS list. in prism2_translate_scan()
2003 list_for_each(ptr, &local->bss_list) { in prism2_translate_scan()
2008 current_ev = __prism2_translate_scan(local, info, NULL, bss, in prism2_translate_scan()
2013 spin_unlock_bh(&local->lock); in prism2_translate_scan()
2018 spin_unlock_bh(&local->lock); in prism2_translate_scan()
2033 local_info_t *local; in prism2_ioctl_giwscan_sta()
2037 local = iface->local; in prism2_ioctl_giwscan_sta()
2041 if (local->scan_timestamp && in prism2_ioctl_giwscan_sta()
2042 time_before(jiffies, local->scan_timestamp + 3 * HZ)) { in prism2_ioctl_giwscan_sta()
2053 local->scan_timestamp = 0; in prism2_ioctl_giwscan_sta()
2055 res = prism2_translate_scan(local, info, extra, data->length); in prism2_ioctl_giwscan_sta()
2073 local_info_t *local; in prism2_ioctl_giwscan() local
2077 local = iface->local; in prism2_ioctl_giwscan()
2079 if (local->iw_mode == IW_MODE_MASTER) { in prism2_ioctl_giwscan()
2302 local_info_t *local; in prism2_ioctl_priv_inquire() local
2305 local = iface->local; in prism2_ioctl_priv_inquire()
2307 if (local->func->cmd(dev, HFA384X_CMDCODE_INQUIRE, *i, NULL, NULL)) in prism2_ioctl_priv_inquire()
2319 local_info_t *local; in prism2_ioctl_priv_prism2_param() local
2327 local = iface->local; in prism2_ioctl_priv_prism2_param()
2331 local->fw_tx_rate_control = value; in prism2_ioctl_priv_prism2_param()
2336 local->func->reset_port(dev)) in prism2_ioctl_priv_prism2_param()
2339 local->beacon_int = value; in prism2_ioctl_priv_prism2_param()
2344 if (value == local->pseudo_adhoc) in prism2_ioctl_priv_prism2_param()
2353 dev->name, local->pseudo_adhoc, value); in prism2_ioctl_priv_prism2_param()
2354 local->pseudo_adhoc = value; in prism2_ioctl_priv_prism2_param()
2355 if (local->iw_mode != IW_MODE_ADHOC) in prism2_ioctl_priv_prism2_param()
2359 hostap_get_porttype(local))) { in prism2_ioctl_priv_prism2_param()
2364 if (local->func->reset_port(dev)) in prism2_ioctl_priv_prism2_param()
2373 local->func->cmd(dev, HFA384X_CMDCODE_TEST | in prism2_ioctl_priv_prism2_param()
2379 local->frame_dump = value; in prism2_ioctl_priv_prism2_param()
2387 if (local->ap != NULL) in prism2_ioctl_priv_prism2_param()
2388 local->ap->ap_policy = value; in prism2_ioctl_priv_prism2_param()
2396 if (local->ap != NULL) in prism2_ioctl_priv_prism2_param()
2397 local->ap->max_inactivity = value * HZ; in prism2_ioctl_priv_prism2_param()
2401 if (local->ap != NULL) in prism2_ioctl_priv_prism2_param()
2402 local->ap->bridge_packets = value; in prism2_ioctl_priv_prism2_param()
2411 || local->func->reset_port(dev)) in prism2_ioctl_priv_prism2_param()
2414 local->dtim_period = value; in prism2_ioctl_priv_prism2_param()
2418 if (local->ap != NULL) in prism2_ioctl_priv_prism2_param()
2419 local->ap->nullfunc_ack = value; in prism2_ioctl_priv_prism2_param()
2423 local->wds_max_connections = value; in prism2_ioctl_priv_prism2_param()
2427 if (local->ap != NULL) { in prism2_ioctl_priv_prism2_param()
2428 if (!local->ap->autom_ap_wds && value) { in prism2_ioctl_priv_prism2_param()
2430 hostap_add_wds_links(local); in prism2_ioctl_priv_prism2_param()
2432 local->ap->autom_ap_wds = value; in prism2_ioctl_priv_prism2_param()
2437 local->auth_algs = value; in prism2_ioctl_priv_prism2_param()
2438 if (hostap_set_auth_algs(local)) in prism2_ioctl_priv_prism2_param()
2443 local->monitor_allow_fcserr = value; in prism2_ioctl_priv_prism2_param()
2447 local->host_encrypt = value; in prism2_ioctl_priv_prism2_param()
2448 if (hostap_set_encryption(local) || in prism2_ioctl_priv_prism2_param()
2449 local->func->reset_port(dev)) in prism2_ioctl_priv_prism2_param()
2454 local->host_decrypt = value; in prism2_ioctl_priv_prism2_param()
2455 if (hostap_set_encryption(local) || in prism2_ioctl_priv_prism2_param()
2456 local->func->reset_port(dev)) in prism2_ioctl_priv_prism2_param()
2466 local->host_roaming = value; in prism2_ioctl_priv_prism2_param()
2467 if (hostap_set_roaming(local) || local->func->reset_port(dev)) in prism2_ioctl_priv_prism2_param()
2473 local->bcrx_sta_key = value; in prism2_ioctl_priv_prism2_param()
2477 local->ieee_802_1x = value; in prism2_ioctl_priv_prism2_param()
2485 local->antsel_tx = value; in prism2_ioctl_priv_prism2_param()
2486 hostap_set_antsel(local); in prism2_ioctl_priv_prism2_param()
2494 local->antsel_rx = value; in prism2_ioctl_priv_prism2_param()
2495 hostap_set_antsel(local); in prism2_ioctl_priv_prism2_param()
2506 local->monitor_type = value; in prism2_ioctl_priv_prism2_param()
2507 if (local->iw_mode == IW_MODE_MONITOR) in prism2_ioctl_priv_prism2_param()
2508 hostap_monitor_set_type(local); in prism2_ioctl_priv_prism2_param()
2512 local->wds_type = value; in prism2_ioctl_priv_prism2_param()
2532 if (local->iw_mode == IW_MODE_MASTER) { in prism2_ioctl_priv_prism2_param()
2535 local->func->reset_port(dev)) in prism2_ioctl_priv_prism2_param()
2540 if (local->func->set_rid(dev, HFA384X_RID_HOSTSCAN, &scan_req, in prism2_ioctl_priv_prism2_param()
2545 if (local->iw_mode == IW_MODE_MASTER) { in prism2_ioctl_priv_prism2_param()
2548 add_wait_queue(&local->hostscan_wq, &__wait); in prism2_ioctl_priv_prism2_param()
2554 remove_wait_queue(&local->hostscan_wq, &__wait); in prism2_ioctl_priv_prism2_param()
2558 local->func->reset_port(dev)) in prism2_ioctl_priv_prism2_param()
2566 local->passive_scan_interval = value; in prism2_ioctl_priv_prism2_param()
2567 if (timer_pending(&local->passive_scan_timer)) in prism2_ioctl_priv_prism2_param()
2568 del_timer(&local->passive_scan_timer); in prism2_ioctl_priv_prism2_param()
2570 local->passive_scan_timer.expires = jiffies + in prism2_ioctl_priv_prism2_param()
2571 local->passive_scan_interval * HZ; in prism2_ioctl_priv_prism2_param()
2572 add_timer(&local->passive_scan_timer); in prism2_ioctl_priv_prism2_param()
2581 local->enh_sec = value; in prism2_ioctl_priv_prism2_param()
2583 local->enh_sec) || in prism2_ioctl_priv_prism2_param()
2584 local->func->reset_port(dev)) { in prism2_ioctl_priv_prism2_param()
2593 local->io_debug_enabled = value; in prism2_ioctl_priv_prism2_param()
2598 if ((value & local->tx_rate_control) != value || value == 0) { in prism2_ioctl_priv_prism2_param()
2605 local->basic_rates = value; in prism2_ioctl_priv_prism2_param()
2607 local->basic_rates) || in prism2_ioctl_priv_prism2_param()
2608 local->func->reset_port(dev)) in prism2_ioctl_priv_prism2_param()
2613 local->tx_rate_control = value; in prism2_ioctl_priv_prism2_param()
2619 ret = hostap_set_hostapd(local, value, 1); in prism2_ioctl_priv_prism2_param()
2623 ret = hostap_set_hostapd_sta(local, value, 1); in prism2_ioctl_priv_prism2_param()
2627 local->wpa = value; in prism2_ioctl_priv_prism2_param()
2628 if (local->sta_fw_ver < PRISM2_FW_VER(1,7,0)) in prism2_ioctl_priv_prism2_param()
2636 local->privacy_invoked = value; in prism2_ioctl_priv_prism2_param()
2637 if (hostap_set_encryption(local) || in prism2_ioctl_priv_prism2_param()
2638 local->func->reset_port(dev)) in prism2_ioctl_priv_prism2_param()
2643 local->tkip_countermeasures = value; in prism2_ioctl_priv_prism2_param()
2647 local->drop_unencrypted = value; in prism2_ioctl_priv_prism2_param()
2651 local->scan_channel_mask = value; in prism2_ioctl_priv_prism2_param()
2670 local_info_t *local; in prism2_ioctl_priv_get_prism2_param() local
2675 local = iface->local; in prism2_ioctl_priv_get_prism2_param()
2679 *param = local->fw_tx_rate_control; in prism2_ioctl_priv_get_prism2_param()
2683 *param = local->beacon_int; in prism2_ioctl_priv_get_prism2_param()
2687 *param = local->pseudo_adhoc; in prism2_ioctl_priv_get_prism2_param()
2695 *param = local->frame_dump; in prism2_ioctl_priv_get_prism2_param()
2699 if (local->ap != NULL) in prism2_ioctl_priv_get_prism2_param()
2700 *param = local->ap->ap_policy; in prism2_ioctl_priv_get_prism2_param()
2706 if (local->ap != NULL) in prism2_ioctl_priv_get_prism2_param()
2707 *param = local->ap->max_inactivity / HZ; in prism2_ioctl_priv_get_prism2_param()
2713 if (local->ap != NULL) in prism2_ioctl_priv_get_prism2_param()
2714 *param = local->ap->bridge_packets; in prism2_ioctl_priv_get_prism2_param()
2720 *param = local->dtim_period; in prism2_ioctl_priv_get_prism2_param()
2724 if (local->ap != NULL) in prism2_ioctl_priv_get_prism2_param()
2725 *param = local->ap->nullfunc_ack; in prism2_ioctl_priv_get_prism2_param()
2731 *param = local->wds_max_connections; in prism2_ioctl_priv_get_prism2_param()
2735 if (local->ap != NULL) in prism2_ioctl_priv_get_prism2_param()
2736 *param = local->ap->autom_ap_wds; in prism2_ioctl_priv_get_prism2_param()
2742 *param = local->auth_algs; in prism2_ioctl_priv_get_prism2_param()
2746 *param = local->monitor_allow_fcserr; in prism2_ioctl_priv_get_prism2_param()
2750 *param = local->host_encrypt; in prism2_ioctl_priv_get_prism2_param()
2754 *param = local->host_decrypt; in prism2_ioctl_priv_get_prism2_param()
2758 *param = local->host_roaming; in prism2_ioctl_priv_get_prism2_param()
2762 *param = local->bcrx_sta_key; in prism2_ioctl_priv_get_prism2_param()
2766 *param = local->ieee_802_1x; in prism2_ioctl_priv_get_prism2_param()
2770 *param = local->antsel_tx; in prism2_ioctl_priv_get_prism2_param()
2774 *param = local->antsel_rx; in prism2_ioctl_priv_get_prism2_param()
2778 *param = local->monitor_type; in prism2_ioctl_priv_get_prism2_param()
2782 *param = local->wds_type; in prism2_ioctl_priv_get_prism2_param()
2790 *param = local->passive_scan_interval; in prism2_ioctl_priv_get_prism2_param()
2794 *param = local->enh_sec; in prism2_ioctl_priv_get_prism2_param()
2799 *param = local->io_debug_enabled; in prism2_ioctl_priv_get_prism2_param()
2804 *param = local->basic_rates; in prism2_ioctl_priv_get_prism2_param()
2808 *param = local->tx_rate_control; in prism2_ioctl_priv_get_prism2_param()
2812 *param = local->hostapd; in prism2_ioctl_priv_get_prism2_param()
2816 *param = local->hostapd_sta; in prism2_ioctl_priv_get_prism2_param()
2820 if (local->sta_fw_ver < PRISM2_FW_VER(1,7,0)) in prism2_ioctl_priv_get_prism2_param()
2822 *param = local->wpa; in prism2_ioctl_priv_get_prism2_param()
2826 *param = local->privacy_invoked; in prism2_ioctl_priv_get_prism2_param()
2830 *param = local->tkip_countermeasures; in prism2_ioctl_priv_get_prism2_param()
2834 *param = local->drop_unencrypted; in prism2_ioctl_priv_get_prism2_param()
2838 *param = local->scan_channel_mask; in prism2_ioctl_priv_get_prism2_param()
2857 local_info_t *local; in prism2_ioctl_priv_readmif() local
2861 local = iface->local; in prism2_ioctl_priv_readmif()
2863 if (local->func->cmd(dev, HFA384X_CMDCODE_READMIF, *extra, NULL, in prism2_ioctl_priv_readmif()
2878 local_info_t *local; in prism2_ioctl_priv_writemif() local
2882 local = iface->local; in prism2_ioctl_priv_writemif()
2886 if (local->func->cmd(dev, HFA384X_CMDCODE_WRITEMIF, cr, &val, NULL)) in prism2_ioctl_priv_writemif()
2896 local_info_t *local; in prism2_ioctl_priv_monitor() local
2901 local = iface->local; in prism2_ioctl_priv_monitor()
2923 local->monitor_type = PRISM2_MONITOR_80211; in prism2_ioctl_priv_monitor()
2926 local->monitor_type = PRISM2_MONITOR_PRISM; in prism2_ioctl_priv_monitor()
2931 hostap_monitor_mode_enable(local); in prism2_ioctl_priv_monitor()
2942 local_info_t *local; in prism2_ioctl_priv_reset() local
2945 local = iface->local; in prism2_ioctl_priv_reset()
2951 local->func->hw_shutdown(dev, 1); in prism2_ioctl_priv_reset()
2952 local->func->hw_config(dev, 0); in prism2_ioctl_priv_reset()
2957 local->func->hw_reset(dev); in prism2_ioctl_priv_reset()
2962 local->func->reset_port(dev); in prism2_ioctl_priv_reset()
2966 prism2_sta_deauth(local, WLAN_REASON_DEAUTH_LEAVING); in prism2_ioctl_priv_reset()
2967 if (local->func->cmd(dev, HFA384X_CMDCODE_DISABLE, 0, NULL, in prism2_ioctl_priv_reset()
2973 if (local->func->cmd(dev, HFA384X_CMDCODE_ENABLE, 0, NULL, in prism2_ioctl_priv_reset()
3002 static int ap_mac_cmd_ioctl(local_info_t *local, int *cmd) in ap_mac_cmd_ioctl() argument
3008 local->ap->mac_restrictions.policy = MAC_POLICY_OPEN; in ap_mac_cmd_ioctl()
3011 local->ap->mac_restrictions.policy = MAC_POLICY_ALLOW; in ap_mac_cmd_ioctl()
3014 local->ap->mac_restrictions.policy = MAC_POLICY_DENY; in ap_mac_cmd_ioctl()
3017 ap_control_flush_macs(&local->ap->mac_restrictions); in ap_mac_cmd_ioctl()
3020 ap_control_kickall(local->ap); in ap_mac_cmd_ioctl()
3021 hostap_deauth_all_stas(local->dev, local->ap, 0); in ap_mac_cmd_ioctl()
3034 static int prism2_ioctl_priv_download(local_info_t *local, struct iw_point *p) in prism2_ioctl_priv_download() argument
3058 ret = local->func->download(local, param); in prism2_ioctl_priv_download()
3071 local_info_t *local = iface->local; in prism2_set_genericelement() local
3085 kfree(local->generic_elem); in prism2_set_genericelement()
3086 local->generic_elem = buf; in prism2_set_genericelement()
3087 local->generic_elem_len = len + 2; in prism2_set_genericelement()
3089 return local->func->set_rid(local->dev, HFA384X_RID_GENERICELEMENT, in prism2_set_genericelement()
3099 local_info_t *local = iface->local; in prism2_ioctl_siwauth() local
3112 local->tkip_countermeasures = data->value; in prism2_ioctl_siwauth()
3115 local->drop_unencrypted = data->value; in prism2_ioctl_siwauth()
3118 local->auth_algs = data->value; in prism2_ioctl_siwauth()
3122 local->wpa = 0; in prism2_ioctl_siwauth()
3123 if (local->sta_fw_ver < PRISM2_FW_VER(1,7,0)) in prism2_ioctl_siwauth()
3126 local->host_roaming = 0; in prism2_ioctl_siwauth()
3127 local->privacy_invoked = 0; in prism2_ioctl_siwauth()
3130 hostap_set_roaming(local) || in prism2_ioctl_siwauth()
3131 hostap_set_encryption(local) || in prism2_ioctl_siwauth()
3132 local->func->reset_port(dev)) in prism2_ioctl_siwauth()
3136 if (local->sta_fw_ver < PRISM2_FW_VER(1,7,0)) in prism2_ioctl_siwauth()
3138 local->host_roaming = 2; in prism2_ioctl_siwauth()
3139 local->privacy_invoked = 1; in prism2_ioctl_siwauth()
3140 local->wpa = 1; in prism2_ioctl_siwauth()
3142 hostap_set_roaming(local) || in prism2_ioctl_siwauth()
3143 hostap_set_encryption(local) || in prism2_ioctl_siwauth()
3144 local->func->reset_port(dev)) in prism2_ioctl_siwauth()
3148 local->ieee_802_1x = data->value; in prism2_ioctl_siwauth()
3151 local->privacy_invoked = data->value; in prism2_ioctl_siwauth()
3165 local_info_t *local = iface->local; in prism2_ioctl_giwauth() local
3178 data->value = local->tkip_countermeasures; in prism2_ioctl_giwauth()
3181 data->value = local->drop_unencrypted; in prism2_ioctl_giwauth()
3184 data->value = local->auth_algs; in prism2_ioctl_giwauth()
3187 data->value = local->wpa; in prism2_ioctl_giwauth()
3190 data->value = local->ieee_802_1x; in prism2_ioctl_giwauth()
3204 local_info_t *local = iface->local; in prism2_ioctl_siwencodeext() local
3217 i = local->crypt_info.tx_keyidx; in prism2_ioctl_siwencodeext()
3227 crypt = &local->crypt_info.crypt[i]; in prism2_ioctl_siwencodeext()
3231 sta_ptr = ap_crypt_get_ptrs(local->ap, addr, 0, &crypt); in prism2_ioctl_siwencodeext()
3233 if (local->iw_mode == IW_MODE_INFRA) { in prism2_ioctl_siwencodeext()
3240 crypt = &local->crypt_info.crypt[i]; in prism2_ioctl_siwencodeext()
3249 lib80211_crypt_delayed_deinit(&local->crypt_info, crypt); in prism2_ioctl_siwencodeext()
3268 local->dev->name, ext->alg); in prism2_ioctl_siwencodeext()
3280 local->dev->name, alg); in prism2_ioctl_siwencodeext()
3291 local->host_decrypt = local->host_encrypt = 1; in prism2_ioctl_siwencodeext()
3297 lib80211_crypt_delayed_deinit(&local->crypt_info, crypt); in prism2_ioctl_siwencodeext()
3328 local->dev->name); in prism2_ioctl_siwencodeext()
3335 local->crypt_info.tx_keyidx = i; in prism2_ioctl_siwencodeext()
3342 if (j != i && local->crypt_info.crypt[j]) { in prism2_ioctl_siwencodeext()
3348 local->crypt_info.tx_keyidx = i; in prism2_ioctl_siwencodeext()
3355 local->open_wep = erq->flags & IW_ENCODE_OPEN; in prism2_ioctl_siwencodeext()
3365 (hostap_set_encryption(local) || in prism2_ioctl_siwencodeext()
3366 (local->iw_mode != IW_MODE_INFRA && in prism2_ioctl_siwencodeext()
3367 local->func->reset_port(local->dev)))) in prism2_ioctl_siwencodeext()
3379 local_info_t *local = iface->local; in prism2_ioctl_giwencodeext() local
3392 i = local->crypt_info.tx_keyidx; in prism2_ioctl_giwencodeext()
3400 crypt = &local->crypt_info.crypt[i]; in prism2_ioctl_giwencodeext()
3403 sta_ptr = ap_crypt_get_ptrs(local->ap, addr, 0, &crypt); in prism2_ioctl_giwencodeext()
3444 static int prism2_ioctl_set_encryption(local_info_t *local, in prism2_ioctl_set_encryption() argument
3467 crypt = &local->crypt_info.crypt[param->u.crypt.idx]; in prism2_ioctl_set_encryption()
3472 local->ap, param->sta_addr, in prism2_ioctl_set_encryption()
3484 lib80211_crypt_delayed_deinit(&local->crypt_info, crypt); in prism2_ioctl_set_encryption()
3501 local->dev->name, param->u.crypt.alg); in prism2_ioctl_set_encryption()
3509 local->host_decrypt = local->host_encrypt = 1; in prism2_ioctl_set_encryption()
3514 lib80211_crypt_delayed_deinit(&local->crypt_info, crypt); in prism2_ioctl_set_encryption()
3541 local->dev->name); in prism2_ioctl_set_encryption()
3549 local->crypt_info.tx_keyidx = param->u.crypt.idx; in prism2_ioctl_set_encryption()
3552 local->dev->name); in prism2_ioctl_set_encryption()
3570 (hostap_set_encryption(local) || in prism2_ioctl_set_encryption()
3571 (local->iw_mode != IW_MODE_INFRA && in prism2_ioctl_set_encryption()
3572 local->func->reset_port(local->dev)))) { in prism2_ioctl_set_encryption()
3581 static int prism2_ioctl_get_encryption(local_info_t *local, in prism2_ioctl_get_encryption() argument
3601 param->u.crypt.idx = local->crypt_info.tx_keyidx; in prism2_ioctl_get_encryption()
3602 crypt = &local->crypt_info.crypt[param->u.crypt.idx]; in prism2_ioctl_get_encryption()
3605 sta_ptr = ap_crypt_get_ptrs(local->ap, param->sta_addr, 0, in prism2_ioctl_get_encryption()
3640 static int prism2_ioctl_get_rid(local_info_t *local, in prism2_ioctl_get_rid() argument
3650 res = local->func->get_rid(local->dev, param->u.rid.rid, in prism2_ioctl_get_rid()
3661 static int prism2_ioctl_set_rid(local_info_t *local, in prism2_ioctl_set_rid() argument
3671 return local->func->set_rid(local->dev, param->u.rid.rid, in prism2_ioctl_set_rid()
3676 static int prism2_ioctl_set_assoc_ap_addr(local_info_t *local, in prism2_ioctl_set_assoc_ap_addr() argument
3681 local->dev->name, param->sta_addr); in prism2_ioctl_set_assoc_ap_addr()
3682 memcpy(local->assoc_ap_addr, param->sta_addr, ETH_ALEN); in prism2_ioctl_set_assoc_ap_addr()
3700 local_info_t *local = iface->local; in prism2_ioctl_giwgenie() local
3701 int len = local->generic_elem_len - 2; in prism2_ioctl_giwgenie()
3703 if (len <= 0 || local->generic_elem == NULL) { in prism2_ioctl_giwgenie()
3712 memcpy(extra, local->generic_elem + 2, len); in prism2_ioctl_giwgenie()
3718 static int prism2_ioctl_set_generic_element(local_info_t *local, in prism2_ioctl_set_generic_element() argument
3729 return prism2_set_genericelement(local->dev, in prism2_ioctl_set_generic_element()
3739 local_info_t *local = iface->local; in prism2_ioctl_siwmlme() local
3747 return prism2_sta_send_mgmt(local, mlme->addr.sa_data, in prism2_ioctl_siwmlme()
3751 return prism2_sta_send_mgmt(local, mlme->addr.sa_data, in prism2_ioctl_siwmlme()
3760 static int prism2_ioctl_mlme(local_info_t *local, in prism2_ioctl_mlme() argument
3768 return prism2_sta_send_mgmt(local, param->sta_addr, in prism2_ioctl_mlme()
3772 return prism2_sta_send_mgmt(local, param->sta_addr, in prism2_ioctl_mlme()
3781 static int prism2_ioctl_scan_req(local_info_t *local, in prism2_ioctl_scan_req() argument
3785 if ((local->iw_mode != IW_MODE_INFRA && in prism2_ioctl_scan_req()
3786 local->iw_mode != IW_MODE_ADHOC) || in prism2_ioctl_scan_req()
3787 (local->sta_fw_ver < PRISM2_FW_VER(1,3,1))) in prism2_ioctl_scan_req()
3790 if (!local->dev_enabled) in prism2_ioctl_scan_req()
3793 return prism2_request_hostscan(local->dev, param->u.scan_req.ssid, in prism2_ioctl_scan_req()
3801 static int prism2_ioctl_priv_hostapd(local_info_t *local, struct iw_point *p) in prism2_ioctl_priv_hostapd() argument
3822 ret = prism2_ioctl_set_encryption(local, param, p->length); in prism2_ioctl_priv_hostapd()
3825 ret = prism2_ioctl_get_encryption(local, param, p->length); in prism2_ioctl_priv_hostapd()
3828 ret = prism2_ioctl_get_rid(local, param, p->length); in prism2_ioctl_priv_hostapd()
3831 ret = prism2_ioctl_set_rid(local, param, p->length); in prism2_ioctl_priv_hostapd()
3834 ret = prism2_ioctl_set_assoc_ap_addr(local, param, p->length); in prism2_ioctl_priv_hostapd()
3837 ret = prism2_ioctl_set_generic_element(local, param, in prism2_ioctl_priv_hostapd()
3841 ret = prism2_ioctl_mlme(local, param); in prism2_ioctl_priv_hostapd()
3844 ret = prism2_ioctl_scan_req(local, param); in prism2_ioctl_priv_hostapd()
3847 ret = prism2_hostapd(local->ap, param); in prism2_ioctl_priv_hostapd()
3870 local_info_t *local; in prism2_get_drvinfo() local
3873 local = iface->local; in prism2_get_drvinfo()
3877 "%d.%d.%d", (local->sta_fw_ver >> 16) & 0xff, in prism2_get_drvinfo()
3878 (local->sta_fw_ver >> 8) & 0xff, in prism2_get_drvinfo()
3879 local->sta_fw_ver & 0xff); in prism2_get_drvinfo()
3973 local_info_t *local; in hostap_ioctl() local
3977 local = iface->local; in hostap_ioctl()
4000 else ret = prism2_wds_add(local, wrq->u.ap_addr.sa_data, 1); in hostap_ioctl()
4005 else ret = prism2_wds_del(local, wrq->u.ap_addr.sa_data, 1, 0); in hostap_ioctl()
4017 else ret = ap_mac_cmd_ioctl(local, (int *) wrq->u.name); in hostap_ioctl()
4022 else ret = ap_control_add_mac(&local->ap->mac_restrictions, in hostap_ioctl()
4027 else ret = ap_control_del_mac(&local->ap->mac_restrictions, in hostap_ioctl()
4032 else ret = ap_control_kick_mac(local->ap, local->dev, in hostap_ioctl()
4044 else ret = prism2_ioctl_priv_download(local, &wrq->u.data); in hostap_ioctl()
4050 else ret = prism2_ioctl_priv_hostapd(local, &wrq->u.data); in hostap_ioctl()