From: Eric Biggers <ebiggers@kernel.org>
To: LiaoYuanhong-vivo <liaoyuanhong@vivo.com>
Cc: tytso@mit.edu, jaegeuk@kernel.org, linux-fscrypt@vger.kernel.org,
linux-kernel@vger.kernel.org, linux-ext4@vger.kernel.org,
linux-f2fs-devel@lists.sourceforge.net
Subject: Re: [PATCH] fscrypt: add software key support for filesystem-managed data
Date: Wed, 22 Apr 2026 16:27:47 -0700 [thread overview]
Message-ID: <20260422232747.GD2226@sol> (raw)
In-Reply-To: <20260421075717.170840-1-liaoyuanhong@vivo.com>
On Tue, Apr 21, 2026 at 03:57:17PM +0800, LiaoYuanhong-vivo wrote:
> Some filesystems store small file contents in filesystem-managed regions
> rather than in regular data blocks submitted through bios. One example is
> F2FS inline_data, where the payload is stored inside the inode node block.
> Such regions still need to follow the inode's fscrypt contents encryption
> semantics, but they cannot rely on blk-crypto because they are not
> submitted as standalone file data bios.
>
> As a result, when blk-crypto is enabled, mechanisms such as inline_data are
> typically disabled outright. However, it is desirable to re-enable such
> space-saving features while still preserving the required encryption
> semantics.
>
> To support this, add fscrypt_crypt_fs_layer_page_inplace(), a helper that
> encrypts or decrypts a caller-provided page region in place using
> filesystem-layer software crypto and the inode's contents encryption
> policy.
>
> This support is limited to v2 encryption policies. v1 policies do not
> provide the key setup model used here, so this path returns -EOPNOTSUPP for
> v1. Hardware-wrapped keys are not supported either, since deriving a
> software skcipher key requires software-accessible key material, which
> conflicts with the hardware-wrapped key model.
>
> When the inode's normal contents path uses blk-crypto, fscrypt may not have
> a software skcipher key prepared for the inode contents key. Add an
> optional filesystem-layer prepared key to fscrypt_inode_info. This key is
> derived using the same v2 contents-encryption KDF as the normal contents
> key, but is prepared as a software skcipher key and is used only by the new
> filesystem-layer helper.
>
> Signed-off-by: LiaoYuanhong-vivo <liaoyuanhong@vivo.com>
I don't have time for a super detailed review at the moment, but here
are my initial thoughts:
- This needs to be sent along with the code that actually uses it in
ext4 and f2fs. Please also Cc the mailing lists for those
filesystems.
- This is going to require an "incompat" filesystem feature flag. After
all, once a filesystem contains files that use this scheme, older
kernels won't understand it.
- UBIFS and CephFS already use fs/crypto/ but don't support blk-crypto
(inline encryption). This new code feels duplicative of that. It
should be possible to reuse the existing code instead. That would
include, for example, reusing the existing en/decryption functions and
the existing struct ci_enc_key field. This would keep the changes
limited mainly to how the key is being set up.
- Supporting all the different IV generation methods doesn't make sense
when a per-file key is always used.
- The fact that this is incompatible with hardware-wrapped keys greatly
limits the usefulness of this. (Note that technically, it could be
supported in combination with them anyway. But the security models
would be inconsistent, which I assume is what you have in mind.)
Hope this is helpful,
- Eric
next parent reply other threads:[~2026-04-22 23:29 UTC|newest]
Thread overview: 2+ messages / expand[flat|nested] mbox.gz Atom feed top
[not found] <20260421075717.170840-1-liaoyuanhong@vivo.com>
2026-04-22 23:27 ` Eric Biggers [this message]
2026-04-23 10:41 ` [PATCH] fscrypt: add software key support for filesystem-managed data Liao Yuanhong
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=20260422232747.GD2226@sol \
--to=ebiggers@kernel.org \
--cc=jaegeuk@kernel.org \
--cc=liaoyuanhong@vivo.com \
--cc=linux-ext4@vger.kernel.org \
--cc=linux-f2fs-devel@lists.sourceforge.net \
--cc=linux-fscrypt@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=tytso@mit.edu \
/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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox