summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMatti Vaittinen <matti.vaittinen@nokia.com>2016-01-11 12:26:19 (GMT)
committerDavid S. Miller <davem@davemloft.net>2016-01-12 21:40:15 (GMT)
commitccdf6ce6a8dba374668ae9b4d763e19903611c38 (patch)
tree80e82e6d7ecc3d5204bcb83478dd36beadc06451
parent06928b3870d213cb42b00e2949419f2d44b9d45f (diff)
downloadlinux-ccdf6ce6a8dba374668ae9b4d763e19903611c38.tar.xz
net: netlink: Fix multicast group storage allocation for families with more than one groups
Multicast groups are stored in global buffer. Check for needed buffer size incorrectly compares buffer size to first id for family. This means that for families with more than one mcast id one may allocate too small buffer and end up writing rest of the groups to some unallocated memory. Fix the buffer size check to compare allocated space to last mcast id for the family. Tested on ARM using kernel 3.14 Signed-off-by: Matti Vaittinen <matti.vaittinen@nokia.com> Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r--net/netlink/genetlink.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/net/netlink/genetlink.c b/net/netlink/genetlink.c
index bc0e504..a992083 100644
--- a/net/netlink/genetlink.c
+++ b/net/netlink/genetlink.c
@@ -185,7 +185,7 @@ static int genl_allocate_reserve_groups(int n_groups, int *first_id)
}
}
- if (id >= mc_groups_longs * BITS_PER_LONG) {
+ if (id + n_groups >= mc_groups_longs * BITS_PER_LONG) {
unsigned long new_longs = mc_groups_longs +
BITS_TO_LONGS(n_groups);
size_t nlen = new_longs * sizeof(unsigned long);