RDMA/cxgb4: Use for_each_sg_dma_page iterator on umem SGL
Use the for_each_sg_dma_page iterator variant to walk the umem DMA-mapped SGL and get the page DMA address. This avoids the extra loop to iterate pages in the SGE when for_each_sg iterator is used. Additionally, purge umem->page_shift usage in the driver as its only relevant for ODP MRs. Use system page size and shift instead. Signed-off-by: Shiraz, Saleem <shiraz.saleem@intel.com> Acked-by: Steve Wise <swise@opengridcomputing.com> Signed-off-by: Jason Gunthorpe <jgg@mellanox.com>
This commit is contained in:
parent
3856ec5527
commit
48b586ac36
|
@ -502,10 +502,9 @@ struct ib_mr *c4iw_reg_user_mr(struct ib_pd *pd, u64 start, u64 length,
|
||||||
u64 virt, int acc, struct ib_udata *udata)
|
u64 virt, int acc, struct ib_udata *udata)
|
||||||
{
|
{
|
||||||
__be64 *pages;
|
__be64 *pages;
|
||||||
int shift, n, len;
|
int shift, n, i;
|
||||||
int i, k, entry;
|
|
||||||
int err = -ENOMEM;
|
int err = -ENOMEM;
|
||||||
struct scatterlist *sg;
|
struct sg_dma_page_iter sg_iter;
|
||||||
struct c4iw_dev *rhp;
|
struct c4iw_dev *rhp;
|
||||||
struct c4iw_pd *php;
|
struct c4iw_pd *php;
|
||||||
struct c4iw_mr *mhp;
|
struct c4iw_mr *mhp;
|
||||||
|
@ -541,7 +540,7 @@ struct ib_mr *c4iw_reg_user_mr(struct ib_pd *pd, u64 start, u64 length,
|
||||||
if (IS_ERR(mhp->umem))
|
if (IS_ERR(mhp->umem))
|
||||||
goto err_free_skb;
|
goto err_free_skb;
|
||||||
|
|
||||||
shift = mhp->umem->page_shift;
|
shift = PAGE_SHIFT;
|
||||||
|
|
||||||
n = mhp->umem->nmap;
|
n = mhp->umem->nmap;
|
||||||
err = alloc_pbl(mhp, n);
|
err = alloc_pbl(mhp, n);
|
||||||
|
@ -556,14 +555,10 @@ struct ib_mr *c4iw_reg_user_mr(struct ib_pd *pd, u64 start, u64 length,
|
||||||
|
|
||||||
i = n = 0;
|
i = n = 0;
|
||||||
|
|
||||||
for_each_sg(mhp->umem->sg_head.sgl, sg, mhp->umem->nmap, entry) {
|
for_each_sg_dma_page(mhp->umem->sg_head.sgl, &sg_iter, mhp->umem->nmap, 0) {
|
||||||
len = sg_dma_len(sg) >> shift;
|
pages[i++] = cpu_to_be64(sg_page_iter_dma_address(&sg_iter));
|
||||||
for (k = 0; k < len; ++k) {
|
if (i == PAGE_SIZE / sizeof(*pages)) {
|
||||||
pages[i++] = cpu_to_be64(sg_dma_address(sg) +
|
err = write_pbl(&mhp->rhp->rdev, pages,
|
||||||
(k << shift));
|
|
||||||
if (i == PAGE_SIZE / sizeof *pages) {
|
|
||||||
err = write_pbl(&mhp->rhp->rdev,
|
|
||||||
pages,
|
|
||||||
mhp->attr.pbl_addr + (n << 3), i,
|
mhp->attr.pbl_addr + (n << 3), i,
|
||||||
mhp->wr_waitp);
|
mhp->wr_waitp);
|
||||||
if (err)
|
if (err)
|
||||||
|
@ -572,7 +567,6 @@ struct ib_mr *c4iw_reg_user_mr(struct ib_pd *pd, u64 start, u64 length,
|
||||||
i = 0;
|
i = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
if (i)
|
if (i)
|
||||||
err = write_pbl(&mhp->rhp->rdev, pages,
|
err = write_pbl(&mhp->rhp->rdev, pages,
|
||||||
|
|
Loading…
Reference in New Issue