The 08/27/2019 15:18, Andrew Lunn wrote: > External E-Mail > > > > That sounds like a great idea. I was expecting to add this logic in the > > set_rx_mode function of the driver. But unfortunetly, I got the calls to > > this function before the dev->promiscuity is updated or not to get the > > call at all. For example in case the port is member of a bridge and I try > > to enable the promisc mode. > > Hi Horatiu Hi Andrew, > > What about the notifier? Is it called in all the conditions you need > to know about? I had a look also over this but without any luck. I can get good information from this, like knowing when a port is added or removed from the bridge(NETDEV_CHANGEUPPER). But not in case the promisc is change by an application(eg. tcpdump). In this case if port is part of the bridge and then promisc is enable, then there is no callback to the driver or any notifications. > > Or, you could consider adding a new switchdev call to pass this > information to any switchdev driver which is interested in the > information. Having this new switchdev call and listening for NETDEV_CHANGEUPPER seems to be enough to know when a port needs to go in promisc mode. > > At the moment, the DSA driver core does not pass onto the driver it > should put a port into promisc mode. So pcap etc, will only see > traffic directed to the CPU, not all the traffic ingressing the > interface. If you put the needed core infrastructure into place, we > could plumb it down from the DSA core to DSA drivers. > > Having said that, i don't actually know if the Marvell switches > support this. Forward using the ATU and send a copy to the CPU? What > switches tend to support is port mirroring, sending all the traffic > out another port. A couple of DSA drivers support that, via TC. > > Andrew > -- /Horatiu