[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20140315020826.GB28801@wotan.suse.de>
Date: Sat, 15 Mar 2014 03:08:26 +0100
From: "Luis R. Rodriguez" <mcgrof@...e.com>
To: Stephen Hemminger <stephen@...workplumber.org>
Cc: "Luis R. Rodriguez" <mcgrof@...not-panic.com>,
netdev@...r.kernel.org, linux-kernel@...r.kernel.org,
kvm@...r.kernel.org, xen-devel@...ts.xenproject.org,
bridge@...ts.linux-foundation.org
Subject: Re: [PATCH 3/3] bridge: fix bridge root block on designated port
On Thu, Mar 13, 2014 at 03:16:23PM -0700, Stephen Hemminger wrote:
> On Wed, 12 Mar 2014 20:15:27 -0700
> "Luis R. Rodriguez" <mcgrof@...not-panic.com> wrote:
>
> > --- a/net/bridge/br_private.h
> > +++ b/net/bridge/br_private.h
> > @@ -150,6 +150,7 @@ struct net_bridge_port
> > u8 priority;
> > u8 state;
> > u16 port_no;
> > + bool root_block_enabled;
> > unsigned char topology_change_ack;
>
> It seems a bit confusing to have both a ROOT_BLOCK flag in the
> data structure and and additional root_block_enabled flag.
> If nothing else it is a waste of space.
Indeed, however there is a use for it. Consider the case where we loop
over each port and check to see if its root blocked and need to tickle it
or the bridge. In the case that root port block was enabled before and
someone is lifting it the flag would be removed and therefore not on
but it was root blocked though and we need a way to keep track of that.
The flag then is a toggle for userspace, while the bool tells us about
the current state.
> Looks like you are changing the meaning slightly.
Let me know in what way. I can't see it.
> is possible to have BR_ROOT_BLOCK set but !root_block_enabled?
Yeah in the case a new request to set it to root block then
BR_ROOT_BLOCK would be set but root_block_enabled would not be set.
> and what about the inverse?
BR_ROOT_BLOCK would not be set when userspace wants to disable root
port block and root_block_enabled would be enabled in this case if
it used to be enabled. So yes, both are possible.
Luis
Content of type "application/pgp-signature" skipped
Powered by blists - more mailing lists