aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorHolger Schurig <hs4233@mail.mn-solutions.de>2008-03-26 12:56:26 -0400
committerJohn W. Linville <linville@tuxdriver.com>2008-04-01 17:13:17 -0400
commit04850a47aa7d03cbf651a91262fdaa9f18373dfc (patch)
tree2cfb6ef447bdae044bc049cae89dd331ebbd0833
parentf539f2efe9fdf9e7db2022a757190858576d34fd (diff)
libertas: don't depend on IEEE80211
Runtime-wise we only need escape_ssid from the deprecated IEEE80211 subsystem. However, it's easy to provide our own copy. Signed-off-by: Holger Schurig <hs4233@mail.mn-solutions.de> Acked-by: Dan Williams <dcbw@redhat.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
-rw-r--r--drivers/net/wireless/Kconfig1
-rw-r--r--drivers/net/wireless/libertas/decl.h5
-rw-r--r--drivers/net/wireless/libertas/main.c26
3 files changed, 31 insertions, 1 deletions
diff --git a/drivers/net/wireless/Kconfig b/drivers/net/wireless/Kconfig
index 9cba8ea58ca8..3c8cf682e9bd 100644
--- a/drivers/net/wireless/Kconfig
+++ b/drivers/net/wireless/Kconfig
@@ -271,7 +271,6 @@ config LIBERTAS
271 tristate "Marvell 8xxx Libertas WLAN driver support" 271 tristate "Marvell 8xxx Libertas WLAN driver support"
272 depends on WLAN_80211 272 depends on WLAN_80211
273 select WIRELESS_EXT 273 select WIRELESS_EXT
274 select IEEE80211
275 select FW_LOADER 274 select FW_LOADER
276 ---help--- 275 ---help---
277 A library for Marvell Libertas 8xxx devices. 276 A library for Marvell Libertas 8xxx devices.
diff --git a/drivers/net/wireless/libertas/decl.h b/drivers/net/wireless/libertas/decl.h
index cadc59d7f77f..1ca747b28ef5 100644
--- a/drivers/net/wireless/libertas/decl.h
+++ b/drivers/net/wireless/libertas/decl.h
@@ -71,4 +71,9 @@ int lbs_stop_card(struct lbs_private *priv);
71void lbs_host_to_card_done(struct lbs_private *priv); 71void lbs_host_to_card_done(struct lbs_private *priv);
72 72
73int lbs_update_channel(struct lbs_private *priv); 73int lbs_update_channel(struct lbs_private *priv);
74
75#ifndef CONFIG_IEEE80211
76const char *escape_essid(const char *essid, u8 essid_len);
77#endif
78
74#endif 79#endif
diff --git a/drivers/net/wireless/libertas/main.c b/drivers/net/wireless/libertas/main.c
index efff63fb6b66..6c2af176da20 100644
--- a/drivers/net/wireless/libertas/main.c
+++ b/drivers/net/wireless/libertas/main.c
@@ -1559,6 +1559,32 @@ out:
1559 return ret; 1559 return ret;
1560} 1560}
1561 1561
1562#ifndef CONFIG_IEEE80211
1563const char *escape_essid(const char *essid, u8 essid_len)
1564{
1565 static char escaped[IW_ESSID_MAX_SIZE * 2 + 1];
1566 const char *s = essid;
1567 char *d = escaped;
1568
1569 if (ieee80211_is_empty_essid(essid, essid_len)) {
1570 memcpy(escaped, "<hidden>", sizeof("<hidden>"));
1571 return escaped;
1572 }
1573
1574 essid_len = min(essid_len, (u8) IW_ESSID_MAX_SIZE);
1575 while (essid_len--) {
1576 if (*s == '\0') {
1577 *d++ = '\\';
1578 *d++ = '0';
1579 s++;
1580 } else {
1581 *d++ = *s++;
1582 }
1583 }
1584 *d = '\0';
1585 return escaped;
1586}
1587#endif
1562 1588
1563module_init(lbs_init_module); 1589module_init(lbs_init_module);
1564module_exit(lbs_exit_module); 1590module_exit(lbs_exit_module);