diff options
author | Roland Dreier <roland@topspin.com> | 2005-04-16 18:26:34 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@ppc970.osdl.org> | 2005-04-16 18:26:34 -0400 |
commit | 08aeb14e5f6c28878266b01c87cc5ce31101afa8 (patch) | |
tree | 830f591f6931ceb411f0ae97196f113db2cd766b /drivers/infiniband/hw/mthca/mthca_main.c | |
parent | ddf841f052fa218547c86169d1074968eca8c503 (diff) |
[PATCH] IB/mthca: map context for RDMA responder in mem-free mode
Fix RDMA in mem-free mode: we need to make sure that the RDMA context memory
is mapped for the HCA.
Signed-off-by: Roland Dreier <roland@topspin.com>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'drivers/infiniband/hw/mthca/mthca_main.c')
-rw-r--r-- | drivers/infiniband/hw/mthca/mthca_main.c | 18 |
1 files changed, 16 insertions, 2 deletions
diff --git a/drivers/infiniband/hw/mthca/mthca_main.c b/drivers/infiniband/hw/mthca/mthca_main.c index c9c94686e7a9..014369626f65 100644 --- a/drivers/infiniband/hw/mthca/mthca_main.c +++ b/drivers/infiniband/hw/mthca/mthca_main.c | |||
@@ -430,14 +430,25 @@ static int __devinit mthca_init_icm(struct mthca_dev *mdev, | |||
430 | goto err_unmap_qp; | 430 | goto err_unmap_qp; |
431 | } | 431 | } |
432 | 432 | ||
433 | mdev->cq_table.table = mthca_alloc_icm_table(mdev, init_hca->cqc_base, | 433 | mdev->qp_table.rdb_table = mthca_alloc_icm_table(mdev, init_hca->rdb_base, |
434 | MTHCA_RDB_ENTRY_SIZE, | ||
435 | mdev->limits.num_qps << | ||
436 | mdev->qp_table.rdb_shift, | ||
437 | 0, 0); | ||
438 | if (!mdev->qp_table.rdb_table) { | ||
439 | mthca_err(mdev, "Failed to map RDB context memory, aborting\n"); | ||
440 | err = -ENOMEM; | ||
441 | goto err_unmap_eqp; | ||
442 | } | ||
443 | |||
444 | mdev->cq_table.table = mthca_alloc_icm_table(mdev, init_hca->cqc_base, | ||
434 | dev_lim->cqc_entry_sz, | 445 | dev_lim->cqc_entry_sz, |
435 | mdev->limits.num_cqs, | 446 | mdev->limits.num_cqs, |
436 | mdev->limits.reserved_cqs, 0); | 447 | mdev->limits.reserved_cqs, 0); |
437 | if (!mdev->cq_table.table) { | 448 | if (!mdev->cq_table.table) { |
438 | mthca_err(mdev, "Failed to map CQ context memory, aborting.\n"); | 449 | mthca_err(mdev, "Failed to map CQ context memory, aborting.\n"); |
439 | err = -ENOMEM; | 450 | err = -ENOMEM; |
440 | goto err_unmap_eqp; | 451 | goto err_unmap_rdb; |
441 | } | 452 | } |
442 | 453 | ||
443 | /* | 454 | /* |
@@ -463,6 +474,9 @@ static int __devinit mthca_init_icm(struct mthca_dev *mdev, | |||
463 | err_unmap_cq: | 474 | err_unmap_cq: |
464 | mthca_free_icm_table(mdev, mdev->cq_table.table); | 475 | mthca_free_icm_table(mdev, mdev->cq_table.table); |
465 | 476 | ||
477 | err_unmap_rdb: | ||
478 | mthca_free_icm_table(mdev, mdev->qp_table.rdb_table); | ||
479 | |||
466 | err_unmap_eqp: | 480 | err_unmap_eqp: |
467 | mthca_free_icm_table(mdev, mdev->qp_table.eqp_table); | 481 | mthca_free_icm_table(mdev, mdev->qp_table.eqp_table); |
468 | 482 | ||