net: microchip: sparx5: Clear rule counter even if lookup is disabled
authorSteen Hegelund <steen.hegelund@microchip.com>
Tue, 14 Feb 2023 10:40:41 +0000 (11:40 +0100)
committerPaolo Abeni <pabeni@redhat.com>
Thu, 16 Feb 2023 07:59:48 +0000 (08:59 +0100)
The rule counter must be cleared when creating a new rule, even if the VCAP
lookup is currently disabled.

This ensures that rules located in VCAPs that use external counters (such
as Sparx5 IS2 and ES0) will have their counter reset even if the VCAP
lookup is not enabled at the moment.

Signed-off-by: Steen Hegelund <steen.hegelund@microchip.com>
Fixes: 95fa74148daa ("net: microchip: sparx5: Reset VCAP counter for new rules")
Signed-off-by: Paolo Abeni <pabeni@redhat.com>
drivers/net/ethernet/microchip/vcap/vcap_api.c
drivers/net/ethernet/microchip/vcap/vcap_api_kunit.c

index 6307d59f23da67655b72fca7360cf58f68513941..68e04d47f6fd74fa4b71fd3c34e9700522f8be2c 100644 (file)
@@ -2246,6 +2246,11 @@ int vcap_add_rule(struct vcap_rule *rule)
        if (move.count > 0)
                vcap_move_rules(ri, &move);
 
+       /* Set the counter to zero */
+       ret = vcap_write_counter(ri, &ctr);
+       if (ret)
+               goto out;
+
        if (ri->state == VCAP_RS_DISABLED) {
                /* Erase the rule area */
                ri->vctrl->ops->init(ri->ndev, ri->admin, ri->addr, ri->size);
@@ -2264,8 +2269,6 @@ int vcap_add_rule(struct vcap_rule *rule)
                pr_err("%s:%d: rule write error: %d\n", __func__, __LINE__, ret);
                goto out;
        }
-       /* Set the counter to zero */
-       ret = vcap_write_counter(ri, &ctr);
 out:
        mutex_unlock(&ri->admin->lock);
        return ret;
index b2753aac8ad213b2b91c494d964ba8e974411f3d..0a1d4d74056790487a3f1d390cbb6773ef821cb5 100644 (file)
@@ -1337,8 +1337,8 @@ static void vcap_api_encode_rule_test(struct kunit *test)
        u32 port_mask_rng_mask = 0x0f;
        u32 igr_port_mask_value = 0xffabcd01;
        u32 igr_port_mask_mask = ~0;
-       /* counter is written as the last operation */
-       u32 expwriteaddr[] = {792, 793, 794, 795, 796, 797, 792};
+       /* counter is written as the first operation */
+       u32 expwriteaddr[] = {792, 792, 793, 794, 795, 796, 797};
        int idx;
 
        vcap_test_api_init(&is2_admin);