[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <CA+CtxLSvB+vbUPS_7eJd8tfjQ1H_XVB9or=r=HAuusKVpoz9Kw@mail.gmail.com>
Date: Sat, 3 Jan 2015 06:53:58 +0530
From: Siva Mannem <siva.mannem.lnx@...il.com>
To: Scott Feldman <sfeldma@...il.com>
Cc: "stephen@...workplumber.org" <stephen@...workplumber.org>,
Netdev <netdev@...r.kernel.org>,
Jiří Pírko <jiri@...nulli.us>,
Roopa Prabhu <roopa@...ulusnetworks.com>
Subject: Re: [PATCH iproute2 v2] bridge/link: add learning_sync policy flag
> I think the aging settings are per-bridge, not per-bridge-port, so the
> policy control you're talking about wouldn't end up here on
> /sbin/bridge link.
>
Agree.
> However, I would argue even with hardware aging capability, we still
> should use Linux for aging since all the controls are already there
> and it just works. It keeps the swdev model simple and the swdev
> driver simple. Do you have a counter-argument for why enabling
> hardware aging would be better?
When traffic is being forwarded in hardware and if the entries are to
be software aged, the aging logic needs to periodically(once every
configured age interval) retrieve the FDB entry's hit bit in the
hardware. If this bit is not set it deletes the entry. If the hit bit
is set, it clears it. This could be CPU intensive if the FDB size runs
into few thousand entries.
If hardware aging is enabled, the above job is offloaded to hardware.
The current aging logic does not differentiate between software
forwarded and hardware forwarded entries. When the traffic is being
forwarded in hardware, the aging logic is deleting the entries after
age interval.
So the solution could be
1)When hardware aging is enabled, only the notifications(probably via
br_fdb_external_learn_delete()) delete the fdb entries.
2)When software aging is enabled, aging logic needs to differentiate
between software forwarded and hardware forwarded entries. For entries
forwarded in hardware, the above aging logic needs to be implemented.
On Fri, Jan 2, 2015 at 11:27 PM, Scott Feldman <sfeldma@...il.com> wrote:
> On Fri, Jan 2, 2015 at 9:14 AM, Siva Mannem <siva.mannem.lnx@...il.com> wrote:
>> Hi,
>>
>>
>>> +.BR "learning_sync on " or " learning_sync off "
>>> +Controls whether a given port will sync MAC addresses learned on device port to
>>> +bridge FDB.
>>> +
>>
>> For the FDB entries synced from device port to bridge FDB, can the
>> device port also mention that it will take care of aging the synced
>> entries? I am thinking of a use case where the port supports hardware
>> learning and hardware aging?
>
> I think the aging settings are per-bridge, not per-bridge-port, so the
> policy control you're talking about wouldn't end up here on
> /sbin/bridge link.
>
> However, I would argue even with hardware aging capability, we still
> should use Linux for aging since all the controls are already there
> and it just works. It keeps the swdev model simple and the swdev
> driver simple. Do you have a counter-argument for why enabling
> hardware aging would be better?
>
> -scott
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists