net/mlx5: Avoid group version scan when not necessary
authorEli Cohen <eli@mellanox.com>
Wed, 4 Mar 2020 08:32:56 +0000 (10:32 +0200)
committerSaeed Mahameed <saeedm@mellanox.com>
Thu, 26 Mar 2020 06:19:11 +0000 (23:19 -0700)
Group version is used when modifying a rule is allowed
(FLOW_ACT_NO_APPEND is clear) to detect a case where the rule was found
but while the groups where unlocked a new FTE was added. In this case,
the added FTE could be one with identical match value so we need to
attempt again with group lock held.

Change the code so version is retrieved only when FLOW_ACT_NO_APPEND is
cleared. As result, later compare can also be avoided if FLOW_ACT_NO_APPEND
is cleared.

Also improve comments text.

Signed-off-by: Eli Cohen <eli@mellanox.com>
Reviewed-by: Mark Bloch <markb@mellanox.com>
Signed-off-by: Saeed Mahameed <saeedm@mellanox.com>
drivers/net/ethernet/mellanox/mlx5/core/fs_core.c

index 44ed42e0e1c7e719a3fff97fdd1b86b4c70d037e..62ce2b9417abca4e8b5aaf3f25609b629978fc6b 100644 (file)
@@ -1680,7 +1680,7 @@ try_add_to_existing_fg(struct mlx5_flow_table *ft,
        struct match_list *iter;
        bool take_write = false;
        struct fs_fte *fte;
-       u64  version;
+       u64  version = 0;
        int err;
 
        fte = alloc_fte(ft, spec, flow_act);
@@ -1688,10 +1688,12 @@ try_add_to_existing_fg(struct mlx5_flow_table *ft,
                return  ERR_PTR(-ENOMEM);
 
 search_again_locked:
-       version = matched_fgs_get_version(match_head);
        if (flow_act->flags & FLOW_ACT_NO_APPEND)
                goto skip_search;
-       /* Try to find a fg that already contains a matching fte */
+       version = matched_fgs_get_version(match_head);
+       /* Try to find an fte with identical match value and attempt update its
+        * action.
+        */
        list_for_each_entry(iter, match_head, list) {
                struct fs_fte *fte_tmp;
 
@@ -1719,10 +1721,12 @@ skip_search:
                goto out;
        }
 
-       /* Check the fgs version, for case the new FTE with the
-        * same values was added while the fgs weren't locked
+       /* Check the fgs version. If version have changed it could be that an
+        * FTE with the same match value was added while the fgs weren't
+        * locked.
         */
-       if (version != matched_fgs_get_version(match_head)) {
+       if (!(flow_act->flags & FLOW_ACT_NO_APPEND) &&
+           version != matched_fgs_get_version(match_head)) {
                take_write = true;
                goto search_again_locked;
        }