]> git.apps.os.sepia.ceph.com Git - ceph-client.git/commitdiff
ixgbe: fix ixgbe_orom_civd_info struct layout
authorJedrzej Jagielski <jedrzej.jagielski@intel.com>
Thu, 31 Jul 2025 12:45:33 +0000 (14:45 +0200)
committerTony Nguyen <anthony.l.nguyen@intel.com>
Mon, 25 Aug 2025 16:45:23 +0000 (09:45 -0700)
The current layout of struct ixgbe_orom_civd_info causes incorrect data
storage due to compiler-inserted padding. This results in issues when
writing OROM data into the structure.

Add the __packed attribute to ensure the structure layout matches the
expected binary format without padding.

Fixes: 70db0788a262 ("ixgbe: read the OROM version information")
Reviewed-by: Aleksandr Loktionov <aleksandr.loktionov@intel.com>
Signed-off-by: Jedrzej Jagielski <jedrzej.jagielski@intel.com>
Reviewed-by: Simon Horman <horms@kernel.org>
Tested-by: Rinitha S <sx.rinitha@intel.com> (A Contingent worker at Intel)
Signed-off-by: Tony Nguyen <anthony.l.nguyen@intel.com>
drivers/net/ethernet/intel/ixgbe/ixgbe_e610.c
drivers/net/ethernet/intel/ixgbe/ixgbe_type_e610.h

index d74116441d1c651c02fb5599609467e35b51e4fc..bfeef5b0b99d87ea98d27fd3f763d99da775633f 100644 (file)
@@ -3125,7 +3125,7 @@ static int ixgbe_get_orom_ver_info(struct ixgbe_hw *hw,
        if (err)
                return err;
 
-       combo_ver = le32_to_cpu(civd.combo_ver);
+       combo_ver = get_unaligned_le32(&civd.combo_ver);
 
        orom->major = (u8)FIELD_GET(IXGBE_OROM_VER_MASK, combo_ver);
        orom->patch = (u8)FIELD_GET(IXGBE_OROM_VER_PATCH_MASK, combo_ver);
index d2f22d8558f830574c04492de4fdf555a4a6253e..ff8d640a50b1c10f279e9e7ea97335a9258033eb 100644 (file)
@@ -932,7 +932,7 @@ struct ixgbe_orom_civd_info {
        __le32 combo_ver;       /* Combo Image Version number */
        u8 combo_name_len;      /* Length of the unicode combo image version string, max of 32 */
        __le16 combo_name[32];  /* Unicode string representing the Combo Image version */
-};
+} __packed;
 
 /* Function specific capabilities */
 struct ixgbe_hw_func_caps {