diff options
author | David S. Miller <davem@davemloft.net> | 2018-08-02 13:55:32 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2018-08-02 13:55:32 -0400 |
commit | 89b1698c93a9dee043154f33d96bca9964e705f1 (patch) | |
tree | dd9dcb1965baae8edcf0b496aaa6a70609b6fc11 /net/netlink | |
parent | ffd7ce3cd9c294f1ff49ec02cdbd1bc7cb913db6 (diff) | |
parent | e30cb13c5a09ff5f043a6570c32e49b063bea6a1 (diff) |
Merge ra.kernel.org:/pub/scm/linux/kernel/git/davem/net
The BTF conflicts were simple overlapping changes.
The virtio_net conflict was an overlap of a fix of statistics counter,
happening alongisde a move over to a bonafide statistics structure
rather than counting value on the stack.
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/netlink')
-rw-r--r-- | net/netlink/af_netlink.c | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/net/netlink/af_netlink.c b/net/netlink/af_netlink.c index f6ac7693d2cc..505bf36474ba 100644 --- a/net/netlink/af_netlink.c +++ b/net/netlink/af_netlink.c | |||
@@ -63,6 +63,7 @@ | |||
63 | #include <linux/hash.h> | 63 | #include <linux/hash.h> |
64 | #include <linux/genetlink.h> | 64 | #include <linux/genetlink.h> |
65 | #include <linux/net_namespace.h> | 65 | #include <linux/net_namespace.h> |
66 | #include <linux/nospec.h> | ||
66 | 67 | ||
67 | #include <net/net_namespace.h> | 68 | #include <net/net_namespace.h> |
68 | #include <net/netns/generic.h> | 69 | #include <net/netns/generic.h> |
@@ -679,6 +680,7 @@ static int netlink_create(struct net *net, struct socket *sock, int protocol, | |||
679 | 680 | ||
680 | if (protocol < 0 || protocol >= MAX_LINKS) | 681 | if (protocol < 0 || protocol >= MAX_LINKS) |
681 | return -EPROTONOSUPPORT; | 682 | return -EPROTONOSUPPORT; |
683 | protocol = array_index_nospec(protocol, MAX_LINKS); | ||
682 | 684 | ||
683 | netlink_lock_table(); | 685 | netlink_lock_table(); |
684 | #ifdef CONFIG_MODULES | 686 | #ifdef CONFIG_MODULES |
@@ -1009,6 +1011,11 @@ static int netlink_bind(struct socket *sock, struct sockaddr *addr, | |||
1009 | return err; | 1011 | return err; |
1010 | } | 1012 | } |
1011 | 1013 | ||
1014 | if (nlk->ngroups == 0) | ||
1015 | groups = 0; | ||
1016 | else | ||
1017 | groups &= (1ULL << nlk->ngroups) - 1; | ||
1018 | |||
1012 | bound = nlk->bound; | 1019 | bound = nlk->bound; |
1013 | if (bound) { | 1020 | if (bound) { |
1014 | /* Ensure nlk->portid is up-to-date. */ | 1021 | /* Ensure nlk->portid is up-to-date. */ |