ice: fix ice_is_tc_ena
authorJacob Keller <jacob.e.keller@intel.com>
Thu, 25 Jul 2019 09:54:01 +0000 (02:54 -0700)
committerJeff Kirsher <jeffrey.t.kirsher@intel.com>
Tue, 27 Aug 2019 06:27:10 +0000 (23:27 -0700)
ice_is_tc_ena is used to check whether a given traffic class is
enabled. Because there are only 8 traffic classes, the function took
a u8 bitmap. This causes problems because it is cast to an unsigned
long causing a static analysis warning regarding Out-of-bounds read.

Fix this by simply updating ice_is_tc_ena to take an unsigned long.
Passing a u8 to this function should implicitly convert the value.

Signed-off-by: Jacob Keller <jacob.e.keller@intel.com>
Signed-off-by: Tony Nguyen <anthony.l.nguyen@intel.com>
Tested-by: Andrew Bowers <andrewx.bowers@intel.com>
Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
drivers/net/ethernet/intel/ice/ice_type.h

index d76e0cb7ef46fab36793e9ff7499667695dea763..b538d0b9eb80492291295b7da02813dfe4314a67 100644 (file)
@@ -13,9 +13,9 @@
 #define ICE_BYTES_PER_WORD     2
 #define ICE_BYTES_PER_DWORD    4
 
-static inline bool ice_is_tc_ena(u8 bitmap, u8 tc)
+static inline bool ice_is_tc_ena(unsigned long bitmap, u8 tc)
 {
-       return test_bit(tc, (unsigned long *)&bitmap);
+       return test_bit(tc, &bitmap);
 }
 
 /* Driver always calls main vsi_handle first */