summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSebastian Hense <sebastian.hense1@ibm.com>2020-02-20 08:11:36 +0100
committerSaeed Mahameed <saeedm@mellanox.com>2020-03-06 00:13:42 +0100
commit404402abd5f90aa90a134eb9604b1750c1941529 (patch)
tree9ef7bb2ff22bf4163d6b033c5c0546f3db6a19fa
parentnet/mlx5e: kTLS, Fix wrong value in record tracker enum (diff)
downloadlinux-404402abd5f90aa90a134eb9604b1750c1941529.tar.xz
linux-404402abd5f90aa90a134eb9604b1750c1941529.zip
net/mlx5e: Fix endianness handling in pedit mask
The mask value is provided as 64 bit and has to be casted in either 32 or 16 bit. On big endian systems the wrong half was casted which resulted in an all zero mask. Fixes: 2b64beba0251 ("net/mlx5e: Support header re-write of partial fields in TC pedit offload") Signed-off-by: Sebastian Hense <sebastian.hense1@ibm.com> Reviewed-by: Roi Dayan <roid@mellanox.com> Signed-off-by: Saeed Mahameed <saeedm@mellanox.com>
-rw-r--r--drivers/net/ethernet/mellanox/mlx5/core/en_tc.c5
1 files changed, 3 insertions, 2 deletions
diff --git a/drivers/net/ethernet/mellanox/mlx5/core/en_tc.c b/drivers/net/ethernet/mellanox/mlx5/core/en_tc.c
index 74091f72c9a8..ec5fc52bf572 100644
--- a/drivers/net/ethernet/mellanox/mlx5/core/en_tc.c
+++ b/drivers/net/ethernet/mellanox/mlx5/core/en_tc.c
@@ -2476,10 +2476,11 @@ static int offload_pedit_fields(struct pedit_headers_action *hdrs,
continue;
if (f->field_bsize == 32) {
- mask_be32 = *(__be32 *)&mask;
+ mask_be32 = (__be32)mask;
mask = (__force unsigned long)cpu_to_le32(be32_to_cpu(mask_be32));
} else if (f->field_bsize == 16) {
- mask_be16 = *(__be16 *)&mask;
+ mask_be32 = (__be32)mask;
+ mask_be16 = *(__be16 *)&mask_be32;
mask = (__force unsigned long)cpu_to_le16(be16_to_cpu(mask_be16));
}