Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp3510656pxf; Mon, 15 Mar 2021 11:08:37 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyny3u5KIFwLBBJaoDX3zMCDyubLwOVokJ1vNa70No3OqWhjk/9Crm29ZF9EBasDjXzPKVi X-Received: by 2002:a17:906:fa04:: with SMTP id lo4mr25186888ejb.44.1615831717260; Mon, 15 Mar 2021 11:08:37 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1615831717; cv=none; d=google.com; s=arc-20160816; b=FDlWlVX28+Rhsl/6yYEjPE3hPk31pOFOXZMErbqpCFNHktC0sw1wlXMGPXJuFIgFpQ Y3EmB9J1BZqcAilbnFWcfYPk/QcAEfXdsuar/kfSuRwuwdPjYTLjVSb5mFwgOl/5vJaz 9LVOtJ5wWG1+wVpOSNeQmwUn35SciO2s01fiIyb21EOL/s+1jZIv1sMRuLxGQwuUVpAh PFggQWf4U1suF43dlN2wcqW6CkunxybqKNxTKpbPLKMXBoGhyAC0Eq3/ahyE1lQHg1I0 lVCC6EBcIhpG/qCuPNtpNu80hKHTF94E6MavMzNs6bBMNfAlYtUZ+2jMqtTZZW9iq7qU zjMA== 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:message-id:date:subject:cc:to :from:dkim-signature; bh=5ReBodN/GdVg7rQG6F6/01QsPkBuhL00aIDPRs243Ds=; b=NsXkI5UPDUJ7GGynt7Rl4rHY+4bbRP3X5G27wetamQoNBHWGfqwfMi3217PHfv3jaC nLOW5We1zSHqwPKzOD0vofl1rkkVrDprnmrNBpf5wpgevoZICECFqLlx2iE7D47XWW/O UjMCLYoQGFgRfOd6lYqRz6x0fKY+I0jXKuP8Pm9YCHTnwn+GC4oX0NlqCaZP1uZk6hUO Py2FC7PuhiTQjYwbYUGaU816rfl89J/U6ESKJBuhGK4D+GDiXrLWzBdQTj7OEi/LBnvn dsv5xwvLM9zn70uTD4MER4hu7coJ7HOl3b6BB0Mk10IfHg3YkbzaxvDrZw4YDWW56JRJ yyPw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=1D6yVZDl; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id gb35si12588792ejc.351.2021.03.15.11.08.00; Mon, 15 Mar 2021 11:08:37 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=1D6yVZDl; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234169AbhCOOIv (ORCPT + 99 others); Mon, 15 Mar 2021 10:08:51 -0400 Received: from mail.kernel.org ([198.145.29.99]:36238 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232174AbhCON5x (ORCPT ); Mon, 15 Mar 2021 09:57:53 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id C380264EF9; Mon, 15 Mar 2021 13:57:51 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1615816673; bh=/h7Fo9PsZEYEPkZLIfWEe7IaRWIQsXhllhe6nkvyAgw=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=1D6yVZDliGPAx4snnmXB7KyI4HCdFJ45jNpcyQs458GwIEZgMz4QpOKKl21nGpFhe Zd9h9oJay5AWV0PWQ4rG85XSTNrV0rGPE6FaN/FdzX/q5y/c/uqcCtP52uBY/1ywOw nraIyyjLpATXJrLNDsI0veo6bRQTYKIiVaAsi3wQ= From: gregkh@linuxfoundation.org To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Ido Schimmel , Donald Sharp , David Ahern , "David S. Miller" Subject: [PATCH 5.10 047/290] nexthop: Do not flush blackhole nexthops when loopback goes down Date: Mon, 15 Mar 2021 14:52:20 +0100 Message-Id: <20210315135543.512518648@linuxfoundation.org> X-Mailer: git-send-email 2.30.2 In-Reply-To: <20210315135541.921894249@linuxfoundation.org> References: <20210315135541.921894249@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Greg Kroah-Hartman From: Ido Schimmel commit 76c03bf8e2624076b88d93542d78e22d5345c88e upstream. As far as user space is concerned, blackhole nexthops do not have a nexthop device and therefore should not be affected by the administrative or carrier state of any netdev. However, when the loopback netdev goes down all the blackhole nexthops are flushed. This happens because internally the kernel associates blackhole nexthops with the loopback netdev. This behavior is both confusing to those not familiar with kernel internals and also diverges from the legacy API where blackhole IPv4 routes are not flushed when the loopback netdev goes down: # ip route add blackhole 198.51.100.0/24 # ip link set dev lo down # ip route show 198.51.100.0/24 blackhole 198.51.100.0/24 Blackhole IPv6 routes are flushed, but at least user space knows that they are associated with the loopback netdev: # ip -6 route show 2001:db8:1::/64 blackhole 2001:db8:1::/64 dev lo metric 1024 pref medium Fix this by only flushing blackhole nexthops when the loopback netdev is unregistered. Fixes: ab84be7e54fc ("net: Initial nexthop code") Signed-off-by: Ido Schimmel Reported-by: Donald Sharp Reviewed-by: David Ahern Signed-off-by: David S. Miller Signed-off-by: Greg Kroah-Hartman --- net/ipv4/nexthop.c | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) --- a/net/ipv4/nexthop.c +++ b/net/ipv4/nexthop.c @@ -1182,7 +1182,7 @@ out: /* rtnl */ /* remove all nexthops tied to a device being deleted */ -static void nexthop_flush_dev(struct net_device *dev) +static void nexthop_flush_dev(struct net_device *dev, unsigned long event) { unsigned int hash = nh_dev_hashfn(dev->ifindex); struct net *net = dev_net(dev); @@ -1194,6 +1194,10 @@ static void nexthop_flush_dev(struct net if (nhi->fib_nhc.nhc_dev != dev) continue; + if (nhi->reject_nh && + (event == NETDEV_DOWN || event == NETDEV_CHANGE)) + continue; + remove_nexthop(net, nhi->nh_parent, NULL); } } @@ -1940,11 +1944,11 @@ static int nh_netdev_event(struct notifi switch (event) { case NETDEV_DOWN: case NETDEV_UNREGISTER: - nexthop_flush_dev(dev); + nexthop_flush_dev(dev, event); break; case NETDEV_CHANGE: if (!(dev_get_flags(dev) & (IFF_RUNNING | IFF_LOWER_UP))) - nexthop_flush_dev(dev); + nexthop_flush_dev(dev, event); break; case NETDEV_CHANGEMTU: info_ext = ptr;