• Home
  • Raw
  • Download

Lines Matching refs:rbm

61 	struct gfs2_rbm rbm;  member
73 static int gfs2_rbm_find(struct gfs2_rbm *rbm, u8 state, u32 *minext,
85 static inline void gfs2_setbit(const struct gfs2_rbm *rbm, bool do_clone, in gfs2_setbit() argument
89 struct gfs2_bitmap *bi = rbm_bi(rbm); in gfs2_setbit()
91 const unsigned int bit = (rbm->offset % GFS2_NBBY) * GFS2_BIT_SIZE; in gfs2_setbit()
93 byte1 = bi->bi_bh->b_data + bi->bi_offset + (rbm->offset / GFS2_NBBY); in gfs2_setbit()
101 struct gfs2_sbd *sdp = rbm->rgd->rd_sbd; in gfs2_setbit()
104 rbm->offset, cur_state, new_state); in gfs2_setbit()
106 (unsigned long long)rbm->rgd->rd_addr, bi->bi_start, in gfs2_setbit()
110 (unsigned long long)gfs2_rbm_to_block(rbm)); in gfs2_setbit()
112 gfs2_consist_rgrpd(rbm->rgd); in gfs2_setbit()
118 byte2 = bi->bi_clone + bi->bi_offset + (rbm->offset / GFS2_NBBY); in gfs2_setbit()
135 static inline u8 gfs2_testbit(const struct gfs2_rbm *rbm, bool use_clone) in gfs2_testbit() argument
137 struct gfs2_bitmap *bi = rbm_bi(rbm); in gfs2_testbit()
147 byte = buffer + (rbm->offset / GFS2_NBBY); in gfs2_testbit()
148 bit = (rbm->offset % GFS2_NBBY) * GFS2_BIT_SIZE; in gfs2_testbit()
271 static int gfs2_rbm_from_block(struct gfs2_rbm *rbm, u64 block) in gfs2_rbm_from_block() argument
273 if (!rgrp_contains_block(rbm->rgd, block)) in gfs2_rbm_from_block()
275 rbm->bii = 0; in gfs2_rbm_from_block()
276 rbm->offset = block - rbm->rgd->rd_data0; in gfs2_rbm_from_block()
278 if (rbm->offset < rbm_bi(rbm)->bi_blocks) in gfs2_rbm_from_block()
282 rbm->offset += (sizeof(struct gfs2_rgrp) - in gfs2_rbm_from_block()
284 rbm->bii = rbm->offset / rbm->rgd->rd_sbd->sd_blocks_per_bitmap; in gfs2_rbm_from_block()
285 rbm->offset -= rbm->bii * rbm->rgd->rd_sbd->sd_blocks_per_bitmap; in gfs2_rbm_from_block()
301 static bool gfs2_rbm_incr(struct gfs2_rbm *rbm) in gfs2_rbm_incr() argument
303 if (rbm->offset + 1 < rbm_bi(rbm)->bi_blocks) { /* in the same bitmap */ in gfs2_rbm_incr()
304 rbm->offset++; in gfs2_rbm_incr()
307 if (rbm->bii == rbm->rgd->rd_length - 1) /* at the last bitmap */ in gfs2_rbm_incr()
310 rbm->offset = 0; in gfs2_rbm_incr()
311 rbm->bii++; in gfs2_rbm_incr()
324 static bool gfs2_unaligned_extlen(struct gfs2_rbm *rbm, u32 n_unaligned, u32 *len) in gfs2_unaligned_extlen() argument
330 res = gfs2_testbit(rbm, true); in gfs2_unaligned_extlen()
336 if (gfs2_rbm_incr(rbm)) in gfs2_unaligned_extlen()
360 struct gfs2_rbm rbm = *rrbm; in gfs2_free_extlen() local
361 u32 n_unaligned = rbm.offset & 3; in gfs2_free_extlen()
370 gfs2_unaligned_extlen(&rbm, 4 - n_unaligned, &len)) in gfs2_free_extlen()
376 bi = rbm_bi(&rbm); in gfs2_free_extlen()
382 BUG_ON(rbm.offset & 3); in gfs2_free_extlen()
383 start += (rbm.offset / GFS2_NBBY); in gfs2_free_extlen()
390 block = gfs2_rbm_to_block(&rbm); in gfs2_free_extlen()
391 if (gfs2_rbm_from_block(&rbm, block + chunk_size)) { in gfs2_free_extlen()
404 gfs2_unaligned_extlen(&rbm, n_unaligned, &len); in gfs2_free_extlen()
1575 struct gfs2_rbm rbm = { .rgd = rgd, }; in rg_mblk_search() local
1598 if (WARN_ON(gfs2_rbm_from_block(&rbm, goal))) in rg_mblk_search()
1601 ret = gfs2_rbm_find(&rbm, GFS2_BLKST_FREE, &extlen, ip, true); in rg_mblk_search()
1603 rs->rs_rbm = rbm; in rg_mblk_search()
1676 static int gfs2_reservation_check_and_update(struct gfs2_rbm *rbm, in gfs2_reservation_check_and_update() argument
1681 u64 block = gfs2_rbm_to_block(rbm); in gfs2_reservation_check_and_update()
1691 extlen = gfs2_free_extlen(rbm, minext); in gfs2_reservation_check_and_update()
1700 nblock = gfs2_next_unreserved_block(rbm->rgd, block, extlen, ip); in gfs2_reservation_check_and_update()
1707 maxext->rbm = *rbm; in gfs2_reservation_check_and_update()
1712 ret = gfs2_rbm_from_block(rbm, nblock); in gfs2_reservation_check_and_update()
1737 static int gfs2_rbm_find(struct gfs2_rbm *rbm, u8 state, u32 *minext, in gfs2_rbm_find() argument
1740 bool scan_from_start = rbm->bii == 0 && rbm->offset == 0; in gfs2_rbm_find()
1748 struct gfs2_extent maxext = { .rbm.rgd = rbm->rgd, }; in gfs2_rbm_find()
1755 last_bii = rbm->bii - (rbm->offset == 0); in gfs2_rbm_find()
1758 bi = rbm_bi(rbm); in gfs2_rbm_find()
1769 offset = gfs2_bitfit(buffer, bi->bi_bytes, rbm->offset, state); in gfs2_rbm_find()
1771 if (state == GFS2_BLKST_FREE && rbm->offset == 0) in gfs2_rbm_find()
1775 rbm->offset = offset; in gfs2_rbm_find()
1779 ret = gfs2_reservation_check_and_update(rbm, ip, in gfs2_rbm_find()
1787 rbm->bii = 0; in gfs2_rbm_find()
1788 rbm->offset = 0; in gfs2_rbm_find()
1794 rbm->offset = 0; in gfs2_rbm_find()
1795 rbm->bii++; in gfs2_rbm_find()
1796 if (rbm->bii == rbm->rgd->rd_length) in gfs2_rbm_find()
1797 rbm->bii = 0; in gfs2_rbm_find()
1799 if (rbm->bii == 0) { in gfs2_rbm_find()
1808 if (wrapped && rbm->bii > last_bii) in gfs2_rbm_find()
1818 if (wrapped && (scan_from_start || rbm->bii > last_bii) && in gfs2_rbm_find()
1819 *minext < rbm->rgd->rd_extfail_pt) in gfs2_rbm_find()
1820 rbm->rgd->rd_extfail_pt = *minext; in gfs2_rbm_find()
1825 *rbm = maxext.rbm; in gfs2_rbm_find()
1851 struct gfs2_rbm rbm = { .rgd = rgd, .bii = 0, .offset = 0 }; in try_rgrp_unlink() local
1855 error = gfs2_rbm_find(&rbm, GFS2_BLKST_UNLINKED, NULL, NULL, in try_rgrp_unlink()
1863 block = gfs2_rbm_to_block(&rbm); in try_rgrp_unlink()
1864 if (gfs2_rbm_from_block(&rbm, block + 1)) in try_rgrp_unlink()
2196 static void gfs2_alloc_extent(const struct gfs2_rbm *rbm, bool dinode, in gfs2_alloc_extent() argument
2199 struct gfs2_rbm pos = { .rgd = rbm->rgd, }; in gfs2_alloc_extent()
2205 block = gfs2_rbm_to_block(rbm); in gfs2_alloc_extent()
2206 gfs2_trans_add_meta(rbm->rgd->rd_gl, rbm_bi(rbm)->bi_bh); in gfs2_alloc_extent()
2207 gfs2_setbit(rbm, true, dinode ? GFS2_BLKST_DINODE : GFS2_BLKST_USED); in gfs2_alloc_extent()
2232 struct gfs2_rbm rbm; in rgblk_free() local
2235 rbm.rgd = rgd; in rgblk_free()
2236 if (WARN_ON_ONCE(gfs2_rbm_from_block(&rbm, bstart))) in rgblk_free()
2239 bi = rbm_bi(&rbm); in rgblk_free()
2248 gfs2_trans_add_meta(rbm.rgd->rd_gl, bi->bi_bh); in rgblk_free()
2251 gfs2_setbit(&rbm, false, new_state); in rgblk_free()
2252 gfs2_rbm_incr(&rbm); in rgblk_free()
2319 const struct gfs2_rbm *rbm, unsigned len) in gfs2_adjust_reservation() argument
2322 struct gfs2_rgrpd *rgd = rbm->rgd; in gfs2_adjust_reservation()
2329 if (gfs2_rbm_eq(&rs->rs_rbm, rbm)) { in gfs2_adjust_reservation()
2330 block = gfs2_rbm_to_block(rbm); in gfs2_adjust_reservation()
2359 static void gfs2_set_alloc_start(struct gfs2_rbm *rbm, in gfs2_set_alloc_start() argument
2365 *rbm = ip->i_res.rs_rbm; in gfs2_set_alloc_start()
2369 if (!dinode && rgrp_contains_block(rbm->rgd, ip->i_goal)) in gfs2_set_alloc_start()
2372 goal = rbm->rgd->rd_last_alloc + rbm->rgd->rd_data0; in gfs2_set_alloc_start()
2374 if (WARN_ON_ONCE(gfs2_rbm_from_block(rbm, goal))) { in gfs2_set_alloc_start()
2375 rbm->bii = 0; in gfs2_set_alloc_start()
2376 rbm->offset = 0; in gfs2_set_alloc_start()
2396 struct gfs2_rbm rbm = { .rgd = ip->i_res.rs_rbm.rgd, }; in gfs2_alloc_blocks() local
2401 gfs2_set_alloc_start(&rbm, ip, dinode); in gfs2_alloc_blocks()
2402 error = gfs2_rbm_find(&rbm, GFS2_BLKST_FREE, NULL, ip, false); in gfs2_alloc_blocks()
2405 gfs2_set_alloc_start(&rbm, ip, dinode); in gfs2_alloc_blocks()
2406 error = gfs2_rbm_find(&rbm, GFS2_BLKST_FREE, NULL, NULL, false); in gfs2_alloc_blocks()
2413 test_bit(GBF_FULL, &rbm.rgd->rd_bits->bi_flags), in gfs2_alloc_blocks()
2414 rbm.rgd->rd_extfail_pt); in gfs2_alloc_blocks()
2418 gfs2_alloc_extent(&rbm, dinode, nblocks); in gfs2_alloc_blocks()
2419 block = gfs2_rbm_to_block(&rbm); in gfs2_alloc_blocks()
2420 rbm.rgd->rd_last_alloc = block - rbm.rgd->rd_data0; in gfs2_alloc_blocks()
2422 gfs2_adjust_reservation(ip, &rbm, *nblocks); in gfs2_alloc_blocks()
2439 if (rbm.rgd->rd_free < *nblocks) { in gfs2_alloc_blocks()
2444 rbm.rgd->rd_free -= *nblocks; in gfs2_alloc_blocks()
2446 rbm.rgd->rd_dinodes++; in gfs2_alloc_blocks()
2447 *generation = rbm.rgd->rd_igeneration++; in gfs2_alloc_blocks()
2449 *generation = rbm.rgd->rd_igeneration++; in gfs2_alloc_blocks()
2452 gfs2_trans_add_meta(rbm.rgd->rd_gl, rbm.rgd->rd_bits[0].bi_bh); in gfs2_alloc_blocks()
2453 gfs2_rgrp_out(rbm.rgd, rbm.rgd->rd_bits[0].bi_bh->b_data); in gfs2_alloc_blocks()
2461 rbm.rgd->rd_free_clone -= *nblocks; in gfs2_alloc_blocks()
2462 trace_gfs2_block_alloc(ip, rbm.rgd, block, *nblocks, in gfs2_alloc_blocks()
2468 gfs2_rgrp_error(rbm.rgd); in gfs2_alloc_blocks()
2570 struct gfs2_rbm rbm; in gfs2_check_blk_type() local
2581 rbm.rgd = rgd; in gfs2_check_blk_type()
2582 error = gfs2_rbm_from_block(&rbm, no_addr); in gfs2_check_blk_type()
2584 if (gfs2_testbit(&rbm, false) != type) in gfs2_check_blk_type()