cfg80211_remain_on_channel代码具体实现
时间: 2023-08-06 20:07:57 浏览: 185
cfg80211_remain_on_channel函数的具体实现代码如下:
```
int cfg80211_remain_on_channel(struct wiphy *wiphy,
struct net_device *dev,
struct ieee80211_channel *chan,
unsigned int duration,
u64 *cookie)
{
struct cfg80211_registered_device *rdev = wiphy_to_rdev(wiphy);
struct cfg80211_roc_request *roc_req;
int err;
if (!rdev->ops->remain_on_channel)
return -EOPNOTSUPP;
roc_req = kzalloc(sizeof(*roc_req), GFP_KERNEL);
if (!roc_req)
return -ENOMEM;
roc_req->cookie = get_wiphy_cookie(wiphy);
roc_req->wdev = dev_to_wdev(dev);
roc_req->chan = chan;
roc_req->duration = duration;
roc_req->aborted = false;
roc_req->wait = wait_event_interruptible(rdev->roc_wait, roc_req->aborted);
if (roc_req->wait < 0) {
/* user cancelled */
kfree(roc_req);
return roc_req->wait;
}
err = rdev_remain_on_channel(rdev, roc_req);
if (err) {
kfree(roc_req);
return err;
}
*cookie = roc_req->cookie;
return 0;
}
```
在此实现中,首先检查设备是否支持ROC功能。如果不支持,则返回-EOPNOTSUPP。如果支持ROC,则会创建一个新的cfg80211_roc_request结构体,该结构体用于保存ROC请求信息。然后,会将ROC请求添加到设备的ROC请求列表中,并调用驱动程序的remain_on_channel函数启动ROC操作。最后,会等待ROC操作完成,并将ROC请求从设备的ROC请求列表中删除。
需要注意的是,实际的ROC操作是由驱动程序完成的,因此具体的实现方式可能会因不同的硬件平台而有所不同。
阅读全文