Commit e459398d authored by Arnd Bergmann's avatar Arnd Bergmann Committed by Greg Kroah-Hartman

drop_monitor: work around gcc-10 stringop-overflow warning

[ Upstream commit dc30b405 ]

The current gcc-10 snapshot produces a false-positive warning:

net/core/drop_monitor.c: In function 'trace_drop_common.constprop':
cc1: error: writing 8 bytes into a region of size 0 [-Werror=stringop-overflow=]
In file included from net/core/drop_monitor.c:23:
include/uapi/linux/net_dropmon.h:36:8: note: at offset 0 to object 'entries' with size 4 declared here
   36 |  __u32 entries;
      |        ^~~~~~~

I reported this in the gcc bugzilla, but in case it does not get
fixed in the release, work around it by using a temporary variable.

Fixes: 9a8afc8d ("Network Drop Monitor: Adding drop monitor implementation & Netlink protocol")
Link: https://gcc.gnu.org/bugzilla/show_bug.cgi?id=94881Signed-off-by: default avatarArnd Bergmann <arnd@arndb.de>
Acked-by: default avatarNeil Horman <nhorman@tuxdriver.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
Signed-off-by: default avatarSasha Levin <sashal@kernel.org>
parent 7b77f42f
...@@ -154,6 +154,7 @@ static void sched_send_work(struct timer_list *t) ...@@ -154,6 +154,7 @@ static void sched_send_work(struct timer_list *t)
static void trace_drop_common(struct sk_buff *skb, void *location) static void trace_drop_common(struct sk_buff *skb, void *location)
{ {
struct net_dm_alert_msg *msg; struct net_dm_alert_msg *msg;
struct net_dm_drop_point *point;
struct nlmsghdr *nlh; struct nlmsghdr *nlh;
struct nlattr *nla; struct nlattr *nla;
int i; int i;
...@@ -172,11 +173,13 @@ static void trace_drop_common(struct sk_buff *skb, void *location) ...@@ -172,11 +173,13 @@ static void trace_drop_common(struct sk_buff *skb, void *location)
nlh = (struct nlmsghdr *)dskb->data; nlh = (struct nlmsghdr *)dskb->data;
nla = genlmsg_data(nlmsg_data(nlh)); nla = genlmsg_data(nlmsg_data(nlh));
msg = nla_data(nla); msg = nla_data(nla);
point = msg->points;
for (i = 0; i < msg->entries; i++) { for (i = 0; i < msg->entries; i++) {
if (!memcmp(&location, msg->points[i].pc, sizeof(void *))) { if (!memcmp(&location, &point->pc, sizeof(void *))) {
msg->points[i].count++; point->count++;
goto out; goto out;
} }
point++;
} }
if (msg->entries == dm_hit_limit) if (msg->entries == dm_hit_limit)
goto out; goto out;
...@@ -185,8 +188,8 @@ static void trace_drop_common(struct sk_buff *skb, void *location) ...@@ -185,8 +188,8 @@ static void trace_drop_common(struct sk_buff *skb, void *location)
*/ */
__nla_reserve_nohdr(dskb, sizeof(struct net_dm_drop_point)); __nla_reserve_nohdr(dskb, sizeof(struct net_dm_drop_point));
nla->nla_len += NLA_ALIGN(sizeof(struct net_dm_drop_point)); nla->nla_len += NLA_ALIGN(sizeof(struct net_dm_drop_point));
memcpy(msg->points[msg->entries].pc, &location, sizeof(void *)); memcpy(point->pc, &location, sizeof(void *));
msg->points[msg->entries].count = 1; point->count = 1;
msg->entries++; msg->entries++;
if (!timer_pending(&data->send_timer)) { if (!timer_pending(&data->send_timer)) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment