struct folio *folio, u64 start, u32 len)
{
struct btrfs_folio_state *bfs = folio_get_private(folio);
- const int start_bit = subpage_calc_start_bit(fs_info, folio, locked, start, len);
const int nbits = (len >> fs_info->sectorsize_bits);
unsigned long flags;
- unsigned int cleared = 0;
- int bit = start_bit;
bool last;
btrfs_subpage_assert(fs_info, folio, start, len);
spin_unlock_irqrestore(&bfs->lock, flags);
return true;
}
-
- for_each_set_bit_from(bit, bfs->bitmaps, start_bit + nbits) {
- clear_bit(bit, bfs->bitmaps);
- cleared++;
- }
- ASSERT(atomic_read(&bfs->nr_locked) >= cleared,
- "atomic_read(&bfs->nr_locked)=%d cleared=%d",
- atomic_read(&bfs->nr_locked), cleared);
- last = atomic_sub_and_test(cleared, &bfs->nr_locked);
+ ASSERT(atomic_read(&bfs->nr_locked) >= nbits,
+ "atomic_read(&bfs->nr_locked)=%d nbits=%d",
+ atomic_read(&bfs->nr_locked), nbits);
+ last = atomic_sub_and_test(nbits, &bfs->nr_locked);
spin_unlock_irqrestore(&bfs->lock, flags);
return last;
}
{
struct btrfs_folio_state *bfs = folio_get_private(folio);
const unsigned int blocks_per_folio = btrfs_blocks_per_folio(fs_info, folio);
- const int start_bit = blocks_per_folio * btrfs_bitmap_nr_locked;
+ const unsigned int nbits = bitmap_weight(&bitmap, blocks_per_folio);
unsigned long flags;
bool last = false;
- int cleared = 0;
- int bit;
if (!btrfs_is_subpage(fs_info, folio)) {
folio_unlock(folio);
}
spin_lock_irqsave(&bfs->lock, flags);
- for_each_set_bit(bit, &bitmap, blocks_per_folio) {
- if (test_and_clear_bit(bit + start_bit, bfs->bitmaps))
- cleared++;
- }
- ASSERT(atomic_read(&bfs->nr_locked) >= cleared,
- "atomic_read(&bfs->nr_locked)=%d cleared=%d",
- atomic_read(&bfs->nr_locked), cleared);
- last = atomic_sub_and_test(cleared, &bfs->nr_locked);
+ ASSERT(atomic_read(&bfs->nr_locked) >= nbits,
+ "atomic_read(&bfs->nr_locked)=%d nbits=%d",
+ atomic_read(&bfs->nr_locked), nbits);
+ last = atomic_sub_and_test(nbits, &bfs->nr_locked);
spin_unlock_irqrestore(&bfs->lock, flags);
if (last)
folio_unlock(folio);
{
struct btrfs_folio_state *bfs;
unsigned long flags;
- unsigned int start_bit;
unsigned int nbits;
int ret;
return;
bfs = folio_get_private(folio);
- start_bit = subpage_calc_start_bit(fs_info, folio, locked, start, len);
nbits = len >> fs_info->sectorsize_bits;
spin_lock_irqsave(&bfs->lock, flags);
- /* Target range should not yet be locked. */
- if (unlikely(!bitmap_test_range_all_zero(bfs->bitmaps, start_bit, nbits))) {
- SUBPAGE_DUMP_BITMAP(fs_info, folio, locked, start, len);
- ASSERT(bitmap_test_range_all_zero(bfs->bitmaps, start_bit, nbits));
- }
- bitmap_set(bfs->bitmaps, start_bit, nbits);
ret = atomic_add_return(nbits, &bfs->nr_locked);
ASSERT(ret <= btrfs_blocks_per_folio(fs_info, folio));
spin_unlock_irqrestore(&bfs->lock, flags);
unsigned long dirty_bitmap;
unsigned long writeback_bitmap;
unsigned long ordered_bitmap;
- unsigned long locked_bitmap;
unsigned long flags;
ASSERT(folio_test_private(folio) && folio_get_private(folio));
GET_SUBPAGE_BITMAP(fs_info, folio, dirty, &dirty_bitmap);
GET_SUBPAGE_BITMAP(fs_info, folio, writeback, &writeback_bitmap);
GET_SUBPAGE_BITMAP(fs_info, folio, ordered, &ordered_bitmap);
- GET_SUBPAGE_BITMAP(fs_info, folio, locked, &locked_bitmap);
spin_unlock_irqrestore(&bfs->lock, flags);
dump_page(folio_page(folio, 0), "btrfs folio state dump");
btrfs_warn(fs_info,
-"start=%llu len=%u page=%llu, bitmaps uptodate=%*pbl dirty=%*pbl locked=%*pbl writeback=%*pbl ordered=%*pbl",
+"start=%llu len=%u page=%llu, bitmaps uptodate=%*pbl dirty=%*pbl writeback=%*pbl ordered=%*pbl",
start, len, folio_pos(folio),
blocks_per_folio, &uptodate_bitmap,
blocks_per_folio, &dirty_bitmap,
- blocks_per_folio, &locked_bitmap,
blocks_per_folio, &writeback_bitmap,
blocks_per_folio, &ordered_bitmap);
}