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 c396b942d0c81c1d88c6a14de36e00434524e8db..a9808e022b1f5e3dc2ad63ae685cc9ea9f889de2 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;
 }