aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--net/mac80211/cfg.c25
-rw-r--r--net/wireless/nl80211.c40
2 files changed, 40 insertions, 25 deletions
diff --git a/net/mac80211/cfg.c b/net/mac80211/cfg.c
index f5c15c9a00ce..b5810b4c79ac 100644
--- a/net/mac80211/cfg.c
+++ b/net/mac80211/cfg.c
@@ -728,10 +728,6 @@ static int ieee80211_add_station(struct wiphy *wiphy, struct net_device *dev,
728 int err; 728 int err;
729 int layer2_update; 729 int layer2_update;
730 730
731 /* Prevent a race with changing the rate control algorithm */
732 if (!netif_running(dev))
733 return -ENETDOWN;
734
735 if (params->vlan) { 731 if (params->vlan) {
736 sdata = IEEE80211_DEV_TO_SUB_IF(params->vlan); 732 sdata = IEEE80211_DEV_TO_SUB_IF(params->vlan);
737 733
@@ -860,9 +856,6 @@ static int ieee80211_add_mpath(struct wiphy *wiphy, struct net_device *dev,
860 struct sta_info *sta; 856 struct sta_info *sta;
861 int err; 857 int err;
862 858
863 if (!netif_running(dev))
864 return -ENETDOWN;
865
866 sdata = IEEE80211_DEV_TO_SUB_IF(dev); 859 sdata = IEEE80211_DEV_TO_SUB_IF(dev);
867 860
868 if (sdata->vif.type != NL80211_IFTYPE_MESH_POINT) 861 if (sdata->vif.type != NL80211_IFTYPE_MESH_POINT)
@@ -913,9 +906,6 @@ static int ieee80211_change_mpath(struct wiphy *wiphy,
913 struct mesh_path *mpath; 906 struct mesh_path *mpath;
914 struct sta_info *sta; 907 struct sta_info *sta;
915 908
916 if (!netif_running(dev))
917 return -ENETDOWN;
918
919 sdata = IEEE80211_DEV_TO_SUB_IF(dev); 909 sdata = IEEE80211_DEV_TO_SUB_IF(dev);
920 910
921 if (sdata->vif.type != NL80211_IFTYPE_MESH_POINT) 911 if (sdata->vif.type != NL80211_IFTYPE_MESH_POINT)
@@ -1202,9 +1192,6 @@ static int ieee80211_scan(struct wiphy *wiphy,
1202{ 1192{
1203 struct ieee80211_sub_if_data *sdata; 1193 struct ieee80211_sub_if_data *sdata;
1204 1194
1205 if (!netif_running(dev))
1206 return -ENETDOWN;
1207
1208 sdata = IEEE80211_DEV_TO_SUB_IF(dev); 1195 sdata = IEEE80211_DEV_TO_SUB_IF(dev);
1209 1196
1210 if (sdata->vif.type != NL80211_IFTYPE_STATION && 1197 if (sdata->vif.type != NL80211_IFTYPE_STATION &&
@@ -1220,9 +1207,6 @@ static int ieee80211_auth(struct wiphy *wiphy, struct net_device *dev,
1220{ 1207{
1221 struct ieee80211_sub_if_data *sdata; 1208 struct ieee80211_sub_if_data *sdata;
1222 1209
1223 if (!netif_running(dev))
1224 return -ENETDOWN;
1225
1226 sdata = IEEE80211_DEV_TO_SUB_IF(dev); 1210 sdata = IEEE80211_DEV_TO_SUB_IF(dev);
1227 1211
1228 if (sdata->vif.type != NL80211_IFTYPE_STATION) 1212 if (sdata->vif.type != NL80211_IFTYPE_STATION)
@@ -1282,9 +1266,6 @@ static int ieee80211_assoc(struct wiphy *wiphy, struct net_device *dev,
1282 struct ieee80211_sub_if_data *sdata; 1266 struct ieee80211_sub_if_data *sdata;
1283 int ret; 1267 int ret;
1284 1268
1285 if (!netif_running(dev))
1286 return -ENETDOWN;
1287
1288 sdata = IEEE80211_DEV_TO_SUB_IF(dev); 1269 sdata = IEEE80211_DEV_TO_SUB_IF(dev);
1289 1270
1290 if (sdata->vif.type != NL80211_IFTYPE_STATION) 1271 if (sdata->vif.type != NL80211_IFTYPE_STATION)
@@ -1323,9 +1304,6 @@ static int ieee80211_deauth(struct wiphy *wiphy, struct net_device *dev,
1323{ 1304{
1324 struct ieee80211_sub_if_data *sdata; 1305 struct ieee80211_sub_if_data *sdata;
1325 1306
1326 if (!netif_running(dev))
1327 return -ENETDOWN;
1328
1329 sdata = IEEE80211_DEV_TO_SUB_IF(dev); 1307 sdata = IEEE80211_DEV_TO_SUB_IF(dev);
1330 if (sdata->vif.type != NL80211_IFTYPE_STATION) 1308 if (sdata->vif.type != NL80211_IFTYPE_STATION)
1331 return -EOPNOTSUPP; 1309 return -EOPNOTSUPP;
@@ -1339,9 +1317,6 @@ static int ieee80211_disassoc(struct wiphy *wiphy, struct net_device *dev,
1339{ 1317{
1340 struct ieee80211_sub_if_data *sdata; 1318 struct ieee80211_sub_if_data *sdata;
1341 1319
1342 if (!netif_running(dev))
1343 return -ENETDOWN;
1344
1345 sdata = IEEE80211_DEV_TO_SUB_IF(dev); 1320 sdata = IEEE80211_DEV_TO_SUB_IF(dev);
1346 1321
1347 if (sdata->vif.type != NL80211_IFTYPE_STATION) 1322 if (sdata->vif.type != NL80211_IFTYPE_STATION)
diff --git a/net/wireless/nl80211.c b/net/wireless/nl80211.c
index 6f38ee7a3c92..6bb73a3a3391 100644
--- a/net/wireless/nl80211.c
+++ b/net/wireless/nl80211.c
@@ -1556,6 +1556,11 @@ static int nl80211_new_station(struct sk_buff *skb, struct genl_info *info)
1556 goto out; 1556 goto out;
1557 } 1557 }
1558 1558
1559 if (!netif_running(dev)) {
1560 err = -ENETDOWN;
1561 goto out;
1562 }
1563
1559 err = drv->ops->add_station(&drv->wiphy, dev, mac_addr, &params); 1564 err = drv->ops->add_station(&drv->wiphy, dev, mac_addr, &params);
1560 1565
1561 out: 1566 out:
@@ -1808,6 +1813,11 @@ static int nl80211_set_mpath(struct sk_buff *skb, struct genl_info *info)
1808 goto out; 1813 goto out;
1809 } 1814 }
1810 1815
1816 if (!netif_running(dev)) {
1817 err = -ENETDOWN;
1818 goto out;
1819 }
1820
1811 err = drv->ops->change_mpath(&drv->wiphy, dev, dst, next_hop); 1821 err = drv->ops->change_mpath(&drv->wiphy, dev, dst, next_hop);
1812 1822
1813 out: 1823 out:
@@ -1846,6 +1856,11 @@ static int nl80211_new_mpath(struct sk_buff *skb, struct genl_info *info)
1846 goto out; 1856 goto out;
1847 } 1857 }
1848 1858
1859 if (!netif_running(dev)) {
1860 err = -ENETDOWN;
1861 goto out;
1862 }
1863
1849 err = drv->ops->add_mpath(&drv->wiphy, dev, dst, next_hop); 1864 err = drv->ops->add_mpath(&drv->wiphy, dev, dst, next_hop);
1850 1865
1851 out: 1866 out:
@@ -2380,6 +2395,11 @@ static int nl80211_trigger_scan(struct sk_buff *skb, struct genl_info *info)
2380 goto out; 2395 goto out;
2381 } 2396 }
2382 2397
2398 if (!netif_running(dev)) {
2399 err = -ENETDOWN;
2400 goto out;
2401 }
2402
2383 if (drv->scan_req) { 2403 if (drv->scan_req) {
2384 err = -EBUSY; 2404 err = -EBUSY;
2385 goto out; 2405 goto out;
@@ -2641,6 +2661,11 @@ static int nl80211_authenticate(struct sk_buff *skb, struct genl_info *info)
2641 goto out; 2661 goto out;
2642 } 2662 }
2643 2663
2664 if (!netif_running(dev)) {
2665 err = -ENETDOWN;
2666 goto out;
2667 }
2668
2644 if (!info->attrs[NL80211_ATTR_MAC]) { 2669 if (!info->attrs[NL80211_ATTR_MAC]) {
2645 err = -EINVAL; 2670 err = -EINVAL;
2646 goto out; 2671 goto out;
@@ -2709,6 +2734,11 @@ static int nl80211_associate(struct sk_buff *skb, struct genl_info *info)
2709 goto out; 2734 goto out;
2710 } 2735 }
2711 2736
2737 if (!netif_running(dev)) {
2738 err = -ENETDOWN;
2739 goto out;
2740 }
2741
2712 if (!info->attrs[NL80211_ATTR_MAC] || 2742 if (!info->attrs[NL80211_ATTR_MAC] ||
2713 !info->attrs[NL80211_ATTR_SSID]) { 2743 !info->attrs[NL80211_ATTR_SSID]) {
2714 err = -EINVAL; 2744 err = -EINVAL;
@@ -2767,6 +2797,11 @@ static int nl80211_deauthenticate(struct sk_buff *skb, struct genl_info *info)
2767 goto out; 2797 goto out;
2768 } 2798 }
2769 2799
2800 if (!netif_running(dev)) {
2801 err = -ENETDOWN;
2802 goto out;
2803 }
2804
2770 if (!info->attrs[NL80211_ATTR_MAC]) { 2805 if (!info->attrs[NL80211_ATTR_MAC]) {
2771 err = -EINVAL; 2806 err = -EINVAL;
2772 goto out; 2807 goto out;
@@ -2821,6 +2856,11 @@ static int nl80211_disassociate(struct sk_buff *skb, struct genl_info *info)
2821 goto out; 2856 goto out;
2822 } 2857 }
2823 2858
2859 if (!netif_running(dev)) {
2860 err = -ENETDOWN;
2861 goto out;
2862 }
2863
2824 if (!info->attrs[NL80211_ATTR_MAC]) { 2864 if (!info->attrs[NL80211_ATTR_MAC]) {
2825 err = -EINVAL; 2865 err = -EINVAL;
2826 goto out; 2866 goto out;