The wrapper rdev_start_radar_detection() checks whether the driver provides the start_radar_detection callback and returns -ENOTSUPP if not. However, this check is already performed in nl80211_start_radar_detection() resulting in -EOPNOTSUPP. This patch removes check from rdev wrapper function and move the callback checking in nl80211_start_radar_detection() before the other checks. Signed-off-by: Arend van Spriel <arend.vanspriel@xxxxxxxxxxxx> --- net/wireless/nl80211.c | 7 ++++--- net/wireless/rdev-ops.h | 7 +++---- 2 files changed, 7 insertions(+), 7 deletions(-) diff --git a/net/wireless/nl80211.c b/net/wireless/nl80211.c index f02653a..8ab63b5 100644 --- a/net/wireless/nl80211.c +++ b/net/wireless/nl80211.c @@ -6826,6 +6826,9 @@ static int nl80211_start_radar_detection(struct sk_buff *skb, unsigned int cac_time_ms; int err; + if (!rdev->ops->start_radar_detection) + return -EOPNOTSUPP; + dfs_region = reg_get_dfs_region(wdev->wiphy); if (dfs_region == NL80211_DFS_UNSET) return -EINVAL; @@ -6845,15 +6848,13 @@ static int nl80211_start_radar_detection(struct sk_buff *skb, if (err < 0) return err; + /* 0 value means no dfs is required so bail out */ if (err == 0) return -EINVAL; if (!cfg80211_chandef_dfs_usable(wdev->wiphy, &chandef)) return -EINVAL; - if (!rdev->ops->start_radar_detection) - return -EOPNOTSUPP; - cac_time_ms = cfg80211_chandef_dfs_cac_time(&rdev->wiphy, &chandef); if (WARN_ON(!cac_time_ms)) cac_time_ms = IEEE80211_DFS_MIN_CAC_TIME_MS; diff --git a/net/wireless/rdev-ops.h b/net/wireless/rdev-ops.h index d002415..2020606 100644 --- a/net/wireless/rdev-ops.h +++ b/net/wireless/rdev-ops.h @@ -1034,13 +1034,12 @@ rdev_start_radar_detection(struct cfg80211_registered_device *rdev, struct cfg80211_chan_def *chandef, u32 cac_time_ms) { - int ret = -ENOTSUPP; + int ret; trace_rdev_start_radar_detection(&rdev->wiphy, dev, chandef, cac_time_ms); - if (rdev->ops->start_radar_detection) - ret = rdev->ops->start_radar_detection(&rdev->wiphy, dev, - chandef, cac_time_ms); + ret = rdev->ops->start_radar_detection(&rdev->wiphy, dev, + chandef, cac_time_ms); trace_rdev_return_int(&rdev->wiphy, ret); return ret; } -- 1.9.1 -- To unsubscribe from this list: send the line "unsubscribe linux-wireless" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html