Skip to content

Commit 3a46f4f

Browse files
mark-blochSaeed Mahameed
authored andcommitted
net/mlx5: E-Switch, Refactor send to vport to be more generic
Now that each representor stores a pointer to the managing E-Switch use that information when creating the send-to-vport rules. Signed-off-by: Mark Bloch <[email protected]> Reviewed-by: Saeed Mahameed <[email protected]> Signed-off-by: Saeed Mahameed <[email protected]>
1 parent 658cfce commit 3a46f4f

File tree

4 files changed

+16
-14
lines changed

4 files changed

+16
-14
lines changed

drivers/infiniband/hw/mlx5/ib_rep.c

Lines changed: 1 addition & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -123,8 +123,7 @@ struct mlx5_flow_handle *create_flow_rule_vport_sq(struct mlx5_ib_dev *dev,
123123

124124
rep = dev->port[port - 1].rep;
125125

126-
return mlx5_eswitch_add_send_to_vport_rule(esw, rep->vport,
127-
sq->base.mqp.qpn);
126+
return mlx5_eswitch_add_send_to_vport_rule(esw, rep, sq->base.mqp.qpn);
128127
}
129128

130129
static int mlx5r_rep_probe(struct auxiliary_device *adev,

drivers/net/ethernet/mellanox/mlx5/core/en_rep.c

Lines changed: 1 addition & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -411,8 +411,7 @@ static int mlx5e_sqs2vport_start(struct mlx5_eswitch *esw,
411411
}
412412

413413
/* Add re-inject rule to the PF/representor sqs */
414-
flow_rule = mlx5_eswitch_add_send_to_vport_rule(esw,
415-
rep->vport,
414+
flow_rule = mlx5_eswitch_add_send_to_vport_rule(esw, rep,
416415
sqns_array[i]);
417416
if (IS_ERR(flow_rule)) {
418417
err = PTR_ERR(flow_rule);

drivers/net/ethernet/mellanox/mlx5/core/eswitch_offloads.c

Lines changed: 12 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -1036,7 +1036,8 @@ int mlx5_eswitch_del_vlan_action(struct mlx5_eswitch *esw,
10361036
}
10371037

10381038
struct mlx5_flow_handle *
1039-
mlx5_eswitch_add_send_to_vport_rule(struct mlx5_eswitch *esw, u16 vport,
1039+
mlx5_eswitch_add_send_to_vport_rule(struct mlx5_eswitch *on_esw,
1040+
struct mlx5_eswitch_rep *rep,
10401041
u32 sqn)
10411042
{
10421043
struct mlx5_flow_act flow_act = {0};
@@ -1054,27 +1055,30 @@ mlx5_eswitch_add_send_to_vport_rule(struct mlx5_eswitch *esw, u16 vport,
10541055
misc = MLX5_ADDR_OF(fte_match_param, spec->match_value, misc_parameters);
10551056
MLX5_SET(fte_match_set_misc, misc, source_sqn, sqn);
10561057
/* source vport is the esw manager */
1057-
MLX5_SET(fte_match_set_misc, misc, source_port, esw->manager_vport);
1058-
if (MLX5_CAP_ESW(esw->dev, merged_eswitch))
1058+
MLX5_SET(fte_match_set_misc, misc, source_port, rep->esw->manager_vport);
1059+
if (MLX5_CAP_ESW(on_esw->dev, merged_eswitch))
10591060
MLX5_SET(fte_match_set_misc, misc, source_eswitch_owner_vhca_id,
1060-
MLX5_CAP_GEN(esw->dev, vhca_id));
1061+
MLX5_CAP_GEN(rep->esw->dev, vhca_id));
10611062

10621063
misc = MLX5_ADDR_OF(fte_match_param, spec->match_criteria, misc_parameters);
10631064
MLX5_SET_TO_ONES(fte_match_set_misc, misc, source_sqn);
10641065
MLX5_SET_TO_ONES(fte_match_set_misc, misc, source_port);
1065-
if (MLX5_CAP_ESW(esw->dev, merged_eswitch))
1066+
if (MLX5_CAP_ESW(on_esw->dev, merged_eswitch))
10661067
MLX5_SET_TO_ONES(fte_match_set_misc, misc,
10671068
source_eswitch_owner_vhca_id);
10681069

10691070
spec->match_criteria_enable = MLX5_MATCH_MISC_PARAMETERS;
10701071
dest.type = MLX5_FLOW_DESTINATION_TYPE_VPORT;
1071-
dest.vport.num = vport;
1072+
dest.vport.num = rep->vport;
1073+
dest.vport.vhca_id = MLX5_CAP_GEN(rep->esw->dev, vhca_id);
1074+
dest.vport.flags |= MLX5_FLOW_DEST_VPORT_VHCA_ID;
10721075
flow_act.action = MLX5_FLOW_CONTEXT_ACTION_FWD_DEST;
10731076

1074-
flow_rule = mlx5_add_flow_rules(esw->fdb_table.offloads.slow_fdb,
1077+
flow_rule = mlx5_add_flow_rules(on_esw->fdb_table.offloads.slow_fdb,
10751078
spec, &flow_act, &dest, 1);
10761079
if (IS_ERR(flow_rule))
1077-
esw_warn(esw->dev, "FDB: Failed to add send to vport rule err %ld\n", PTR_ERR(flow_rule));
1080+
esw_warn(on_esw->dev, "FDB: Failed to add send to vport rule err %ld\n",
1081+
PTR_ERR(flow_rule));
10781082
out:
10791083
kvfree(spec);
10801084
return flow_rule;

include/linux/mlx5/eswitch.h

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -62,8 +62,8 @@ struct mlx5_eswitch_rep *mlx5_eswitch_vport_rep(struct mlx5_eswitch *esw,
6262
u16 vport_num);
6363
void *mlx5_eswitch_uplink_get_proto_dev(struct mlx5_eswitch *esw, u8 rep_type);
6464
struct mlx5_flow_handle *
65-
mlx5_eswitch_add_send_to_vport_rule(struct mlx5_eswitch *esw,
66-
u16 vport_num, u32 sqn);
65+
mlx5_eswitch_add_send_to_vport_rule(struct mlx5_eswitch *on_esw,
66+
struct mlx5_eswitch_rep *rep, u32 sqn);
6767

6868
u16 mlx5_eswitch_get_total_vports(const struct mlx5_core_dev *dev);
6969

0 commit comments

Comments
 (0)