From mboxrd@z Thu Jan 1 00:00:00 1970 From: Stephen Hemminger Subject: Re: [PATCH net-next v12 1/5] net: Introduce generic failover module Date: Fri, 25 May 2018 16:29:30 -0700 Message-ID: <20180525162917.77c3b334@xeon-e3> References: <1527180917-39737-1-git-send-email-sridhar.samudrala@intel.com> <1527180917-39737-2-git-send-email-sridhar.samudrala@intel.com> <20180525153843.503ee052@xeon-e3> <00d34f67-f26f-0b20-af3f-2add24ae8a5c@intel.com> Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Cc: mst@redhat.com, davem@davemloft.net, netdev@vger.kernel.org, virtualization@lists.linux-foundation.org, virtio-dev@lists.oasis-open.org, jesse.brandeburg@intel.com, alexander.h.duyck@intel.com, kubakici@wp.pl, jasowang@redhat.com, loseweigh@gmail.com, jiri@resnulli.us, aaron.f.brown@intel.com, anjali.singhai@intel.com To: "Samudrala, Sridhar" Return-path: Received: from mail-pf0-f193.google.com ([209.85.192.193]:35842 "EHLO mail-pf0-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751918AbeE2E2Y (ORCPT ); Tue, 29 May 2018 00:28:24 -0400 Received: by mail-pf0-f193.google.com with SMTP id w129-v6so6661271pfd.3 for ; Mon, 28 May 2018 21:28:24 -0700 (PDT) In-Reply-To: <00d34f67-f26f-0b20-af3f-2add24ae8a5c@intel.com> Sender: netdev-owner@vger.kernel.org List-ID: On Fri, 25 May 2018 16:06:58 -0700 "Samudrala, Sridhar" wrote: > On 5/25/2018 3:38 PM, Stephen Hemminger wrote: > > On Thu, 24 May 2018 09:55:13 -0700 > > Sridhar Samudrala wrote: > > > >> diff --git a/include/linux/netdevice.h b/include/linux/netdevice.h > >> index 03ed492c4e14..0f4ba52b641d 100644 > >> --- a/include/linux/netdevice.h > >> +++ b/include/linux/netdevice.h > >> @@ -1421,6 +1421,8 @@ struct net_device_ops { > >> * entity (i.e. the master device for bridged veth) > >> * @IFF_MACSEC: device is a MACsec device > >> * @IFF_NO_RX_HANDLER: device doesn't support the rx_handler hook > >> + * @IFF_FAILOVER: device is a failover master device > >> + * @IFF_FAILOVER_SLAVE: device is lower dev of a failover master device > >> */ > >> enum netdev_priv_flags { > >> IFF_802_1Q_VLAN = 1<<0, > >> @@ -1450,6 +1452,8 @@ enum netdev_priv_flags { > >> IFF_PHONY_HEADROOM = 1<<24, > >> IFF_MACSEC = 1<<25, > >> IFF_NO_RX_HANDLER = 1<<26, > >> + IFF_FAILOVER = 1<<27, > >> + IFF_FAILOVER_SLAVE = 1<<28, > >> }; > > Why is FAILOVER any different than other master/slave relationships. > > I don't think you need to take up precious netdev flag bits for this. > > These are netdev priv flags. > Jiri says that IFF_MASTER/IFF_SLAVE are bonding specific flags and cannot be used > with other failover mechanisms. Team also doesn't use this flags and it has its own > priv_flags. > They are already used by bonding and team. I don't see why this can't reuse them.