diff options
author | Johannes Berg <johannes.berg@intel.com> | 2013-11-21 12:17:04 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2013-11-21 13:09:43 -0500 |
commit | 220815a9665f7deca98a09ecca655044f94cfa44 (patch) | |
tree | 9708d1e73ac82cb2514a1f3305695962281c8852 /net/netlink/genetlink.c | |
parent | e40526cb20b5ee53419452e1f03d97092f144418 (diff) |
genetlink: fix genlmsg_multicast() bug
Unfortunately, I introduced a tremendously stupid bug into
genlmsg_multicast() when doing all those multicast group
changes: it adjusts the group number, but then passes it
to genlmsg_multicast_netns() which does that again.
Somehow, my tests failed to catch this, so add a warning
into genlmsg_multicast_netns() and remove the offending
group ID adjustment.
Also add a warning to the similar code in other functions
so people who misuse them are more loudly warned.
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/netlink/genetlink.c')
-rw-r--r-- | net/netlink/genetlink.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/net/netlink/genetlink.c b/net/netlink/genetlink.c index 7dbc4f732c75..4518a57aa5fe 100644 --- a/net/netlink/genetlink.c +++ b/net/netlink/genetlink.c | |||
@@ -1045,7 +1045,7 @@ static int genlmsg_mcast(struct sk_buff *skb, u32 portid, unsigned long group, | |||
1045 | int genlmsg_multicast_allns(struct genl_family *family, struct sk_buff *skb, | 1045 | int genlmsg_multicast_allns(struct genl_family *family, struct sk_buff *skb, |
1046 | u32 portid, unsigned int group, gfp_t flags) | 1046 | u32 portid, unsigned int group, gfp_t flags) |
1047 | { | 1047 | { |
1048 | if (group >= family->n_mcgrps) | 1048 | if (WARN_ON_ONCE(group >= family->n_mcgrps)) |
1049 | return -EINVAL; | 1049 | return -EINVAL; |
1050 | group = family->mcgrp_offset + group; | 1050 | group = family->mcgrp_offset + group; |
1051 | return genlmsg_mcast(skb, portid, group, flags); | 1051 | return genlmsg_mcast(skb, portid, group, flags); |
@@ -1062,7 +1062,7 @@ void genl_notify(struct genl_family *family, | |||
1062 | if (nlh) | 1062 | if (nlh) |
1063 | report = nlmsg_report(nlh); | 1063 | report = nlmsg_report(nlh); |
1064 | 1064 | ||
1065 | if (group >= family->n_mcgrps) | 1065 | if (WARN_ON_ONCE(group >= family->n_mcgrps)) |
1066 | return; | 1066 | return; |
1067 | group = family->mcgrp_offset + group; | 1067 | group = family->mcgrp_offset + group; |
1068 | nlmsg_notify(sk, skb, portid, group, report, flags); | 1068 | nlmsg_notify(sk, skb, portid, group, report, flags); |