Received: by 2002:a05:6358:f14:b0:e5:3b68:ec04 with SMTP id b20csp4063255rwj; Tue, 20 Dec 2022 05:45:24 -0800 (PST) X-Google-Smtp-Source: AMrXdXtVoUuyo9bVxAuZ2u88fy6Grpm30DyXJ5TmTDwr+EdLM/dIr248+ScsxIjl6VxpTlfacUmy X-Received: by 2002:aa7:cd6c:0:b0:472:9af1:163f with SMTP id ca12-20020aa7cd6c000000b004729af1163fmr1976684edb.37.1671543924068; Tue, 20 Dec 2022 05:45:24 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1671543924; cv=none; d=google.com; s=arc-20160816; b=fMrCuGZ7J36+GkTRKkxpl+6jVXFgBUj9LYQsSQz7tPEt5BAMY5HkSUxNbm+A3+XWRz eng1MEKsIaTtdGNl68maA7LK/9RBMHbQQLdcpDVw4k0RSDBp04oYATDemnmFwVog44rW KiIdaX8qTwQrCsXAMwb0BuveySDSMs0YcbIKwanfmm7U+EuOyB8kpmJIUcBxh8VdN0zo I+jvioi1Kg4mmGpB4ogEjG9UfNd+FM+OL1czzicXnFJPJOjs2ppPTqddBtzZqorzLqLB OPCH9R9I63kQwAn8T0xqoM6tpDEpUzrKJNretggNFf7S2AhxI4eNztRkby/qVBumUdJm mP1w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:date:to:from:subject:message-id :dkim-signature; bh=DS9J7lgOk15cDqTwjWfeKKD/FSaeCVKaKczagIUj+Pc=; b=uKk2U+C291iwwTfUCXZNcDhvAsmH4blB4/CgyOkjeOdWlNOL5jGLpcJm7mevKyHR0p GrlkFfb8+k9/6AjclRrTGE65HLevp7rlpxWcQXldfsSo+bNs99+VvWwuz00ibTqrq33G q3s6hxjr3KzhY44MfVnqoYGnqmz03Ix61eygADRU2jLOQPBn3XOBjGbxR6eWWlnQb5z6 kDk2pA0es26PCkIkXITnO6rxKM62nuhdoBG2CDAoRHdvvTeERnX40tsgoRof/TtugycS 9Yh9cP8mjEAMNUOfKV7MZ+PqVrTQHmcjDahB8A4al8goq4czOPNU0XDTwvQC1TIGOXB7 w/4A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=AhHMwURA; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id r3-20020aa7d583000000b0046b5f81019fsi10333433edq.325.2022.12.20.05.45.07; Tue, 20 Dec 2022 05:45:24 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=AhHMwURA; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229994AbiLTNRR (ORCPT + 70 others); Tue, 20 Dec 2022 08:17:17 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43374 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229551AbiLTNRA (ORCPT ); Tue, 20 Dec 2022 08:17:00 -0500 Received: from us-smtp-delivery-124.mimecast.com (us-smtp-delivery-124.mimecast.com [170.10.133.124]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 950AA12607 for ; Tue, 20 Dec 2022 05:16:17 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1671542176; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=DS9J7lgOk15cDqTwjWfeKKD/FSaeCVKaKczagIUj+Pc=; b=AhHMwURA/zaWBJoCnFg8k5nLs5m6taFw+hXUucNSyscUs5FIlFx6F7J9kwuxMN3K5OULJs QOPZAxg1VOZtSQRx4DTGrm1ziphJ2SG5CjSY6cD/JDWqiJt4JzgX0MglPLskZTjg073wMg pf93rAAxTxZzohpMz+ROTNfR6Yk1Sqg= Received: from mail-wm1-f69.google.com (mail-wm1-f69.google.com [209.85.128.69]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.3, cipher=TLS_AES_128_GCM_SHA256) id us-mta-594-3m7qY3vWNzO958gmP8x2eg-1; Tue, 20 Dec 2022 08:16:15 -0500 X-MC-Unique: 3m7qY3vWNzO958gmP8x2eg-1 Received: by mail-wm1-f69.google.com with SMTP id j2-20020a05600c1c0200b003cf7397fc9bso6549129wms.5 for ; Tue, 20 Dec 2022 05:16:15 -0800 (PST) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:user-agent:references :in-reply-to:date:to:from:subject:message-id:x-gm-message-state:from :to:cc:subject:date:message-id:reply-to; bh=DS9J7lgOk15cDqTwjWfeKKD/FSaeCVKaKczagIUj+Pc=; b=0MMjY0LQ9Zgv2ESDtPDX1ntzHYhW9qNMjOEslFfHZE7iUXi/h8egfyObyTn+pLpqpM FxatIOl/hKDZDFdMgECVqYx7qNW4vKSHWN5cNKshn6lLn+ZHx5Ff374QRQDoc+VnhIR5 n9Elg8RlvEDfbRsF6HnFMUSRQc+uweKCh+3ULqwkK17RVIEnFtcjYdpSTuCG3AM8HUNA hkd5qM30ZCeIlwS/Y/v0GFMbsIXqhRp1d13h1SJtnqPlxy42BQ6Csobp4hs3Y3vQCtjI VdpuuZT8H6/QB8G8zxiX5d5zKEUCpIGYn1ctny2pfW5ayGaebSbePfFa4JbNm6x50X5P eaQQ== X-Gm-Message-State: AFqh2krSM7bB7xOjmpM7Z1dXPzcZN1eNf+QL6DKOglRh9pndHMADmHTX W1yQP6qwHmWg3cyBUOZ9xSyxhIMaybTwoKeNRqiUxGDGcS+zzViO1ZtpxvxjDckyRJFync9jUCd UiUKTcv5yDUE+Y8y7NKi4BdFY X-Received: by 2002:a05:600c:3d1b:b0:3cf:497c:c59e with SMTP id bh27-20020a05600c3d1b00b003cf497cc59emr1607033wmb.6.1671542174201; Tue, 20 Dec 2022 05:16:14 -0800 (PST) X-Received: by 2002:a05:600c:3d1b:b0:3cf:497c:c59e with SMTP id bh27-20020a05600c3d1b00b003cf497cc59emr1607018wmb.6.1671542173947; Tue, 20 Dec 2022 05:16:13 -0800 (PST) Received: from gerbillo.redhat.com (146-241-101-173.dyn.eolo.it. [146.241.101.173]) by smtp.gmail.com with ESMTPSA id n7-20020a05600c3b8700b003b492753826sm17549353wms.43.2022.12.20.05.16.12 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 20 Dec 2022 05:16:13 -0800 (PST) Message-ID: <2264ca933c234539774d9ae1d1de5a27dd1c12ae.camel@redhat.com> Subject: Re: [PATCH 1/2] ip/ip6_gre: Fix changing addr gen mode not generating IPv6 link local address From: Paolo Abeni To: Thomas Winter , davem@davemloft.net, yoshfuji@linux-ipv6.org, dsahern@kernel.org, kuba@kernel.org, a@unstable.cc, netdev@vger.kernel.org, linux-kernel@vger.kernel.org Date: Tue, 20 Dec 2022 14:16:11 +0100 In-Reply-To: <20221219010619.1826599-2-Thomas.Winter@alliedtelesis.co.nz> References: <20221219010619.1826599-1-Thomas.Winter@alliedtelesis.co.nz> <20221219010619.1826599-2-Thomas.Winter@alliedtelesis.co.nz> Content-Type: text/plain; charset="UTF-8" User-Agent: Evolution 3.42.4 (3.42.4-2.fc35) MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_NONE, RCVD_IN_MSPIKE_H2,SPF_HELO_NONE,SPF_NONE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, 2022-12-19 at 14:06 +1300, Thomas Winter wrote: > Commit e5dd729460ca changed the code path so that GRE tunnels > generate an IPv6 address based on the tunnel source address. > It also changed the code path so GRE tunnels don't call addrconf_addr_gen > in addrconf_dev_config which is called by addrconf_sysctl_addr_gen_mode > when the IN6_ADDR_GEN_MODE is changed. > > This patch aims to fix this issue by moving the code in addrconf_notify > which calls the addr gen for GRE and SIT into a separate function > and calling it in the places that expect the IPv6 address to be > generated. > > The previous addrconf_dev_config is renamed to addrconf_eth_config > since it only expected eth type interfaces and follows the > addrconf_gre/sit_config format. > > Fixes: e5dd729460ca ("ip/ip6_gre: use the same logic as SIT interfaces when computing v6LL address") > Signed-off-by: Thomas Winter > --- > net/ipv6/addrconf.c | 47 +++++++++++++++++++++++++-------------------- > 1 file changed, 26 insertions(+), 21 deletions(-) > > diff --git a/net/ipv6/addrconf.c b/net/ipv6/addrconf.c > index 6dcf034835ec..e9d7ec03316d 100644 > --- a/net/ipv6/addrconf.c > +++ b/net/ipv6/addrconf.c > @@ -3355,7 +3355,7 @@ static void addrconf_addr_gen(struct inet6_dev *idev, bool prefix_route) > } > } > > -static void addrconf_dev_config(struct net_device *dev) > +static void addrconf_eth_config(struct net_device *dev) You are creating a new function with the name of an existing one, while renaming the latter. IMHO this makes the patch hard to review as there are some existing call side for the old name, which we likelly want to explicitly see here. > { > struct inet6_dev *idev; > > @@ -3447,6 +3447,30 @@ static void addrconf_gre_config(struct net_device *dev) > } > #endif > > +static void addrconf_dev_config(struct net_device *dev) > +{ > + switch (dev->type) { > +#if IS_ENABLED(CONFIG_IPV6_SIT) > + case ARPHRD_SIT: > + addrconf_sit_config(dev); > + break; > +#endif > +#if IS_ENABLED(CONFIG_NET_IPGRE) || IS_ENABLED(CONFIG_IPV6_GRE) > + case ARPHRD_IP6GRE: > + case ARPHRD_IPGRE: > + addrconf_gre_config(dev); > + break; > +#endif > + case ARPHRD_LOOPBACK: > + init_loopback(dev); > + break; If I read correctly, this change will cause unneeded attempt to re-add the loopback address on the loopback device when the lo.addr_gen_mode sysfs entry is touched. I think such side effect should be avoided. Thanks, Paolo