Received: by 2002:ac0:a582:0:0:0:0:0 with SMTP id m2-v6csp87514imm; Thu, 4 Oct 2018 23:52:23 -0700 (PDT) X-Google-Smtp-Source: ACcGV62fVdQ+2ZZ9JBKs0wtFpm/m0VR/0LAqjb1rujPltkqnsVnXXFsfvf6dKOjEKthlAq6BiL+a X-Received: by 2002:a62:ff09:: with SMTP id b9-v6mr10387606pfn.46.1538722343162; Thu, 04 Oct 2018 23:52:23 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1538722343; cv=none; d=google.com; s=arc-20160816; b=A/+CF/hxjkqsksBdWqQFEdGL6ocdm+tnKZ0P8s5DDk11/7rSU0vPtvBNpw47VrWtAH KOH5HF9leX52lDpfKctjwxyQBcaJF1zRhucxr7NnRqPrvE5MYRle0mg0YtOMoTEFSCst DH16ozkhUU+gnusXkPzNoajxo9Hqm8NARNWvEh+FoBFmVqsdQ/u9JA26bnAjiuH2UFIv vyh4jZVOOof5CEoGGzwJ3V/Us7YZlix72DFB/PFWHKw/Mj8dvB+ZKuZbivOblbIFzI3F p1bwZ2ZIc2+b87ydEYJcoZ+7lvNR8tqRhcaruexQavkgBa6uskHesW8fK6r0XMz0jMvn IpJg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=4rTiDMhrNIVz3kNhO6rNZIxtTCiB8NL5jDSncByUcJc=; b=mgVRKkMJwOHoAFYGDbM+BDIppIr42xBE1eHGr0ILY++q/sG2IQpth5jg9ggYNJEn6g dx7eUQsda6NOdd36wuFmf1XFjfxerg4T/pSzgfkWm38kRaO9KZapJKIV4PEzLVKPJFcm nxxGEanYepZGr2qz37O++r3BSkYXATOXpwytYoC3DfLyQb0UMx/ZzOPb/f/+3U8u2u7I aoY3hMSlrDIAZnZfsM66ZuR33C25+nz1qVrmAu4Lg1VIEfOhZrDKn4bQfizlaXG+hgaK 22Cp/jn8opxyMy150fLxWqP4C8bW3rivLBLyTwtQs/eiFUuwA5P/hNrHB59lveoVcXuB 06Sg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@resnulli-us.20150623.gappssmtp.com header.s=20150623 header.b=Q8xLVqmu; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 3-v6si5929091plp.173.2018.10.04.23.52.06; Thu, 04 Oct 2018 23:52:23 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@resnulli-us.20150623.gappssmtp.com header.s=20150623 header.b=Q8xLVqmu; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727836AbeJENtN (ORCPT + 99 others); Fri, 5 Oct 2018 09:49:13 -0400 Received: from mail-wm1-f68.google.com ([209.85.128.68]:40116 "EHLO mail-wm1-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727711AbeJENtM (ORCPT ); Fri, 5 Oct 2018 09:49:12 -0400 Received: by mail-wm1-f68.google.com with SMTP id z204-v6so794029wmc.5 for ; Thu, 04 Oct 2018 23:51:54 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=resnulli-us.20150623.gappssmtp.com; s=20150623; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to:user-agent; bh=4rTiDMhrNIVz3kNhO6rNZIxtTCiB8NL5jDSncByUcJc=; b=Q8xLVqmuCDmjbdRqFEkaL4HLE8sGrvIhhhI70NZyswWREgC8eT/QNor1IZbXm6amcH WeVAsu3Ehri48QkGsqhDgCXLtV8otkoto+OQtCgHUUxmF7EdgxPQW+NyiT6p+X3sXkQ8 mmU20h5BUk09bN3nNv5b0sl8wmT6cSTOPKENZIx4CoBSVBk6kE9mCtOgt8NJQ5E4LgFF VgA8rN7jqWIm3Cq4kXNuspRGzQU1GcJuPqw8HYtKl/F/gvNzNma7PHsgcsfGi1DP+5MP armwKSbJaFLqbuASXCL/y+FSTmp+rXMBEzdpAsrNIlS02AAYP4noQko72QaLrfJdmSqP P8Qw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to:user-agent; bh=4rTiDMhrNIVz3kNhO6rNZIxtTCiB8NL5jDSncByUcJc=; b=MEt+yjm04M3VQ3y06oFSkpi7qCinHaWqLvTLgIS2VtEh08wYtt0kfTOOjD26x6LVyL rXlFLS0qYRjWcGyrggrDzsOb4zLrO+XgNk1v/8CQHe1JGgzLYNG83I3vKLLmcwB8YiQV amRLgAsTXU6gdJpobvZXxMbdMXPa1vCGWXxw+KQfmY7ESBfbLLF26P+iO4vQj3zeObr9 wNadar/SHeUcni8cgNTBOP7fHXffxdN8pjFt+5WguKc8gPzaI2WoQfPyF4yfgWRYeuCT APgCq+VopKBoNJHtPA9Bi2LuZJxoOiR33XyuA1HitvDmVqCkuDSED18GQxgyWwrpqG+b KYEw== X-Gm-Message-State: ABuFfoj/b4hcrGZ2suUIgx6uNjq5T1DdcqXUUXqLdpkNvNkqCSmGyFkH XK8NbvUH4LZwimhdi+XRA52P7A== X-Received: by 2002:a1c:dc0a:: with SMTP id t10-v6mr6783014wmg.105.1538722313242; Thu, 04 Oct 2018 23:51:53 -0700 (PDT) Received: from localhost (jirka.pirko.cz. [84.16.102.26]) by smtp.gmail.com with ESMTPSA id 62-v6sm8487227wra.48.2018.10.04.23.51.52 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Thu, 04 Oct 2018 23:51:52 -0700 (PDT) Date: Fri, 5 Oct 2018 08:46:37 +0200 From: Jiri Pirko To: Chas Williams <3chas3@gmail.com> Cc: Stephen Hemminger , Jan Blunck , LKML , netdev@vger.kernel.org Subject: Re: [PATCH] team: set IFF_SLAVE on team ports Message-ID: <20181005064637.GA3061@nanopsycho.orion> References: <20150710064147.GA2204@nanopsycho.orion> <20180930071414.GF2209@nanopsycho.orion> <20180930113805.3b8e62a1@shemminger-XPS-13-9360> <20180930093452.GG2209@nanopsycho.orion> <20181002111215.GA2222@nanopsycho> <20181003104436.GB2222@nanopsycho> <526bd655-5816-69dd-ac75-bdd4f85f1ce9@gmail.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <526bd655-5816-69dd-ac75-bdd4f85f1ce9@gmail.com> User-Agent: Mutt/1.9.5 (2018-04-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Wed, Oct 03, 2018 at 07:30:06PM CEST, 3chas3@gmail.com wrote: > > >On 10/03/18 06:44, Jiri Pirko wrote: >> Tue, Oct 02, 2018 at 11:20:25PM CEST, 3chas3@gmail.com wrote: >> > >> > >> > On 10/02/18 07:12, Jiri Pirko wrote: >> > > Mon, Oct 01, 2018 at 04:06:16PM CEST, 3chas3@gmail.com wrote: >> > > > >> > > > >> > > > On 09/30/18 05:34, Jiri Pirko wrote: >> > > > > Sun, Sep 30, 2018 at 11:38:05AM CEST, stephen@networkplumber.org wrote: >> > > > > > On Sun, 30 Sep 2018 09:14:14 +0200 >> > > > > > Jiri Pirko wrote: >> > > > > > >> > > > > > > Thu, Sep 27, 2018 at 04:04:26PM CEST, 3chas3@gmail.com wrote: >> > > > > > > > >> > > > > > > > >> > > > > > > > On 07/10/15 02:41, Jiri Pirko wrote: >> > > > > > > > > Thu, Jul 09, 2015 at 05:36:55PM CEST, jblunck@infradead.org wrote: >> > > > > > > > > > On Thu, Jul 9, 2015 at 12:07 PM, Jiri Pirko wrote: >> > > > > > > > > > > Thu, Jul 09, 2015 at 11:58:34AM CEST, jblunck@infradead.org wrote: >> > > > > > > > > > > > The code in net/ipv6/addrconf.c:addrconf_notify() tests for IFF_SLAVE to >> > > > > > > > > > > > decide if it should start the address configuration. Since team ports >> > > > > > > > > > > > shouldn't get link-local addresses assigned lets set IFF_SLAVE when linking >> > > > > > > > > > > > a port to the team master. >> > > > > > > > > > > >> > > > > > > > > > > I don't want to use IFF_SLAVE in team. Other master-slave devices are >> > > > > > > > > > > not using that as well, for example bridge, ovs, etc. >> > > > > > > > > > >> > > > > > > > > > Maybe they need to get fixed too. I've used that flag because it is >> > > > > > > > > > documented as >> > > > > > > > > > a "slave of a load balancer" which describes what a team port is. >> > > > > > > > > > >> > > > > > > > > > > I think that this should be fixed in addrconf_notify. It should lookup >> > > > > > > > > > > if there is a master on top and bail out in that case. >> > > > > > > > > > >> > > > > > > > > > There are other virtual interfaces that have a master assigned and want to >> > > > > > > > > > participate in IPv6 address configuration. >> > > > > > > > > >> > > > > > > > > Can you give me an example? >> > > > > > > > >> > > > > > > > I would like to revisit this patch (yes, I know it has been a while). I >> > > > > > > > believe the VRF implementation uses master to group the interfaces under >> > > > > > > > a single interface. >> > > > > > > > >> > > > > > > > I don't see a reason not to use IFF_SLAVE since team and bonding are fairly >> > > > > > > > similar. >> > > > > > > >> > > > > > > Again, why do you need team port to have IFF_SLAVE flag? What do you >> > > > > > > want to achieve >> > > > > > >> > > > > > Without setting this flag IPv6 will try and make a link specific address. >> > > >> > > You are talking about addrconf_notify() right? Easy to fix to check >> > > something more convenient. Like netif_is_lag_port() if you want to avoid >> > > it for bond/team. netif_is_ovs_port(), netif_is_bridge_port() etc. Lot's >> > > of helpers to cover this. >> > >> > OK, IPv6 should probably be using this. >> > >> > > >> > > >> > > >> > > > > >> > > > > Why is it not an issue with bridge, ovs, and other master-slave devices? >> > > > > >> > > > >> > > > It very well might be an issue for bridge and ovs. Other master-slave >> > > > devices include the existing VRF implementation in the kernel and those slave >> > > > interfaces will certainly want to use IPv6. >> > > > >> > > > However, IFF_SLAVE has a specific meaning: >> > > > >> > > > ./include/uapi/linux/if.h: * @IFF_SLAVE: slave of a load balancer. Volatile. >> > > >> > > I know that some userspace apps are using this flag to determine a >> > > "bonding slave". I don't think that they care much about eql... >> > > >> > > >> > > > >> > > > The bonding driver is not the only user: >> > > > >> > > > ./drivers/net/eql.c:#define eql_is_slave(dev) ((dev->flags & IFF_SLAVE) == >> > > > IFF_SLAVE) >> > > > ./drivers/net/eql.c: slave->dev->flags &= ~IFF_SLAVE; >> > > > ./drivers/net/eql.c: slave->dev->flags |= IFF_SLAVE; >> > > > >> > > > The team driver would like to use this same flag since it is a load balancer >> > > > as well. The side effect of not assigning IPv6 is a bonus. The fact that >> > > >> > > No, please leave IFF_SLAVE as it is. Both kernel and userspace have >> > > their clear indications right now about the master/slave relationships. >> > >> > The team driver does create a master/slave relationship. The team slaves are >> > literally slaves of the master device. It's not clear to me >> > why you we can't mark the slaves of the team master as actually being >> > slave interfaces? >> >> So? IFF_SLAVE flag serves a different purpose. That's it. Team does not >> need it, bridge does not need it, macvlan does not need it, etc. > >I agree. But team *is* a load balancer. Why can't team mark its slave >interfaces as IFF_SLAVE? They are literally slaves of a load balancer which >is the exact meaning of the IFF_SLAVE flag. I described that multiple times, don't want to repeat myself. Please read the thread again. > >> >> >> > >> > > >> > > >> > > > bridges and ovs are also likely broken is a different issue. Should there be >> > > > a another flag that says "layer 2 only"? Very possibly, but that is >> > > > something all these interfaces should be using to include bonding, team, eql, >> > > > obs, bridge etc. That's not a reasonable objection to labeling the team >> > > > slave as slaves since they are literally slaves of a load balancer. >> > > > >> > > > >> > > >