blob: e143505f05bc1e856720458e71c3ed41de907902 [file] [log] [blame]
Michal Kazior60771782012-06-29 12:46:56 +02001#include <linux/ieee80211.h>
2#include <linux/export.h>
3#include <net/cfg80211.h>
4#include "nl80211.h"
5#include "core.h"
Hila Gonene35e4d22012-06-27 17:19:42 +03006#include "rdev-ops.h"
Michal Kazior60771782012-06-29 12:46:56 +02007
8
9static int __cfg80211_stop_ap(struct cfg80211_registered_device *rdev,
10 struct net_device *dev)
11{
12 struct wireless_dev *wdev = dev->ieee80211_ptr;
13 int err;
14
15 ASSERT_WDEV_LOCK(wdev);
16
17 if (!rdev->ops->stop_ap)
18 return -EOPNOTSUPP;
19
20 if (dev->ieee80211_ptr->iftype != NL80211_IFTYPE_AP &&
21 dev->ieee80211_ptr->iftype != NL80211_IFTYPE_P2P_GO)
22 return -EOPNOTSUPP;
23
24 if (!wdev->beacon_interval)
25 return -ENOENT;
26
Hila Gonene35e4d22012-06-27 17:19:42 +030027 err = rdev_stop_ap(rdev, dev);
Michal Kaziorf4489eb2012-06-29 12:46:58 +020028 if (!err) {
Michal Kazior60771782012-06-29 12:46:56 +020029 wdev->beacon_interval = 0;
Michal Kaziorf4489eb2012-06-29 12:46:58 +020030 wdev->channel = NULL;
31 }
Michal Kazior60771782012-06-29 12:46:56 +020032
33 return err;
34}
35
36int cfg80211_stop_ap(struct cfg80211_registered_device *rdev,
37 struct net_device *dev)
38{
39 struct wireless_dev *wdev = dev->ieee80211_ptr;
40 int err;
41
42 wdev_lock(wdev);
43 err = __cfg80211_stop_ap(rdev, dev);
44 wdev_unlock(wdev);
45
46 return err;
47}