On Thu, Dec 19, 2019 at 10:32:06AM -0800, Brian Norris wrote: > On Thu, Dec 19, 2019 at 7:48 AM Jouni Malinen <j@xxxxx> wrote: > > On Thu, Dec 19, 2019 at 09:44:52AM +0000, Pkshih wrote: > > > On Wed, 2019-12-18 at 17:48 +0200, Kalle Valo wrote: > > > > diff --git a/include/uapi/nl80211-vnd-qca.h b/include/uapi/nl80211-vnd-qca.h > > > > + * NOTE: The authoritative place for definition of QCA_NL80211_VENDOR_ID, > > > > + * vendor subcmd definitions prefixed with QCA_NL80211_VENDOR_SUBCMD, and > > > > + * qca_wlan_vendor_attr is open source file src/common/qca-vendor.h in > > > > + * git://w1.fi/srv/git/hostap.git; the values here are just a copy of that > > By the way, I wonder -- why have this statement? That's not how I > recall any other piece of kernel development ever working; upstream > Linux defines the upstream Linux API, not some arbitrary user space > project. This statement could be useful for saying, "don't stomp on > those command numbers please," but the response should probably be to > go out and define a totally new vendor ID or something. (See below.) As far as the OUI 00:13:74 is concerned, the defined mechanism for getting any new identifier values assigned is by getting a patch applied into hostap.git. If another OUI is used, that can clearly use different mechanism for this. Anyway, I'd expect the process for OUI 00:13:74 to be the most convenient one to use. This does not mean that there could not be new subcmds and attributes defined as part of the upstream kernel review and those changes being modified as part of that review. However, the final ID values for the subcmds/attributes would happen through whatever mechanism defined for the particular OUI. For 00:13:74, that would mean defining the subcmds/attributes first with TBD ID values and once the definitions are otherwise fine in the kernel patch review, contributing a patch to hostap.git to get the identifiers assigned, updating the kernel patch to use the assigned values, and apply it to the kernel. > > Please note that the vendor subcmd and attributes used here are already > > deployed and in use as a kernel interface. As such, the existing > > attributes cannot really be modified; if anything else would be needed, > > that would need to be defined as a new attribute and/or command. > > Clarification: you're talking about out-of-tree drivers, which really > have no relevance in upstream discussion, except possibly as examples. > I don't think it's ever been a valid approach to dictate upstream > kernel design based simply on "what $vendor already implemented for > Android." There is clearly no requirement to use an existing attribute, but since there is such an attribute already defined, I'd claim it is perfectly fine to consider it as an option for this. If something else is identified to be needed, a new subcmd/attribute can obviously be defined. > Maybe it's a better idea to just use different command numbers (or > vendor ID?) here, to avoid stomping on each others' implementation > choices. Otherwise, it sounds like our only choice here is to copy > your Android driver verbatim, or get lost. I'd use the same OUI 00:13:74 since there is a defined process for getting identifiers assigned from there for upstream Linux WLAN needs. Defining other/new non-conflicting subcmds/attributes is of course fine when needed. > > This was discussed during the 2019 wireless workshop. The conclusion > > from that discussion was that while there is clear need for SAR power > > limits for various devices and multiple vendors/drivers, it did not look > > clear that a single common interface could be defined cleanly taken into > > account the differences in the ways vendors have designed the mechanism > > in driver and firmware implementations. As such, vendor specific > > commands were identified as the approach. > > [citation needed] I'm not aware of any publicly available meeting minutes that covered the details for that discussion. My personal notes indicate that there were at least two vendors indicating existence of vendor specific commands for configuring SAR parameters, a discussion about the parameters used for this being different, and a conclusion that this would be an example kernel interface where a generic nl80211 interface may not be achievable and a vendor specific interface would be more likely. This discussion resulted in the discussion on how to use vendor specific nl80211 commands/attributes in upstream drivers and the eventual documentation of that in the location you noted. -- Jouni Malinen PGP id EFC895FA