mirror of https://gitee.com/openkylin/linux.git
net/mlx5: E-Switch, Change vhca id valid bool field to bit flag
Change the driver flow destination struct to use bit flags with the vhca id valid being the 1st one. The flags field is more extendable and will be used in downstream patch. Signed-off-by: Eli Britstein <elibr@mellanox.com> Reviewed-by: Or Gerlitz <ogerlitz@mellanox.com> Reviewed-by: Oz Shlomo <ozsh@mellanox.com> Signed-off-by: Saeed Mahameed <saeedm@mellanox.com>
This commit is contained in:
parent
1b11549859
commit
aa39c2c0e4
|
@ -125,8 +125,9 @@ mlx5_eswitch_add_offloaded_rule(struct mlx5_eswitch *esw,
|
||||||
dest[i].vport.num = attr->out_rep[j]->vport;
|
dest[i].vport.num = attr->out_rep[j]->vport;
|
||||||
dest[i].vport.vhca_id =
|
dest[i].vport.vhca_id =
|
||||||
MLX5_CAP_GEN(attr->out_mdev[j], vhca_id);
|
MLX5_CAP_GEN(attr->out_mdev[j], vhca_id);
|
||||||
dest[i].vport.vhca_id_valid =
|
if (MLX5_CAP_ESW(esw->dev, merged_eswitch))
|
||||||
!!MLX5_CAP_ESW(esw->dev, merged_eswitch);
|
dest[i].vport.flags |=
|
||||||
|
MLX5_FLOW_DEST_VPORT_VHCA_ID;
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -220,7 +221,8 @@ mlx5_eswitch_add_fwd_rule(struct mlx5_eswitch *esw,
|
||||||
dest[i].vport.num = attr->out_rep[i]->vport;
|
dest[i].vport.num = attr->out_rep[i]->vport;
|
||||||
dest[i].vport.vhca_id =
|
dest[i].vport.vhca_id =
|
||||||
MLX5_CAP_GEN(attr->out_mdev[i], vhca_id);
|
MLX5_CAP_GEN(attr->out_mdev[i], vhca_id);
|
||||||
dest[i].vport.vhca_id_valid = !!MLX5_CAP_ESW(esw->dev, merged_eswitch);
|
if (MLX5_CAP_ESW(esw->dev, merged_eswitch))
|
||||||
|
dest[i].vport.flags |= MLX5_FLOW_DEST_VPORT_VHCA_ID;
|
||||||
}
|
}
|
||||||
dest[i].type = MLX5_FLOW_DESTINATION_TYPE_FLOW_TABLE;
|
dest[i].type = MLX5_FLOW_DESTINATION_TYPE_FLOW_TABLE;
|
||||||
dest[i].ft = fwd_fdb,
|
dest[i].ft = fwd_fdb,
|
||||||
|
|
|
@ -387,7 +387,8 @@ static int mlx5_cmd_set_fte(struct mlx5_core_dev *dev,
|
||||||
id = dst->dest_attr.vport.num;
|
id = dst->dest_attr.vport.num;
|
||||||
MLX5_SET(dest_format_struct, in_dests,
|
MLX5_SET(dest_format_struct, in_dests,
|
||||||
destination_eswitch_owner_vhca_id_valid,
|
destination_eswitch_owner_vhca_id_valid,
|
||||||
dst->dest_attr.vport.vhca_id_valid);
|
!!(dst->dest_attr.vport.flags &
|
||||||
|
MLX5_FLOW_DEST_VPORT_VHCA_ID));
|
||||||
MLX5_SET(dest_format_struct, in_dests,
|
MLX5_SET(dest_format_struct, in_dests,
|
||||||
destination_eswitch_owner_vhca_id,
|
destination_eswitch_owner_vhca_id,
|
||||||
dst->dest_attr.vport.vhca_id);
|
dst->dest_attr.vport.vhca_id);
|
||||||
|
|
|
@ -86,6 +86,10 @@ struct mlx5_flow_spec {
|
||||||
u32 match_value[MLX5_ST_SZ_DW(fte_match_param)];
|
u32 match_value[MLX5_ST_SZ_DW(fte_match_param)];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
enum {
|
||||||
|
MLX5_FLOW_DEST_VPORT_VHCA_ID = BIT(0),
|
||||||
|
};
|
||||||
|
|
||||||
struct mlx5_flow_destination {
|
struct mlx5_flow_destination {
|
||||||
enum mlx5_flow_destination_type type;
|
enum mlx5_flow_destination_type type;
|
||||||
union {
|
union {
|
||||||
|
@ -96,7 +100,7 @@ struct mlx5_flow_destination {
|
||||||
struct {
|
struct {
|
||||||
u16 num;
|
u16 num;
|
||||||
u16 vhca_id;
|
u16 vhca_id;
|
||||||
bool vhca_id_valid;
|
u8 flags;
|
||||||
} vport;
|
} vport;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in New Issue