OSDN Git Service

RDMA/mlx5: Fix MR cache debugfs error in IB representors mode
authorLeon Romanovsky <leonro@nvidia.com>
Thu, 2 Feb 2023 09:03:06 +0000 (11:03 +0200)
committerLeon Romanovsky <leon@kernel.org>
Mon, 6 Feb 2023 13:44:10 +0000 (15:44 +0200)
Block MR cache debugfs creation for IB representor flow as MR cache shouldn't be used
at all in that mode. As part of this change, add missing debugfs cleanup in error path
too.

This change fixes the following debugfs errors:

 bond0: (slave enp8s0f1): Enslaving as a backup interface with an up link
 mlx5_core 0000:08:00.0: lag map: port 1:1 port 2:1
 mlx5_core 0000:08:00.0: shared_fdb:1 mode:queue_affinity
 mlx5_core 0000:08:00.0: Operation mode is single FDB
 debugfs: Directory '2' with parent '/' already present!
...
 debugfs: Directory '22' with parent '/' already present!

Fixes: 73d09b2fe833 ("RDMA/mlx5: Introduce mlx5r_cache_rb_key")
Signed-off-by: Michael Guralnik <michaelgur@nvidia.com>
Link: https://lore.kernel.org/r/482a78c54acbcfa1742a0e06a452546428900ffa.1675328463.git.leon@kernel.org
Signed-off-by: Leon Romanovsky <leonro@nvidia.com>
drivers/infiniband/hw/mlx5/mr.c

index c396b94..a9808e0 100644 (file)
@@ -845,6 +845,9 @@ static void mlx5_mkey_cache_debugfs_add_ent(struct mlx5_ib_dev *dev,
        int order = order_base_2(ent->rb_key.ndescs);
        struct dentry *dir;
 
+       if (!mlx5_debugfs_root || dev->is_rep)
+               return;
+
        if (ent->rb_key.access_mode == MLX5_MKC_ACCESS_MODE_KSM)
                order = MLX5_IMR_KSM_CACHE_ENTRY + 2;
 
@@ -1003,6 +1006,7 @@ int mlx5_mkey_cache_init(struct mlx5_ib_dev *dev)
 
 err:
        mutex_unlock(&cache->rb_lock);
+       mlx5_mkey_cache_debugfs_cleanup(dev);
        mlx5_ib_warn(dev, "failed to create mkey cache entry\n");
        return ret;
 }