diff options
author | Daniel Walter <[email protected]> | 2017-06-19 09:27:58 +0200 |
---|---|---|
committer | Theodore Ts'o <[email protected]> | 2017-06-23 20:05:07 -0400 |
commit | b7e7cf7a66a27e62c5f873a0068cee34094bf5d7 (patch) | |
tree | e86d2bbc849e8a854e7f3a22846a08bef49423b9 /lib/netdev-notifier-error-inject.c | |
parent | 27e47a6342e21b005a15a1f0afea0b6f179e0a71 (diff) |
fscrypt: add support for AES-128-CBC
fscrypt provides facilities to use different encryption algorithms which
are selectable by userspace when setting the encryption policy. Currently,
only AES-256-XTS for file contents and AES-256-CBC-CTS for file names are
implemented. This is a clear case of kernel offers the mechanism and
userspace selects a policy. Similar to what dm-crypt and ecryptfs have.
This patch adds support for using AES-128-CBC for file contents and
AES-128-CBC-CTS for file name encryption. To mitigate watermarking
attacks, IVs are generated using the ESSIV algorithm. While AES-CBC is
actually slightly less secure than AES-XTS from a security point of view,
there is more widespread hardware support. Using AES-CBC gives us the
acceptable performance while still providing a moderate level of security
for persistent storage.
Especially low-powered embedded devices with crypto accelerators such as
CAAM or CESA often only support AES-CBC. Since using AES-CBC over AES-XTS
is basically thought of a last resort, we use AES-128-CBC over AES-256-CBC
since it has less encryption rounds and yields noticeable better
performance starting from a file size of just a few kB.
Signed-off-by: Daniel Walter <[email protected]>
[[email protected]: addressed review comments]
Signed-off-by: David Gstir <[email protected]>
Reviewed-by: Eric Biggers <[email protected]>
Signed-off-by: Theodore Ts'o <[email protected]>
Diffstat (limited to 'lib/netdev-notifier-error-inject.c')
0 files changed, 0 insertions, 0 deletions