diff options
-rw-r--r-- | net/l2tp/l2tp_ip.c | 16 |
1 files changed, 9 insertions, 7 deletions
diff --git a/net/l2tp/l2tp_ip.c b/net/l2tp/l2tp_ip.c index bd0cc0b8f32f..1ca74892ff09 100644 --- a/net/l2tp/l2tp_ip.c +++ b/net/l2tp/l2tp_ip.c | |||
@@ -298,7 +298,7 @@ static int l2tp_ip_connect(struct sock *sk, struct sockaddr *uaddr, int addr_len | |||
298 | { | 298 | { |
299 | struct sockaddr_l2tpip *lsa = (struct sockaddr_l2tpip *) uaddr; | 299 | struct sockaddr_l2tpip *lsa = (struct sockaddr_l2tpip *) uaddr; |
300 | struct inet_sock *inet = inet_sk(sk); | 300 | struct inet_sock *inet = inet_sk(sk); |
301 | struct flowi4 fl4; | 301 | struct flowi4 *fl4; |
302 | struct rtable *rt; | 302 | struct rtable *rt; |
303 | __be32 saddr; | 303 | __be32 saddr; |
304 | int oif, rc; | 304 | int oif, rc; |
@@ -322,7 +322,8 @@ static int l2tp_ip_connect(struct sock *sk, struct sockaddr *uaddr, int addr_len | |||
322 | if (ipv4_is_multicast(lsa->l2tp_addr.s_addr)) | 322 | if (ipv4_is_multicast(lsa->l2tp_addr.s_addr)) |
323 | goto out; | 323 | goto out; |
324 | 324 | ||
325 | rt = ip_route_connect(&fl4, lsa->l2tp_addr.s_addr, saddr, | 325 | fl4 = &inet->cork.fl.u.ip4; |
326 | rt = ip_route_connect(fl4, lsa->l2tp_addr.s_addr, saddr, | ||
326 | RT_CONN_FLAGS(sk), oif, | 327 | RT_CONN_FLAGS(sk), oif, |
327 | IPPROTO_L2TP, | 328 | IPPROTO_L2TP, |
328 | 0, 0, sk, true); | 329 | 0, 0, sk, true); |
@@ -342,10 +343,10 @@ static int l2tp_ip_connect(struct sock *sk, struct sockaddr *uaddr, int addr_len | |||
342 | l2tp_ip_sk(sk)->peer_conn_id = lsa->l2tp_conn_id; | 343 | l2tp_ip_sk(sk)->peer_conn_id = lsa->l2tp_conn_id; |
343 | 344 | ||
344 | if (!inet->inet_saddr) | 345 | if (!inet->inet_saddr) |
345 | inet->inet_saddr = fl4.saddr; | 346 | inet->inet_saddr = fl4->saddr; |
346 | if (!inet->inet_rcv_saddr) | 347 | if (!inet->inet_rcv_saddr) |
347 | inet->inet_rcv_saddr = fl4.saddr; | 348 | inet->inet_rcv_saddr = fl4->saddr; |
348 | inet->inet_daddr = fl4.daddr; | 349 | inet->inet_daddr = fl4->daddr; |
349 | sk->sk_state = TCP_ESTABLISHED; | 350 | sk->sk_state = TCP_ESTABLISHED; |
350 | inet->inet_id = jiffies; | 351 | inet->inet_id = jiffies; |
351 | 352 | ||
@@ -420,6 +421,7 @@ static int l2tp_ip_sendmsg(struct kiocb *iocb, struct sock *sk, struct msghdr *m | |||
420 | struct l2tp_ip_sock *lsa = l2tp_ip_sk(sk); | 421 | struct l2tp_ip_sock *lsa = l2tp_ip_sk(sk); |
421 | struct inet_sock *inet = inet_sk(sk); | 422 | struct inet_sock *inet = inet_sk(sk); |
422 | struct rtable *rt = NULL; | 423 | struct rtable *rt = NULL; |
424 | struct flowi4 *fl4; | ||
423 | int connected = 0; | 425 | int connected = 0; |
424 | __be32 daddr; | 426 | __be32 daddr; |
425 | 427 | ||
@@ -474,12 +476,12 @@ static int l2tp_ip_sendmsg(struct kiocb *iocb, struct sock *sk, struct msghdr *m | |||
474 | goto error; | 476 | goto error; |
475 | } | 477 | } |
476 | 478 | ||
479 | fl4 = &inet->cork.fl.u.ip4; | ||
477 | if (connected) | 480 | if (connected) |
478 | rt = (struct rtable *) __sk_dst_check(sk, 0); | 481 | rt = (struct rtable *) __sk_dst_check(sk, 0); |
479 | 482 | ||
480 | if (rt == NULL) { | 483 | if (rt == NULL) { |
481 | struct ip_options_rcu *inet_opt; | 484 | struct ip_options_rcu *inet_opt; |
482 | struct flowi4 fl4; | ||
483 | 485 | ||
484 | rcu_read_lock(); | 486 | rcu_read_lock(); |
485 | inet_opt = rcu_dereference(inet->inet_opt); | 487 | inet_opt = rcu_dereference(inet->inet_opt); |
@@ -494,7 +496,7 @@ static int l2tp_ip_sendmsg(struct kiocb *iocb, struct sock *sk, struct msghdr *m | |||
494 | * keep trying until route appears or the connection times | 496 | * keep trying until route appears or the connection times |
495 | * itself out. | 497 | * itself out. |
496 | */ | 498 | */ |
497 | rt = ip_route_output_ports(sock_net(sk), &fl4, sk, | 499 | rt = ip_route_output_ports(sock_net(sk), fl4, sk, |
498 | daddr, inet->inet_saddr, | 500 | daddr, inet->inet_saddr, |
499 | inet->inet_dport, inet->inet_sport, | 501 | inet->inet_dport, inet->inet_sport, |
500 | sk->sk_protocol, RT_CONN_FLAGS(sk), | 502 | sk->sk_protocol, RT_CONN_FLAGS(sk), |