Commit 542e6e2c authored by Steen Hegelund's avatar Steen Hegelund Committed by Paolo Abeni

net: microchip: sparx5: Add TC support for IS0 VCAP

This enables the TC command to use the Sparx5 IS0 VCAP
Signed-off-by: default avatarSteen Hegelund <steen.hegelund@microchip.com>
Signed-off-by: default avatarPaolo Abeni <pabeni@redhat.com>
parent 7306fcd1
...@@ -30,6 +30,7 @@ struct sparx5_tc_flower_parse_usage { ...@@ -30,6 +30,7 @@ struct sparx5_tc_flower_parse_usage {
struct flow_cls_offload *fco; struct flow_cls_offload *fco;
struct flow_rule *frule; struct flow_rule *frule;
struct vcap_rule *vrule; struct vcap_rule *vrule;
struct vcap_admin *admin;
u16 l3_proto; u16 l3_proto;
u8 l4_proto; u8 l4_proto;
unsigned int used_keys; unsigned int used_keys;
...@@ -304,6 +305,13 @@ sparx5_tc_flower_handler_basic_usage(struct sparx5_tc_flower_parse_usage *st) ...@@ -304,6 +305,13 @@ sparx5_tc_flower_handler_basic_usage(struct sparx5_tc_flower_parse_usage *st)
VCAP_BIT_0); VCAP_BIT_0);
if (err) if (err)
goto out; goto out;
if (st->admin->vtype == VCAP_TYPE_IS0) {
err = vcap_rule_add_key_bit(st->vrule,
VCAP_KF_TCP_UDP_IS,
VCAP_BIT_1);
if (err)
goto out;
}
} else { } else {
err = vcap_rule_add_key_u32(st->vrule, err = vcap_rule_add_key_u32(st->vrule,
VCAP_KF_L3_IP_PROTO, VCAP_KF_L3_IP_PROTO,
...@@ -542,6 +550,7 @@ static int sparx5_tc_use_dissectors(struct flow_cls_offload *fco, ...@@ -542,6 +550,7 @@ static int sparx5_tc_use_dissectors(struct flow_cls_offload *fco,
.fco = fco, .fco = fco,
.vrule = vrule, .vrule = vrule,
.l3_proto = ETH_P_ALL, .l3_proto = ETH_P_ALL,
.admin = admin,
}; };
int idx, err = 0; int idx, err = 0;
...@@ -623,18 +632,21 @@ static int sparx5_tc_flower_action_check(struct vcap_control *vctrl, ...@@ -623,18 +632,21 @@ static int sparx5_tc_flower_action_check(struct vcap_control *vctrl,
return 0; return 0;
} }
/* Add a rule counter action - only IS2 is considered for now */ /* Add a rule counter action */
static int sparx5_tc_add_rule_counter(struct vcap_admin *admin, static int sparx5_tc_add_rule_counter(struct vcap_admin *admin,
struct vcap_rule *vrule) struct vcap_rule *vrule)
{ {
int err; int err;
err = vcap_rule_mod_action_u32(vrule, VCAP_AF_CNT_ID, vrule->id); if (admin->vtype == VCAP_TYPE_IS2) {
if (err) err = vcap_rule_mod_action_u32(vrule, VCAP_AF_CNT_ID,
return err; vrule->id);
if (err)
return err;
vcap_rule_set_counter_id(vrule, vrule->id);
}
vcap_rule_set_counter_id(vrule, vrule->id); return 0;
return err;
} }
/* Collect all port keysets and apply the first of them, possibly wildcarded */ /* Collect all port keysets and apply the first of them, possibly wildcarded */
...@@ -815,6 +827,29 @@ static int sparx5_tc_add_remaining_rules(struct vcap_control *vctrl, ...@@ -815,6 +827,29 @@ static int sparx5_tc_add_remaining_rules(struct vcap_control *vctrl,
return err; return err;
} }
/* Add the actionset that is the default for the VCAP type */
static int sparx5_tc_set_actionset(struct vcap_admin *admin,
struct vcap_rule *vrule)
{
enum vcap_actionfield_set aset;
int err = 0;
switch (admin->vtype) {
case VCAP_TYPE_IS0:
aset = VCAP_AFS_CLASSIFICATION;
break;
case VCAP_TYPE_IS2:
aset = VCAP_AFS_BASE_TYPE;
break;
default:
return -EINVAL;
}
/* Do not overwrite any current actionset */
if (vrule->actionset == VCAP_AFS_NO_VALUE)
err = vcap_set_rule_set_actionset(vrule, aset);
return err;
}
static int sparx5_tc_flower_replace(struct net_device *ndev, static int sparx5_tc_flower_replace(struct net_device *ndev,
struct flow_cls_offload *fco, struct flow_cls_offload *fco,
struct vcap_admin *admin) struct vcap_admin *admin)
...@@ -874,13 +909,14 @@ static int sparx5_tc_flower_replace(struct net_device *ndev, ...@@ -874,13 +909,14 @@ static int sparx5_tc_flower_replace(struct net_device *ndev,
goto out; goto out;
break; break;
case FLOW_ACTION_ACCEPT: case FLOW_ACTION_ACCEPT:
/* For now the actionset is hardcoded */ err = sparx5_tc_set_actionset(admin, vrule);
err = vcap_set_rule_set_actionset(vrule,
VCAP_AFS_BASE_TYPE);
if (err) if (err)
goto out; goto out;
break; break;
case FLOW_ACTION_GOTO: case FLOW_ACTION_GOTO:
err = sparx5_tc_set_actionset(admin, vrule);
if (err)
goto out;
/* Links between VCAPs will be added later */ /* Links between VCAPs will be added later */
break; break;
default: default:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment