mirror of https://gitee.com/openkylin/linux.git
fm10k: correctly pack TLV structures and explain reasoning
The TLV format for little endian structures is actually 4 byte aligned copy. To this end, we need to add an additional __aligned(4) marker along with __packed to ensure that these structures are actually 4 byte aligned and packed correctly. Use of just __packed will not work as this will result in 1byte alignment which is incorrect. Add a comment explaining the reasoning behind why these structures need the special treatment. Signed-off-by: Jacob Keller <jacob.e.keller@intel.com> Tested-by: Krishneil Singh <Krishneil.k.singh@intel.com> Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
This commit is contained in:
parent
07146e2ea8
commit
8c2a029c7e
drivers/net/ethernet/intel/fm10k
|
@ -74,6 +74,11 @@ enum fm10k_pf_tlv_attr_id_v1 {
|
||||||
#define FM10K_MSG_UPDATE_PVID_PVID_SHIFT 16
|
#define FM10K_MSG_UPDATE_PVID_PVID_SHIFT 16
|
||||||
#define FM10K_MSG_UPDATE_PVID_PVID_SIZE 16
|
#define FM10K_MSG_UPDATE_PVID_PVID_SIZE 16
|
||||||
|
|
||||||
|
/* The following data structures are overlayed directly onto TLV mailbox
|
||||||
|
* messages, and must not break 4 byte alignment. Ensure the structures line
|
||||||
|
* up correctly as per their TLV definition.
|
||||||
|
*/
|
||||||
|
|
||||||
struct fm10k_mac_update {
|
struct fm10k_mac_update {
|
||||||
__le32 mac_lower;
|
__le32 mac_lower;
|
||||||
__le16 mac_upper;
|
__le16 mac_upper;
|
||||||
|
@ -81,26 +86,26 @@ struct fm10k_mac_update {
|
||||||
__le16 glort;
|
__le16 glort;
|
||||||
u8 flags;
|
u8 flags;
|
||||||
u8 action;
|
u8 action;
|
||||||
} __packed;
|
} __aligned(4) __packed;
|
||||||
|
|
||||||
struct fm10k_global_table_data {
|
struct fm10k_global_table_data {
|
||||||
__le32 used;
|
__le32 used;
|
||||||
__le32 avail;
|
__le32 avail;
|
||||||
} __packed;
|
} __aligned(4) __packed;
|
||||||
|
|
||||||
struct fm10k_swapi_error {
|
struct fm10k_swapi_error {
|
||||||
__le32 status;
|
__le32 status;
|
||||||
struct fm10k_global_table_data mac;
|
struct fm10k_global_table_data mac;
|
||||||
struct fm10k_global_table_data nexthop;
|
struct fm10k_global_table_data nexthop;
|
||||||
struct fm10k_global_table_data ffu;
|
struct fm10k_global_table_data ffu;
|
||||||
} __packed;
|
} __aligned(4) __packed;
|
||||||
|
|
||||||
struct fm10k_swapi_1588_timestamp {
|
struct fm10k_swapi_1588_timestamp {
|
||||||
__le64 egress;
|
__le64 egress;
|
||||||
__le64 ingress;
|
__le64 ingress;
|
||||||
__le16 dglort;
|
__le16 dglort;
|
||||||
__le16 sglort;
|
__le16 sglort;
|
||||||
} __packed;
|
} __aligned(4) __packed;
|
||||||
|
|
||||||
s32 fm10k_msg_lport_map_pf(struct fm10k_hw *, u32 **, struct fm10k_mbx_info *);
|
s32 fm10k_msg_lport_map_pf(struct fm10k_hw *, u32 **, struct fm10k_mbx_info *);
|
||||||
extern const struct fm10k_tlv_attr fm10k_lport_map_msg_attr[];
|
extern const struct fm10k_tlv_attr fm10k_lport_map_msg_attr[];
|
||||||
|
|
Loading…
Reference in New Issue