Received: by 2002:a05:6358:d09b:b0:dc:cd0c:909e with SMTP id jc27csp162797rwb; Wed, 14 Dec 2022 15:30:45 -0800 (PST) X-Google-Smtp-Source: AA0mqf4Ra9EtppstFD2LL02WFeNM7NXBEWPYrfptM+UEDxAwHUP5xt4BNyWctLwllSc+hwW24uC6 X-Received: by 2002:a05:6a20:a69d:b0:af:7762:3c29 with SMTP id ba29-20020a056a20a69d00b000af77623c29mr5585956pzb.10.1671060644836; Wed, 14 Dec 2022 15:30:44 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1671060644; cv=none; d=google.com; s=arc-20160816; b=V5PwLUJUaKdBOFibVrqnc/ajBp+D9zgRPd5oS7d11GKnSZYtXk/c1QM1bgKKDe479k tvMWnShIQ5EaTsNMbi4kNUsvl/0NaUM5ujSwn2p1Q3kvxQ0dQsRB22N9hx53ThSYDNN6 Hq3BYCE6atYyTJkCMz2C3L6dUL+9ppo5h5L9rZbBxwwe1axG42qDm5hLrcx6wsSS20Gn fQ3g3h/3LMg2c8ofGG7fsA8UyHyBvyaYFEhAKRbhUN7spstszLFWkv8731zMorUJ1O+D X+tp2XHnoX1TqIb4AbG+zTxIq0ikGHKyiT1RiUXAzagDHpPoVt2OOfBMO88D5aHURgYe FIaw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:from:subject:message-id:mime-version:date :dkim-signature; bh=mrPwVim4lxf8gn0+1ipqGx0TxDKuJ3J9+9eguqRThD8=; b=ocL6IFB+y4Vll2DNe6AJ3cEGK1nFdrlkEF+xgIOXRJuT9SaEQjzgEAWw+EtLltSIWs IaZR4EhQky+GNM8zR4BsJvRh3IBhzc1ox3X2iM29wH26daki1VBnKz0nsuAIQ+6PHkgJ D8ZX9Ng58EDeY/MxWH37653vGEIMkl5kZgGF67QLzAe5OKolaWegLWJyWJwYHN/pKikJ b2Ap7hiZv7iD7tgD3qFiDJZ7SkE2bK6Um47cUlRgj7HBEuUsBQIFOtM0pzsu8BiMRxe6 ht5TUVm9tmqMTwQN85NMJw4LIJ6OqFwFTkrB+N0ssYFpxtjs/6KdGhSJYP8oouSxai4v 3OyQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20210112 header.b=DsqJN0ri; 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=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id k70-20020a638449000000b004790797af7bsi1074694pgd.117.2022.12.14.15.30.35; Wed, 14 Dec 2022 15:30:44 -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=@google.com header.s=20210112 header.b=DsqJN0ri; 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=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229807AbiLNXVG (ORCPT + 69 others); Wed, 14 Dec 2022 18:21:06 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:51794 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229511AbiLNXVD (ORCPT ); Wed, 14 Dec 2022 18:21:03 -0500 Received: from mail-pj1-x104a.google.com (mail-pj1-x104a.google.com [IPv6:2607:f8b0:4864:20::104a]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id C16EB30B for ; Wed, 14 Dec 2022 15:21:02 -0800 (PST) Received: by mail-pj1-x104a.google.com with SMTP id o6-20020a17090ab88600b0021edf53917eso4706599pjr.3 for ; Wed, 14 Dec 2022 15:21:02 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20210112; h=cc:to:from:subject:message-id:mime-version:date:from:to:cc:subject :date:message-id:reply-to; bh=mrPwVim4lxf8gn0+1ipqGx0TxDKuJ3J9+9eguqRThD8=; b=DsqJN0rigBMWtAXYlvtBpKuld4XB+qDegJnzXmEutZJgGhDQveVUDC0O3bpiS740Qx xL47gJKmKEOaRW4EDNLKHGCMiWs9r0Ow57+64+sAlkfFohzb39x4QEEA4wxNoFSBr+Q7 hURRtwh5vQ44Y8h15RAH+VvDq+CSYB0bl8Yq0OIH1VbTEWPOnEa4YRECYk1ndOZVF1r1 lu3fISoqtCiVUuuJhxx3J2/9NYxvESBBPkMT0ZZzjbikC2oUj+5wTnL0+bKWcFGO3jDu xxsCoZkAYOixD43dWewi04cQlY5IiLhG3Fu1bOTFPYFmmhydWbGo9pCBNwoB8gBJUjq9 nY7Q== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=cc:to:from:subject:message-id:mime-version:date:x-gm-message-state :from:to:cc:subject:date:message-id:reply-to; bh=mrPwVim4lxf8gn0+1ipqGx0TxDKuJ3J9+9eguqRThD8=; b=I+HfAYQD7KKmkjMSCBQDgtN12PJRF+aObxysl2aPWCkIe/134jS6GPFSjsb8K3MEeM 46dHYdDmvb9jWCBLUL7jHB9QlU3Xudhxov2EBH3v2t+/ld0luFvMgmDEn0+4VkmXMA8B hJocyGIjTbAkq+kKCkq/h2sMLIYseGdICrEHNBD3QvaKo1QJI2rA8FCFXxP2YxkxU7OP p9+NIbzutgDnSfNmPicbX/LVyjBDA0mklT319SOr/a/RlZJTqf1ZW8cjjtDVu1f8XiGu RH6tRklUdJxQo+f9EHubr2VT2GXCpBuxsAy6MxxhtHHqfqZM++++l8fP0iqQl6qHuFUa j3Cg== X-Gm-Message-State: ANoB5pmTX6GD0comPDv9UgkZzRG+Buz9k0CNmq2Oj1bQuCswLoq/dpDd 5v/VhaGvzLyEnsALjBurccNcze1Hqg== X-Received: from decot.c.googlers.com ([fda3:e722:ac3:cc00:24:72f4:c0a8:5fa2]) (user=decot job=sendgmr) by 2002:a17:902:b282:b0:189:91f3:bfe2 with SMTP id u2-20020a170902b28200b0018991f3bfe2mr51458709plr.34.1671060062139; Wed, 14 Dec 2022 15:21:02 -0800 (PST) Date: Wed, 14 Dec 2022 15:20:59 -0800 Mime-Version: 1.0 X-Mailer: git-send-email 2.39.0.rc1.256.g54fd8350bd-goog Message-ID: <20221214232059.760233-1-decot+git@google.com> Subject: [PATCH net-next v2 1/1] net: neigh: persist proxy config across link flaps From: David Decotigny To: "David S. Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , netdev@vger.kernel.org, linux-kernel@vger.kernel.org Cc: Nikolay Aleksandrov , David Ahern , "Denis V. Lunev" , Daniel Borkmann , Chen Zhongjin , David Decotigny , Yuwei Wang , Alexander Mikhalitsyn , Thomas Zeitlhofer Content-Type: text/plain; charset="UTF-8" X-Spam-Status: No, score=-9.6 required=5.0 tests=BAYES_00,DKIMWL_WL_MED, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_NONE, SPF_HELO_NONE,SPF_PASS,USER_IN_DEF_DKIM_WL 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 From: David Decotigny Without this patch, the 'ip neigh add proxy' config is lost when the cable or peer disappear, ie. when the link goes down while staying admin up. When the link comes back, the config is never recovered. This patch makes sure that such an nd proxy config survives a switch or cable issue. Signed-off-by: David Decotigny --- v1: initial revision v2: same as v1, except rebased on top of latest net-next, and includes "net-next" in the description net/core/neighbour.c | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/net/core/neighbour.c b/net/core/neighbour.c index f00a79fc301b..f4b65bbbdc32 100644 --- a/net/core/neighbour.c +++ b/net/core/neighbour.c @@ -426,7 +426,10 @@ static int __neigh_ifdown(struct neigh_table *tbl, struct net_device *dev, { write_lock_bh(&tbl->lock); neigh_flush_dev(tbl, dev, skip_perm); - pneigh_ifdown_and_unlock(tbl, dev); + if (skip_perm) + write_unlock_bh(&tbl->lock); + else + pneigh_ifdown_and_unlock(tbl, dev); pneigh_queue_purge(&tbl->proxy_queue, dev ? dev_net(dev) : NULL, tbl->family); if (skb_queue_empty_lockless(&tbl->proxy_queue)) -- 2.39.0.rc1.256.g54fd8350bd-goog