Hi, Sorry for the delay. > I would like to start by explaining why we prioritized the operating > class. > > In IEEE Std 802.11-2020 11.38.4 (Channel switching methods for a VHT > BSS), there is a note about operating class and WBCS Element: > > “NOTE 2—The indicated operating class within the Extended Channel > Switch Announcement element identifies the bandwidth and the relative > position of the primary 20 MHz and secondary 20 MHz channels. Hence a > Wide Bandwidth Channel Switch subelement is unnecessary when the > Extended Channel Switch Announcement element is used for a channel > switch to a 40 MHz bandwidth.” That's ... interesting. I hadn't seen that. But I guess it doesn't surprise me, it's in line with what seems to be a general push to give the operating class more relevance :) > Although it only limits the switch to a 40 MHz bandwidth, we thought it > is applicable in 80/80+80/160 MHz bandwidth. So in the version 1, we > preferred to use the operating class than the WBCS Element. Right. Though at least with 40 MHz you can do "opclass X -> secondary is above" and "opclass Y -> secondary is below", without really relying on the channelisation plan. For wider than 40, you can't do that any more, I think? > Also, we agree your suggestion that WBCS Element has higher priority > than operating class. Our reason is, when channel switch to a bandwidth > wider than 40 MHz, WBCS Element is mandatory while ECSA (which contains > operating class) is not. OK :) > (Note that either CSA or ECSA will be sent in a channel switch.) Right. > BTW, I would also like to clarify one thing. We did this upstream work > solely based on the standard and with the intention of contributing to > mac80211. In fact, we developed and tested with the upstream driver > (mt76) for AP and STA solution together. Before doing upstream, we used > the MTK AP (proprietary solution) to do IOT tests and indeed found some > problems, which were already reported and fixed. > So, we were not aware of what was going on to MTK AP until we used it > to do an IOT test. We didn’t do it with the intention of covering the > broken WBCS element sent by MTK AP. :-) I'm sorry I shouldn't have phrased it that way, I apologize. Just by sheer coincidence, both these patches and the AP bug report for our client landed in my Inbox at around the same time, and I clearly drew a conclusion I shouldn't have. > For other replies, please see the inline. (we deleted some of your > replies since we just change as you suggested) > In summary, we’ll modify the code and submit a new version. sounds good > > So perhaps better: > > - use, in this order: BWI, WBCS, ECSA, CSA (according to the mode > > we parse as, and our own capabilities) > > - if present, check that operating class agrees > > > > no? > > we agree the order. AS for the check for operating class, we think it’s > a little useless. I don't disagree that checking the operating class is "a little useless". Up to you :-) What I've been brewing in my head for a while now though is a (per- wiphy?) "strict mode" where we do more such consistency checks, and also disable workarounds like using beacon elements if missing in association response. I'd want to enable that in our testing, and perhaps also when doing interoperability testing with other APs. I realize that's only tangentially related to this patch, but I think it could be very useful. > Image the case that the WBCS Element and the operating class indicate > two different chandef, but both are valid, which one should we trust, > or neither? > Our answer is that WBCS Element is worth trusting, since it is > mandatory in a channel switch to bandwidth wider than 40 MHz, while > operating class isn’t. Yeah, makes sense. We could have a check behind a "strict mode" flag, but I guess that's something for the future. > The operating class can be use in the case that the WBCS Element is > missing or indicates a wrong chandef. In other word, the operating > class has lower priority than WBCS Element. > What do you think? I'm not sure I'd use it for the case of "wrong chandef"? You said yourself that WBCS is mandatory and opclass is optional, so I think we should be able to trust the AP when it says WBCS is something, and if it's confused about it, we'd better not trust it to accidentally (?) have gotten the opclass correct? > We will change the HT/VHT operation to static allocation in the > function. However, the size of HE/EHT operation are variable, so it can > only be dynamically allocated. There's a pretty small upper bound though, so you could just pack it into a struct with a buffer? struct { struct eht_operation oper; u8 buf[MAX_EHT_OPER_OPTIONAL]; } __packed eht; and use it as "eht.oper"? Maybe not worth it though. We cannot use dynamically sized stack arrays in the kernel, so that wouldn't work either. > According to the Standard, 80+80 MHz bandwidth still exists in HE mode. > The function ieee80211_chandef_he_6ghz_oper() handles this case. Hah, OK. > However, from our experience, there are few commercial APs that support > 80+80 MHz bandwidth in HE mode. We can remove it, what do you think? I have no idea. We don't support it even as a client, so we'd always just use 80 MHz. So from our (Intel) POV it doesn't matter. Up to you. I don't mind having it or leaving it out, either way. Now that you have the code anyway maybe leave it? > > > +/* parse one of the Elements to build a new chandef */ > > > > except you don't really, as discussed above > > > > I'd actually kind of like to have these validated against each other, > > but that's for another day, and we don't build the strictest > > implementation. > > > > Though I probably will make the implementation optionally stricter in > > some places like this, and enable that for all testing/certification > > in the future. > > we agree that the validation can be done in the future. Right, which basically the discussion above. Thanks! johannes