ice: fix theoretical out-of-bounds access in ethtool link modes
authorMichal Schmidt <mschmidt@redhat.com>
Thu, 30 Nov 2023 16:58:06 +0000 (17:58 +0100)
committerTony Nguyen <anthony.l.nguyen@intel.com>
Wed, 13 Dec 2023 18:44:31 +0000 (10:44 -0800)
commit91f9181c738101a276d9da333e0ab665ad806e6d
treeffe8e49713fa6e230916b93b72014142b2776b94
parent2513974cc3e120bd26ecf43bcc1c40ac32669226
ice: fix theoretical out-of-bounds access in ethtool link modes

To map phy types reported by the hardware to ethtool link mode bits,
ice uses two lookup tables (phy_type_low_lkup, phy_type_high_lkup).
The "low" table has 64 elements to cover every possible bit the hardware
may report, but the "high" table has only 13. If the hardware reports a
higher bit in phy_types_high, the driver would access memory beyond the
lookup table's end.

Instead of iterating through all 64 bits of phy_types_{low,high}, use
the sizes of the respective lookup tables.

Fixes: 9136e1f1e5c3 ("ice: refactor PHY type to ethtool link mode")
Signed-off-by: Michal Schmidt <mschmidt@redhat.com>
Reviewed-by: Przemek Kitszel <przemyslaw.kitszel@intel.com>
Reviewed-by: Simon Horman <horms@kernel.org>
Tested-by: Pucha Himasekhar Reddy <himasekharx.reddy.pucha@intel.com> (A Contingent worker at Intel)
Signed-off-by: Tony Nguyen <anthony.l.nguyen@intel.com>
drivers/net/ethernet/intel/ice/ice_ethtool.c