]> www.infradead.org Git - users/dwmw2/linux.git/commitdiff
IB/uverbs: Set IOVA on IB MR in uverbs layer
authorYishai Hadas <yishaih@mellanox.com>
Tue, 30 Jun 2020 09:39:11 +0000 (12:39 +0300)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 21 Aug 2020 11:05:31 +0000 (13:05 +0200)
[ Upstream commit 04c0a5fcfcf65aade2fb238b6336445f1a99b646 ]

Set IOVA on IB MR in uverbs layer to let all drivers have it, this
includes both reg/rereg MR flows.
As part of this change cleaned-up this setting from the drivers that
already did it by themselves in their user flows.

Fixes: e6f0330106f4 ("mlx4_ib: set user mr attributes in struct ib_mr")
Link: https://lore.kernel.org/r/20200630093916.332097-3-leon@kernel.org
Signed-off-by: Yishai Hadas <yishaih@mellanox.com>
Signed-off-by: Leon Romanovsky <leonro@mellanox.com>
Signed-off-by: Jason Gunthorpe <jgg@nvidia.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/infiniband/core/uverbs_cmd.c
drivers/infiniband/hw/cxgb4/mem.c
drivers/infiniband/hw/mlx4/mr.c

index e2ddcb0dc4ee33a273178bdcdae37a9018b7b0cb..c398d1a64614cfb52280e62be7ff17a9a8ff361e 100644 (file)
@@ -757,6 +757,7 @@ static int ib_uverbs_reg_mr(struct uverbs_attr_bundle *attrs)
        mr->uobject = uobj;
        atomic_inc(&pd->usecnt);
        mr->res.type = RDMA_RESTRACK_MR;
+       mr->iova = cmd.hca_va;
        rdma_restrack_uadd(&mr->res);
 
        uobj->object = mr;
@@ -847,6 +848,9 @@ static int ib_uverbs_rereg_mr(struct uverbs_attr_bundle *attrs)
                atomic_dec(&old_pd->usecnt);
        }
 
+       if (cmd.flags & IB_MR_REREG_TRANS)
+               mr->iova = cmd.hca_va;
+
        memset(&resp, 0, sizeof(resp));
        resp.lkey      = mr->lkey;
        resp.rkey      = mr->rkey;
index 35c284af574dadaee494f71e5381f0462c6bb3f1..dcb58cef336d9ca1e48a98210031750ecefe0432 100644 (file)
@@ -399,7 +399,6 @@ static int finish_mem_reg(struct c4iw_mr *mhp, u32 stag)
        mmid = stag >> 8;
        mhp->ibmr.rkey = mhp->ibmr.lkey = stag;
        mhp->ibmr.length = mhp->attr.len;
-       mhp->ibmr.iova = mhp->attr.va_fbo;
        mhp->ibmr.page_size = 1U << (mhp->attr.page_size + 12);
        pr_debug("mmid 0x%x mhp %p\n", mmid, mhp);
        return xa_insert_irq(&mhp->rhp->mrs, mmid, mhp, GFP_KERNEL);
index 6ae503cfc52640144cc7521f0d2fb67e9de80cfa..9114cb73076924efd24c1fc35e2fee8052761602 100644 (file)
@@ -439,7 +439,6 @@ struct ib_mr *mlx4_ib_reg_user_mr(struct ib_pd *pd, u64 start, u64 length,
 
        mr->ibmr.rkey = mr->ibmr.lkey = mr->mmr.key;
        mr->ibmr.length = length;
-       mr->ibmr.iova = virt_addr;
        mr->ibmr.page_size = 1U << shift;
 
        return &mr->ibmr;