diff options
Diffstat (limited to 'net')
-rw-r--r-- | net/ieee80211/Kconfig | 1 | ||||
-rw-r--r-- | net/ieee80211/ieee80211_module.c | 26 | ||||
-rw-r--r-- | net/ieee80211/ieee80211_rx.c | 31 | ||||
-rw-r--r-- | net/ieee80211/ieee80211_wx.c | 6 | ||||
-rw-r--r-- | net/wireless/Kconfig | 10 | ||||
-rw-r--r-- | net/wireless/Makefile | 1 | ||||
-rw-r--r-- | net/wireless/lib80211.c | 58 |
7 files changed, 89 insertions, 44 deletions
diff --git a/net/ieee80211/Kconfig b/net/ieee80211/Kconfig index df9624c3cebf..d2282bb2e4f1 100644 --- a/net/ieee80211/Kconfig +++ b/net/ieee80211/Kconfig | |||
@@ -11,6 +11,7 @@ config IEEE80211 | |||
11 | select IEEE80211_CRYPT_WEP | 11 | select IEEE80211_CRYPT_WEP |
12 | select IEEE80211_CRYPT_TKIP | 12 | select IEEE80211_CRYPT_TKIP |
13 | select IEEE80211_CRYPT_CCMP | 13 | select IEEE80211_CRYPT_CCMP |
14 | select LIB80211 | ||
14 | ---help--- | 15 | ---help--- |
15 | This option enables the hardware independent IEEE 802.11 | 16 | This option enables the hardware independent IEEE 802.11 |
16 | networking stack. This component is deprecated in favor of the | 17 | networking stack. This component is deprecated in favor of the |
diff --git a/net/ieee80211/ieee80211_module.c b/net/ieee80211/ieee80211_module.c index 949772a5a7dc..d34d4e79b6f7 100644 --- a/net/ieee80211/ieee80211_module.c +++ b/net/ieee80211/ieee80211_module.c | |||
@@ -308,31 +308,5 @@ MODULE_PARM_DESC(debug, "debug output mask"); | |||
308 | module_exit(ieee80211_exit); | 308 | module_exit(ieee80211_exit); |
309 | module_init(ieee80211_init); | 309 | module_init(ieee80211_init); |
310 | 310 | ||
311 | const char *escape_essid(const char *essid, u8 essid_len) | ||
312 | { | ||
313 | static char escaped[IW_ESSID_MAX_SIZE * 2 + 1]; | ||
314 | const char *s = essid; | ||
315 | char *d = escaped; | ||
316 | |||
317 | if (ieee80211_is_empty_essid(essid, essid_len)) { | ||
318 | memcpy(escaped, "<hidden>", sizeof("<hidden>")); | ||
319 | return escaped; | ||
320 | } | ||
321 | |||
322 | essid_len = min(essid_len, (u8) IW_ESSID_MAX_SIZE); | ||
323 | while (essid_len--) { | ||
324 | if (*s == '\0') { | ||
325 | *d++ = '\\'; | ||
326 | *d++ = '0'; | ||
327 | s++; | ||
328 | } else { | ||
329 | *d++ = *s++; | ||
330 | } | ||
331 | } | ||
332 | *d = '\0'; | ||
333 | return escaped; | ||
334 | } | ||
335 | |||
336 | EXPORT_SYMBOL(alloc_ieee80211); | 311 | EXPORT_SYMBOL(alloc_ieee80211); |
337 | EXPORT_SYMBOL(free_ieee80211); | 312 | EXPORT_SYMBOL(free_ieee80211); |
338 | EXPORT_SYMBOL(escape_essid); | ||
diff --git a/net/ieee80211/ieee80211_rx.c b/net/ieee80211/ieee80211_rx.c index 281223e41c58..876a004918b0 100644 --- a/net/ieee80211/ieee80211_rx.c +++ b/net/ieee80211/ieee80211_rx.c | |||
@@ -32,6 +32,7 @@ | |||
32 | #include <asm/uaccess.h> | 32 | #include <asm/uaccess.h> |
33 | #include <linux/ctype.h> | 33 | #include <linux/ctype.h> |
34 | 34 | ||
35 | #include <net/lib80211.h> | ||
35 | #include <net/ieee80211.h> | 36 | #include <net/ieee80211.h> |
36 | 37 | ||
37 | static void ieee80211_monitor_rx(struct ieee80211_device *ieee, | 38 | static void ieee80211_monitor_rx(struct ieee80211_device *ieee, |
@@ -1145,8 +1146,8 @@ static int ieee80211_parse_info_param(struct ieee80211_info_element | |||
1145 | 1146 | ||
1146 | switch (info_element->id) { | 1147 | switch (info_element->id) { |
1147 | case MFIE_TYPE_SSID: | 1148 | case MFIE_TYPE_SSID: |
1148 | if (ieee80211_is_empty_essid(info_element->data, | 1149 | if (is_empty_ssid(info_element->data, |
1149 | info_element->len)) { | 1150 | info_element->len)) { |
1150 | network->flags |= NETWORK_EMPTY_ESSID; | 1151 | network->flags |= NETWORK_EMPTY_ESSID; |
1151 | break; | 1152 | break; |
1152 | } | 1153 | } |
@@ -1390,7 +1391,7 @@ static int ieee80211_handle_assoc_resp(struct ieee80211_device *ieee, struct iee | |||
1390 | network->mode |= IEEE_B; | 1391 | network->mode |= IEEE_B; |
1391 | } | 1392 | } |
1392 | 1393 | ||
1393 | if (ieee80211_is_empty_essid(network->ssid, network->ssid_len)) | 1394 | if (is_empty_ssid(network->ssid, network->ssid_len)) |
1394 | network->flags |= NETWORK_EMPTY_ESSID; | 1395 | network->flags |= NETWORK_EMPTY_ESSID; |
1395 | 1396 | ||
1396 | memcpy(&network->stats, stats, sizeof(network->stats)); | 1397 | memcpy(&network->stats, stats, sizeof(network->stats)); |
@@ -1456,13 +1457,13 @@ static int ieee80211_network_init(struct ieee80211_device *ieee, struct ieee8021 | |||
1456 | if (network->mode == 0) { | 1457 | if (network->mode == 0) { |
1457 | IEEE80211_DEBUG_SCAN("Filtered out '%s (%pM)' " | 1458 | IEEE80211_DEBUG_SCAN("Filtered out '%s (%pM)' " |
1458 | "network.\n", | 1459 | "network.\n", |
1459 | escape_essid(network->ssid, | 1460 | escape_ssid(network->ssid, |
1460 | network->ssid_len), | 1461 | network->ssid_len), |
1461 | network->bssid); | 1462 | network->bssid); |
1462 | return 1; | 1463 | return 1; |
1463 | } | 1464 | } |
1464 | 1465 | ||
1465 | if (ieee80211_is_empty_essid(network->ssid, network->ssid_len)) | 1466 | if (is_empty_ssid(network->ssid, network->ssid_len)) |
1466 | network->flags |= NETWORK_EMPTY_ESSID; | 1467 | network->flags |= NETWORK_EMPTY_ESSID; |
1467 | 1468 | ||
1468 | memcpy(&network->stats, stats, sizeof(network->stats)); | 1469 | memcpy(&network->stats, stats, sizeof(network->stats)); |
@@ -1576,7 +1577,7 @@ static void ieee80211_process_probe_response(struct ieee80211_device | |||
1576 | 1577 | ||
1577 | IEEE80211_DEBUG_SCAN("'%s' (%pM" | 1578 | IEEE80211_DEBUG_SCAN("'%s' (%pM" |
1578 | "): %c%c%c%c %c%c%c%c-%c%c%c%c %c%c%c%c\n", | 1579 | "): %c%c%c%c %c%c%c%c-%c%c%c%c %c%c%c%c\n", |
1579 | escape_essid(info_element->data, info_element->len), | 1580 | escape_ssid(info_element->data, info_element->len), |
1580 | beacon->header.addr3, | 1581 | beacon->header.addr3, |
1581 | (beacon->capability & cpu_to_le16(1 << 0xf)) ? '1' : '0', | 1582 | (beacon->capability & cpu_to_le16(1 << 0xf)) ? '1' : '0', |
1582 | (beacon->capability & cpu_to_le16(1 << 0xe)) ? '1' : '0', | 1583 | (beacon->capability & cpu_to_le16(1 << 0xe)) ? '1' : '0', |
@@ -1597,8 +1598,8 @@ static void ieee80211_process_probe_response(struct ieee80211_device | |||
1597 | 1598 | ||
1598 | if (ieee80211_network_init(ieee, beacon, &network, stats)) { | 1599 | if (ieee80211_network_init(ieee, beacon, &network, stats)) { |
1599 | IEEE80211_DEBUG_SCAN("Dropped '%s' (%pM) via %s.\n", | 1600 | IEEE80211_DEBUG_SCAN("Dropped '%s' (%pM) via %s.\n", |
1600 | escape_essid(info_element->data, | 1601 | escape_ssid(info_element->data, |
1601 | info_element->len), | 1602 | info_element->len), |
1602 | beacon->header.addr3, | 1603 | beacon->header.addr3, |
1603 | is_beacon(beacon->header.frame_ctl) ? | 1604 | is_beacon(beacon->header.frame_ctl) ? |
1604 | "BEACON" : "PROBE RESPONSE"); | 1605 | "BEACON" : "PROBE RESPONSE"); |
@@ -1635,8 +1636,8 @@ static void ieee80211_process_probe_response(struct ieee80211_device | |||
1635 | target = oldest; | 1636 | target = oldest; |
1636 | IEEE80211_DEBUG_SCAN("Expired '%s' (%pM) from " | 1637 | IEEE80211_DEBUG_SCAN("Expired '%s' (%pM) from " |
1637 | "network list.\n", | 1638 | "network list.\n", |
1638 | escape_essid(target->ssid, | 1639 | escape_ssid(target->ssid, |
1639 | target->ssid_len), | 1640 | target->ssid_len), |
1640 | target->bssid); | 1641 | target->bssid); |
1641 | ieee80211_network_reset(target); | 1642 | ieee80211_network_reset(target); |
1642 | } else { | 1643 | } else { |
@@ -1648,8 +1649,8 @@ static void ieee80211_process_probe_response(struct ieee80211_device | |||
1648 | 1649 | ||
1649 | #ifdef CONFIG_IEEE80211_DEBUG | 1650 | #ifdef CONFIG_IEEE80211_DEBUG |
1650 | IEEE80211_DEBUG_SCAN("Adding '%s' (%pM) via %s.\n", | 1651 | IEEE80211_DEBUG_SCAN("Adding '%s' (%pM) via %s.\n", |
1651 | escape_essid(network.ssid, | 1652 | escape_ssid(network.ssid, |
1652 | network.ssid_len), | 1653 | network.ssid_len), |
1653 | network.bssid, | 1654 | network.bssid, |
1654 | is_beacon(beacon->header.frame_ctl) ? | 1655 | is_beacon(beacon->header.frame_ctl) ? |
1655 | "BEACON" : "PROBE RESPONSE"); | 1656 | "BEACON" : "PROBE RESPONSE"); |
@@ -1659,8 +1660,8 @@ static void ieee80211_process_probe_response(struct ieee80211_device | |||
1659 | list_add_tail(&target->list, &ieee->network_list); | 1660 | list_add_tail(&target->list, &ieee->network_list); |
1660 | } else { | 1661 | } else { |
1661 | IEEE80211_DEBUG_SCAN("Updating '%s' (%pM) via %s.\n", | 1662 | IEEE80211_DEBUG_SCAN("Updating '%s' (%pM) via %s.\n", |
1662 | escape_essid(target->ssid, | 1663 | escape_ssid(target->ssid, |
1663 | target->ssid_len), | 1664 | target->ssid_len), |
1664 | target->bssid, | 1665 | target->bssid, |
1665 | is_beacon(beacon->header.frame_ctl) ? | 1666 | is_beacon(beacon->header.frame_ctl) ? |
1666 | "BEACON" : "PROBE RESPONSE"); | 1667 | "BEACON" : "PROBE RESPONSE"); |
diff --git a/net/ieee80211/ieee80211_wx.c b/net/ieee80211/ieee80211_wx.c index 89a81062ab4b..3b031c2910ac 100644 --- a/net/ieee80211/ieee80211_wx.c +++ b/net/ieee80211/ieee80211_wx.c | |||
@@ -283,8 +283,8 @@ int ieee80211_wx_get_scan(struct ieee80211_device *ieee, | |||
283 | else | 283 | else |
284 | IEEE80211_DEBUG_SCAN("Not showing network '%s (" | 284 | IEEE80211_DEBUG_SCAN("Not showing network '%s (" |
285 | "%pM)' due to age (%dms).\n", | 285 | "%pM)' due to age (%dms).\n", |
286 | escape_essid(network->ssid, | 286 | escape_ssid(network->ssid, |
287 | network->ssid_len), | 287 | network->ssid_len), |
288 | network->bssid, | 288 | network->bssid, |
289 | jiffies_to_msecs(jiffies - | 289 | jiffies_to_msecs(jiffies - |
290 | network-> | 290 | network-> |
@@ -408,7 +408,7 @@ int ieee80211_wx_set_encode(struct ieee80211_device *ieee, | |||
408 | memset(sec.keys[key] + erq->length, 0, | 408 | memset(sec.keys[key] + erq->length, 0, |
409 | len - erq->length); | 409 | len - erq->length); |
410 | IEEE80211_DEBUG_WX("Setting key %d to '%s' (%d:%d bytes)\n", | 410 | IEEE80211_DEBUG_WX("Setting key %d to '%s' (%d:%d bytes)\n", |
411 | key, escape_essid(sec.keys[key], len), | 411 | key, escape_ssid(sec.keys[key], len), |
412 | erq->length, len); | 412 | erq->length, len); |
413 | sec.key_sizes[key] = len; | 413 | sec.key_sizes[key] = len; |
414 | if (*crypt) | 414 | if (*crypt) |
diff --git a/net/wireless/Kconfig b/net/wireless/Kconfig index 646c7121dbc0..ae7f2262dfb5 100644 --- a/net/wireless/Kconfig +++ b/net/wireless/Kconfig | |||
@@ -72,3 +72,13 @@ config WIRELESS_EXT_SYSFS | |||
72 | 72 | ||
73 | Say Y if you have programs using it, like old versions of | 73 | Say Y if you have programs using it, like old versions of |
74 | hal. | 74 | hal. |
75 | |||
76 | config LIB80211 | ||
77 | tristate "Common routines for IEEE802.11 drivers" | ||
78 | default n | ||
79 | help | ||
80 | This options enables a library of common routines used | ||
81 | by IEEE802.11 wireless LAN drivers. | ||
82 | |||
83 | Drivers should select this themselves if needed. Say Y if | ||
84 | you want this built into your kernel. | ||
diff --git a/net/wireless/Makefile b/net/wireless/Makefile index b9f943c45f3b..d2d848d445f2 100644 --- a/net/wireless/Makefile +++ b/net/wireless/Makefile | |||
@@ -1,5 +1,6 @@ | |||
1 | obj-$(CONFIG_WIRELESS_EXT) += wext.o | 1 | obj-$(CONFIG_WIRELESS_EXT) += wext.o |
2 | obj-$(CONFIG_CFG80211) += cfg80211.o | 2 | obj-$(CONFIG_CFG80211) += cfg80211.o |
3 | obj-$(CONFIG_LIB80211) += lib80211.o | ||
3 | 4 | ||
4 | cfg80211-y += core.o sysfs.o radiotap.o util.o reg.o | 5 | cfg80211-y += core.o sysfs.o radiotap.o util.o reg.o |
5 | cfg80211-$(CONFIG_NL80211) += nl80211.o | 6 | cfg80211-$(CONFIG_NL80211) += nl80211.o |
diff --git a/net/wireless/lib80211.c b/net/wireless/lib80211.c new file mode 100644 index 000000000000..b22d271fb675 --- /dev/null +++ b/net/wireless/lib80211.c | |||
@@ -0,0 +1,58 @@ | |||
1 | /* | ||
2 | * lib80211 -- common bits for IEEE802.11 drivers | ||
3 | * | ||
4 | * Copyright(c) 2008 John W. Linville <linville@tuxdriver.com> | ||
5 | * | ||
6 | */ | ||
7 | |||
8 | #include <linux/module.h> | ||
9 | #include <linux/ieee80211.h> | ||
10 | |||
11 | #include <net/lib80211.h> | ||
12 | |||
13 | #define DRV_NAME "lib80211" | ||
14 | |||
15 | #define DRV_DESCRIPTION "common routines for IEEE802.11 drivers" | ||
16 | |||
17 | MODULE_DESCRIPTION(DRV_DESCRIPTION); | ||
18 | MODULE_AUTHOR("John W. Linville <linville@tuxdriver.com>"); | ||
19 | MODULE_LICENSE("GPL"); | ||
20 | |||
21 | const char *escape_ssid(const char *ssid, u8 ssid_len) | ||
22 | { | ||
23 | static char escaped[IEEE80211_MAX_SSID_LEN * 2 + 1]; | ||
24 | const char *s = ssid; | ||
25 | char *d = escaped; | ||
26 | |||
27 | if (is_empty_ssid(ssid, ssid_len)) { | ||
28 | memcpy(escaped, "<hidden>", sizeof("<hidden>")); | ||
29 | return escaped; | ||
30 | } | ||
31 | |||
32 | ssid_len = min_t(u8, ssid_len, IEEE80211_MAX_SSID_LEN); | ||
33 | while (ssid_len--) { | ||
34 | if (*s == '\0') { | ||
35 | *d++ = '\\'; | ||
36 | *d++ = '0'; | ||
37 | s++; | ||
38 | } else { | ||
39 | *d++ = *s++; | ||
40 | } | ||
41 | } | ||
42 | *d = '\0'; | ||
43 | return escaped; | ||
44 | } | ||
45 | EXPORT_SYMBOL(escape_ssid); | ||
46 | |||
47 | static int __init ieee80211_init(void) | ||
48 | { | ||
49 | printk(KERN_INFO DRV_NAME ": " DRV_DESCRIPTION "\n"); | ||
50 | return 0; | ||
51 | } | ||
52 | |||
53 | static void __exit ieee80211_exit(void) | ||
54 | { | ||
55 | } | ||
56 | |||
57 | module_init(ieee80211_init); | ||
58 | module_exit(ieee80211_exit); | ||