Ido Schimmel
2022-Jul-03 07:00 UTC
[Bridge] [PATCH net-next v1 1/1] net: bridge: ensure that link-local traffic cannot unlock a locked port
On Fri, Jul 01, 2022 at 09:17:27PM +0200, Hans S wrote:> On Fri, Jul 1, 2022 at 7:00 PM Ido Schimmel <idosch at nvidia.com> wrote: > > > > On Fri, Jul 01, 2022 at 06:07:10PM +0200, Hans S wrote: > > > There is several issues when learning is turned off with the mv88e6xxx driver: > > > > Please don't top-post... > > Sorry, I am using gmails own web interface for a short while now as my > other options are not supported anymore by Google (not secure apps) > > > > > > > > > Mac-Auth requires learning turned on, otherwise there will be no miss > > > violation interrupts afair. > > > Refreshing of ATU entries does not work with learning turn off, as the > > > PAV is set to zero when learning is turned off. > > > This then further eliminates the use of the HoldAt1 feature and > > > age-out interrupts. > > > > > > With dynamic ATU entries (an upcoming patch set), an authorized unit > > > gets a dynamic ATU entry, and if it goes quiet for 5 minutes, it's > > > entry will age out and thus get removed. > > > That also solves the port relocation issue as if a device relocates to > > > another port it will be able to get access again after 5 minutes. > > > > You assume I'm familiar with mv88e6xxx, when in fact I'm not. Here is > > what I think you are saying: > > > > 1. When a port is locked and a packet is received with a SA that is not > > in the FDB, it will only generate a miss violation if learning is > > enabled. In which case, you will notify the bridge driver about this > > entry as externally learned and locked entry. > > Right. > > > 2. When a port is locked and a packet is received with a SA that matches > > a different port, it will be dropped regardless if learning is enabled > > or not. > > I would think so. > > > 3. From the above I conclude that the HW will not auto-populate its FDB > > when a port is locked. > > Right, and it should not as the locked port feature is basically CPU > controlled learning. > (yes it is an irony to have CPU controlled learning and learning > turned on, but that is just how it is with the mv88e6xxx series :-) ) > > > 4. FDB entries that point to a port that does not have learning enabled > > are not subject to ageing (why?). > > Sorry if I said so. Dynamic ATU entries will age I am sure, but they > will not refresh unless there is a match between the ingress port and > the Port Association Vector (PAV). > But an age out violation will not occur, and the HoldAt1 (entries age > from 7 -> 0) feature will not work either as it is related to the > refresh mechanism. > > > > > Assuming the above is correct, in order for mv88e6xxx to work correctly, > > it needs to enable learning on all locked ports, but it should happen > > regardless of the bridge driver learning configuration let alone impose > > any limitations on it. In fact, hostapd must disable learning for all > > locked ports. > > To have hardware induced refreshing I would say learning should be on > also for 802.1X (hostapd). This relies of course on user added dynamic > ATU entries, which is what my follow-up patch set is about. Besides it > is perfectly feasible to have both 802.1X and Mac-Auth on the same > port.IIUC, with mv88e6xxx, when the port is locked and learning is disabled: 1. You do not get miss violation interrupts. Meaning, you can't report 'locked' entries to the bridge driver. 2. You do not get aged-out interrupts. Meaning, you can't tell the bridge driver to remove aged-out entries. My point is that this should happen regardless if learning is enabled on the bridge driver or not. Just make sure it is always enabled in mv88e6xxx when the port is locked. Learning in the bridge driver itself can be off, thereby eliminating the need to disable learning from link-local packets.
Hans S
2022-Jul-04 07:54 UTC
[Bridge] [PATCH net-next v1 1/1] net: bridge: ensure that link-local traffic cannot unlock a locked port
> > IIUC, with mv88e6xxx, when the port is locked and learning is disabled: > > 1. You do not get miss violation interrupts. Meaning, you can't report > 'locked' entries to the bridge driver. > > 2. You do not get aged-out interrupts. Meaning, you can't tell the > bridge driver to remove aged-out entries. > > My point is that this should happen regardless if learning is enabled on > the bridge driver or not. Just make sure it is always enabled in > mv88e6xxx when the port is locked. Learning in the bridge driver itself > can be off, thereby eliminating the need to disable learning from > link-local packets.So you suggest that we enable learning in the driver when locking the port and document that learning should be turned off from user space before locking the port?