diff options
Diffstat (limited to 'drivers/net/wireless')
-rw-r--r-- | drivers/net/wireless/libertas/assoc.h | 18 | ||||
-rw-r--r-- | drivers/net/wireless/libertas/wext.c | 50 |
2 files changed, 34 insertions, 34 deletions
diff --git a/drivers/net/wireless/libertas/assoc.h b/drivers/net/wireless/libertas/assoc.h index e09b7490abbd..ed737eb995c0 100644 --- a/drivers/net/wireless/libertas/assoc.h +++ b/drivers/net/wireless/libertas/assoc.h | |||
@@ -11,22 +11,4 @@ struct assoc_request * wlan_get_association_request(wlan_adapter *adapter); | |||
11 | 11 | ||
12 | void libertas_sync_channel(struct work_struct *work); | 12 | void libertas_sync_channel(struct work_struct *work); |
13 | 13 | ||
14 | #define ASSOC_DELAY (HZ / 2) | ||
15 | static inline void wlan_postpone_association_work(wlan_private *priv) | ||
16 | { | ||
17 | if (priv->adapter->surpriseremoved) | ||
18 | return; | ||
19 | cancel_delayed_work(&priv->assoc_work); | ||
20 | queue_delayed_work(priv->work_thread, &priv->assoc_work, ASSOC_DELAY); | ||
21 | } | ||
22 | |||
23 | static inline void wlan_cancel_association_work(wlan_private *priv) | ||
24 | { | ||
25 | cancel_delayed_work(&priv->assoc_work); | ||
26 | if (priv->adapter->pending_assoc_req) { | ||
27 | kfree(priv->adapter->pending_assoc_req); | ||
28 | priv->adapter->pending_assoc_req = NULL; | ||
29 | } | ||
30 | } | ||
31 | |||
32 | #endif /* _WLAN_ASSOC_H */ | 14 | #endif /* _WLAN_ASSOC_H */ |
diff --git a/drivers/net/wireless/libertas/wext.c b/drivers/net/wireless/libertas/wext.c index 395b7882d4d6..135116d90703 100644 --- a/drivers/net/wireless/libertas/wext.c +++ b/drivers/net/wireless/libertas/wext.c | |||
@@ -21,6 +21,24 @@ | |||
21 | #include "assoc.h" | 21 | #include "assoc.h" |
22 | 22 | ||
23 | 23 | ||
24 | static inline void libertas_postpone_association_work(wlan_private *priv) | ||
25 | { | ||
26 | if (priv->adapter->surpriseremoved) | ||
27 | return; | ||
28 | cancel_delayed_work(&priv->assoc_work); | ||
29 | queue_delayed_work(priv->work_thread, &priv->assoc_work, HZ / 2); | ||
30 | } | ||
31 | |||
32 | static inline void libertas_cancel_association_work(wlan_private *priv) | ||
33 | { | ||
34 | cancel_delayed_work(&priv->assoc_work); | ||
35 | if (priv->adapter->pending_assoc_req) { | ||
36 | kfree(priv->adapter->pending_assoc_req); | ||
37 | priv->adapter->pending_assoc_req = NULL; | ||
38 | } | ||
39 | } | ||
40 | |||
41 | |||
24 | /** | 42 | /** |
25 | * @brief Find the channel frequency power info with specific channel | 43 | * @brief Find the channel frequency power info with specific channel |
26 | * | 44 | * |
@@ -949,9 +967,9 @@ static int wlan_set_freq(struct net_device *dev, struct iw_request_info *info, | |||
949 | out: | 967 | out: |
950 | if (ret == 0) { | 968 | if (ret == 0) { |
951 | set_bit(ASSOC_FLAG_CHANNEL, &assoc_req->flags); | 969 | set_bit(ASSOC_FLAG_CHANNEL, &assoc_req->flags); |
952 | wlan_postpone_association_work(priv); | 970 | libertas_postpone_association_work(priv); |
953 | } else { | 971 | } else { |
954 | wlan_cancel_association_work(priv); | 972 | libertas_cancel_association_work(priv); |
955 | } | 973 | } |
956 | mutex_unlock(&adapter->lock); | 974 | mutex_unlock(&adapter->lock); |
957 | 975 | ||
@@ -1050,11 +1068,11 @@ static int wlan_set_mode(struct net_device *dev, | |||
1050 | assoc_req = wlan_get_association_request(adapter); | 1068 | assoc_req = wlan_get_association_request(adapter); |
1051 | if (!assoc_req) { | 1069 | if (!assoc_req) { |
1052 | ret = -ENOMEM; | 1070 | ret = -ENOMEM; |
1053 | wlan_cancel_association_work(priv); | 1071 | libertas_cancel_association_work(priv); |
1054 | } else { | 1072 | } else { |
1055 | assoc_req->mode = *uwrq; | 1073 | assoc_req->mode = *uwrq; |
1056 | set_bit(ASSOC_FLAG_MODE, &assoc_req->flags); | 1074 | set_bit(ASSOC_FLAG_MODE, &assoc_req->flags); |
1057 | wlan_postpone_association_work(priv); | 1075 | libertas_postpone_association_work(priv); |
1058 | lbs_deb_wext("Switching to mode: 0x%x\n", *uwrq); | 1076 | lbs_deb_wext("Switching to mode: 0x%x\n", *uwrq); |
1059 | } | 1077 | } |
1060 | mutex_unlock(&adapter->lock); | 1078 | mutex_unlock(&adapter->lock); |
@@ -1335,9 +1353,9 @@ static int wlan_set_encode(struct net_device *dev, | |||
1335 | out: | 1353 | out: |
1336 | if (ret == 0) { | 1354 | if (ret == 0) { |
1337 | set_bit(ASSOC_FLAG_SECINFO, &assoc_req->flags); | 1355 | set_bit(ASSOC_FLAG_SECINFO, &assoc_req->flags); |
1338 | wlan_postpone_association_work(priv); | 1356 | libertas_postpone_association_work(priv); |
1339 | } else { | 1357 | } else { |
1340 | wlan_cancel_association_work(priv); | 1358 | libertas_cancel_association_work(priv); |
1341 | } | 1359 | } |
1342 | mutex_unlock(&adapter->lock); | 1360 | mutex_unlock(&adapter->lock); |
1343 | 1361 | ||
@@ -1576,9 +1594,9 @@ static int wlan_set_encodeext(struct net_device *dev, | |||
1576 | 1594 | ||
1577 | out: | 1595 | out: |
1578 | if (ret == 0) { | 1596 | if (ret == 0) { |
1579 | wlan_postpone_association_work(priv); | 1597 | libertas_postpone_association_work(priv); |
1580 | } else { | 1598 | } else { |
1581 | wlan_cancel_association_work(priv); | 1599 | libertas_cancel_association_work(priv); |
1582 | } | 1600 | } |
1583 | mutex_unlock(&adapter->lock); | 1601 | mutex_unlock(&adapter->lock); |
1584 | 1602 | ||
@@ -1623,9 +1641,9 @@ static int wlan_set_genie(struct net_device *dev, | |||
1623 | out: | 1641 | out: |
1624 | if (ret == 0) { | 1642 | if (ret == 0) { |
1625 | set_bit(ASSOC_FLAG_WPA_IE, &assoc_req->flags); | 1643 | set_bit(ASSOC_FLAG_WPA_IE, &assoc_req->flags); |
1626 | wlan_postpone_association_work(priv); | 1644 | libertas_postpone_association_work(priv); |
1627 | } else { | 1645 | } else { |
1628 | wlan_cancel_association_work(priv); | 1646 | libertas_cancel_association_work(priv); |
1629 | } | 1647 | } |
1630 | mutex_unlock(&adapter->lock); | 1648 | mutex_unlock(&adapter->lock); |
1631 | 1649 | ||
@@ -1752,9 +1770,9 @@ out: | |||
1752 | if (ret == 0) { | 1770 | if (ret == 0) { |
1753 | if (updated) | 1771 | if (updated) |
1754 | set_bit(ASSOC_FLAG_SECINFO, &assoc_req->flags); | 1772 | set_bit(ASSOC_FLAG_SECINFO, &assoc_req->flags); |
1755 | wlan_postpone_association_work(priv); | 1773 | libertas_postpone_association_work(priv); |
1756 | } else if (ret != -EOPNOTSUPP) { | 1774 | } else if (ret != -EOPNOTSUPP) { |
1757 | wlan_cancel_association_work(priv); | 1775 | libertas_cancel_association_work(priv); |
1758 | } | 1776 | } |
1759 | mutex_unlock(&adapter->lock); | 1777 | mutex_unlock(&adapter->lock); |
1760 | 1778 | ||
@@ -1929,13 +1947,13 @@ out: | |||
1929 | memcpy(&assoc_req->ssid, &ssid, IW_ESSID_MAX_SIZE); | 1947 | memcpy(&assoc_req->ssid, &ssid, IW_ESSID_MAX_SIZE); |
1930 | assoc_req->ssid_len = ssid_len; | 1948 | assoc_req->ssid_len = ssid_len; |
1931 | set_bit(ASSOC_FLAG_SSID, &assoc_req->flags); | 1949 | set_bit(ASSOC_FLAG_SSID, &assoc_req->flags); |
1932 | wlan_postpone_association_work(priv); | 1950 | libertas_postpone_association_work(priv); |
1933 | } | 1951 | } |
1934 | } | 1952 | } |
1935 | 1953 | ||
1936 | /* Cancel the association request if there was an error */ | 1954 | /* Cancel the association request if there was an error */ |
1937 | if (ret != 0) { | 1955 | if (ret != 0) { |
1938 | wlan_cancel_association_work(priv); | 1956 | libertas_cancel_association_work(priv); |
1939 | } | 1957 | } |
1940 | 1958 | ||
1941 | mutex_unlock(&adapter->lock); | 1959 | mutex_unlock(&adapter->lock); |
@@ -1974,13 +1992,13 @@ static int wlan_set_wap(struct net_device *dev, struct iw_request_info *info, | |||
1974 | /* Get or create the current association request */ | 1992 | /* Get or create the current association request */ |
1975 | assoc_req = wlan_get_association_request(adapter); | 1993 | assoc_req = wlan_get_association_request(adapter); |
1976 | if (!assoc_req) { | 1994 | if (!assoc_req) { |
1977 | wlan_cancel_association_work(priv); | 1995 | libertas_cancel_association_work(priv); |
1978 | ret = -ENOMEM; | 1996 | ret = -ENOMEM; |
1979 | } else { | 1997 | } else { |
1980 | /* Copy the BSSID to the association request */ | 1998 | /* Copy the BSSID to the association request */ |
1981 | memcpy(&assoc_req->bssid, awrq->sa_data, ETH_ALEN); | 1999 | memcpy(&assoc_req->bssid, awrq->sa_data, ETH_ALEN); |
1982 | set_bit(ASSOC_FLAG_BSSID, &assoc_req->flags); | 2000 | set_bit(ASSOC_FLAG_BSSID, &assoc_req->flags); |
1983 | wlan_postpone_association_work(priv); | 2001 | libertas_postpone_association_work(priv); |
1984 | } | 2002 | } |
1985 | 2003 | ||
1986 | mutex_unlock(&adapter->lock); | 2004 | mutex_unlock(&adapter->lock); |