]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
ipv4: Use inet_sk_init_flowi4() in __ip_queue_xmit().
authorGuillaume Nault <gnault@redhat.com>
Mon, 16 Dec 2024 17:21:51 +0000 (18:21 +0100)
committerJakub Kicinski <kuba@kernel.org>
Fri, 20 Dec 2024 21:50:09 +0000 (13:50 -0800)
Use inet_sk_init_flowi4() to automatically initialise the flowi4
structure in __ip_queue_xmit() instead of passing parameters manually
to ip_route_output_ports().

Override ->flowi4_tos with the value passed as parameter since that's
required by SCTP.

Signed-off-by: Guillaume Nault <gnault@redhat.com>
Link: https://patch.msgid.link/37e64ffbd9adac187b14aa9097b095f5c86e85be.1734357769.git.gnault@redhat.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
net/ipv4/ip_output.c

index f45a083f2c13bf091da7909b0690c893028b6ffa..ea7a260bec8aa436233e8abebe91aa66561fc1e4 100644 (file)
@@ -478,24 +478,16 @@ int __ip_queue_xmit(struct sock *sk, struct sk_buff *skb, struct flowi *fl,
        /* Make sure we can route this packet. */
        rt = dst_rtable(__sk_dst_check(sk, 0));
        if (!rt) {
-               __be32 daddr;
+               inet_sk_init_flowi4(inet, fl4);
 
-               /* Use correct destination address if we have options. */
-               daddr = inet->inet_daddr;
-               if (inet_opt && inet_opt->opt.srr)
-                       daddr = inet_opt->opt.faddr;
+               /* sctp_v4_xmit() uses its own DSCP value */
+               fl4->flowi4_tos = tos & INET_DSCP_MASK;
 
                /* If this fails, retransmit mechanism of transport layer will
                 * keep trying until route appears or the connection times
                 * itself out.
                 */
-               rt = ip_route_output_ports(net, fl4, sk,
-                                          daddr, inet->inet_saddr,
-                                          inet->inet_dport,
-                                          inet->inet_sport,
-                                          sk->sk_protocol,
-                                          tos & INET_DSCP_MASK,
-                                          sk->sk_bound_dev_if);
+               rt = ip_route_output_flow(net, fl4, sk);
                if (IS_ERR(rt))
                        goto no_route;
                sk_setup_caps(sk, &rt->dst);