alx: fix OOB-read compiler warning
[ Upstream commit 3a198c95c95da10ad844cbeade2fe40bdf14c411 ] The following message shows up when compiling with W=1: In function ‘fortify_memcpy_chk’, inlined from ‘alx_get_ethtool_stats’ at drivers/net/ethernet/atheros/alx/ethtool.c:297:2: ./include/linux/fortify-string.h:592:4: error: call to ‘__read_overflow2_field’ declared with attribute warning: detected read beyond size of field (2nd parameter); maybe use struct_group()? [-Werror=attribute-warning] 592 | __read_overflow2_field(q_size_field, size); | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ In order to get alx stats altogether, alx_get_ethtool_stats() reads beyond hw->stats.rx_ok. Fix this warning by directly copying hw->stats, and refactor the unnecessarily complicated BUILD_BUG_ON btw. Signed-off-by: GONG, Ruiqi <gongruiqi1@huawei.com> Reviewed-by: Simon Horman <horms@kernel.org> Link: https://lore.kernel.org/r/20230821013218.1614265-1-gongruiqi@huaweicloud.com Signed-off-by: Paolo Abeni <pabeni@redhat.com> Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
parent
a13c1f6c32
commit
1c27b73ffa
@ -292,9 +292,8 @@ static void alx_get_ethtool_stats(struct net_device *netdev,
|
||||
spin_lock(&alx->stats_lock);
|
||||
|
||||
alx_update_hw_stats(hw);
|
||||
BUILD_BUG_ON(sizeof(hw->stats) - offsetof(struct alx_hw_stats, rx_ok) <
|
||||
ALX_NUM_STATS * sizeof(u64));
|
||||
memcpy(data, &hw->stats.rx_ok, ALX_NUM_STATS * sizeof(u64));
|
||||
BUILD_BUG_ON(sizeof(hw->stats) != ALX_NUM_STATS * sizeof(u64));
|
||||
memcpy(data, &hw->stats, sizeof(hw->stats));
|
||||
|
||||
spin_unlock(&alx->stats_lock);
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user