ipv4: Unmask upper DSCP bits in input route lookup
authorIdo Schimmel <idosch@nvidia.com>
Wed, 21 Aug 2024 12:52:47 +0000 (15:52 +0300)
committerJakub Kicinski <kuba@kernel.org>
Thu, 22 Aug 2024 23:59:57 +0000 (16:59 -0700)
Unmask the upper DSCP bits in input route lookup so that in the future
the lookup could be performed according to the full DSCP value.

No functional changes intended since the upper DSCP bits are masked when
comparing against the TOS selectors in FIB rules and routes.

Signed-off-by: Ido Schimmel <idosch@nvidia.com>
Reviewed-by: Guillaume Nault <gnault@redhat.com>
Acked-by: Florian Westphal <fw@strlen.de>
Reviewed-by: David Ahern <dsahern@kernel.org>
Link: https://patch.msgid.link/20240821125251.1571445-9-idosch@nvidia.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
net/ipv4/route.c

index 9b6528b7b5629b8caee4b96636e33253143b79dc..73bb61162445fb9c3275db2dd1ef9410c7617b5b 100644 (file)
@@ -2470,7 +2470,7 @@ int ip_route_input_noref(struct sk_buff *skb, __be32 daddr, __be32 saddr,
        struct fib_result res;
        int err;
 
-       tos &= IPTOS_RT_MASK;
+       tos &= INET_DSCP_MASK;
        rcu_read_lock();
        err = ip_route_input_rcu(skb, daddr, saddr, tos, dev, &res);
        rcu_read_unlock();