|
@@ -340,6 +340,7 @@ int ip_queue_xmit(struct sk_buff *skb, int ipfragok)
|
|
|
.saddr = inet->saddr,
|
|
|
.tos = RT_CONN_FLAGS(sk) } },
|
|
|
.proto = sk->sk_protocol,
|
|
|
+ .flags = inet_sk_flowi_flags(sk),
|
|
|
.uli_u = { .ports =
|
|
|
{ .sport = inet->sport,
|
|
|
.dport = inet->dport } } };
|
|
@@ -1371,7 +1372,8 @@ void ip_send_reply(struct sock *sk, struct sk_buff *skb, struct ip_reply_arg *ar
|
|
|
.uli_u = { .ports =
|
|
|
{ .sport = tcp_hdr(skb)->dest,
|
|
|
.dport = tcp_hdr(skb)->source } },
|
|
|
- .proto = sk->sk_protocol };
|
|
|
+ .proto = sk->sk_protocol,
|
|
|
+ .flags = ip_reply_arg_flowi_flags(arg) };
|
|
|
security_skb_classify_flow(skb, &fl);
|
|
|
if (ip_route_output_key(sock_net(sk), &rt, &fl))
|
|
|
return;
|