From owner-p4-projects@FreeBSD.ORG Tue Nov 23 22:44:12 2004 Return-Path: Delivered-To: p4-projects@freebsd.org Received: by hub.freebsd.org (Postfix, from userid 32767) id 7264616A4D0; Tue, 23 Nov 2004 22:44:12 +0000 (GMT) Delivered-To: perforce@freebsd.org Received: from mx1.FreeBSD.org (mx1.freebsd.org [216.136.204.125]) by hub.freebsd.org (Postfix) with ESMTP id 3563016A4CE for ; Tue, 23 Nov 2004 22:44:12 +0000 (GMT) Received: from repoman.freebsd.org (repoman.freebsd.org [216.136.204.115]) by mx1.FreeBSD.org (Postfix) with ESMTP id 08BFE43D55 for ; Tue, 23 Nov 2004 22:44:12 +0000 (GMT) (envelope-from sam@freebsd.org) Received: from repoman.freebsd.org (localhost [127.0.0.1]) by repoman.freebsd.org (8.13.1/8.13.1) with ESMTP id iANMiBCS078043 for ; Tue, 23 Nov 2004 22:44:11 GMT (envelope-from sam@freebsd.org) Received: (from perforce@localhost) by repoman.freebsd.org (8.13.1/8.13.1/Submit) id iANMiBMj078040 for perforce@freebsd.org; Tue, 23 Nov 2004 22:44:11 GMT (envelope-from sam@freebsd.org) Date: Tue, 23 Nov 2004 22:44:11 GMT Message-Id: <200411232244.iANMiBMj078040@repoman.freebsd.org> X-Authentication-Warning: repoman.freebsd.org: perforce set sender to sam@freebsd.org using -f From: Sam Leffler To: Perforce Change Reviews Subject: PERFORCE change 65734 for review X-BeenThere: p4-projects@freebsd.org X-Mailman-Version: 2.1.1 Precedence: list List-Id: p4 projects tree changes List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Tue, 23 Nov 2004 22:44:13 -0000 http://perforce.freebsd.org/chv.cgi?CH=65734 Change 65734 by sam@sam_ebb on 2004/11/23 22:43:12 o redo callback decls+definitions using macros o add basic wme parameters Affected files ... .. //depot/projects/wifi/sbin/ifconfig/ifieee80211.c#16 edit Differences ... ==== //depot/projects/wifi/sbin/ifconfig/ifieee80211.c#16 (text+ko) ==== @@ -481,40 +481,82 @@ } } -static void -set80211cwmin(const char *val, int d, int s, const struct afswtch *rafp) +static int +getac(const char *ac) +{ + if (strcasecmp(ac, "ac_be") == 0 || strcasecmp(ac, "be") == 0) + return WME_AC_BE; + if (strcasecmp(ac, "ac_bk") == 0 || strcasecmp(ac, "bk") == 0) + return WME_AC_BK; + if (strcasecmp(ac, "ac_vi") == 0 || strcasecmp(ac, "vi") == 0) + return WME_AC_VI; + if (strcasecmp(ac, "ac_vo") == 0 || strcasecmp(ac, "vo") == 0) + return WME_AC_VO; + errx(1, "unknown wme access class %s", ac); +} + +static +DECL_CMD_FUNC2(set80211cwmin, ac, val) +{ + set80211(s, IEEE80211_IOC_WME_CWMIN, atoi(val), getac(ac), NULL); +} + +static +DECL_CMD_FUNC2(set80211cwmax, ac, val) +{ + set80211(s, IEEE80211_IOC_WME_CWMAX, atoi(val), getac(ac), NULL); +} + +static +DECL_CMD_FUNC2(set80211aifs, ac, val) +{ + set80211(s, IEEE80211_IOC_WME_AIFS, atoi(val), getac(ac), NULL); +} + +static +DECL_CMD_FUNC2(set80211txoplimit, ac, val) +{ + set80211(s, IEEE80211_IOC_WME_TXOPLIMIT, atoi(val), getac(ac), NULL); +} + +static +DECL_CMD_FUNC(set80211acm, val, d) { - set80211(s, IEEE80211_IOC_WME_CWMIN, atoi(val), 0, NULL); + set80211(s, IEEE80211_IOC_WME_ACM, d, WME_AC_BE, NULL); } -static void -set80211cwmax(const char *val, int d, int s, const struct afswtch *rafp) +static +DECL_CMD_FUNC(set80211ackpolicy, val, d) { - set80211(s, IEEE80211_IOC_WME_CWMAX, atoi(val), 0, NULL); + set80211(s, IEEE80211_IOC_WME_ACKPOLICY, d, WME_AC_BE, NULL); } -static void -set80211aifs(const char *val, int d, int s, const struct afswtch *rafp) +static +DECL_CMD_FUNC2(set80211bsscwmin, ac, val) { - set80211(s, IEEE80211_IOC_WME_AIFS, atoi(val), 0, NULL); + set80211(s, IEEE80211_IOC_WME_CWMIN, atoi(val), + getac(ac)|IEEE80211_WMEPARAM_BSS, NULL); } -static void -set80211txoplimit(const char *val, int d, int s, const struct afswtch *rafp) +static +DECL_CMD_FUNC2(set80211bsscwmax, ac, val) { - set80211(s, IEEE80211_IOC_WME_TXOPLIMIT, atoi(val), 0, NULL); + set80211(s, IEEE80211_IOC_WME_CWMAX, atoi(val), + getac(ac)|IEEE80211_WMEPARAM_BSS, NULL); } -static void -set80211acm(const char *val, int d, int s, const struct afswtch *rafp) +static +DECL_CMD_FUNC2(set80211bssaifs, ac, val) { - set80211(s, IEEE80211_IOC_WME_ACM, atoi(val), 0, NULL); + set80211(s, IEEE80211_IOC_WME_AIFS, atoi(val), + getac(ac)|IEEE80211_WMEPARAM_BSS, NULL); } -static void -set80211ackpolicy(const char *val, int d, int s, const struct afswtch *rafp) +static +DECL_CMD_FUNC2(set80211bsstxoplimit, ac, val) { - set80211(s, IEEE80211_IOC_WME_ACKPOLICY, d, 0, NULL); + set80211(s, IEEE80211_IOC_WME_TXOPLIMIT, atoi(val), + getac(ac)|IEEE80211_WMEPARAM_BSS, NULL); } static int @@ -726,8 +768,8 @@ close(sroute); } -static void -set80211scan(const char *val, int d, int s, const struct afswtch *rafp) +static +DECL_CMD_FUNC(set80211scan, val, d) { scan_and_wait(s); list_scan(s); @@ -914,7 +956,65 @@ } static void -set80211list(const char *arg, int d, int s, const struct afswtch *rafp) +list_wme(int s) +{ + static const char *acnames[] = { "AC_BE", "AC_BK", "AC_VI", "AC_VO" }; + struct ieee80211req ireq; + int ac; + + (void) memset(&ireq, 0, sizeof(ireq)); + (void) strncpy(ireq.i_name, name, sizeof(ireq.i_name)); + ireq.i_len = 0; + for (ac = WME_AC_BE; ac <= WME_AC_VO; ac++) { +again: + if (ireq.i_len & IEEE80211_WMEPARAM_BSS) + printf("\t%s", " "); + else + printf("\t%s", acnames[ac]); + + ireq.i_len = (ireq.i_len & IEEE80211_WMEPARAM_BSS) | ac; + + /* show WME BSS parameters */ + ireq.i_type = IEEE80211_IOC_WME_CWMIN; + if (ioctl(s, SIOCG80211, &ireq) != -1) + printf(" cwmin %2u", ireq.i_val); + ireq.i_type = IEEE80211_IOC_WME_CWMAX; + if (ioctl(s, SIOCG80211, &ireq) != -1) + printf(" cwmax %2u", ireq.i_val); + ireq.i_type = IEEE80211_IOC_WME_AIFS; + if (ioctl(s, SIOCG80211, &ireq) != -1) + printf(" aifs %2u", ireq.i_val); + ireq.i_type = IEEE80211_IOC_WME_TXOPLIMIT; + if (ioctl(s, SIOCG80211, &ireq) != -1) + printf(" txopLimit %3u", ireq.i_val); + ireq.i_type = IEEE80211_IOC_WME_ACM; + if (ioctl(s, SIOCG80211, &ireq) != -1) { + if (ireq.i_val) + printf(" acm"); + else if (verbose) + printf(" -acm"); + } + /* !BSS only */ + if ((ireq.i_len & IEEE80211_WMEPARAM_BSS) == 0) { + ireq.i_type = IEEE80211_IOC_WME_ACKPOLICY; + if (ioctl(s, SIOCG80211, &ireq) != -1) { + if (!ireq.i_val) + printf(" -ack"); + else if (verbose) + printf(" ack"); + } + } + printf("\n"); + if ((ireq.i_len & IEEE80211_WMEPARAM_BSS) == 0) { + ireq.i_len |= IEEE80211_WMEPARAM_BSS; + goto again; + } else + ireq.i_len &= ~IEEE80211_WMEPARAM_BSS; + } +} + +static +DECL_CMD_FUNC(set80211list, arg, d) { #define iseq(a,b) (strncasecmp(a,b,sizeof(b)-1) == 0) @@ -928,6 +1028,8 @@ list_keys(s); else if (iseq(arg, "caps")) list_capabilities(s); + else if (iseq(arg, "wme")) + list_wme(s); else errx(1, "Don't know how to list %s for %s", arg, name); #undef iseq @@ -1054,7 +1156,7 @@ { static const uint8_t zerobssid[IEEE80211_ADDR_LEN]; enum ieee80211_opmode opmode = get80211opmode(s); - int i, num, wpa; + int i, num, wpa, wme; struct ieee80211req ireq; u_int8_t data[32]; char spacer; @@ -1302,14 +1404,16 @@ ireq.i_type = IEEE80211_IOC_WME; if (ioctl(s, SIOCG80211, &ireq) != -1) { - if (ireq.i_val) { + wme = ireq.i_val; + if (wme) { printf("%cwme", spacer); spacer = ' '; } else if (verbose) { printf("%c-wme", spacer); spacer = ' '; } - } + } else + wme = 0; if (opmode == IEEE80211_M_HOSTAP) { ireq.i_type = IEEE80211_IOC_HIDESSID; @@ -1359,6 +1463,9 @@ printf("\n"); spacer = '\t'; + if (wme && verbose) + list_wme(s); + if (wpa) { spacer = '\t'; ireq.i_type = IEEE80211_IOC_COUNTERMEASURES; @@ -1507,45 +1614,50 @@ } static struct cmd ieee80211_cmds[] = { - { "ssid", NEXTARG, set80211ssid }, - { "nwid", NEXTARG, set80211ssid }, - { "stationname", NEXTARG, set80211stationname }, - { "station", NEXTARG, set80211stationname }, /* BSD/OS */ - { "channel", NEXTARG, set80211channel }, - { "authmode", NEXTARG, set80211authmode }, - { "powersavemode", NEXTARG, set80211powersavemode }, - { "powersave", 1, set80211powersave }, - { "-powersave", 0, set80211powersave }, - { "powersavesleep", NEXTARG, set80211powersavesleep }, - { "wepmode", NEXTARG, set80211wepmode }, - { "wep", 1, set80211wep }, - { "-wep", 0, set80211wep }, - { "weptxkey", NEXTARG, set80211weptxkey }, - { "wepkey", NEXTARG, set80211wepkey }, - { "nwkey", NEXTARG, set80211nwkey }, /* NetBSD */ - { "-nwkey", 0, set80211wep }, /* NetBSD */ - { "rtsthreshold",NEXTARG, set80211rtsthreshold }, - { "protmode", NEXTARG, set80211protmode }, - { "txpower", NEXTARG, set80211txpower }, - { "roaming", NEXTARG, set80211roaming }, - { "wme", 1, set80211wme }, - { "-wme", 0, set80211wme }, - { "hidessid", 1, set80211hidessid }, - { "-hidessid", 0, set80211hidessid }, - { "apbridge", 1, set80211apbridge }, - { "-apbridge", 0, set80211apbridge }, - { "chanlist", NEXTARG, set80211chanlist }, - { "bssid", NEXTARG, set80211bssid }, - { "ap", NEXTARG, set80211bssid }, - { "scan", 0, set80211scan }, - { "list", NEXTARG, set80211list }, - { "cwmin", NEXTARG, set80211cwmin }, - { "cwmax", NEXTARG, set80211cwmax }, - { "aifs", NEXTARG, set80211aifs }, - { "txoplimit", NEXTARG, set80211txoplimit }, - { "acm", NEXTARG, set80211acm }, - { "ack", 1, set80211ackpolicy }, - { "-ack", 0, set80211ackpolicy }, + DEF_CMD_ARG("ssid", set80211ssid), + DEF_CMD_ARG("nwid", set80211ssid), + DEF_CMD_ARG("stationname", set80211stationname), + DEF_CMD_ARG("station", set80211stationname), /* BSD/OS */ + DEF_CMD_ARG("channel", set80211channel), + DEF_CMD_ARG("authmode", set80211authmode), + DEF_CMD_ARG("powersavemode", set80211powersavemode), + DEF_CMD("powersave", 1, set80211powersave), + DEF_CMD("-powersave", 0, set80211powersave), + DEF_CMD_ARG("powersavesleep", set80211powersavesleep), + DEF_CMD_ARG("wepmode", set80211wepmode), + DEF_CMD("wep", 1, set80211wep), + DEF_CMD("-wep", 0, set80211wep), + DEF_CMD_ARG("weptxkey", set80211weptxkey), + DEF_CMD_ARG("wepkey", set80211wepkey), + DEF_CMD_ARG("nwkey", set80211nwkey), /* NetBSD */ + DEF_CMD("-nwkey", 0, set80211wep), /* NetBSD */ + DEF_CMD_ARG("rtsthreshold", set80211rtsthreshold), + DEF_CMD_ARG("protmode", set80211protmode), + DEF_CMD_ARG("txpower", set80211txpower), + DEF_CMD_ARG("roaming", set80211roaming), + DEF_CMD("wme", 1, set80211wme), + DEF_CMD("-wme", 0, set80211wme), + DEF_CMD("hidessid", 1, set80211hidessid), + DEF_CMD("-hidessid", 0, set80211hidessid), + DEF_CMD("apbridge", 1, set80211apbridge), + DEF_CMD("-apbridge", 0, set80211apbridge), + DEF_CMD_ARG("chanlist", set80211chanlist), + DEF_CMD_ARG("bssid", set80211bssid), + DEF_CMD_ARG("ap", set80211bssid), + DEF_CMD("scan", 0, set80211scan), + DEF_CMD_ARG("list", set80211list), + DEF_CMD_ARG2("cwmin", set80211cwmin), + DEF_CMD_ARG2("cwmax", set80211cwmax), + DEF_CMD_ARG2("aifs", set80211aifs), + DEF_CMD_ARG2("txoplimit", set80211txoplimit), + DEF_CMD("acm", 1, set80211acm), + DEF_CMD("-acm", 0, set80211acm), + DEF_CMD("ack", 1, set80211ackpolicy), + DEF_CMD("-ack", 0, set80211ackpolicy), + DEF_CMD_ARG2("bss:cwmin", set80211bsscwmin), + DEF_CMD_ARG2("bss:cwmax", set80211bsscwmax), + DEF_CMD_ARG2("bss:aifs", set80211bssaifs), + DEF_CMD_ARG2("bss:txoplimit", set80211bsstxoplimit), }; static struct afswtch af_ieee80211 = { .af_name = "ieee80211",