[PATCH] erofs: add "noinline_data" extended option
胡玮文
sehuww at mail.scut.edu.cn
Mon Jul 5 02:18:38 AEST 2021
Should the commit message starts with “erofs-utils:” instead of “erofs:”?
> 在 2021年7月4日,21:41,Gao Xiang <hsiangkao at linux.alibaba.com> 写道:
>
> In order to add preliminary DAX feature support.
>
> Signed-off-by: Gao Xiang <hsiangkao at linux.alibaba.com>
> ---
> include/erofs/config.h | 1 +
> lib/inode.c | 5 +++++
> mkfs/main.c | 6 ++++++
> 3 files changed, 12 insertions(+)
>
> diff --git a/include/erofs/config.h b/include/erofs/config.h
> index 67e7a0fed24c..8124f3b36baf 100644
> --- a/include/erofs/config.h
> +++ b/include/erofs/config.h
> @@ -44,6 +44,7 @@ struct erofs_configure {
> bool c_random_pclusterblks;
> #endif
> char c_timeinherit;
> + bool c_noinline_data;
>
> #ifdef HAVE_LIBSELINUX
> struct selabel_handle *sehnd;
> diff --git a/lib/inode.c b/lib/inode.c
> index 97f0cf763baf..38906370f533 100644
> --- a/lib/inode.c
> +++ b/lib/inode.c
> @@ -562,6 +562,11 @@ static int erofs_prepare_inode_buffer(struct erofs_inode *inode)
> if (is_inode_layout_compression(inode))
> goto noinline;
>
> + if (cfg.c_noinline_data && S_ISREG(inode->i_mode)) {
> + inode->datalayout = EROFS_INODE_FLAT_PLAIN;
> + goto noinline;
> + }
> +
> /*
> * if the file size is block-aligned for uncompressed files,
> * should use EROFS_INODE_FLAT_PLAIN data mapping mode.
> diff --git a/mkfs/main.c b/mkfs/main.c
> index 28539da5ea5f..10fe14d7a722 100644
> --- a/mkfs/main.c
> +++ b/mkfs/main.c
> @@ -161,6 +161,12 @@ static int parse_extended_opts(const char *opts)
> return -EINVAL;
> erofs_sb_clear_sb_chksum();
> }
> +
> + if (MATCH_EXTENTED_OPT("noinline_data", token, keylen)) {
> + if (vallen)
> + return -EINVAL;
> + cfg.c_noinline_data = true;
> + }
> }
> return 0;
> }
> --
> 2.24.4
More information about the Linux-erofs
mailing list