From: Chao Yu <chao@kernel.org>
To: Chao Liu <chaoliu719@gmail.com>, Jaegeuk Kim <jaegeuk@kernel.org>
Cc: Chao Liu <liuchao@coolpad.com>,
linux-kernel@vger.kernel.org, Wayne Zhang <zhangwen@coolpad.com>,
Yue Hu <huyue2@coolpad.com>,
linux-f2fs-devel@lists.sourceforge.net
Subject: Re: [f2fs-dev] [PATCH] f2fs: fix to remove F2FS_COMPR_FL and tag F2FS_NOCOMP_FL at the same time
Date: Wed, 22 Jun 2022 21:42:13 +0800 [thread overview]
Message-ID: <0771b00b-e781-cd29-896a-4b6ebc948c2e@kernel.org> (raw)
In-Reply-To: <20220621064833.1079383-1-chaoliu719@gmail.com>
On 2022/6/21 14:48, Chao Liu wrote:
> From: Chao Liu <liuchao@coolpad.com>
>
> If the inode has the compress flag, it will fail to use
> 'chattr -c +m' to remove its compress flag and tag no compress flag.
> However, the same command will be successful when executed again,
> as shown below:
>
> $ touch foo.txt
> $ chattr +c foo.txt
> $ chattr -c +m foo.txt
> chattr: Invalid argument while setting flags on foo.txt
> $ chattr -c +m foo.txt
> $ f2fs_io getflags foo.txt
> get a flag on foo.txt ret=0, flags=nocompression,inline_data
>
> Fix this by removing some checks in f2fs_setflags_common()
> that do not affect the original logic. I go through all the
> possible scenarios, and the results are as follows. Bold is
> the only thing that has changed.
>
> +---------------+-----------+-----------+----------+
> | | file flags |
> + command +-----------+-----------+----------+
> | | no flag | compr | nocompr |
> +---------------+-----------+-----------+----------+
> | chattr +c | compr | compr | -EINVAL |
> | chattr -c | no flag | no flag | nocompr |
> | chattr +m | nocompr | -EINVAL | nocompr |
> | chattr -m | no flag | compr | no flag |
> | chattr +c +m | -EINVAL | -EINVAL | -EINVAL |
> | chattr +c -m | compr | compr | compr |
> | chattr -c +m | nocompr | *nocompr* | nocompr |
> | chattr -c -m | no flag | no flag | no flag |
> +---------------+-----------+-----------+----------+
>
> Fixes: 4c8ff7095bef ("f2fs: support data compression")
> Signed-off-by: Chao Liu <liuchao@coolpad.com>
> ---
>
> This patch depends on the the patch
> "f2fs: allow compression of files without blocks" sent earlier this day.
>
> fs/f2fs/file.c | 9 +--------
> 1 file changed, 1 insertion(+), 8 deletions(-)
>
> diff --git a/fs/f2fs/file.c b/fs/f2fs/file.c
> index daaa0dfd2d2e..0c3ae5993b7a 100644
> --- a/fs/f2fs/file.c
> +++ b/fs/f2fs/file.c
> @@ -1873,10 +1873,7 @@ static int f2fs_setflags_common(struct inode *inode, u32 iflags, u32 mask)
> if (masked_flags & F2FS_COMPR_FL) {
> if (!f2fs_disable_compressed_file(inode))
> return -EINVAL;
> - }
> - if (iflags & F2FS_NOCOMP_FL)
> - return -EINVAL;
> - if (iflags & F2FS_COMPR_FL) {
> + } else {
> if (!f2fs_may_compress(inode))
> return -EINVAL;
> if (S_ISREG(inode->i_mode) && F2FS_HAS_BLOCKS(inode))
> @@ -1885,10 +1882,6 @@ static int f2fs_setflags_common(struct inode *inode, u32 iflags, u32 mask)
> set_compress_context(inode);
> }
> }
> - if ((iflags ^ masked_flags) & F2FS_NOCOMP_FL) {
> - if (masked_flags & F2FS_COMPR_FL)
> - return -EINVAL;
> - }
Without above check condition, can we return -EINVAL for the case:
chattr +c on file w/ nocompr flag
| | no flag | compr | nocompr |
+---------------+-----------+-----------+----------+
| chattr +c | compr | compr | *-EINVAL* |
Thanks,
>
> fi->i_flags = iflags | (fi->i_flags & ~mask);
> f2fs_bug_on(F2FS_I_SB(inode), (fi->i_flags & F2FS_COMPR_FL) &&
> --
> 2.36.1
_______________________________________________
Linux-f2fs-devel mailing list
Linux-f2fs-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/linux-f2fs-devel
WARNING: multiple messages have this Message-ID (diff)
From: Chao Yu <chao@kernel.org>
To: Chao Liu <chaoliu719@gmail.com>, Jaegeuk Kim <jaegeuk@kernel.org>
Cc: linux-f2fs-devel@lists.sourceforge.net,
linux-kernel@vger.kernel.org, Yue Hu <huyue2@coolpad.com>,
Wayne Zhang <zhangwen@coolpad.com>,
Xiaoyu Qi <qxy65535@gmail.com>, Chao Liu <liuchao@coolpad.com>
Subject: Re: [PATCH] f2fs: fix to remove F2FS_COMPR_FL and tag F2FS_NOCOMP_FL at the same time
Date: Wed, 22 Jun 2022 21:42:13 +0800 [thread overview]
Message-ID: <0771b00b-e781-cd29-896a-4b6ebc948c2e@kernel.org> (raw)
In-Reply-To: <20220621064833.1079383-1-chaoliu719@gmail.com>
On 2022/6/21 14:48, Chao Liu wrote:
> From: Chao Liu <liuchao@coolpad.com>
>
> If the inode has the compress flag, it will fail to use
> 'chattr -c +m' to remove its compress flag and tag no compress flag.
> However, the same command will be successful when executed again,
> as shown below:
>
> $ touch foo.txt
> $ chattr +c foo.txt
> $ chattr -c +m foo.txt
> chattr: Invalid argument while setting flags on foo.txt
> $ chattr -c +m foo.txt
> $ f2fs_io getflags foo.txt
> get a flag on foo.txt ret=0, flags=nocompression,inline_data
>
> Fix this by removing some checks in f2fs_setflags_common()
> that do not affect the original logic. I go through all the
> possible scenarios, and the results are as follows. Bold is
> the only thing that has changed.
>
> +---------------+-----------+-----------+----------+
> | | file flags |
> + command +-----------+-----------+----------+
> | | no flag | compr | nocompr |
> +---------------+-----------+-----------+----------+
> | chattr +c | compr | compr | -EINVAL |
> | chattr -c | no flag | no flag | nocompr |
> | chattr +m | nocompr | -EINVAL | nocompr |
> | chattr -m | no flag | compr | no flag |
> | chattr +c +m | -EINVAL | -EINVAL | -EINVAL |
> | chattr +c -m | compr | compr | compr |
> | chattr -c +m | nocompr | *nocompr* | nocompr |
> | chattr -c -m | no flag | no flag | no flag |
> +---------------+-----------+-----------+----------+
>
> Fixes: 4c8ff7095bef ("f2fs: support data compression")
> Signed-off-by: Chao Liu <liuchao@coolpad.com>
> ---
>
> This patch depends on the the patch
> "f2fs: allow compression of files without blocks" sent earlier this day.
>
> fs/f2fs/file.c | 9 +--------
> 1 file changed, 1 insertion(+), 8 deletions(-)
>
> diff --git a/fs/f2fs/file.c b/fs/f2fs/file.c
> index daaa0dfd2d2e..0c3ae5993b7a 100644
> --- a/fs/f2fs/file.c
> +++ b/fs/f2fs/file.c
> @@ -1873,10 +1873,7 @@ static int f2fs_setflags_common(struct inode *inode, u32 iflags, u32 mask)
> if (masked_flags & F2FS_COMPR_FL) {
> if (!f2fs_disable_compressed_file(inode))
> return -EINVAL;
> - }
> - if (iflags & F2FS_NOCOMP_FL)
> - return -EINVAL;
> - if (iflags & F2FS_COMPR_FL) {
> + } else {
> if (!f2fs_may_compress(inode))
> return -EINVAL;
> if (S_ISREG(inode->i_mode) && F2FS_HAS_BLOCKS(inode))
> @@ -1885,10 +1882,6 @@ static int f2fs_setflags_common(struct inode *inode, u32 iflags, u32 mask)
> set_compress_context(inode);
> }
> }
> - if ((iflags ^ masked_flags) & F2FS_NOCOMP_FL) {
> - if (masked_flags & F2FS_COMPR_FL)
> - return -EINVAL;
> - }
Without above check condition, can we return -EINVAL for the case:
chattr +c on file w/ nocompr flag
| | no flag | compr | nocompr |
+---------------+-----------+-----------+----------+
| chattr +c | compr | compr | *-EINVAL* |
Thanks,
>
> fi->i_flags = iflags | (fi->i_flags & ~mask);
> f2fs_bug_on(F2FS_I_SB(inode), (fi->i_flags & F2FS_COMPR_FL) &&
> --
> 2.36.1
next prev parent reply other threads:[~2022-06-22 13:42 UTC|newest]
Thread overview: 10+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-06-21 6:48 [f2fs-dev] [PATCH] f2fs: fix to remove F2FS_COMPR_FL and tag F2FS_NOCOMP_FL at the same time Chao Liu
2022-06-21 6:48 ` Chao Liu
2022-06-22 13:42 ` Chao Yu [this message]
2022-06-22 13:42 ` Chao Yu
2022-06-23 4:44 ` [f2fs-dev] " Chao Liu
2022-06-23 4:44 ` Chao Liu
2022-07-06 2:57 ` [f2fs-dev] " Chao Liu
2022-07-06 2:57 ` Chao Liu
2022-07-06 14:21 ` [f2fs-dev] " Chao Yu
2022-07-06 14:21 ` Chao Yu
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=0771b00b-e781-cd29-896a-4b6ebc948c2e@kernel.org \
--to=chao@kernel.org \
--cc=chaoliu719@gmail.com \
--cc=huyue2@coolpad.com \
--cc=jaegeuk@kernel.org \
--cc=linux-f2fs-devel@lists.sourceforge.net \
--cc=linux-kernel@vger.kernel.org \
--cc=liuchao@coolpad.com \
--cc=zhangwen@coolpad.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.