}
 
 /**
- * gfs2_rbm_incr - increment an rbm structure
+ * gfs2_rbm_add - add a number of blocks to an rbm
  * @rbm: The rbm with rgd already set correctly
+ * @blocks: The number of blocks to add to rpm
  *
- * This function takes an existing rbm structure and increments it to the next
- * viable block offset.
- *
- * Returns: If incrementing the offset would cause the rbm to go past the
- *          end of the rgrp, true is returned, otherwise false.
+ * This function takes an existing rbm structure and adds a number of blocks to
+ * it.
  *
+ * Returns: True if the new rbm would point past the end of the rgrp.
  */
 
-static bool gfs2_rbm_incr(struct gfs2_rbm *rbm)
+static bool gfs2_rbm_add(struct gfs2_rbm *rbm, u32 blocks)
 {
-       if (rbm->offset + 1 < rbm_bi(rbm)->bi_blocks) { /* in the same bitmap */
-               rbm->offset++;
+       struct gfs2_rgrpd *rgd = rbm->rgd;
+       struct gfs2_bitmap *bi = rgd->rd_bits + rbm->bii;
+
+       if (rbm->offset + blocks < bi->bi_blocks) {
+               rbm->offset += blocks;
                return false;
        }
-       if (rbm->bii == rbm->rgd->rd_length - 1) /* at the last bitmap */
-               return true;
+       blocks -= bi->bi_blocks - rbm->offset;
 
-       rbm->offset = 0;
-       rbm->bii++;
-       return false;
+       for(;;) {
+               bi++;
+               if (bi == rgd->rd_bits + rgd->rd_length)
+                       return true;
+               if (blocks < bi->bi_blocks) {
+                       rbm->offset = blocks;
+                       rbm->bii = bi - rgd->rd_bits;
+                       return false;
+               }
+               blocks -= bi->bi_blocks;
+       }
 }
 
 /**
                (*len)--;
                if (*len == 0)
                        return true;
-               if (gfs2_rbm_incr(rbm))
+               if (gfs2_rbm_add(rbm, 1))
                        return true;
        }
 
        u64 block = gfs2_rbm_to_block(rbm);
        u32 extlen = 1;
        u64 nblock;
-       int ret;
 
        /*
         * If we have a minimum extent length, then skip over any extent
                        maxext->len = extlen;
                        maxext->rbm = *rbm;
                }
-fail:
-               nblock = block + extlen;
+       } else {
+               u64 len = nblock - block;
+               if (len >= (u64)1 << 32)
+                       return -E2BIG;
+               extlen = len;
        }
-       ret = gfs2_rbm_from_block(rbm, nblock);
-       if (ret < 0)
-               return ret;
+fail:
+       if (gfs2_rbm_add(rbm, extlen))
+               return -E2BIG;
        return 1;
 }
 
                        bi_prev = bi;
                }
                gfs2_setbit(&rbm, false, new_state);
-               gfs2_rbm_incr(&rbm);
+               gfs2_rbm_add(&rbm, 1);
        }
 }