From: Benjamin Berg Move the TX channel selection into the NAN specific file and select the channel based on the current slot. Signed-off-by: Benjamin Berg --- .../net/wireless/virtual/mac80211_hwsim_main.c | 6 +----- .../net/wireless/virtual/mac80211_hwsim_nan.c | 18 ++++++++++++++++++ .../net/wireless/virtual/mac80211_hwsim_nan.h | 3 +++ 3 files changed, 22 insertions(+), 5 deletions(-) diff --git a/drivers/net/wireless/virtual/mac80211_hwsim_main.c b/drivers/net/wireless/virtual/mac80211_hwsim_main.c index 0f8769ccfd9a..6903f6044a10 100644 --- a/drivers/net/wireless/virtual/mac80211_hwsim_main.c +++ b/drivers/net/wireless/virtual/mac80211_hwsim_main.c @@ -1918,11 +1918,7 @@ static void mac80211_hwsim_tx(struct ieee80211_hw *hw, } if (vif && vif->type == NL80211_IFTYPE_NAN && !data->tmp_chan) { - /* For NAN Device simulation purposes, assume that NAN is always - * on channel 6 or channel 149, unless a ROC is in progress (for - * USD use cases). - */ - channel = data->nan.channel; + channel = mac80211_hwsim_nan_get_tx_channel(hw); if (WARN_ON(!channel)) { ieee80211_free_txskb(hw, skb); diff --git a/drivers/net/wireless/virtual/mac80211_hwsim_nan.c b/drivers/net/wireless/virtual/mac80211_hwsim_nan.c index 029499bf965f..ce8bb73f9dd6 100644 --- a/drivers/net/wireless/virtual/mac80211_hwsim_nan.c +++ b/drivers/net/wireless/virtual/mac80211_hwsim_nan.c @@ -310,3 +310,21 @@ bool mac80211_hwsim_nan_txq_transmitting(struct ieee80211_hw *hw, return true; } + +struct ieee80211_channel * +mac80211_hwsim_nan_get_tx_channel(struct ieee80211_hw *hw) +{ + struct mac80211_hwsim_data *data = hw->priv; + u64 tsf = mac80211_hwsim_get_tsf(data->hw, data->nan.device_vif); + u8 slot = hwsim_nan_slot_from_tsf(tsf); + + if (slot == SLOT_24GHZ_DW) + return ieee80211_get_channel(hw->wiphy, 2437); + + if (slot == SLOT_5GHZ_DW && + data->nan.bands & BIT(NL80211_BAND_5GHZ)) + return ieee80211_get_channel(hw->wiphy, 5745); + + /* drop frame and warn, NAN_CHAN_SWITCH_TIME_US should avoid races */ + return NULL; +} diff --git a/drivers/net/wireless/virtual/mac80211_hwsim_nan.h b/drivers/net/wireless/virtual/mac80211_hwsim_nan.h index 6a0780797273..796cc17d194e 100644 --- a/drivers/net/wireless/virtual/mac80211_hwsim_nan.h +++ b/drivers/net/wireless/virtual/mac80211_hwsim_nan.h @@ -39,4 +39,7 @@ int mac80211_hwsim_nan_change_config(struct ieee80211_hw *hw, bool mac80211_hwsim_nan_txq_transmitting(struct ieee80211_hw *hw, struct ieee80211_txq *txq); +struct ieee80211_channel * +mac80211_hwsim_nan_get_tx_channel(struct ieee80211_hw *hw); + #endif /* __MAC80211_HWSIM_NAN_H */ -- 2.51.1