Skip to content

Commit a2cde15

Browse files
cmonroegregkh
authored andcommitted
wifi: mt76: fix multi-radio on-channel scanning
[ Upstream commit 0420180 ] avoid unnecessary channel switch when performing an on-channel scan using a multi-radio device. Fixes: c56d6ed ("wifi: mt76: mt7996: use emulated hardware scan support") Signed-off-by: Chad Monroe <chad@monroe.io> Link: https://patch.msgid.link/20251118102723.47997-1-nbd@nbd.name Link: https://patch.msgid.link/20260309060730.87840-1-nbd@nbd.name Signed-off-by: Felix Fietkau <nbd@nbd.name> Signed-off-by: Sasha Levin <sashal@kernel.org>
1 parent 98e0118 commit a2cde15

1 file changed

Lines changed: 12 additions & 5 deletions

File tree

  • drivers/net/wireless/mediatek/mt76

drivers/net/wireless/mediatek/mt76/scan.c

Lines changed: 12 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -16,7 +16,7 @@ static void mt76_scan_complete(struct mt76_dev *dev, bool abort)
1616

1717
clear_bit(MT76_SCANNING, &phy->state);
1818

19-
if (dev->scan.chan && phy->main_chandef.chan &&
19+
if (dev->scan.chan && phy->main_chandef.chan && phy->offchannel &&
2020
!test_bit(MT76_MCU_RESET, &dev->phy.state))
2121
mt76_set_channel(phy, &phy->main_chandef, false);
2222
mt76_put_vif_phy_link(phy, dev->scan.vif, dev->scan.mlink);
@@ -85,35 +85,42 @@ void mt76_scan_work(struct work_struct *work)
8585
struct cfg80211_chan_def chandef = {};
8686
struct mt76_phy *phy = dev->scan.phy;
8787
int duration = HZ / 9; /* ~110 ms */
88+
bool offchannel = true;
8889
int i;
8990

9091
if (dev->scan.chan_idx >= req->n_channels) {
9192
mt76_scan_complete(dev, false);
9293
return;
9394
}
9495

95-
if (dev->scan.chan && phy->num_sta) {
96+
if (dev->scan.chan && phy->num_sta && phy->offchannel) {
9697
dev->scan.chan = NULL;
9798
mt76_set_channel(phy, &phy->main_chandef, false);
9899
goto out;
99100
}
100101

101102
dev->scan.chan = req->channels[dev->scan.chan_idx++];
102103
cfg80211_chandef_create(&chandef, dev->scan.chan, NL80211_CHAN_HT20);
103-
mt76_set_channel(phy, &chandef, true);
104+
if (phy->main_chandef.chan == dev->scan.chan) {
105+
chandef = phy->main_chandef;
106+
offchannel = false;
107+
}
108+
109+
mt76_set_channel(phy, &chandef, offchannel);
104110

105111
if (!req->n_ssids ||
106112
chandef.chan->flags & (IEEE80211_CHAN_NO_IR | IEEE80211_CHAN_RADAR))
107113
goto out;
108114

109-
duration = HZ / 16; /* ~60 ms */
115+
if (phy->offchannel)
116+
duration = HZ / 16; /* ~60 ms */
110117
local_bh_disable();
111118
for (i = 0; i < req->n_ssids; i++)
112119
mt76_scan_send_probe(dev, &req->ssids[i]);
113120
local_bh_enable();
114121

115122
out:
116-
if (dev->scan.chan)
123+
if (dev->scan.chan && phy->offchannel)
117124
duration = max_t(int, duration,
118125
msecs_to_jiffies(req->duration +
119126
(req->duration >> 5)));

0 commit comments

Comments
 (0)