Skip to content

Commit f09ef13

Browse files
RajuRangojujgunthorpe
authored andcommitted
iw_cxgb4: cq/qp mask depends on bar2 pages in a host page
Adjust the cq/qp mask based on the number of bar2 pages in a host page. For user-mode rdma, the granularity of the BAR2 memory mapped to a user rdma process during queue allocation must be based on the host page size. The lld attributes udb_density and ucq_density are used to figure out how many sge contexts are in a bar2 page. So the rdev->qpmask and rdev->cqmask in iw_cxgb4 need to now be adjusted based on how many sge bar2 pages are in a host page. Otherwise the device fails to work on non 4k page size systems. Fixes: 2391b00 ("cxgb4: Remove SGE_HOST_PAGE_SIZE dependency on page size") Signed-off-by: Raju Rangoju <rajur@chelsio.com> Signed-off-by: Jason Gunthorpe <jgg@mellanox.com>
1 parent fc4144e commit f09ef13

File tree

1 file changed

+13
-2
lines changed

1 file changed

+13
-2
lines changed

drivers/infiniband/hw/cxgb4/device.c

Lines changed: 13 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -783,6 +783,7 @@ void c4iw_init_dev_ucontext(struct c4iw_rdev *rdev,
783783
static int c4iw_rdev_open(struct c4iw_rdev *rdev)
784784
{
785785
int err;
786+
unsigned int factor;
786787

787788
c4iw_init_dev_ucontext(rdev, &rdev->uctx);
788789

@@ -806,8 +807,18 @@ static int c4iw_rdev_open(struct c4iw_rdev *rdev)
806807
return -EINVAL;
807808
}
808809

809-
rdev->qpmask = rdev->lldi.udb_density - 1;
810-
rdev->cqmask = rdev->lldi.ucq_density - 1;
810+
/* This implementation requires a sge_host_page_size <= PAGE_SIZE. */
811+
if (rdev->lldi.sge_host_page_size > PAGE_SIZE) {
812+
pr_err("%s: unsupported sge host page size %u\n",
813+
pci_name(rdev->lldi.pdev),
814+
rdev->lldi.sge_host_page_size);
815+
return -EINVAL;
816+
}
817+
818+
factor = PAGE_SIZE / rdev->lldi.sge_host_page_size;
819+
rdev->qpmask = (rdev->lldi.udb_density * factor) - 1;
820+
rdev->cqmask = (rdev->lldi.ucq_density * factor) - 1;
821+
811822
pr_debug("dev %s stag start 0x%0x size 0x%0x num stags %d pbl start 0x%0x size 0x%0x rq start 0x%0x size 0x%0x qp qid start %u size %u cq qid start %u size %u srq size %u\n",
812823
pci_name(rdev->lldi.pdev), rdev->lldi.vr->stag.start,
813824
rdev->lldi.vr->stag.size, c4iw_num_stags(rdev),

0 commit comments

Comments
 (0)