bcachefs: bs > ps support
authorKent Overstreet <kent.overstreet@linux.dev>
Thu, 20 Feb 2025 20:03:38 +0000 (15:03 -0500)
committerKent Overstreet <kent.overstreet@linux.dev>
Fri, 14 Mar 2025 23:45:57 +0000 (19:45 -0400)
bcachefs removed most PAGE_SIZE references long ago, so this is easy;
only readpage_bio_extend() has to be tweaked to respect the minimum
order.

Signed-off-by: Kent Overstreet <kent.overstreet@linux.dev>
fs/bcachefs/fs-io-buffered.c
fs/bcachefs/fs.c
fs/bcachefs/super-io.c

index ab1d5db..d9a3607 100644 (file)
@@ -110,11 +110,21 @@ static int readpage_bio_extend(struct btree_trans *trans,
                        if (!get_more)
                                break;
 
+                       unsigned sectors_remaining = sectors_this_extent - bio_sectors(bio);
+
+                       if (sectors_remaining < PAGE_SECTORS << mapping_min_folio_order(iter->mapping))
+                               break;
+
+                       unsigned order = ilog2(rounddown_pow_of_two(sectors_remaining) / PAGE_SECTORS);
+
+                       /* ensure proper alignment */
+                       order = min(order, __ffs(folio_offset|BIT(31)));
+
                        folio = xa_load(&iter->mapping->i_pages, folio_offset);
                        if (folio && !xa_is_value(folio))
                                break;
 
-                       folio = filemap_alloc_folio(readahead_gfp_mask(iter->mapping), 0);
+                       folio = filemap_alloc_folio(readahead_gfp_mask(iter->mapping), order);
                        if (!folio)
                                break;
 
index 90ade8f..5d910f1 100644 (file)
@@ -1802,7 +1802,8 @@ static void bch2_vfs_inode_init(struct btree_trans *trans,
                break;
        }
 
-       mapping_set_large_folios(inode->v.i_mapping);
+       mapping_set_folio_min_order(inode->v.i_mapping,
+                                   get_order(trans->c->opts.block_size));
 }
 
 static void bch2_free_inode(struct inode *vinode)
index a81a7b6..5bd7bb9 100644 (file)
@@ -372,7 +372,6 @@ static int bch2_sb_validate(struct bch_sb_handle *disk_sb,
        struct bch_sb *sb = disk_sb->sb;
        struct bch_sb_field_members_v1 *mi;
        enum bch_opt_id opt_id;
-       u16 block_size;
        int ret;
 
        ret = bch2_sb_compatible(sb, out);
@@ -391,14 +390,6 @@ static int bch2_sb_validate(struct bch_sb_handle *disk_sb,
                return -BCH_ERR_invalid_sb_features;
        }
 
-       block_size = le16_to_cpu(sb->block_size);
-
-       if (block_size > PAGE_SECTORS) {
-               prt_printf(out, "Block size too big (got %u, max %u)",
-                      block_size, PAGE_SECTORS);
-               return -BCH_ERR_invalid_sb_block_size;
-       }
-
        if (bch2_is_zero(sb->user_uuid.b, sizeof(sb->user_uuid))) {
                prt_printf(out, "Bad user UUID (got zeroes)");
                return -BCH_ERR_invalid_sb_uuid;