Hi. On Tue, 4 Jan 2022 at 13:18, Miquel Raynal <miquel.raynal@xxxxxxxxxxx> wrote: > > Hi Alexander, > ... > > > > I see now why promiscuous mode is necessary here. The actual > > promiscuous mode setting for the driver is not the same as promiscuous > > mode in 802.15.4 spec. For until now it was there for running a > > sniffer device only. > > As the 802.15.4 spec defines some "filtering levels" I came up with a > > draft so we can define which filtering level should be done on the > > hardware. > > I like the idea but I'm not sure on what side you want to tackle the > problem first. Is it the phy drivers which should advertise the mac > about the promiscuous mode they support (which matches the description > below but does not fit the purpose of an enum very well)? Or is it the > MAC that requests a particular filtering mode? In this case what a phy > driver should do if: > - the requested mode is more constrained than its usual promiscuous > capabilities? Then, the driver needs to go one level lower and tell mac802154 to filter more out. > - the requested mode is less constrained than its usual promiscuous > capabilities? > Then mac802154 needs to filter more out. I am more worried at the point the transceiver will shut off automatic acknowledge handling which we probably can't do in software in cases where it's required. Some transceivers will shut that off if they turn off address filtering and if they don't have a detailed setting for that they will ack every frame what they see, which is... not so good. Future work would be to warn about mismatch of seeing frames, what the hardware would filter out vs what mac802154 sees. More further work could be to use a monitor interface and raw sockets and verify transceivers how they act to frames. > > > > diff --git a/include/net/mac802154.h b/include/net/mac802154.h > > index 72978fb72a3a..3839ed3f8f0d 100644 > > --- a/include/net/mac802154.h > > +++ b/include/net/mac802154.h > > @@ -130,6 +130,48 @@ enum ieee802154_hw_flags { > > #define IEEE802154_HW_OMIT_CKSUM (IEEE802154_HW_TX_OMIT_CKSUM | \ > > IEEE802154_HW_RX_OMIT_CKSUM) > > > > +/** > > + * enum ieee802154_filter_mode - hardware filter mode that a driver > > will pass to > > + * pass to mac802154. > > Isn't it the opposite: The filtering level the mac is requesting? Here > it looks like we are describing driver capabilities (ie what drivers > advertise supporting). > I am sorry. I meant what the transceiver "should" deliver or "level less" to mac802154. I think the filtering when not much resources are required can also be done in a hardirq context. There exists a tasklet which is there to switch to a softirq context [0], currently we do all parsing there. > > + * > > + * @IEEE802154_FILTER_MODE_0: No MFR filtering at all. > > I suppose this would be for a sniffer accepting all frames, including > the bad ones. > yes. > > + * > > + * @IEEE802154_FILTER_MODE_1: IEEE802154_FILTER_MODE_1 with a bad FCS filter. > > This means that the driver should only discard bad frames and propagate > all the remaining frames, right? So this typically is a regular sniffer > mode. > I think this depends on what you want to filter out, so far I know in wireless this is configurable. Wireshark always expects the FCS in their payload for a linux 802.15.4 monitor interface and I think this is because of some historical reason to support the first 802.15.4 sniffers in wireshark. There is a difference between filter bad FCS and cutoff FCS. I need to look it up but I think wireless would cut off the checksum if FCS is filtered on hardware (may even some transceivers will not deliver FCS to you if you enable filtering). > > + * > > + * @IEEE802154_FILTER_MODE_2: Same as IEEE802154_FILTER_MODE_1, known as > > + * 802.15.4 promiscuous mode, sets > > + * mib.PromiscuousMode. > > I believe what you call mib.PromiscuousMode is the mode that is > referred in the spec, ie. being in the official promiscuous mode? So > that is the mode that should be used "by default" when really asking > for a 802154 promiscuous mode. > then we don't call it in driver level promiscuous mode, we call it "filtering level". And this is the filtering for cases when the standard says set "mib.PromiscuousMode". > Is there really a need for a different mode than mode_1 ? > I think so, I am not sure what they or will define if PromiscuousMode is set or not and might the transceiver need to get notice about it? It's not needed now, but we might keep it in mind then. > > + * > > + * @IEEE802154_FILTER_MODE_3_SCAN: Same as IEEE802154_FILTER_MODE_2 without > > + * set mib.PromiscuousMode. > > And here what is the difference between MODE_1 and MODE_3 ? > > I suppose here we should as well drop all non-beacon frames? Yes, additionally there could be a transceiver doing this filtering on hardware and tell that it's in scan and this is the difference. > > > + * > > + * @IEEE802154_FILTER_MODE_3_NO_SCAN: > > + * IEEE802154_FILTER_MODE_3_SCAN with MFR additional filter on: > > + * should be IEEE802154_FILTER_MODE_2. Maybe we can also get some better names for that but the standard describes it with numbers as well. > > + * - No reserved value in frame type > > + * - No reserved value in frame version > > + * - Match mib.PanId or broadcast > > + * - Destination address field: > > + * - Match mib.ShortAddress or broadcast > > + * - Match mib.ExtendedAddress or GroupRxMode is true > > + * - ImplicitBroadcast is true and destination address field/destination > > + * panid is not included. > > + * - Device is coordinator only source address present in data > > + * frame/command frame and source panid matches mib.PanId > > + * - Device is coordinator only source address present in multipurpose > > + * frame and destination panid matches macPanId > > + * - Beacon frames source panid matches mib.PanId. If mib.PanId is > > + * broadcast it should always be accepted. > > This is a bit counter intuitive, but do we agree on the fact that the > higher level of filtering should refer to promiscuous = false? > Yes, it's a lot of filter rules at this level. Yes, promiscuous is false in this case. That is what currently what wpan "node" interface should filter at mac802154 [1] (for cases device coordinator is false). I might mention a lot of future work here. I think we can live for now to make a difference between those levels and be sure that we drop everything else in the scan operation (inclusive check fcs in software). Moving stuff that we can do in hardware to hardware and the rest in software is a bigger task here... - Alex [0] https://elixir.bootlin.com/linux/v5.16-rc8/source/net/mac802154/rx.c#L294 [1] https://elixir.bootlin.com/linux/v5.16-rc8/source/net/mac802154/rx.c#L132