lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <55501BF1.10202@cumulusnetworks.com>
Date:	Sun, 10 May 2015 20:03:13 -0700
From:	roopa <roopa@...ulusnetworks.com>
To:	Scott Feldman <sfeldma@...il.com>
CC:	Jiri Pirko <jiri@...nulli.us>, Netdev <netdev@...r.kernel.org>,
	Guenter Roeck <linux@...ck-us.net>,
	Florian Fainelli <f.fainelli@...il.com>,
	"andrew@...n.ch" <andrew@...n.ch>,
	"simon.horman@...ronome.com" <simon.horman@...ronome.com>,
	Joe Perches <joe@...ches.com>,
	"Samudrala, Sridhar" <sridhar.samudrala@...el.com>,
	"Arad, Ronen" <ronen.arad@...el.com>
Subject: Re: [PATCH net-next v6 14/23] bridge: restore br_setlink back to
 original

On 5/10/15, 7:46 PM, Scott Feldman wrote:
> On Sun, May 10, 2015 at 5:55 PM, roopa <roopa@...ulusnetworks.com> wrote:
>> On 5/10/15, 4:55 PM, Scott Feldman wrote:
>>> On Sun, May 10, 2015 at 9:10 AM, roopa <roopa@...ulusnetworks.com> wrote:
>>>> On 5/9/15, 12:00 PM, Jiri Pirko wrote:
>>>>> Sat, May 09, 2015 at 07:40:16PM CEST, sfeldma@...il.com wrote:
>>>>>> From: Scott Feldman <sfeldma@...il.com>
>>>>>>
>>>>>> Restore br_setlink back to original and don't call into SELF port
>>>>>> driver.
>>>>>> rtnetlink.c:bridge_setlink() already does a call into port driver for
>>>>>> SELF.
>>>>>>
>>>>>> bridge set link cmd defaults to MASTER.  From man page for bridge link
>>>>>> set
>>>>>> cmd:
>>>>>>
>>>>>>          self   link setting is configured on specified physical device
>>>>>>
>>>>>>          master link setting is configured on the software bridge
>>>>>> (default)
>>>>>>
>>>>>> The link setting has two values: the device-side value and the software
>>>>>> bridge-side value.  These are independent and settable using the bridge
>>>>>> link set cmd by specifying some combination of [master] | [self].
>>>>>> Futhermore, the device-side and bridge-side settings have their own
>>>>>> initial
>>>>>> value, viewable from bridge -d link show cmd.
>>>>>>
>>>>>> Restoring br_setlink back to original makes rocker (the only in-kernel
>>>>>> user
>>>>>> of SELF link settings) work as first implement: two-sided values.
>>>>>>
>>>>>> It's true that when both MASTER and SELF are specified from the
>>>>>> command,
>>>>>> two netlink notifications are generated, one for each side of the
>>>>>> settings.
>>>>>> The user-space app can distiquish between the two notifications by
>>>>>> observing the MASTER or SELF flag.
>>>>> This is revert of:
>>>>>
>>>>> commit 68e331c785b85b78f4155e2ab6f90e976b609dc1
>>>>> Author: Roopa Prabhu <roopa@...ulusnetworks.com>
>>>>> Date:   Thu Jan 29 22:40:14 2015 -0800
>>>>>
>>>>>        bridge: offload bridge port attributes to switch asic if feature
>>>>> flag
>>>>> set
>>>>>
>>>>> Noting that because I want to make sure everybody is ok with new
>>>>> behaviour. I tend to like it more.
>>>>>
>>>> I am not ok with it. I have raised this earlier. same argument as the fib
>>>> code, app now has to remember to call with both master and self. I do
>>>> however feel that this code needs some rework..,.add to hardware first
>>>> and
>>>> then software
>>>> just like fib and rollback hardware on failure. In which case, i am ok
>>>> with
>>>> submitting a new patch to do it differently.
>>> The problem with your patch to br_setlink/br_dellink is it hard-coded
>>> a default in the kernel bridge driver, inconsistent with the default
>>> of the application (iproute2/bridge).  Reverting it keeps the kernel
>>> out of the default decision and lets the application define a default
>>> that suits it.
>> sorry, I am not understanding how this is different from how we do offload
>> for fib and stp.
>> just like stp offload from the bridge driver, i am hoping we can also
>> offload vlans (current patch under discussion)
>> and fdb entries. The switch driver can decide if it is only interested in
>> calls with flags set to 'self' (rocker for example).
>>
>> another example: mstp daemon running in userspace will use bridge setlink to
>> propagate stp states to the in-kernel bridge driver. If the current patch is
>> removed, mstp daemon will now have to make sure it calls bridge setlink with
>> self and master flags to hit both the bridge driver and hardware.
> You're making my point with this example: let the application set the
> flags it wants, and let the kernel provide the mechanism.
>
> The kernel mechanism for both FDB (rtnl_fdb_add) and bridge settings
> (rtnl_bridge_setlink) are the same: they both have this basic logic to
> handle MASTER and SELF flags:
>
> if (!flags || flags & MASTER)
>      if (master->ops->ndo_xxx)
>          master->ops->ndo_xxx(...);
> if (flags & SELF)
>      if (port->ops->ndo_xxx)
>          port->ops->ndo_xxx(...);
>
> That's all the kernel should do.  What is the default flags when
> explicit flags aren't specified by the user is up to the application.
> Current example apps:
>
> iproute2/bridge/fbd app passes SELF when no flags are given by user.
> iproute2/bridge/vlan app passes no flags when no flags are given by user.
> iproute2/bridge/link set app passes SELF if setting hwmode, otherwise
> passes no flags when no flags are given by user.
> mstp app passes no flags (I assume, based on what you wrote above).
>
> So if you want different app defaults than above, we need to change
> the app, not the kernel.
yes, I understand your point... and this is where we have a difference 
of opinion. I have only been saying that
the kernel defaults should be in favor of existing apps (for easier 
migration of these
apps to switch-devices).
>
> (FIB isn't part of this discussion because there is (currently) no
> MASTER|SELF flags for FIB entries, so I'm not sure why you're bringing
> up FIB).
>
I brought up FIB because you and I had a similar thread last week for 
FIB on the use of RTNH_F_EXTERNAL
by apps. RTNH_F_EXTERNAL is analogous to NTF_SELF in the FIB context IMO.

--
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

Powered by Openwall GNU/*/Linux Powered by OpenVZ