rtnetlink: fix if_nlmsg_stats_size() under estimation
authorEric Dumazet <edumazet@google.com>
Tue, 5 Oct 2021 21:04:17 +0000 (14:04 -0700)
committerDavid S. Miller <davem@davemloft.net>
Wed, 6 Oct 2021 14:09:46 +0000 (15:09 +0100)
commitd34367991933d28bd7331f67a759be9a8c474014
tree76422a7776e5ba6948a3a293d5fe42feb8ebade1
parentd4b111fda69a01e0a7439d05993f5dad567c93aa
rtnetlink: fix if_nlmsg_stats_size() under estimation

rtnl_fill_statsinfo() is filling skb with one mandatory if_stats_msg structure.

nlmsg_put(skb, pid, seq, type, sizeof(struct if_stats_msg), flags);

But if_nlmsg_stats_size() never considered the needed storage.

This bug did not show up because alloc_skb(X) allocates skb with
extra tailroom, because of added alignments. This could very well
be changed in the future to have deterministic behavior.

Fixes: 10c9ead9f3c6 ("rtnetlink: add new RTM_GETSTATS message to dump link stats")
Signed-off-by: Eric Dumazet <edumazet@google.com>
Cc: Roopa Prabhu <roopa@nvidia.com>
Acked-by: Roopa Prabhu <roopa@nvidia.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/core/rtnetlink.c