|
@@ -278,6 +278,7 @@ struct sock *cookie_v4_check(struct sock *sk, struct sk_buff *skb,
|
|
struct rtable *rt;
|
|
struct rtable *rt;
|
|
__u8 rcv_wscale;
|
|
__u8 rcv_wscale;
|
|
bool ecn_ok = false;
|
|
bool ecn_ok = false;
|
|
|
|
+ struct flowi4 fl4;
|
|
|
|
|
|
if (!sysctl_tcp_syncookies || !th->ack || th->rst)
|
|
if (!sysctl_tcp_syncookies || !th->ack || th->rst)
|
|
goto out;
|
|
goto out;
|
|
@@ -346,20 +347,16 @@ struct sock *cookie_v4_check(struct sock *sk, struct sk_buff *skb,
|
|
* hasn't changed since we received the original syn, but I see
|
|
* hasn't changed since we received the original syn, but I see
|
|
* no easy way to do this.
|
|
* no easy way to do this.
|
|
*/
|
|
*/
|
|
- {
|
|
|
|
- struct flowi4 fl4;
|
|
|
|
-
|
|
|
|
- flowi4_init_output(&fl4, 0, sk->sk_mark, RT_CONN_FLAGS(sk),
|
|
|
|
- RT_SCOPE_UNIVERSE, IPPROTO_TCP,
|
|
|
|
- inet_sk_flowi_flags(sk),
|
|
|
|
- (opt && opt->srr) ? opt->faddr : ireq->rmt_addr,
|
|
|
|
- ireq->loc_addr, th->source, th->dest);
|
|
|
|
- security_req_classify_flow(req, flowi4_to_flowi(&fl4));
|
|
|
|
- rt = ip_route_output_key(sock_net(sk), &fl4);
|
|
|
|
- if (IS_ERR(rt)) {
|
|
|
|
- reqsk_free(req);
|
|
|
|
- goto out;
|
|
|
|
- }
|
|
|
|
|
|
+ flowi4_init_output(&fl4, 0, sk->sk_mark, RT_CONN_FLAGS(sk),
|
|
|
|
+ RT_SCOPE_UNIVERSE, IPPROTO_TCP,
|
|
|
|
+ inet_sk_flowi_flags(sk),
|
|
|
|
+ (opt && opt->srr) ? opt->faddr : ireq->rmt_addr,
|
|
|
|
+ ireq->loc_addr, th->source, th->dest);
|
|
|
|
+ security_req_classify_flow(req, flowi4_to_flowi(&fl4));
|
|
|
|
+ rt = ip_route_output_key(sock_net(sk), &fl4);
|
|
|
|
+ if (IS_ERR(rt)) {
|
|
|
|
+ reqsk_free(req);
|
|
|
|
+ goto out;
|
|
}
|
|
}
|
|
|
|
|
|
/* Try to redo what tcp_v4_send_synack did. */
|
|
/* Try to redo what tcp_v4_send_synack did. */
|
|
@@ -373,5 +370,10 @@ struct sock *cookie_v4_check(struct sock *sk, struct sk_buff *skb,
|
|
ireq->rcv_wscale = rcv_wscale;
|
|
ireq->rcv_wscale = rcv_wscale;
|
|
|
|
|
|
ret = get_cookie_sock(sk, skb, req, &rt->dst);
|
|
ret = get_cookie_sock(sk, skb, req, &rt->dst);
|
|
|
|
+ /* ip_queue_xmit() depends on our flow being setup
|
|
|
|
+ * Normal sockets get it right from inet_csk_route_child_sock()
|
|
|
|
+ */
|
|
|
|
+ if (ret)
|
|
|
|
+ inet_sk(ret)->cork.fl.u.ip4 = fl4;
|
|
out: return ret;
|
|
out: return ret;
|
|
}
|
|
}
|