diff options
author | David S. Miller <davem@davemloft.net> | 2013-04-03 01:31:54 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2013-04-03 01:31:54 -0400 |
commit | d66248326410ed0d3e813ebe974b3e6638df0717 (patch) | |
tree | a1dbe86f5540596a70c6f3b9aab051d37f37daf5 /net | |
parent | 8facd5fb73c6e960555e5913743dfbb6c3d984a5 (diff) | |
parent | da241efcd9c3da2af6ba20055c7e158ec725005c (diff) |
Merge git://git.kernel.org/pub/scm/linux/kernel/git/davem/net
Pull net into net-next to get the synchronize_net() bug fix in
bonding.
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net')
-rw-r--r-- | net/ipv6/addrconf.c | 27 | ||||
-rw-r--r-- | net/sched/sch_cbq.c | 5 | ||||
-rw-r--r-- | net/vmw_vsock/af_vsock.c | 6 | ||||
-rw-r--r-- | net/vmw_vsock/vmci_transport.c | 31 | ||||
-rw-r--r-- | net/vmw_vsock/vsock_addr.c | 10 | ||||
-rw-r--r-- | net/vmw_vsock/vsock_addr.h | 2 |
6 files changed, 54 insertions, 27 deletions
diff --git a/net/ipv6/addrconf.c b/net/ipv6/addrconf.c index d6279cb3d547..a33b157d9ccf 100644 --- a/net/ipv6/addrconf.c +++ b/net/ipv6/addrconf.c | |||
@@ -2616,6 +2616,9 @@ static void sit_add_v4_addrs(struct inet6_dev *idev) | |||
2616 | static void init_loopback(struct net_device *dev) | 2616 | static void init_loopback(struct net_device *dev) |
2617 | { | 2617 | { |
2618 | struct inet6_dev *idev; | 2618 | struct inet6_dev *idev; |
2619 | struct net_device *sp_dev; | ||
2620 | struct inet6_ifaddr *sp_ifa; | ||
2621 | struct rt6_info *sp_rt; | ||
2619 | 2622 | ||
2620 | /* ::1 */ | 2623 | /* ::1 */ |
2621 | 2624 | ||
@@ -2627,6 +2630,30 @@ static void init_loopback(struct net_device *dev) | |||
2627 | } | 2630 | } |
2628 | 2631 | ||
2629 | add_addr(idev, &in6addr_loopback, 128, IFA_HOST); | 2632 | add_addr(idev, &in6addr_loopback, 128, IFA_HOST); |
2633 | |||
2634 | /* Add routes to other interface's IPv6 addresses */ | ||
2635 | for_each_netdev(dev_net(dev), sp_dev) { | ||
2636 | if (!strcmp(sp_dev->name, dev->name)) | ||
2637 | continue; | ||
2638 | |||
2639 | idev = __in6_dev_get(sp_dev); | ||
2640 | if (!idev) | ||
2641 | continue; | ||
2642 | |||
2643 | read_lock_bh(&idev->lock); | ||
2644 | list_for_each_entry(sp_ifa, &idev->addr_list, if_list) { | ||
2645 | |||
2646 | if (sp_ifa->flags & (IFA_F_DADFAILED | IFA_F_TENTATIVE)) | ||
2647 | continue; | ||
2648 | |||
2649 | sp_rt = addrconf_dst_alloc(idev, &sp_ifa->addr, 0); | ||
2650 | |||
2651 | /* Failure cases are ignored */ | ||
2652 | if (!IS_ERR(sp_rt)) | ||
2653 | ip6_ins_rt(sp_rt); | ||
2654 | } | ||
2655 | read_unlock_bh(&idev->lock); | ||
2656 | } | ||
2630 | } | 2657 | } |
2631 | 2658 | ||
2632 | static void addrconf_add_linklocal(struct inet6_dev *idev, const struct in6_addr *addr) | 2659 | static void addrconf_add_linklocal(struct inet6_dev *idev, const struct in6_addr *addr) |
diff --git a/net/sched/sch_cbq.c b/net/sched/sch_cbq.c index 13aa47aa2ffb..1bc210ffcba2 100644 --- a/net/sched/sch_cbq.c +++ b/net/sched/sch_cbq.c | |||
@@ -962,8 +962,11 @@ cbq_dequeue(struct Qdisc *sch) | |||
962 | cbq_update(q); | 962 | cbq_update(q); |
963 | if ((incr -= incr2) < 0) | 963 | if ((incr -= incr2) < 0) |
964 | incr = 0; | 964 | incr = 0; |
965 | q->now += incr; | ||
966 | } else { | ||
967 | if (now > q->now) | ||
968 | q->now = now; | ||
965 | } | 969 | } |
966 | q->now += incr; | ||
967 | q->now_rt = now; | 970 | q->now_rt = now; |
968 | 971 | ||
969 | for (;;) { | 972 | for (;;) { |
diff --git a/net/vmw_vsock/af_vsock.c b/net/vmw_vsock/af_vsock.c index ca511c4f388a..d8079daf1bde 100644 --- a/net/vmw_vsock/af_vsock.c +++ b/net/vmw_vsock/af_vsock.c | |||
@@ -207,7 +207,7 @@ static struct sock *__vsock_find_bound_socket(struct sockaddr_vm *addr) | |||
207 | struct vsock_sock *vsk; | 207 | struct vsock_sock *vsk; |
208 | 208 | ||
209 | list_for_each_entry(vsk, vsock_bound_sockets(addr), bound_table) | 209 | list_for_each_entry(vsk, vsock_bound_sockets(addr), bound_table) |
210 | if (vsock_addr_equals_addr_any(addr, &vsk->local_addr)) | 210 | if (addr->svm_port == vsk->local_addr.svm_port) |
211 | return sk_vsock(vsk); | 211 | return sk_vsock(vsk); |
212 | 212 | ||
213 | return NULL; | 213 | return NULL; |
@@ -220,8 +220,8 @@ static struct sock *__vsock_find_connected_socket(struct sockaddr_vm *src, | |||
220 | 220 | ||
221 | list_for_each_entry(vsk, vsock_connected_sockets(src, dst), | 221 | list_for_each_entry(vsk, vsock_connected_sockets(src, dst), |
222 | connected_table) { | 222 | connected_table) { |
223 | if (vsock_addr_equals_addr(src, &vsk->remote_addr) | 223 | if (vsock_addr_equals_addr(src, &vsk->remote_addr) && |
224 | && vsock_addr_equals_addr(dst, &vsk->local_addr)) { | 224 | dst->svm_port == vsk->local_addr.svm_port) { |
225 | return sk_vsock(vsk); | 225 | return sk_vsock(vsk); |
226 | } | 226 | } |
227 | } | 227 | } |
diff --git a/net/vmw_vsock/vmci_transport.c b/net/vmw_vsock/vmci_transport.c index faf81b8c1a3a..9caa91c0bdaf 100644 --- a/net/vmw_vsock/vmci_transport.c +++ b/net/vmw_vsock/vmci_transport.c | |||
@@ -472,19 +472,16 @@ static struct sock *vmci_transport_get_pending( | |||
472 | struct vsock_sock *vlistener; | 472 | struct vsock_sock *vlistener; |
473 | struct vsock_sock *vpending; | 473 | struct vsock_sock *vpending; |
474 | struct sock *pending; | 474 | struct sock *pending; |
475 | struct sockaddr_vm src; | ||
476 | |||
477 | vsock_addr_init(&src, pkt->dg.src.context, pkt->src_port); | ||
475 | 478 | ||
476 | vlistener = vsock_sk(listener); | 479 | vlistener = vsock_sk(listener); |
477 | 480 | ||
478 | list_for_each_entry(vpending, &vlistener->pending_links, | 481 | list_for_each_entry(vpending, &vlistener->pending_links, |
479 | pending_links) { | 482 | pending_links) { |
480 | struct sockaddr_vm src; | ||
481 | struct sockaddr_vm dst; | ||
482 | |||
483 | vsock_addr_init(&src, pkt->dg.src.context, pkt->src_port); | ||
484 | vsock_addr_init(&dst, pkt->dg.dst.context, pkt->dst_port); | ||
485 | |||
486 | if (vsock_addr_equals_addr(&src, &vpending->remote_addr) && | 483 | if (vsock_addr_equals_addr(&src, &vpending->remote_addr) && |
487 | vsock_addr_equals_addr(&dst, &vpending->local_addr)) { | 484 | pkt->dst_port == vpending->local_addr.svm_port) { |
488 | pending = sk_vsock(vpending); | 485 | pending = sk_vsock(vpending); |
489 | sock_hold(pending); | 486 | sock_hold(pending); |
490 | goto found; | 487 | goto found; |
@@ -749,10 +746,15 @@ static int vmci_transport_recv_stream_cb(void *data, struct vmci_datagram *dg) | |||
749 | */ | 746 | */ |
750 | bh_lock_sock(sk); | 747 | bh_lock_sock(sk); |
751 | 748 | ||
752 | if (!sock_owned_by_user(sk) && sk->sk_state == SS_CONNECTED) | 749 | if (!sock_owned_by_user(sk)) { |
753 | vmci_trans(vsk)->notify_ops->handle_notify_pkt( | 750 | /* The local context ID may be out of date, update it. */ |
754 | sk, pkt, true, &dst, &src, | 751 | vsk->local_addr.svm_cid = dst.svm_cid; |
755 | &bh_process_pkt); | 752 | |
753 | if (sk->sk_state == SS_CONNECTED) | ||
754 | vmci_trans(vsk)->notify_ops->handle_notify_pkt( | ||
755 | sk, pkt, true, &dst, &src, | ||
756 | &bh_process_pkt); | ||
757 | } | ||
756 | 758 | ||
757 | bh_unlock_sock(sk); | 759 | bh_unlock_sock(sk); |
758 | 760 | ||
@@ -912,6 +914,9 @@ static void vmci_transport_recv_pkt_work(struct work_struct *work) | |||
912 | 914 | ||
913 | lock_sock(sk); | 915 | lock_sock(sk); |
914 | 916 | ||
917 | /* The local context ID may be out of date. */ | ||
918 | vsock_sk(sk)->local_addr.svm_cid = pkt->dg.dst.context; | ||
919 | |||
915 | switch (sk->sk_state) { | 920 | switch (sk->sk_state) { |
916 | case SS_LISTEN: | 921 | case SS_LISTEN: |
917 | vmci_transport_recv_listen(sk, pkt); | 922 | vmci_transport_recv_listen(sk, pkt); |
@@ -968,6 +973,10 @@ static int vmci_transport_recv_listen(struct sock *sk, | |||
968 | pending = vmci_transport_get_pending(sk, pkt); | 973 | pending = vmci_transport_get_pending(sk, pkt); |
969 | if (pending) { | 974 | if (pending) { |
970 | lock_sock(pending); | 975 | lock_sock(pending); |
976 | |||
977 | /* The local context ID may be out of date. */ | ||
978 | vsock_sk(pending)->local_addr.svm_cid = pkt->dg.dst.context; | ||
979 | |||
971 | switch (pending->sk_state) { | 980 | switch (pending->sk_state) { |
972 | case SS_CONNECTING: | 981 | case SS_CONNECTING: |
973 | err = vmci_transport_recv_connecting_server(sk, | 982 | err = vmci_transport_recv_connecting_server(sk, |
diff --git a/net/vmw_vsock/vsock_addr.c b/net/vmw_vsock/vsock_addr.c index b7df1aea7c59..ec2611b4ea0e 100644 --- a/net/vmw_vsock/vsock_addr.c +++ b/net/vmw_vsock/vsock_addr.c | |||
@@ -64,16 +64,6 @@ bool vsock_addr_equals_addr(const struct sockaddr_vm *addr, | |||
64 | } | 64 | } |
65 | EXPORT_SYMBOL_GPL(vsock_addr_equals_addr); | 65 | EXPORT_SYMBOL_GPL(vsock_addr_equals_addr); |
66 | 66 | ||
67 | bool vsock_addr_equals_addr_any(const struct sockaddr_vm *addr, | ||
68 | const struct sockaddr_vm *other) | ||
69 | { | ||
70 | return (addr->svm_cid == VMADDR_CID_ANY || | ||
71 | other->svm_cid == VMADDR_CID_ANY || | ||
72 | addr->svm_cid == other->svm_cid) && | ||
73 | addr->svm_port == other->svm_port; | ||
74 | } | ||
75 | EXPORT_SYMBOL_GPL(vsock_addr_equals_addr_any); | ||
76 | |||
77 | int vsock_addr_cast(const struct sockaddr *addr, | 67 | int vsock_addr_cast(const struct sockaddr *addr, |
78 | size_t len, struct sockaddr_vm **out_addr) | 68 | size_t len, struct sockaddr_vm **out_addr) |
79 | { | 69 | { |
diff --git a/net/vmw_vsock/vsock_addr.h b/net/vmw_vsock/vsock_addr.h index cdfbcefdf843..9ccd5316eac0 100644 --- a/net/vmw_vsock/vsock_addr.h +++ b/net/vmw_vsock/vsock_addr.h | |||
@@ -24,8 +24,6 @@ bool vsock_addr_bound(const struct sockaddr_vm *addr); | |||
24 | void vsock_addr_unbind(struct sockaddr_vm *addr); | 24 | void vsock_addr_unbind(struct sockaddr_vm *addr); |
25 | bool vsock_addr_equals_addr(const struct sockaddr_vm *addr, | 25 | bool vsock_addr_equals_addr(const struct sockaddr_vm *addr, |
26 | const struct sockaddr_vm *other); | 26 | const struct sockaddr_vm *other); |
27 | bool vsock_addr_equals_addr_any(const struct sockaddr_vm *addr, | ||
28 | const struct sockaddr_vm *other); | ||
29 | int vsock_addr_cast(const struct sockaddr *addr, size_t len, | 27 | int vsock_addr_cast(const struct sockaddr *addr, size_t len, |
30 | struct sockaddr_vm **out_addr); | 28 | struct sockaddr_vm **out_addr); |
31 | 29 | ||