net: netlink: Fix multicast group storage allocation for families with more than...
authorMatti Vaittinen <matti.vaittinen@nokia.com>
Mon, 11 Jan 2016 12:26:19 +0000 (14:26 +0200)
committerDavid S. Miller <davem@davemloft.net>
Tue, 12 Jan 2016 21:40:15 +0000 (16:40 -0500)
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>
net/netlink/genetlink.c

index bc0e504f33a68ee92897cb3c45241d4d3348deba..a992083c0a64bc0db4c80bb4743937c05ce22977 100644 (file)
@@ -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);