{
        struct rpcrdma_ia *ia = &r_xprt->rx_ia;
        struct ib_reg_wr *reg_wr;
+       int i, n, dma_nents;
        struct ib_mr *ibmr;
-       int i, n;
        u8 key;
 
        if (nsegs > ia->ri_max_frwr_depth)
                        break;
        }
        mr->mr_dir = rpcrdma_data_dir(writing);
+       mr->mr_nents = i;
 
-       mr->mr_nents =
-               ib_dma_map_sg(ia->ri_id->device, mr->mr_sg, i, mr->mr_dir);
-       if (!mr->mr_nents)
+       dma_nents = ib_dma_map_sg(ia->ri_id->device, mr->mr_sg, mr->mr_nents,
+                                 mr->mr_dir);
+       if (!dma_nents)
                goto out_dmamap_err;
 
        ibmr = mr->frwr.fr_mr;
-       n = ib_map_mr_sg(ibmr, mr->mr_sg, mr->mr_nents, NULL, PAGE_SIZE);
-       if (unlikely(n != mr->mr_nents))
+       n = ib_map_mr_sg(ibmr, mr->mr_sg, dma_nents, NULL, PAGE_SIZE);
+       if (n != dma_nents)
                goto out_mapmr_err;
 
        ibmr->iova &= 0x00000000ffffffff;