]> www.infradead.org Git - users/willy/pagecache.git/commitdiff
mlxsw: Add return value check for mlxsw_sp_port_get_stats_raw()
authorWentao Liang <vulab@iscas.ac.cn>
Wed, 12 Feb 2025 15:23:11 +0000 (23:23 +0800)
committerJakub Kicinski <kuba@kernel.org>
Thu, 13 Feb 2025 16:38:06 +0000 (08:38 -0800)
Add a check for the return value of mlxsw_sp_port_get_stats_raw()
in __mlxsw_sp_port_get_stats(). If mlxsw_sp_port_get_stats_raw()
returns an error, exit the function to prevent further processing
with potentially invalid data.

Fixes: 614d509aa1e7 ("mlxsw: Move ethtool_ops to spectrum_ethtool.c")
Cc: stable@vger.kernel.org # 5.9+
Signed-off-by: Wentao Liang <vulab@iscas.ac.cn>
Reviewed-by: Petr Machata <petrm@nvidia.com>
Link: https://patch.msgid.link/20250212152311.1332-1-vulab@iscas.ac.cn
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
drivers/net/ethernet/mellanox/mlxsw/spectrum_ethtool.c

index 2bed8c86b7cfc578bb56ec6855e69fa28c70b75e..3f64cdbabfa3c1d9149b0215962516f326033ee8 100644 (file)
@@ -768,7 +768,9 @@ static void __mlxsw_sp_port_get_stats(struct net_device *dev,
        err = mlxsw_sp_get_hw_stats_by_group(&hw_stats, &len, grp);
        if (err)
                return;
-       mlxsw_sp_port_get_stats_raw(dev, grp, prio, ppcnt_pl);
+       err = mlxsw_sp_port_get_stats_raw(dev, grp, prio, ppcnt_pl);
+       if (err)
+               return;
        for (i = 0; i < len; i++) {
                data[data_index + i] = hw_stats[i].getter(ppcnt_pl);
                if (!hw_stats[i].cells_bytes)