diff options
author | Reiter Wolfgang <wr0112358@gmail.com> | 2016-12-31 15:11:57 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2017-01-01 22:00:26 -0500 |
commit | 4200462d88f47f3759bdf4705f87e207b0f5b2e4 (patch) | |
tree | 0aab7672e9f4bc19666b587e5c06b8af029baac5 | |
parent | e1a3a60a2ebe991605acb14cd58e39c0545e174e (diff) |
drop_monitor: add missing call to genlmsg_end
Update nlmsg_len field with genlmsg_end to enable userspace processing
using nlmsg_next helper. Also adds error handling.
Signed-off-by: Reiter Wolfgang <wr0112358@gmail.com>
Acked-by: Neil Horman <nhorman@tuxdriver.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | net/core/drop_monitor.c | 33 |
1 files changed, 24 insertions, 9 deletions
diff --git a/net/core/drop_monitor.c b/net/core/drop_monitor.c index 8e0c0635ee97..f465bad2ef2c 100644 --- a/net/core/drop_monitor.c +++ b/net/core/drop_monitor.c | |||
@@ -75,6 +75,7 @@ static struct sk_buff *reset_per_cpu_data(struct per_cpu_dm_data *data) | |||
75 | struct nlattr *nla; | 75 | struct nlattr *nla; |
76 | struct sk_buff *skb; | 76 | struct sk_buff *skb; |
77 | unsigned long flags; | 77 | unsigned long flags; |
78 | void *msg_header; | ||
78 | 79 | ||
79 | al = sizeof(struct net_dm_alert_msg); | 80 | al = sizeof(struct net_dm_alert_msg); |
80 | al += dm_hit_limit * sizeof(struct net_dm_drop_point); | 81 | al += dm_hit_limit * sizeof(struct net_dm_drop_point); |
@@ -82,17 +83,31 @@ static struct sk_buff *reset_per_cpu_data(struct per_cpu_dm_data *data) | |||
82 | 83 | ||
83 | skb = genlmsg_new(al, GFP_KERNEL); | 84 | skb = genlmsg_new(al, GFP_KERNEL); |
84 | 85 | ||
85 | if (skb) { | 86 | if (!skb) |
86 | genlmsg_put(skb, 0, 0, &net_drop_monitor_family, | 87 | goto err; |
87 | 0, NET_DM_CMD_ALERT); | 88 | |
88 | nla = nla_reserve(skb, NLA_UNSPEC, | 89 | msg_header = genlmsg_put(skb, 0, 0, &net_drop_monitor_family, |
89 | sizeof(struct net_dm_alert_msg)); | 90 | 0, NET_DM_CMD_ALERT); |
90 | msg = nla_data(nla); | 91 | if (!msg_header) { |
91 | memset(msg, 0, al); | 92 | nlmsg_free(skb); |
92 | } else { | 93 | skb = NULL; |
93 | mod_timer(&data->send_timer, jiffies + HZ / 10); | 94 | goto err; |
95 | } | ||
96 | nla = nla_reserve(skb, NLA_UNSPEC, | ||
97 | sizeof(struct net_dm_alert_msg)); | ||
98 | if (!nla) { | ||
99 | nlmsg_free(skb); | ||
100 | skb = NULL; | ||
101 | goto err; | ||
94 | } | 102 | } |
103 | msg = nla_data(nla); | ||
104 | memset(msg, 0, al); | ||
105 | genlmsg_end(skb, msg_header); | ||
106 | goto out; | ||
95 | 107 | ||
108 | err: | ||
109 | mod_timer(&data->send_timer, jiffies + HZ / 10); | ||
110 | out: | ||
96 | spin_lock_irqsave(&data->lock, flags); | 111 | spin_lock_irqsave(&data->lock, flags); |
97 | swap(data->skb, skb); | 112 | swap(data->skb, skb); |
98 | spin_unlock_irqrestore(&data->lock, flags); | 113 | spin_unlock_irqrestore(&data->lock, flags); |