aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/infiniband
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/infiniband')
-rw-r--r--drivers/infiniband/hw/ehca/ehca_mrmw.c47
1 files changed, 24 insertions, 23 deletions
diff --git a/drivers/infiniband/hw/ehca/ehca_mrmw.c b/drivers/infiniband/hw/ehca/ehca_mrmw.c
index 1fe4f726cee9..58e8b33d030b 100644
--- a/drivers/infiniband/hw/ehca/ehca_mrmw.c
+++ b/drivers/infiniband/hw/ehca/ehca_mrmw.c
@@ -48,6 +48,8 @@
48#include "hcp_if.h" 48#include "hcp_if.h"
49#include "hipz_hw.h" 49#include "hipz_hw.h"
50 50
51#define NUM_CHUNKS(length, chunk_size) \
52 (((length) + (chunk_size - 1)) / (chunk_size))
51/* max number of rpages (per hcall register_rpages) */ 53/* max number of rpages (per hcall register_rpages) */
52#define MAX_RPAGES 512 54#define MAX_RPAGES 512
53 55
@@ -195,10 +197,10 @@ struct ib_mr *ehca_reg_phys_mr(struct ib_pd *pd,
195 } 197 }
196 198
197 /* determine number of MR pages */ 199 /* determine number of MR pages */
198 num_pages_mr = ((((u64)iova_start % PAGE_SIZE) + size + 200 num_pages_mr = NUM_CHUNKS(((u64)iova_start % PAGE_SIZE) + size,
199 PAGE_SIZE - 1) / PAGE_SIZE); 201 PAGE_SIZE);
200 num_pages_4k = ((((u64)iova_start % EHCA_PAGESIZE) + size + 202 num_pages_4k = NUM_CHUNKS(((u64)iova_start % EHCA_PAGESIZE) + size,
201 EHCA_PAGESIZE - 1) / EHCA_PAGESIZE); 203 EHCA_PAGESIZE);
202 204
203 /* register MR on HCA */ 205 /* register MR on HCA */
204 if (ehca_mr_is_maxmr(size, iova_start)) { 206 if (ehca_mr_is_maxmr(size, iova_start)) {
@@ -305,10 +307,9 @@ struct ib_mr *ehca_reg_user_mr(struct ib_pd *pd, u64 start, u64 length, u64 virt
305 } 307 }
306 308
307 /* determine number of MR pages */ 309 /* determine number of MR pages */
308 num_pages_mr = (((virt % PAGE_SIZE) + length + PAGE_SIZE - 1) / 310 num_pages_mr = NUM_CHUNKS((virt % PAGE_SIZE) + length, PAGE_SIZE);
309 PAGE_SIZE); 311 num_pages_4k = NUM_CHUNKS((virt % EHCA_PAGESIZE) + length,
310 num_pages_4k = (((virt % EHCA_PAGESIZE) + length + EHCA_PAGESIZE - 1) / 312 EHCA_PAGESIZE);
311 EHCA_PAGESIZE);
312 313
313 /* register MR on HCA */ 314 /* register MR on HCA */
314 pginfo.type = EHCA_MR_PGI_USER; 315 pginfo.type = EHCA_MR_PGI_USER;
@@ -462,10 +463,10 @@ int ehca_rereg_phys_mr(struct ib_mr *mr,
462 ret = -EINVAL; 463 ret = -EINVAL;
463 goto rereg_phys_mr_exit1; 464 goto rereg_phys_mr_exit1;
464 } 465 }
465 num_pages_mr = ((((u64)new_start % PAGE_SIZE) + new_size + 466 num_pages_mr = NUM_CHUNKS(((u64)new_start % PAGE_SIZE) +
466 PAGE_SIZE - 1) / PAGE_SIZE); 467 new_size, PAGE_SIZE);
467 num_pages_4k = ((((u64)new_start % EHCA_PAGESIZE) + new_size + 468 num_pages_4k = NUM_CHUNKS(((u64)new_start % EHCA_PAGESIZE) +
468 EHCA_PAGESIZE - 1) / EHCA_PAGESIZE); 469 new_size, EHCA_PAGESIZE);
469 pginfo.type = EHCA_MR_PGI_PHYS; 470 pginfo.type = EHCA_MR_PGI_PHYS;
470 pginfo.num_pages = num_pages_mr; 471 pginfo.num_pages = num_pages_mr;
471 pginfo.num_4k = num_pages_4k; 472 pginfo.num_4k = num_pages_4k;
@@ -1030,9 +1031,9 @@ int ehca_reg_mr_rpages(struct ehca_shca *shca,
1030 } 1031 }
1031 1032
1032 /* max 512 pages per shot */ 1033 /* max 512 pages per shot */
1033 for (i = 0; i < ((pginfo->num_4k + MAX_RPAGES - 1) / MAX_RPAGES); i++) { 1034 for (i = 0; i < NUM_CHUNKS(pginfo->num_4k, MAX_RPAGES); i++) {
1034 1035
1035 if (i == ((pginfo->num_4k + MAX_RPAGES - 1) / MAX_RPAGES) - 1) { 1036 if (i == NUM_CHUNKS(pginfo->num_4k, MAX_RPAGES) - 1) {
1036 rnum = pginfo->num_4k % MAX_RPAGES; /* last shot */ 1037 rnum = pginfo->num_4k % MAX_RPAGES; /* last shot */
1037 if (rnum == 0) 1038 if (rnum == 0)
1038 rnum = MAX_RPAGES; /* last shot is full */ 1039 rnum = MAX_RPAGES; /* last shot is full */
@@ -1069,7 +1070,7 @@ int ehca_reg_mr_rpages(struct ehca_shca *shca,
1069 0, /* pagesize 4k */ 1070 0, /* pagesize 4k */
1070 0, rpage, rnum); 1071 0, rpage, rnum);
1071 1072
1072 if (i == ((pginfo->num_4k + MAX_RPAGES - 1) / MAX_RPAGES) - 1) { 1073 if (i == NUM_CHUNKS(pginfo->num_4k, MAX_RPAGES) - 1) {
1073 /* 1074 /*
1074 * check for 'registration complete'==H_SUCCESS 1075 * check for 'registration complete'==H_SUCCESS
1075 * and for 'page registered'==H_PAGE_REGISTERED 1076 * and for 'page registered'==H_PAGE_REGISTERED
@@ -1475,10 +1476,10 @@ int ehca_reg_internal_maxmr(
1475 iova_start = (u64*)KERNELBASE; 1476 iova_start = (u64*)KERNELBASE;
1476 ib_pbuf.addr = 0; 1477 ib_pbuf.addr = 0;
1477 ib_pbuf.size = size_maxmr; 1478 ib_pbuf.size = size_maxmr;
1478 num_pages_mr = ((((u64)iova_start % PAGE_SIZE) + size_maxmr + 1479 num_pages_mr = NUM_CHUNKS(((u64)iova_start % PAGE_SIZE) + size_maxmr,
1479 PAGE_SIZE - 1) / PAGE_SIZE); 1480 PAGE_SIZE);
1480 num_pages_4k = ((((u64)iova_start % EHCA_PAGESIZE) + size_maxmr + 1481 num_pages_4k = NUM_CHUNKS(((u64)iova_start % EHCA_PAGESIZE)
1481 EHCA_PAGESIZE - 1) / EHCA_PAGESIZE); 1482 + size_maxmr, EHCA_PAGESIZE);
1482 1483
1483 pginfo.type = EHCA_MR_PGI_PHYS; 1484 pginfo.type = EHCA_MR_PGI_PHYS;
1484 pginfo.num_pages = num_pages_mr; 1485 pginfo.num_pages = num_pages_mr;
@@ -1700,8 +1701,8 @@ int ehca_set_pagebuf(struct ehca_mr *e_mr,
1700 /* loop over desired phys_buf_array entries */ 1701 /* loop over desired phys_buf_array entries */
1701 while (i < number) { 1702 while (i < number) {
1702 pbuf = pginfo->phys_buf_array + pginfo->next_buf; 1703 pbuf = pginfo->phys_buf_array + pginfo->next_buf;
1703 num4k = ((pbuf->addr % EHCA_PAGESIZE) + pbuf->size + 1704 num4k = NUM_CHUNKS((pbuf->addr % EHCA_PAGESIZE)
1704 EHCA_PAGESIZE - 1) / EHCA_PAGESIZE; 1705 + pbuf->size, EHCA_PAGESIZE);
1705 offs4k = (pbuf->addr & ~PAGE_MASK) / EHCA_PAGESIZE; 1706 offs4k = (pbuf->addr & ~PAGE_MASK) / EHCA_PAGESIZE;
1706 while (pginfo->next_4k < offs4k + num4k) { 1707 while (pginfo->next_4k < offs4k + num4k) {
1707 /* sanity check */ 1708 /* sanity check */
@@ -1873,8 +1874,8 @@ int ehca_set_pagebuf_1(struct ehca_mr *e_mr,
1873 goto ehca_set_pagebuf_1_exit0; 1874 goto ehca_set_pagebuf_1_exit0;
1874 } 1875 }
1875 tmp_pbuf = pginfo->phys_buf_array + pginfo->next_buf; 1876 tmp_pbuf = pginfo->phys_buf_array + pginfo->next_buf;
1876 num4k = ((tmp_pbuf->addr % EHCA_PAGESIZE) + tmp_pbuf->size + 1877 num4k = NUM_CHUNKS((tmp_pbuf->addr % EHCA_PAGESIZE) +
1877 EHCA_PAGESIZE - 1) / EHCA_PAGESIZE; 1878 tmp_pbuf->size, EHCA_PAGESIZE);
1878 offs4k = (tmp_pbuf->addr & ~PAGE_MASK) / EHCA_PAGESIZE; 1879 offs4k = (tmp_pbuf->addr & ~PAGE_MASK) / EHCA_PAGESIZE;
1879 *rpage = phys_to_abs((tmp_pbuf->addr & EHCA_PAGEMASK) + 1880 *rpage = phys_to_abs((tmp_pbuf->addr & EHCA_PAGEMASK) +
1880 (pginfo->next_4k * EHCA_PAGESIZE)); 1881 (pginfo->next_4k * EHCA_PAGESIZE));