On Mon, Jul 18, 2016 at 03:59:38PM -0400, Vivien Didelot wrote: > Andrew Lunn <and...@lunn.ch> writes: > > >> Nope, the bridge ageing time is not per-port, even though switchdev ops > >> are per-port by design. This is a switch-wide attribute. > > > > So you are saying the core is doing all the reference counting, etc, > > when swapping between fast and slow ageing? > > I don't see how checking for the fastest ageing time would fix support > for multiple bridges...
The bridge should switch to fast ageing after a topology change to flush out entries which are now wrong. Using the short age time for too long results in a bit more inefficiency, in that entries time out faster than they need to. But if we go back to slow ageing too quickly, e.g. because of another bridge, we get wrong operation, in that bad entries can get stuck in the table for up to 5 minutes. So either we need to keep fast ageing as long as there is one bridge fast ageing, or we need to flush the whole MAC cache for a bridge on topology change and don't bother with fast ageing at all. > Maybe we can keep it simple for the moment with this switch-wide > set_ageing_time operation, and later add a patch for the DSA layer to > cache and elect the ageing time per-port or per-bridge. I don't think it can be done at the DSA layer. It does not have the information needed. Andrew