From: Vasanthakumar Thiagarajan <quic_vthiagar@xxxxxxxxxxx> Currently, interface combination iterate callback gets notified for each matching combination. To support multi-physical hardware interface combination advertisements, the callback subscriber should additionally receive the hardware index information to indicate which physical hardware is chosen in the matching combination. Refactor the iterate callback by introducing an argument for passing the hardware index. This hardware index is valid for the multi-hardware advertisements and invalid (-1) for the single hardware combination advertisement. Tested-on: QCN9274 hw2.0 PCI WLAN.WBE.1.1.1-00188-QCAHKSWPL_SILICONZ-1 Signed-off-by: Vasanthakumar Thiagarajan <quic_vthiagar@xxxxxxxxxxx> Co-developed-by: Karthikeyan Periyasamy <quic_periyasa@xxxxxxxxxxx> Signed-off-by: Karthikeyan Periyasamy <quic_periyasa@xxxxxxxxxxx> --- include/net/cfg80211.h | 2 +- net/mac80211/util.c | 2 +- net/wireless/util.c | 8 ++++---- 3 files changed, 6 insertions(+), 6 deletions(-) diff --git a/include/net/cfg80211.h b/include/net/cfg80211.h index 491d074fe430..246a8c07becf 100644 --- a/include/net/cfg80211.h +++ b/include/net/cfg80211.h @@ -9233,7 +9233,7 @@ int cfg80211_check_combinations(struct wiphy *wiphy, int cfg80211_iter_combinations(struct wiphy *wiphy, struct iface_combination_params *params, void (*iter)(const struct ieee80211_iface_combination *c, - void *data), + int hw_chan_idx, void *data), void *data); /* diff --git a/net/mac80211/util.c b/net/mac80211/util.c index cda398d8f60d..b1f3b1eb053d 100644 --- a/net/mac80211/util.c +++ b/net/mac80211/util.c @@ -4014,7 +4014,7 @@ int ieee80211_check_combinations(struct ieee80211_sub_if_data *sdata, static void ieee80211_iter_max_chans(const struct ieee80211_iface_combination *c, - void *data) + int hw_chan_idx, void *data) { u32 *max_num_different_channels = data; diff --git a/net/wireless/util.c b/net/wireless/util.c index 2bde8a354631..b60a6a6da744 100644 --- a/net/wireless/util.c +++ b/net/wireless/util.c @@ -2363,13 +2363,13 @@ int cfg80211_validate_beacon_int(struct cfg80211_registered_device *rdev, int cfg80211_iter_combinations(struct wiphy *wiphy, struct iface_combination_params *params, void (*iter)(const struct ieee80211_iface_combination *c, - void *data), + int hw_chan_idx, void *data), void *data) { const struct ieee80211_regdomain *regdom; enum nl80211_dfs_regions region = 0; int i, j, iftype; - int num_interfaces = 0; + int num_interfaces = 0, hw_chan_idx = -1; u32 used_iftypes = 0; u32 beacon_int_gcd; bool beacon_int_different; @@ -2460,7 +2460,7 @@ int cfg80211_iter_combinations(struct wiphy *wiphy, * supported the requested numbers, so we're good. */ - (*iter)(c, data); + (*iter)(c, hw_chan_idx, data); cont: kfree(limits); } @@ -2471,7 +2471,7 @@ EXPORT_SYMBOL(cfg80211_iter_combinations); static void cfg80211_iter_sum_ifcombs(const struct ieee80211_iface_combination *c, - void *data) + int hw_chan_idx, void *data) { int *num = data; (*num)++; -- 2.34.1