Message ID | 20230711080918.20114-1-jk.shin@newratek.com |
---|---|
State | New |
Headers | show |
Series | wifi: mac80211: fix error handling when channel_switch on S1G band | expand |
On Tue, 11 Jul 2023 17:09:18 +0900 JUN-KYU SHIN wrote: > When channel_switch is performed to a channel with a freq_offset, > such as 909.5 MHz, channel_switch fails with the "-EOPNOTSUPP" error. > Since freq_offset is used in the S1G band, it should not be treated > as an error only with the freq_offset condition. > > Fixes: b6011960f392 ("mac80211: handle channel frequency offset") > Signed-off-by: JUN-KYU SHIN <jk.shin@newratek.com> Johannes, since you seem to be around - yes/no/can wait? :)
Hi, Yeah I'm home for this week, so really just a few more days. I think it can wait, I'm not even sure there's a driver that fully supports S1G band upstream yet? Other than hwsim, but that doesn't _really_ matter. Well, arguably it's a whole new feature for S1G, so doesn't matter much anyway. Also, I'd be a bit worried that the comment there means we didn't push the frequency offset through all the APIs, so it would still not work with the patch? Jun-Kyu, did you actually try this? If so, how? But I haven't been able to take a closer look. johannes On 13 July 2023 02:37:24 CEST, Jakub Kicinski <kuba@kernel.org> wrote: >On Tue, 11 Jul 2023 17:09:18 +0900 JUN-KYU SHIN wrote: >> When channel_switch is performed to a channel with a freq_offset, >> such as 909.5 MHz, channel_switch fails with the "-EOPNOTSUPP" error. >> Since freq_offset is used in the S1G band, it should not be treated >> as an error only with the freq_offset condition. >> >> Fixes: b6011960f392 ("mac80211: handle channel frequency offset") >> Signed-off-by: JUN-KYU SHIN <jk.shin@newratek.com> > >Johannes, since you seem to be around - yes/no/can wait? :) >
As mentioned below, frequency offset is not used in the current kernel. I would like to contribute to the kernel so that the use of the S1G band can operate completely, but I cannot afford it. Therefore, I am using the S1G band by modifying some parts of the kernel and hostap on my own. A more detailed explanation of the kernel modifications is as follows: 1.Function to convert frequency and channel index according to the country. 2. Skip the regulation check on the S1G band. 3. Bandwidth setting for the S1G band and other changes. However, as you know, in order to apply a patch with these modifications, there are parts that must be preceded. So, I have uploaded a patch that can be easily checked in terms of logic to see if it needs fixing. We will gradually upload patches to fully support the S1G band. On Thu, Jul 13, 2023 at 08:52:16AM +0200, Johannes Berg wrote: > Hi, > > Yeah I'm home for this week, so really just a few more days. > > I think it can wait, I'm not even sure there's a driver that fully supports S1G band upstream yet? Other than hwsim, but that doesn't _really_ matter. Well, arguably it's a whole new feature for S1G, so doesn't matter much anyway. > > Also, I'd be a bit worried that the comment there means we didn't push the frequency offset through all the APIs, so it would still not work with the patch? Jun-Kyu, did you actually try this? If so, how? > > But I haven't been able to take a closer look. > > johannes > > On 13 July 2023 02:37:24 CEST, Jakub Kicinski <kuba@kernel.org> wrote: > >On Tue, 11 Jul 2023 17:09:18 +0900 JUN-KYU SHIN wrote: > >> When channel_switch is performed to a channel with a freq_offset, > >> such as 909.5 MHz, channel_switch fails with the "-EOPNOTSUPP" error. > >> Since freq_offset is used in the S1G band, it should not be treated > >> as an error only with the freq_offset condition. > >> > >> Fixes: b6011960f392 ("mac80211: handle channel frequency offset") > >> Signed-off-by: JUN-KYU SHIN <jk.shin@newratek.com> > > > >Johannes, since you seem to be around - yes/no/can wait? :) > > > > -- > Sent from my phone.
diff --git a/net/mac80211/cfg.c b/net/mac80211/cfg.c index f2d08dbccfb7..f251945cf6fd 100644 --- a/net/mac80211/cfg.c +++ b/net/mac80211/cfg.c @@ -3909,8 +3909,9 @@ __ieee80211_channel_switch(struct wiphy *wiphy, struct net_device *dev, goto out; } - if (params->chandef.chan->freq_offset) { - /* this may work, but is untested */ + if (params->chandef.chan->freq_offset && + params->chandef.chan->band != NL80211_BAND_S1GHZ) { + /* Currently, offset is supported only on the S1G band. */ err = -EOPNOTSUPP; goto out; }
When channel_switch is performed to a channel with a freq_offset, such as 909.5 MHz, channel_switch fails with the "-EOPNOTSUPP" error. Since freq_offset is used in the S1G band, it should not be treated as an error only with the freq_offset condition. Fixes: b6011960f392 ("mac80211: handle channel frequency offset") Signed-off-by: JUN-KYU SHIN <jk.shin@newratek.com> --- net/mac80211/cfg.c | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-)