ethtool: fix ethtool msg len calculation for pause stats
[ Upstream commit 1aabe578dd86e9f2867c4db4fba9a15f4ba1825d ]
ETHTOOL_A_PAUSE_STAT_MAX is the MAX attribute id,
so we need to subtract non-stats and add one to
get a count (IOW -2+1 == -1).
Otherwise we'll see:
ethnl cmd 21: calculated reply length 40, but consumed 52
Fixes: 9a27a33027
("ethtool: add standard pause stats")
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
Reviewed-by: Saeed Mahameed <saeedm@nvidia.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:

committed by
Greg Kroah-Hartman

parent
e78c267eb7
commit
628773a759
@@ -62,8 +62,7 @@ static int pause_reply_size(const struct ethnl_req_info *req_base,
|
||||
|
||||
if (req_base->flags & ETHTOOL_FLAG_STATS)
|
||||
n += nla_total_size(0) + /* _PAUSE_STATS */
|
||||
nla_total_size_64bit(sizeof(u64)) *
|
||||
(ETHTOOL_A_PAUSE_STAT_MAX - 2);
|
||||
nla_total_size_64bit(sizeof(u64)) * ETHTOOL_PAUSE_STAT_CNT;
|
||||
return n;
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user