diff options
author | Qu Wenruo <wqu@suse.com> | 2022-08-15 19:45:19 +0800 |
---|---|---|
committer | Tom Rini <trini@konsulko.com> | 2022-08-26 10:11:24 -0400 |
commit | 5347384a078270d5ec179e2beb9472c0647589cb (patch) | |
tree | 9bfc392d13c7bb925780c5cf4c326cf970b14662 | |
parent | 19a31333591c991fa33740989c3a22c22885db80 (diff) | |
download | u-boot-WIP/2022-08-26-fs-add-generic-unaligned-offset-handling.zip u-boot-WIP/2022-08-26-fs-add-generic-unaligned-offset-handling.tar.gz u-boot-WIP/2022-08-26-fs-add-generic-unaligned-offset-handling.tar.bz2 |
fs: erofs: add unaligned read range handlingWIP/2022-08-26-fs-add-generic-unaligned-offset-handling
I'm not an expert on erofs, but my quick glance didn't expose any
special handling on unaligned range, thus I think the U-boot erofs
driver doesn't really support unaligned read range.
This patch will add erofs_get_blocksize() so erofs can benefit from the
generic unaligned read support.
Cc: Huang Jianan <jnhuang95@gmail.com>
Cc: linux-erofs@lists.ozlabs.org
Signed-off-by: Qu Wenruo <wqu@suse.com>
-rw-r--r-- | fs/erofs/internal.h | 1 | ||||
-rw-r--r-- | fs/erofs/super.c | 6 | ||||
-rw-r--r-- | fs/fs.c | 2 | ||||
-rw-r--r-- | include/erofs.h | 1 |
4 files changed, 9 insertions, 1 deletions
diff --git a/fs/erofs/internal.h b/fs/erofs/internal.h index 4af7c91..d368a64 100644 --- a/fs/erofs/internal.h +++ b/fs/erofs/internal.h @@ -83,6 +83,7 @@ struct erofs_sb_info { u16 available_compr_algs; u16 lz4_max_distance; u32 checksum; + u32 blocksize; u16 extra_devices; union { u16 devt_slotoff; /* used for mkfs */ diff --git a/fs/erofs/super.c b/fs/erofs/super.c index 8277d9b..82625da 100644 --- a/fs/erofs/super.c +++ b/fs/erofs/super.c @@ -99,7 +99,13 @@ int erofs_read_superblock(void) sbi.build_time = le64_to_cpu(dsb->build_time); sbi.build_time_nsec = le32_to_cpu(dsb->build_time_nsec); + sbi.blocksize = 1 << blkszbits; memcpy(&sbi.uuid, dsb->uuid, sizeof(dsb->uuid)); return erofs_init_devices(&sbi, dsb); } + +int erofs_get_blocksize(const char *filename) +{ + return sbi.blocksize; +} @@ -376,7 +376,7 @@ static struct fstype_info fstypes[] = { .readdir = erofs_readdir, .ls = fs_ls_generic, .read = erofs_read, - .get_blocksize = fs_get_blocksize_unsupported, + .get_blocksize = erofs_get_blocksize, .size = erofs_size, .close = erofs_close, .closedir = erofs_closedir, diff --git a/include/erofs.h b/include/erofs.h index 1fbe82b..18bd680 100644 --- a/include/erofs.h +++ b/include/erofs.h @@ -10,6 +10,7 @@ int erofs_probe(struct blk_desc *fs_dev_desc, struct disk_partition *fs_partition); int erofs_read(const char *filename, void *buf, loff_t offset, loff_t len, loff_t *actread); +int erofs_get_blocksize(const char *filename); int erofs_size(const char *filename, loff_t *size); int erofs_exists(const char *filename); void erofs_close(void); |