From: Ido Schimmel <idosch@nvidia.com>
To: Jiayuan Chen <jiayuan.chen@linux.dev>
Cc: netdev@vger.kernel.org, jiayuna.chen@linux.dev,
jiayuna.chen@shopee.com, Jiayuan Chen <jiayuan.chen@shopee.com>,
syzbot+334190e097a98a1b81bb@syzkaller.appspotmail.com,
"David S. Miller" <davem@davemloft.net>,
David Ahern <dsahern@kernel.org>,
Eric Dumazet <edumazet@google.com>,
Jakub Kicinski <kuba@kernel.org>, Paolo Abeni <pabeni@redhat.com>,
Simon Horman <horms@kernel.org>, Shuah Khan <shuah@kernel.org>,
linux-kernel@vger.kernel.org, linux-kselftest@vger.kernel.org
Subject: Re: [PATCH net v3 1/2] net: ipv6: fix panic when IPv4 route references loopback IPv6 nexthop
Date: Wed, 4 Mar 2026 11:16:30 +0200 [thread overview]
Message-ID: <20260304091630.GA1054438@shredder> (raw)
In-Reply-To: <20260303031318.339716-2-jiayuan.chen@linux.dev>
Code looks fine, but see a few comments below
On Tue, Mar 03, 2026 at 11:13:14AM +0800, Jiayuan Chen wrote:
> From: Jiayuan Chen <jiayuan.chen@shopee.com>
>
> When a standalone IPv6 nexthop object is created with a loopback device
> (e.g., "ip -6 nexthop add id 100 dev lo"), fib6_nh_init() misclassifies
> it as a reject route. This is because nexthop objects have no destination
> prefix (fc_dst=::), causing fib6_is_reject() to match any loopback
> nexthop. The reject path skips fib_nh_common_init(), leaving
> nhc_pcpu_rth_output unallocated. If an IPv4 route later references this
> nexthop, __mkroute_output() dereferences NULL nhc_pcpu_rth_output and
> panics.
>
> Simplify the check in fib6_nh_init() to only match explicit reject
> routes (RTF_REJECT) instead of using fib6_is_reject(). The loopback
> promotion heuristic in fib6_is_reject() is handled separately by
> ip6_route_info_create(). After this change, the three cases behave as
> follows:
s/ip6_route_info_create/ip6_route_info_create_nh/
>
> 1. Explicit reject route ("ip -6 route add unreachable 2001:db8::/64"):
> RTF_REJECT is set, enters reject path, skips fib_nh_common_init().
> No behavior change.
>
> 2. Implicit loopback reject route ("ip -6 route add 2001:db8::/32 dev lo"):
> RTF_REJECT is not set, takes normal path, fib_nh_common_init() is
> called. ip6_route_info_create() still promotes it to reject afterward.
Same here
> nhc_pcpu_rth_output is allocated but unused, which is harmless.
>
> 3. Standalone nexthop object ("ip -6 nexthop add id 100 dev lo"):
> RTF_REJECT is not set, takes normal path, fib_nh_common_init() is
> called. nhc_pcpu_rth_output is properly allocated, fixing the crash
> when IPv4 routes reference this nexthop.
>
> Suggested-by: Ido Schimmel <idosch@nvidia.com>
> Fixes: 7dd73168e273 ("ipv6: Always allocate pcpu memory in a fib6_nh")
AFAICT, even before this commit fib_nh_common_init() would be skipped for
nexthop objects that use the loopback device as their nexthop device. I
suggest blaming the commit that allowed user space to configure IPv4
routes with nexthop objects:
493ced1ac47c ("ipv4: Allow routes to use nexthop objects")
> Reported-by: syzbot+334190e097a98a1b81bb@syzkaller.appspotmail.com
> Closes: https://lore.kernel.org/all/698f8482.a70a0220.2c38d7.00ca.GAE@google.com/T/
> Signed-off-by: Jiayuan Chen <jiayuan.chen@shopee.com>
> ---
> net/ipv6/route.c | 8 +++-----
> 1 file changed, 3 insertions(+), 5 deletions(-)
>
> diff --git a/net/ipv6/route.c b/net/ipv6/route.c
> index c0350d97307e..fb588a351609 100644
> --- a/net/ipv6/route.c
> +++ b/net/ipv6/route.c
> @@ -3582,7 +3582,6 @@ int fib6_nh_init(struct net *net, struct fib6_nh *fib6_nh,
> netdevice_tracker *dev_tracker = &fib6_nh->fib_nh_dev_tracker;
> struct net_device *dev = NULL;
> struct inet6_dev *idev = NULL;
> - int addr_type;
> int err;
>
> fib6_nh->fib_nh_family = AF_INET6;
> @@ -3624,11 +3623,10 @@ int fib6_nh_init(struct net *net, struct fib6_nh *fib6_nh,
>
> fib6_nh->fib_nh_weight = 1;
>
> - /* We cannot add true routes via loopback here,
> - * they would result in kernel looping; promote them to reject routes
> + /* Only check RTF_REJECT, not fib6_is_reject(): the loopback
> + * promotion heuristic is handled by ip6_route_info_create().
Same here (FTR, I suggested a different comment in [1])
> */
> - addr_type = ipv6_addr_type(&cfg->fc_dst);
> - if (fib6_is_reject(cfg->fc_flags, dev, addr_type)) {
> + if (cfg->fc_flags & RTF_REJECT) {
> /* hold loopback dev/idev if we haven't done so. */
> if (dev != net->loopback_dev) {
> if (dev) {
> --
> 2.43.0
>
[1] https://lore.kernel.org/netdev/20260302082551.GA814377@shredder/
next prev parent reply other threads:[~2026-03-04 9:16 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-03-03 3:13 [PATCH net v3 0/2] net: ipv6: fix panic when IPv4 route references loopback IPv6 nexthop and add selftest Jiayuan Chen
2026-03-03 3:13 ` [PATCH net v3 1/2] net: ipv6: fix panic when IPv4 route references loopback IPv6 nexthop Jiayuan Chen
2026-03-04 9:16 ` Ido Schimmel [this message]
2026-03-03 3:13 ` [PATCH net v3 2/2] selftests: net: add test for IPv4 route with " Jiayuan Chen
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20260304091630.GA1054438@shredder \
--to=idosch@nvidia.com \
--cc=davem@davemloft.net \
--cc=dsahern@kernel.org \
--cc=edumazet@google.com \
--cc=horms@kernel.org \
--cc=jiayuan.chen@linux.dev \
--cc=jiayuan.chen@shopee.com \
--cc=jiayuna.chen@linux.dev \
--cc=jiayuna.chen@shopee.com \
--cc=kuba@kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-kselftest@vger.kernel.org \
--cc=netdev@vger.kernel.org \
--cc=pabeni@redhat.com \
--cc=shuah@kernel.org \
--cc=syzbot+334190e097a98a1b81bb@syzkaller.appspotmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.