staging: lustre: Using macro DIV_ROUND_UP
authorsimran singhal <singhalsimran0@gmail.com>
Wed, 22 Feb 2017 09:32:04 +0000 (15:02 +0530)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 6 Mar 2017 08:17:00 +0000 (09:17 +0100)
The macro DIV_ROUND_UP performs the computation (((n) + (d) - 1) /(d)).
It clarifies the divisor calculations. This occurence was detected using
the coccinelle script:

@@
expression e1;
expression e2;
@@
(
- ((e1) + e2 - 1) / (e2)
+ DIV_ROUND_UP(e1,e2)
|
- ((e1) + (e2 - 1)) / (e2)
+ DIV_ROUND_UP(e1,e2)
)

Signed-off-by: simran singhal <singhalsimran0@gmail.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/staging/lustre/lnet/klnds/o2iblnd/o2iblnd.c
drivers/staging/lustre/lnet/selftest/conrpc.c
drivers/staging/lustre/lustre/ptlrpc/client.c
drivers/staging/lustre/lustre/ptlrpc/niobuf.c
drivers/staging/lustre/lustre/ptlrpc/sec_bulk.c

index 0618b793b180a2baf1bb4ed4eb0bf7ff2448e682..6f73454c7ac13c8e1f7a54e9871303fba832472c 100644 (file)
@@ -2037,7 +2037,7 @@ static int kiblnd_create_tx_pool(struct kib_poolset *ps, int size,
        tpo->tpo_tx_descs = NULL;
        tpo->tpo_tx_pages = NULL;
 
-       npg = (size * IBLND_MSG_SIZE + PAGE_SIZE - 1) / PAGE_SIZE;
+       npg = DIV_ROUND_UP(size * IBLND_MSG_SIZE, PAGE_SIZE);
        if (kiblnd_alloc_pages(&tpo->tpo_tx_pages, ps->ps_cpt, npg)) {
                CERROR("Can't allocate tx pages: %d\n", npg);
                LIBCFS_FREE(tpo, sizeof(*tpo));
index c6a683bda75eb98139f6d8b23e5cb76ee710771c..680a5595f3b6441f719ea9958bc9efbd83f40047 100644 (file)
@@ -785,8 +785,7 @@ lstcon_bulkrpc_v0_prep(struct lst_test_bulk_param *param,
        struct test_bulk_req *brq = &req->tsr_u.bulk_v0;
 
        brq->blk_opc = param->blk_opc;
-       brq->blk_npg = (param->blk_size + PAGE_SIZE - 1) /
-                       PAGE_SIZE;
+       brq->blk_npg = DIV_ROUND_UP(param->blk_size, PAGE_SIZE);
        brq->blk_flags = param->blk_flags;
 
        return 0;
@@ -833,11 +832,9 @@ lstcon_testrpc_prep(struct lstcon_node *nd, int transop, unsigned int feats,
        trq = &(*crpc)->crp_rpc->crpc_reqstmsg.msg_body.tes_reqst;
 
        if (transop == LST_TRANS_TSBSRVADD) {
-               int ndist = (sgrp->grp_nnode + test->tes_dist - 1) /
-                           test->tes_dist;
-               int nspan = (dgrp->grp_nnode + test->tes_span - 1) /
-                           test->tes_span;
-               int nmax = (ndist + nspan - 1) / nspan;
+               int ndist = DIV_ROUND_UP(sgrp->grp_nnode, test->tes_dist);
+               int nspan = DIV_ROUND_UP(dgrp->grp_nnode, test->tes_span);
+               int nmax = DIV_ROUND_UP(ndist, nspan);
 
                trq->tsr_ndest = 0;
                trq->tsr_loop = nmax * test->tes_dist * test->tes_concur;
index 04a98a08ece192763ce7c3acbe267bb1764675db..45b9aec617e975386415dc12f35680034a512dfc 100644 (file)
@@ -3144,8 +3144,7 @@ void ptlrpc_set_bulk_mbits(struct ptlrpc_request *req)
         * that server can infer the number of bulks that were prepared,
         * see LU-1431
         */
-       req->rq_mbits += ((bd->bd_iov_count + LNET_MAX_IOV - 1) /
-                         LNET_MAX_IOV) - 1;
+       req->rq_mbits += DIV_ROUND_UP(bd->bd_iov_count, LNET_MAX_IOV) - 1;
 }
 
 /**
index b8701841ab4af55030d5a9d359d01400835ce668..352f614b781a49fbc0db7c6751528175e4aca5eb 100644 (file)
@@ -142,7 +142,7 @@ static int ptlrpc_register_bulk(struct ptlrpc_request *req)
        LASSERT(desc->bd_cbid.cbid_fn == client_bulk_callback);
        LASSERT(desc->bd_cbid.cbid_arg == desc);
 
-       total_md = (desc->bd_iov_count + LNET_MAX_IOV - 1) / LNET_MAX_IOV;
+       total_md = DIV_ROUND_UP(desc->bd_iov_count, LNET_MAX_IOV);
        /* rq_mbits is matchbits of the final bulk */
        mbits = req->rq_mbits - total_md + 1;
 
index 2fe9085e20340523420f44433aef8e1d3971e2bd..128838a695e0137f820d658a64a89cf5a6daf974 100644 (file)
@@ -272,7 +272,7 @@ static unsigned long enc_pools_shrink_scan(struct shrinker *s,
 static inline
 int npages_to_npools(unsigned long npages)
 {
-       return (int)((npages + PAGES_PER_POOL - 1) / PAGES_PER_POOL);
+       return (int)DIV_ROUND_UP(npages, PAGES_PER_POOL);
 }
 
 /*