RDMA/mlx5: Set the HW IOVA of the child MRs to their place in the tree
authorJason Gunthorpe <jgg@mellanox.com>
Wed, 9 Oct 2019 16:09:27 +0000 (13:09 -0300)
committerJason Gunthorpe <jgg@mellanox.com>
Mon, 28 Oct 2019 19:41:13 +0000 (16:41 -0300)
Instead of rewriting all the IOVA's to 0 as things progress down the tree
make the IOVA of the children equal to placement in the tree. This makes
things easier to understand by keeping mmkey.iova == HW configuration.

Link: https://lore.kernel.org/r/20191009160934.3143-8-jgg@ziepe.ca
Reviewed-by: Artemy Kovalyov <artemyko@mellanox.com>
Signed-off-by: Jason Gunthorpe <jgg@mellanox.com>
drivers/infiniband/hw/mlx5/odp.c

index dfaa39f..b25cf78 100644 (file)
@@ -211,9 +211,11 @@ void mlx5_odp_populate_klm(struct mlx5_klm *pklm, size_t offset,
                        struct mlx5_ib_mr *mtt = odp->private;
 
                        pklm->key = cpu_to_be32(mtt->ibmr.lkey);
+                       pklm->va = cpu_to_be64(va);
                        odp = odp_next(odp);
                } else {
                        pklm->key = cpu_to_be32(dev->null_mkey);
+                       pklm->va = 0;
                }
                mlx5_ib_dbg(dev, "[%d] va %lx key %x\n",
                            i, va, be32_to_cpu(pklm->key));
@@ -446,7 +448,7 @@ static struct mlx5_ib_mr *implicit_get_child_mr(struct mlx5_ib_mr *imr,
        mr->umem = &odp->umem;
        mr->ibmr.lkey = mr->mmkey.key;
        mr->ibmr.rkey = mr->mmkey.key;
-       mr->mmkey.iova = 0;
+       mr->mmkey.iova = idx * MLX5_IMR_MTT_SIZE;
        mr->parent = imr;
        odp->private = mr;
        INIT_WORK(&odp->work, mr_leaf_free_action);
@@ -462,7 +464,6 @@ static struct mlx5_ib_mr *implicit_get_child_mr(struct mlx5_ib_mr *imr,
                goto out_release;
        }
 
-       mr->mmkey.iova = idx * MLX5_IMR_MTT_SIZE;
        xa_store(&imr->dev->odp_mkeys, mlx5_base_mkey(mr->mmkey.key),
                 &mr->mmkey, GFP_ATOMIC);