[PATCH v2 2/6] exfat: use readahead helper in exfat_allocate_bitmap

From: Chi Zhiling

Date: Mon Mar 02 2026 - 22:19:52 EST


From: Chi Zhiling <chizhiling@xxxxxxxxxx>

Use the newly added exfat_blk_readahead() helper in exfat_allocate_bitmap()
to simplify the code. This eliminates the duplicate inline readahead logic
and uses the unified readahead interface.

Signed-off-by: Chi Zhiling <chizhiling@xxxxxxxxxx>
---
fs/exfat/balloc.c | 18 ++++++------------
1 file changed, 6 insertions(+), 12 deletions(-)

diff --git a/fs/exfat/balloc.c b/fs/exfat/balloc.c
index 3a32f49f9dbd..625f2f14d4fe 100644
--- a/fs/exfat/balloc.c
+++ b/fs/exfat/balloc.c
@@ -74,11 +74,10 @@ static int exfat_allocate_bitmap(struct super_block *sb,
struct exfat_dentry *ep)
{
struct exfat_sb_info *sbi = EXFAT_SB(sb);
- struct blk_plug plug;
long long map_size;
unsigned int i, j, need_map_size;
- sector_t sector;
- unsigned int max_ra_count;
+ sector_t sector, end, ra;
+ blkcnt_t ra_cnt = 0;

sbi->map_clu = le32_to_cpu(ep->dentry.bitmap.start_clu);
map_size = le64_to_cpu(ep->dentry.bitmap.size);
@@ -100,17 +99,12 @@ static int exfat_allocate_bitmap(struct super_block *sb,
if (!sbi->vol_amap)
return -ENOMEM;

- sector = exfat_cluster_to_sector(sbi, sbi->map_clu);
- max_ra_count = min(sb->s_bdi->ra_pages, sb->s_bdi->io_pages) <<
- (PAGE_SHIFT - sb->s_blocksize_bits);
+ sector = ra = exfat_cluster_to_sector(sbi, sbi->map_clu);
+ end = sector + sbi->map_sectors - 1;
+
for (i = 0; i < sbi->map_sectors; i++) {
/* Trigger the next readahead in advance. */
- if (max_ra_count && 0 == (i % max_ra_count)) {
- blk_start_plug(&plug);
- for (j = i; j < min(max_ra_count, sbi->map_sectors - i) + i; j++)
- sb_breadahead(sb, sector + j);
- blk_finish_plug(&plug);
- }
+ exfat_blk_readahead(sb, sector + i, &ra, &ra_cnt, end);

sbi->vol_amap[i] = sb_bread(sb, sector + i);
if (!sbi->vol_amap[i])
--
2.43.0