diff options
author | Chandan Rajendra <chandan@linux.vnet.ibm.com> | 2018-12-12 04:50:12 -0500 |
---|---|---|
committer | Theodore Ts'o <tytso@mit.edu> | 2019-01-23 23:56:43 -0500 |
commit | 643fa9612bf1a29153eee46fd398117632f93cbe (patch) | |
tree | cdab043a388581eadf969671e33c440b4c6f36b1 | |
parent | 62230e0d702f613e2f93e9c3ffd2893b36eff2db (diff) |
fscrypt: remove filesystem specific build config option
In order to have a common code base for fscrypt "post read" processing
for all filesystems which support encryption, this commit removes
filesystem specific build config option (e.g. CONFIG_EXT4_FS_ENCRYPTION)
and replaces it with a build option (i.e. CONFIG_FS_ENCRYPTION) whose
value affects all the filesystems making use of fscrypt.
Reviewed-by: Eric Biggers <ebiggers@google.com>
Signed-off-by: Chandan Rajendra <chandan@linux.vnet.ibm.com>
Signed-off-by: Eric Biggers <ebiggers@google.com>
31 files changed, 460 insertions, 535 deletions
diff --git a/Documentation/filesystems/fscrypt.rst b/Documentation/filesystems/fscrypt.rst index 3a7b60521b94..43dd989e2a3f 100644 --- a/Documentation/filesystems/fscrypt.rst +++ b/Documentation/filesystems/fscrypt.rst | |||
@@ -343,9 +343,9 @@ FS_IOC_SET_ENCRYPTION_POLICY can fail with the following errors: | |||
343 | - ``ENOTEMPTY``: the file is unencrypted and is a nonempty directory | 343 | - ``ENOTEMPTY``: the file is unencrypted and is a nonempty directory |
344 | - ``ENOTTY``: this type of filesystem does not implement encryption | 344 | - ``ENOTTY``: this type of filesystem does not implement encryption |
345 | - ``EOPNOTSUPP``: the kernel was not configured with encryption | 345 | - ``EOPNOTSUPP``: the kernel was not configured with encryption |
346 | support for this filesystem, or the filesystem superblock has not | 346 | support for filesystems, or the filesystem superblock has not |
347 | had encryption enabled on it. (For example, to use encryption on an | 347 | had encryption enabled on it. (For example, to use encryption on an |
348 | ext4 filesystem, CONFIG_EXT4_ENCRYPTION must be enabled in the | 348 | ext4 filesystem, CONFIG_FS_ENCRYPTION must be enabled in the |
349 | kernel config, and the superblock must have had the "encrypt" | 349 | kernel config, and the superblock must have had the "encrypt" |
350 | feature flag enabled using ``tune2fs -O encrypt`` or ``mkfs.ext4 -O | 350 | feature flag enabled using ``tune2fs -O encrypt`` or ``mkfs.ext4 -O |
351 | encrypt``.) | 351 | encrypt``.) |
diff --git a/arch/mips/configs/generic_defconfig b/arch/mips/configs/generic_defconfig index 7c138dab87df..5d80521e5d5a 100644 --- a/arch/mips/configs/generic_defconfig +++ b/arch/mips/configs/generic_defconfig | |||
@@ -59,7 +59,7 @@ CONFIG_HID_MONTEREY=y | |||
59 | CONFIG_EXT4_FS=y | 59 | CONFIG_EXT4_FS=y |
60 | CONFIG_EXT4_FS_POSIX_ACL=y | 60 | CONFIG_EXT4_FS_POSIX_ACL=y |
61 | CONFIG_EXT4_FS_SECURITY=y | 61 | CONFIG_EXT4_FS_SECURITY=y |
62 | CONFIG_EXT4_ENCRYPTION=y | 62 | CONFIG_FS_ENCRYPTION=y |
63 | CONFIG_FANOTIFY=y | 63 | CONFIG_FANOTIFY=y |
64 | CONFIG_FUSE_FS=y | 64 | CONFIG_FUSE_FS=y |
65 | CONFIG_CUSE=y | 65 | CONFIG_CUSE=y |
diff --git a/arch/nds32/configs/defconfig b/arch/nds32/configs/defconfig index 2546d8770785..65ce9259081b 100644 --- a/arch/nds32/configs/defconfig +++ b/arch/nds32/configs/defconfig | |||
@@ -74,7 +74,7 @@ CONFIG_GENERIC_PHY=y | |||
74 | CONFIG_EXT4_FS=y | 74 | CONFIG_EXT4_FS=y |
75 | CONFIG_EXT4_FS_POSIX_ACL=y | 75 | CONFIG_EXT4_FS_POSIX_ACL=y |
76 | CONFIG_EXT4_FS_SECURITY=y | 76 | CONFIG_EXT4_FS_SECURITY=y |
77 | CONFIG_EXT4_ENCRYPTION=y | 77 | CONFIG_FS_ENCRYPTION=y |
78 | CONFIG_FUSE_FS=y | 78 | CONFIG_FUSE_FS=y |
79 | CONFIG_MSDOS_FS=y | 79 | CONFIG_MSDOS_FS=y |
80 | CONFIG_VFAT_FS=y | 80 | CONFIG_VFAT_FS=y |
diff --git a/arch/s390/configs/debug_defconfig b/arch/s390/configs/debug_defconfig index c69cb04b7a59..9824c7bad9d4 100644 --- a/arch/s390/configs/debug_defconfig +++ b/arch/s390/configs/debug_defconfig | |||
@@ -500,7 +500,6 @@ CONFIG_S390_AP_IOMMU=y | |||
500 | CONFIG_EXT4_FS=y | 500 | CONFIG_EXT4_FS=y |
501 | CONFIG_EXT4_FS_POSIX_ACL=y | 501 | CONFIG_EXT4_FS_POSIX_ACL=y |
502 | CONFIG_EXT4_FS_SECURITY=y | 502 | CONFIG_EXT4_FS_SECURITY=y |
503 | CONFIG_EXT4_ENCRYPTION=y | ||
504 | CONFIG_JBD2_DEBUG=y | 503 | CONFIG_JBD2_DEBUG=y |
505 | CONFIG_JFS_FS=m | 504 | CONFIG_JFS_FS=m |
506 | CONFIG_JFS_POSIX_ACL=y | 505 | CONFIG_JFS_POSIX_ACL=y |
@@ -520,6 +519,7 @@ CONFIG_BTRFS_DEBUG=y | |||
520 | CONFIG_NILFS2_FS=m | 519 | CONFIG_NILFS2_FS=m |
521 | CONFIG_FS_DAX=y | 520 | CONFIG_FS_DAX=y |
522 | CONFIG_EXPORTFS_BLOCK_OPS=y | 521 | CONFIG_EXPORTFS_BLOCK_OPS=y |
522 | CONFIG_FS_ENCRYPTION=y | ||
523 | CONFIG_FANOTIFY=y | 523 | CONFIG_FANOTIFY=y |
524 | CONFIG_FANOTIFY_ACCESS_PERMISSIONS=y | 524 | CONFIG_FANOTIFY_ACCESS_PERMISSIONS=y |
525 | CONFIG_QUOTA_NETLINK_INTERFACE=y | 525 | CONFIG_QUOTA_NETLINK_INTERFACE=y |
diff --git a/arch/s390/configs/performance_defconfig b/arch/s390/configs/performance_defconfig index 32f539dc9c19..4fcbe5792744 100644 --- a/arch/s390/configs/performance_defconfig +++ b/arch/s390/configs/performance_defconfig | |||
@@ -497,7 +497,6 @@ CONFIG_S390_AP_IOMMU=y | |||
497 | CONFIG_EXT4_FS=y | 497 | CONFIG_EXT4_FS=y |
498 | CONFIG_EXT4_FS_POSIX_ACL=y | 498 | CONFIG_EXT4_FS_POSIX_ACL=y |
499 | CONFIG_EXT4_FS_SECURITY=y | 499 | CONFIG_EXT4_FS_SECURITY=y |
500 | CONFIG_EXT4_ENCRYPTION=y | ||
501 | CONFIG_JBD2_DEBUG=y | 500 | CONFIG_JBD2_DEBUG=y |
502 | CONFIG_JFS_FS=m | 501 | CONFIG_JFS_FS=m |
503 | CONFIG_JFS_POSIX_ACL=y | 502 | CONFIG_JFS_POSIX_ACL=y |
@@ -515,6 +514,7 @@ CONFIG_BTRFS_FS_POSIX_ACL=y | |||
515 | CONFIG_NILFS2_FS=m | 514 | CONFIG_NILFS2_FS=m |
516 | CONFIG_FS_DAX=y | 515 | CONFIG_FS_DAX=y |
517 | CONFIG_EXPORTFS_BLOCK_OPS=y | 516 | CONFIG_EXPORTFS_BLOCK_OPS=y |
517 | CONFIG_FS_ENCRYPTION=y | ||
518 | CONFIG_FANOTIFY=y | 518 | CONFIG_FANOTIFY=y |
519 | CONFIG_FANOTIFY_ACCESS_PERMISSIONS=y | 519 | CONFIG_FANOTIFY_ACCESS_PERMISSIONS=y |
520 | CONFIG_QUOTA_NETLINK_INTERFACE=y | 520 | CONFIG_QUOTA_NETLINK_INTERFACE=y |
diff --git a/fs/crypto/Kconfig b/fs/crypto/Kconfig index 284b589b4774..f0de238000c0 100644 --- a/fs/crypto/Kconfig +++ b/fs/crypto/Kconfig | |||
@@ -1,5 +1,5 @@ | |||
1 | config FS_ENCRYPTION | 1 | config FS_ENCRYPTION |
2 | tristate "FS Encryption (Per-file encryption)" | 2 | bool "FS Encryption (Per-file encryption)" |
3 | select CRYPTO | 3 | select CRYPTO |
4 | select CRYPTO_AES | 4 | select CRYPTO_AES |
5 | select CRYPTO_CBC | 5 | select CRYPTO_CBC |
@@ -12,4 +12,5 @@ config FS_ENCRYPTION | |||
12 | Enable encryption of files and directories. This | 12 | Enable encryption of files and directories. This |
13 | feature is similar to ecryptfs, but it is more memory | 13 | feature is similar to ecryptfs, but it is more memory |
14 | efficient since it avoids caching the encrypted and | 14 | efficient since it avoids caching the encrypted and |
15 | decrypted pages in the page cache. | 15 | decrypted pages in the page cache. Currently Ext4, |
16 | F2FS and UBIFS make use of this feature. | ||
diff --git a/fs/crypto/fscrypt_private.h b/fs/crypto/fscrypt_private.h index 7424f851eb5c..7da276159593 100644 --- a/fs/crypto/fscrypt_private.h +++ b/fs/crypto/fscrypt_private.h | |||
@@ -12,7 +12,6 @@ | |||
12 | #ifndef _FSCRYPT_PRIVATE_H | 12 | #ifndef _FSCRYPT_PRIVATE_H |
13 | #define _FSCRYPT_PRIVATE_H | 13 | #define _FSCRYPT_PRIVATE_H |
14 | 14 | ||
15 | #define __FS_HAS_ENCRYPTION 1 | ||
16 | #include <linux/fscrypt.h> | 15 | #include <linux/fscrypt.h> |
17 | #include <crypto/hash.h> | 16 | #include <crypto/hash.h> |
18 | 17 | ||
diff --git a/fs/ext4/Kconfig b/fs/ext4/Kconfig index a453cc87082b..031e5a82d556 100644 --- a/fs/ext4/Kconfig +++ b/fs/ext4/Kconfig | |||
@@ -96,21 +96,6 @@ config EXT4_FS_SECURITY | |||
96 | If you are not using a security module that requires using | 96 | If you are not using a security module that requires using |
97 | extended attributes for file security labels, say N. | 97 | extended attributes for file security labels, say N. |
98 | 98 | ||
99 | config EXT4_ENCRYPTION | ||
100 | bool "Ext4 Encryption" | ||
101 | depends on EXT4_FS | ||
102 | select FS_ENCRYPTION | ||
103 | help | ||
104 | Enable encryption of ext4 files and directories. This | ||
105 | feature is similar to ecryptfs, but it is more memory | ||
106 | efficient since it avoids caching the encrypted and | ||
107 | decrypted pages in the page cache. | ||
108 | |||
109 | config EXT4_FS_ENCRYPTION | ||
110 | bool | ||
111 | default y | ||
112 | depends on EXT4_ENCRYPTION | ||
113 | |||
114 | config EXT4_DEBUG | 99 | config EXT4_DEBUG |
115 | bool "EXT4 debugging support" | 100 | bool "EXT4 debugging support" |
116 | depends on EXT4_FS | 101 | depends on EXT4_FS |
diff --git a/fs/ext4/dir.c b/fs/ext4/dir.c index fb7a64ea5679..0ccd51f72048 100644 --- a/fs/ext4/dir.c +++ b/fs/ext4/dir.c | |||
@@ -283,9 +283,7 @@ static int ext4_readdir(struct file *file, struct dir_context *ctx) | |||
283 | done: | 283 | done: |
284 | err = 0; | 284 | err = 0; |
285 | errout: | 285 | errout: |
286 | #ifdef CONFIG_EXT4_FS_ENCRYPTION | ||
287 | fscrypt_fname_free_buffer(&fstr); | 286 | fscrypt_fname_free_buffer(&fstr); |
288 | #endif | ||
289 | brelse(bh); | 287 | brelse(bh); |
290 | return err; | 288 | return err; |
291 | } | 289 | } |
diff --git a/fs/ext4/ext4.h b/fs/ext4/ext4.h index afdb9ad8be0e..5012ddb6daf9 100644 --- a/fs/ext4/ext4.h +++ b/fs/ext4/ext4.h | |||
@@ -40,7 +40,6 @@ | |||
40 | #include <linux/compat.h> | 40 | #include <linux/compat.h> |
41 | #endif | 41 | #endif |
42 | 42 | ||
43 | #define __FS_HAS_ENCRYPTION IS_ENABLED(CONFIG_EXT4_FS_ENCRYPTION) | ||
44 | #include <linux/fscrypt.h> | 43 | #include <linux/fscrypt.h> |
45 | 44 | ||
46 | #include <linux/compiler.h> | 45 | #include <linux/compiler.h> |
@@ -1326,7 +1325,7 @@ struct ext4_super_block { | |||
1326 | #define EXT4_MF_FS_ABORTED 0x0002 /* Fatal error detected */ | 1325 | #define EXT4_MF_FS_ABORTED 0x0002 /* Fatal error detected */ |
1327 | #define EXT4_MF_TEST_DUMMY_ENCRYPTION 0x0004 | 1326 | #define EXT4_MF_TEST_DUMMY_ENCRYPTION 0x0004 |
1328 | 1327 | ||
1329 | #ifdef CONFIG_EXT4_FS_ENCRYPTION | 1328 | #ifdef CONFIG_FS_ENCRYPTION |
1330 | #define DUMMY_ENCRYPTION_ENABLED(sbi) (unlikely((sbi)->s_mount_flags & \ | 1329 | #define DUMMY_ENCRYPTION_ENABLED(sbi) (unlikely((sbi)->s_mount_flags & \ |
1331 | EXT4_MF_TEST_DUMMY_ENCRYPTION)) | 1330 | EXT4_MF_TEST_DUMMY_ENCRYPTION)) |
1332 | #else | 1331 | #else |
@@ -2051,7 +2050,7 @@ struct ext4_filename { | |||
2051 | const struct qstr *usr_fname; | 2050 | const struct qstr *usr_fname; |
2052 | struct fscrypt_str disk_name; | 2051 | struct fscrypt_str disk_name; |
2053 | struct dx_hash_info hinfo; | 2052 | struct dx_hash_info hinfo; |
2054 | #ifdef CONFIG_EXT4_FS_ENCRYPTION | 2053 | #ifdef CONFIG_FS_ENCRYPTION |
2055 | struct fscrypt_str crypto_buf; | 2054 | struct fscrypt_str crypto_buf; |
2056 | #endif | 2055 | #endif |
2057 | }; | 2056 | }; |
@@ -2279,7 +2278,7 @@ extern unsigned ext4_free_clusters_after_init(struct super_block *sb, | |||
2279 | struct ext4_group_desc *gdp); | 2278 | struct ext4_group_desc *gdp); |
2280 | ext4_fsblk_t ext4_inode_to_goal_block(struct inode *); | 2279 | ext4_fsblk_t ext4_inode_to_goal_block(struct inode *); |
2281 | 2280 | ||
2282 | #ifdef CONFIG_EXT4_FS_ENCRYPTION | 2281 | #ifdef CONFIG_FS_ENCRYPTION |
2283 | static inline int ext4_fname_setup_filename(struct inode *dir, | 2282 | static inline int ext4_fname_setup_filename(struct inode *dir, |
2284 | const struct qstr *iname, | 2283 | const struct qstr *iname, |
2285 | int lookup, struct ext4_filename *fname) | 2284 | int lookup, struct ext4_filename *fname) |
diff --git a/fs/ext4/inode.c b/fs/ext4/inode.c index 71bd2d28f58d..4356ef6d728e 100644 --- a/fs/ext4/inode.c +++ b/fs/ext4/inode.c | |||
@@ -1150,7 +1150,7 @@ int do_journal_get_write_access(handle_t *handle, | |||
1150 | return ret; | 1150 | return ret; |
1151 | } | 1151 | } |
1152 | 1152 | ||
1153 | #ifdef CONFIG_EXT4_FS_ENCRYPTION | 1153 | #ifdef CONFIG_FS_ENCRYPTION |
1154 | static int ext4_block_write_begin(struct page *page, loff_t pos, unsigned len, | 1154 | static int ext4_block_write_begin(struct page *page, loff_t pos, unsigned len, |
1155 | get_block_t *get_block) | 1155 | get_block_t *get_block) |
1156 | { | 1156 | { |
@@ -1302,7 +1302,7 @@ retry_journal: | |||
1302 | /* In case writeback began while the page was unlocked */ | 1302 | /* In case writeback began while the page was unlocked */ |
1303 | wait_for_stable_page(page); | 1303 | wait_for_stable_page(page); |
1304 | 1304 | ||
1305 | #ifdef CONFIG_EXT4_FS_ENCRYPTION | 1305 | #ifdef CONFIG_FS_ENCRYPTION |
1306 | if (ext4_should_dioread_nolock(inode)) | 1306 | if (ext4_should_dioread_nolock(inode)) |
1307 | ret = ext4_block_write_begin(page, pos, len, | 1307 | ret = ext4_block_write_begin(page, pos, len, |
1308 | ext4_get_block_unwritten); | 1308 | ext4_get_block_unwritten); |
@@ -3104,7 +3104,7 @@ retry_journal: | |||
3104 | /* In case writeback began while the page was unlocked */ | 3104 | /* In case writeback began while the page was unlocked */ |
3105 | wait_for_stable_page(page); | 3105 | wait_for_stable_page(page); |
3106 | 3106 | ||
3107 | #ifdef CONFIG_EXT4_FS_ENCRYPTION | 3107 | #ifdef CONFIG_FS_ENCRYPTION |
3108 | ret = ext4_block_write_begin(page, pos, len, | 3108 | ret = ext4_block_write_begin(page, pos, len, |
3109 | ext4_da_get_block_prep); | 3109 | ext4_da_get_block_prep); |
3110 | #else | 3110 | #else |
@@ -3879,7 +3879,7 @@ static ssize_t ext4_direct_IO(struct kiocb *iocb, struct iov_iter *iter) | |||
3879 | loff_t offset = iocb->ki_pos; | 3879 | loff_t offset = iocb->ki_pos; |
3880 | ssize_t ret; | 3880 | ssize_t ret; |
3881 | 3881 | ||
3882 | #ifdef CONFIG_EXT4_FS_ENCRYPTION | 3882 | #ifdef CONFIG_FS_ENCRYPTION |
3883 | if (IS_ENCRYPTED(inode) && S_ISREG(inode->i_mode)) | 3883 | if (IS_ENCRYPTED(inode) && S_ISREG(inode->i_mode)) |
3884 | return 0; | 3884 | return 0; |
3885 | #endif | 3885 | #endif |
diff --git a/fs/ext4/ioctl.c b/fs/ext4/ioctl.c index d37dafa1d133..d26bcac291bb 100644 --- a/fs/ext4/ioctl.c +++ b/fs/ext4/ioctl.c | |||
@@ -210,7 +210,7 @@ journal_err_out: | |||
210 | return err; | 210 | return err; |
211 | } | 211 | } |
212 | 212 | ||
213 | #ifdef CONFIG_EXT4_FS_ENCRYPTION | 213 | #ifdef CONFIG_FS_ENCRYPTION |
214 | static int uuid_is_zero(__u8 u[16]) | 214 | static int uuid_is_zero(__u8 u[16]) |
215 | { | 215 | { |
216 | int i; | 216 | int i; |
@@ -978,7 +978,7 @@ resizefs_out: | |||
978 | return fscrypt_ioctl_set_policy(filp, (const void __user *)arg); | 978 | return fscrypt_ioctl_set_policy(filp, (const void __user *)arg); |
979 | 979 | ||
980 | case EXT4_IOC_GET_ENCRYPTION_PWSALT: { | 980 | case EXT4_IOC_GET_ENCRYPTION_PWSALT: { |
981 | #ifdef CONFIG_EXT4_FS_ENCRYPTION | 981 | #ifdef CONFIG_FS_ENCRYPTION |
982 | int err, err2; | 982 | int err, err2; |
983 | struct ext4_sb_info *sbi = EXT4_SB(sb); | 983 | struct ext4_sb_info *sbi = EXT4_SB(sb); |
984 | handle_t *handle; | 984 | handle_t *handle; |
diff --git a/fs/ext4/namei.c b/fs/ext4/namei.c index be6cb69beb12..980166a8122a 100644 --- a/fs/ext4/namei.c +++ b/fs/ext4/namei.c | |||
@@ -612,7 +612,7 @@ static struct stats dx_show_leaf(struct inode *dir, | |||
612 | { | 612 | { |
613 | if (show_names) | 613 | if (show_names) |
614 | { | 614 | { |
615 | #ifdef CONFIG_EXT4_FS_ENCRYPTION | 615 | #ifdef CONFIG_FS_ENCRYPTION |
616 | int len; | 616 | int len; |
617 | char *name; | 617 | char *name; |
618 | struct fscrypt_str fname_crypto_str = | 618 | struct fscrypt_str fname_crypto_str = |
@@ -984,7 +984,7 @@ static int htree_dirblock_to_tree(struct file *dir_file, | |||
984 | top = (struct ext4_dir_entry_2 *) ((char *) de + | 984 | top = (struct ext4_dir_entry_2 *) ((char *) de + |
985 | dir->i_sb->s_blocksize - | 985 | dir->i_sb->s_blocksize - |
986 | EXT4_DIR_REC_LEN(0)); | 986 | EXT4_DIR_REC_LEN(0)); |
987 | #ifdef CONFIG_EXT4_FS_ENCRYPTION | 987 | #ifdef CONFIG_FS_ENCRYPTION |
988 | /* Check if the directory is encrypted */ | 988 | /* Check if the directory is encrypted */ |
989 | if (IS_ENCRYPTED(dir)) { | 989 | if (IS_ENCRYPTED(dir)) { |
990 | err = fscrypt_get_encryption_info(dir); | 990 | err = fscrypt_get_encryption_info(dir); |
@@ -1047,7 +1047,7 @@ static int htree_dirblock_to_tree(struct file *dir_file, | |||
1047 | } | 1047 | } |
1048 | errout: | 1048 | errout: |
1049 | brelse(bh); | 1049 | brelse(bh); |
1050 | #ifdef CONFIG_EXT4_FS_ENCRYPTION | 1050 | #ifdef CONFIG_FS_ENCRYPTION |
1051 | fscrypt_fname_free_buffer(&fname_crypto_str); | 1051 | fscrypt_fname_free_buffer(&fname_crypto_str); |
1052 | #endif | 1052 | #endif |
1053 | return count; | 1053 | return count; |
@@ -1267,7 +1267,7 @@ static inline bool ext4_match(const struct ext4_filename *fname, | |||
1267 | 1267 | ||
1268 | f.usr_fname = fname->usr_fname; | 1268 | f.usr_fname = fname->usr_fname; |
1269 | f.disk_name = fname->disk_name; | 1269 | f.disk_name = fname->disk_name; |
1270 | #ifdef CONFIG_EXT4_FS_ENCRYPTION | 1270 | #ifdef CONFIG_FS_ENCRYPTION |
1271 | f.crypto_buf = fname->crypto_buf; | 1271 | f.crypto_buf = fname->crypto_buf; |
1272 | #endif | 1272 | #endif |
1273 | return fscrypt_match_name(&f, de->name, de->name_len); | 1273 | return fscrypt_match_name(&f, de->name, de->name_len); |
@@ -1498,7 +1498,7 @@ static struct buffer_head * ext4_dx_find_entry(struct inode *dir, | |||
1498 | ext4_lblk_t block; | 1498 | ext4_lblk_t block; |
1499 | int retval; | 1499 | int retval; |
1500 | 1500 | ||
1501 | #ifdef CONFIG_EXT4_FS_ENCRYPTION | 1501 | #ifdef CONFIG_FS_ENCRYPTION |
1502 | *res_dir = NULL; | 1502 | *res_dir = NULL; |
1503 | #endif | 1503 | #endif |
1504 | frame = dx_probe(fname, dir, NULL, frames); | 1504 | frame = dx_probe(fname, dir, NULL, frames); |
diff --git a/fs/ext4/page-io.c b/fs/ext4/page-io.c index c398b55da854..b9d6cabe2ea8 100644 --- a/fs/ext4/page-io.c +++ b/fs/ext4/page-io.c | |||
@@ -66,7 +66,7 @@ static void ext4_finish_bio(struct bio *bio) | |||
66 | 66 | ||
67 | bio_for_each_segment_all(bvec, bio, i) { | 67 | bio_for_each_segment_all(bvec, bio, i) { |
68 | struct page *page = bvec->bv_page; | 68 | struct page *page = bvec->bv_page; |
69 | #ifdef CONFIG_EXT4_FS_ENCRYPTION | 69 | #ifdef CONFIG_FS_ENCRYPTION |
70 | struct page *data_page = NULL; | 70 | struct page *data_page = NULL; |
71 | #endif | 71 | #endif |
72 | struct buffer_head *bh, *head; | 72 | struct buffer_head *bh, *head; |
@@ -78,7 +78,7 @@ static void ext4_finish_bio(struct bio *bio) | |||
78 | if (!page) | 78 | if (!page) |
79 | continue; | 79 | continue; |
80 | 80 | ||
81 | #ifdef CONFIG_EXT4_FS_ENCRYPTION | 81 | #ifdef CONFIG_FS_ENCRYPTION |
82 | if (!page->mapping) { | 82 | if (!page->mapping) { |
83 | /* The bounce data pages are unmapped. */ | 83 | /* The bounce data pages are unmapped. */ |
84 | data_page = page; | 84 | data_page = page; |
@@ -111,7 +111,7 @@ static void ext4_finish_bio(struct bio *bio) | |||
111 | bit_spin_unlock(BH_Uptodate_Lock, &head->b_state); | 111 | bit_spin_unlock(BH_Uptodate_Lock, &head->b_state); |
112 | local_irq_restore(flags); | 112 | local_irq_restore(flags); |
113 | if (!under_io) { | 113 | if (!under_io) { |
114 | #ifdef CONFIG_EXT4_FS_ENCRYPTION | 114 | #ifdef CONFIG_FS_ENCRYPTION |
115 | if (data_page) | 115 | if (data_page) |
116 | fscrypt_restore_control_page(data_page); | 116 | fscrypt_restore_control_page(data_page); |
117 | #endif | 117 | #endif |
diff --git a/fs/ext4/readpage.c b/fs/ext4/readpage.c index 52d3ff5a9db1..b18881eb8da6 100644 --- a/fs/ext4/readpage.c +++ b/fs/ext4/readpage.c | |||
@@ -49,7 +49,7 @@ | |||
49 | 49 | ||
50 | static inline bool ext4_bio_encrypted(struct bio *bio) | 50 | static inline bool ext4_bio_encrypted(struct bio *bio) |
51 | { | 51 | { |
52 | #ifdef CONFIG_EXT4_FS_ENCRYPTION | 52 | #ifdef CONFIG_FS_ENCRYPTION |
53 | return unlikely(bio->bi_private != NULL); | 53 | return unlikely(bio->bi_private != NULL); |
54 | #else | 54 | #else |
55 | return false; | 55 | return false; |
diff --git a/fs/ext4/super.c b/fs/ext4/super.c index fb12d3c17c1b..60da0a6e4d86 100644 --- a/fs/ext4/super.c +++ b/fs/ext4/super.c | |||
@@ -1232,7 +1232,7 @@ static int bdev_try_to_free_page(struct super_block *sb, struct page *page, | |||
1232 | return try_to_free_buffers(page); | 1232 | return try_to_free_buffers(page); |
1233 | } | 1233 | } |
1234 | 1234 | ||
1235 | #ifdef CONFIG_EXT4_FS_ENCRYPTION | 1235 | #ifdef CONFIG_FS_ENCRYPTION |
1236 | static int ext4_get_context(struct inode *inode, void *ctx, size_t len) | 1236 | static int ext4_get_context(struct inode *inode, void *ctx, size_t len) |
1237 | { | 1237 | { |
1238 | return ext4_xattr_get(inode, EXT4_XATTR_INDEX_ENCRYPTION, | 1238 | return ext4_xattr_get(inode, EXT4_XATTR_INDEX_ENCRYPTION, |
@@ -1922,7 +1922,7 @@ static int handle_mount_opt(struct super_block *sb, char *opt, int token, | |||
1922 | *journal_ioprio = | 1922 | *journal_ioprio = |
1923 | IOPRIO_PRIO_VALUE(IOPRIO_CLASS_BE, arg); | 1923 | IOPRIO_PRIO_VALUE(IOPRIO_CLASS_BE, arg); |
1924 | } else if (token == Opt_test_dummy_encryption) { | 1924 | } else if (token == Opt_test_dummy_encryption) { |
1925 | #ifdef CONFIG_EXT4_FS_ENCRYPTION | 1925 | #ifdef CONFIG_FS_ENCRYPTION |
1926 | sbi->s_mount_flags |= EXT4_MF_TEST_DUMMY_ENCRYPTION; | 1926 | sbi->s_mount_flags |= EXT4_MF_TEST_DUMMY_ENCRYPTION; |
1927 | ext4_msg(sb, KERN_WARNING, | 1927 | ext4_msg(sb, KERN_WARNING, |
1928 | "Test dummy encryption mode enabled"); | 1928 | "Test dummy encryption mode enabled"); |
@@ -4167,7 +4167,7 @@ static int ext4_fill_super(struct super_block *sb, void *data, int silent) | |||
4167 | sb->s_op = &ext4_sops; | 4167 | sb->s_op = &ext4_sops; |
4168 | sb->s_export_op = &ext4_export_ops; | 4168 | sb->s_export_op = &ext4_export_ops; |
4169 | sb->s_xattr = ext4_xattr_handlers; | 4169 | sb->s_xattr = ext4_xattr_handlers; |
4170 | #ifdef CONFIG_EXT4_FS_ENCRYPTION | 4170 | #ifdef CONFIG_FS_ENCRYPTION |
4171 | sb->s_cop = &ext4_cryptops; | 4171 | sb->s_cop = &ext4_cryptops; |
4172 | #endif | 4172 | #endif |
4173 | #ifdef CONFIG_QUOTA | 4173 | #ifdef CONFIG_QUOTA |
diff --git a/fs/ext4/sysfs.c b/fs/ext4/sysfs.c index 9212a026a1f1..5e4e78fc0b3a 100644 --- a/fs/ext4/sysfs.c +++ b/fs/ext4/sysfs.c | |||
@@ -224,7 +224,7 @@ static struct attribute *ext4_attrs[] = { | |||
224 | EXT4_ATTR_FEATURE(lazy_itable_init); | 224 | EXT4_ATTR_FEATURE(lazy_itable_init); |
225 | EXT4_ATTR_FEATURE(batched_discard); | 225 | EXT4_ATTR_FEATURE(batched_discard); |
226 | EXT4_ATTR_FEATURE(meta_bg_resize); | 226 | EXT4_ATTR_FEATURE(meta_bg_resize); |
227 | #ifdef CONFIG_EXT4_FS_ENCRYPTION | 227 | #ifdef CONFIG_FS_ENCRYPTION |
228 | EXT4_ATTR_FEATURE(encryption); | 228 | EXT4_ATTR_FEATURE(encryption); |
229 | #endif | 229 | #endif |
230 | EXT4_ATTR_FEATURE(metadata_csum_seed); | 230 | EXT4_ATTR_FEATURE(metadata_csum_seed); |
@@ -233,7 +233,7 @@ static struct attribute *ext4_feat_attrs[] = { | |||
233 | ATTR_LIST(lazy_itable_init), | 233 | ATTR_LIST(lazy_itable_init), |
234 | ATTR_LIST(batched_discard), | 234 | ATTR_LIST(batched_discard), |
235 | ATTR_LIST(meta_bg_resize), | 235 | ATTR_LIST(meta_bg_resize), |
236 | #ifdef CONFIG_EXT4_FS_ENCRYPTION | 236 | #ifdef CONFIG_FS_ENCRYPTION |
237 | ATTR_LIST(encryption), | 237 | ATTR_LIST(encryption), |
238 | #endif | 238 | #endif |
239 | ATTR_LIST(metadata_csum_seed), | 239 | ATTR_LIST(metadata_csum_seed), |
diff --git a/fs/f2fs/Kconfig b/fs/f2fs/Kconfig index 9a20ef42fadd..e57cc754d543 100644 --- a/fs/f2fs/Kconfig +++ b/fs/f2fs/Kconfig | |||
@@ -3,6 +3,7 @@ config F2FS_FS | |||
3 | depends on BLOCK | 3 | depends on BLOCK |
4 | select CRYPTO | 4 | select CRYPTO |
5 | select CRYPTO_CRC32 | 5 | select CRYPTO_CRC32 |
6 | select F2FS_FS_XATTR if FS_ENCRYPTION | ||
6 | help | 7 | help |
7 | F2FS is based on Log-structured File System (LFS), which supports | 8 | F2FS is based on Log-structured File System (LFS), which supports |
8 | versatile "flash-friendly" features. The design has been focused on | 9 | versatile "flash-friendly" features. The design has been focused on |
@@ -70,17 +71,6 @@ config F2FS_CHECK_FS | |||
70 | 71 | ||
71 | If you want to improve the performance, say N. | 72 | If you want to improve the performance, say N. |
72 | 73 | ||
73 | config F2FS_FS_ENCRYPTION | ||
74 | bool "F2FS Encryption" | ||
75 | depends on F2FS_FS | ||
76 | depends on F2FS_FS_XATTR | ||
77 | select FS_ENCRYPTION | ||
78 | help | ||
79 | Enable encryption of f2fs files and directories. This | ||
80 | feature is similar to ecryptfs, but it is more memory | ||
81 | efficient since it avoids caching the encrypted and | ||
82 | decrypted pages in the page cache. | ||
83 | |||
84 | config F2FS_IO_TRACE | 74 | config F2FS_IO_TRACE |
85 | bool "F2FS IO tracer" | 75 | bool "F2FS IO tracer" |
86 | depends on F2FS_FS | 76 | depends on F2FS_FS |
diff --git a/fs/f2fs/f2fs.h b/fs/f2fs/f2fs.h index 9ef6f38e51cc..95cc885ccb2f 100644 --- a/fs/f2fs/f2fs.h +++ b/fs/f2fs/f2fs.h | |||
@@ -24,7 +24,6 @@ | |||
24 | #include <linux/quotaops.h> | 24 | #include <linux/quotaops.h> |
25 | #include <crypto/hash.h> | 25 | #include <crypto/hash.h> |
26 | 26 | ||
27 | #define __FS_HAS_ENCRYPTION IS_ENABLED(CONFIG_F2FS_FS_ENCRYPTION) | ||
28 | #include <linux/fscrypt.h> | 27 | #include <linux/fscrypt.h> |
29 | 28 | ||
30 | #ifdef CONFIG_F2FS_CHECK_FS | 29 | #ifdef CONFIG_F2FS_CHECK_FS |
@@ -1137,7 +1136,7 @@ enum fsync_mode { | |||
1137 | FSYNC_MODE_NOBARRIER, /* fsync behaves nobarrier based on posix */ | 1136 | FSYNC_MODE_NOBARRIER, /* fsync behaves nobarrier based on posix */ |
1138 | }; | 1137 | }; |
1139 | 1138 | ||
1140 | #ifdef CONFIG_F2FS_FS_ENCRYPTION | 1139 | #ifdef CONFIG_FS_ENCRYPTION |
1141 | #define DUMMY_ENCRYPTION_ENABLED(sbi) \ | 1140 | #define DUMMY_ENCRYPTION_ENABLED(sbi) \ |
1142 | (unlikely(F2FS_OPTION(sbi).test_dummy_encryption)) | 1141 | (unlikely(F2FS_OPTION(sbi).test_dummy_encryption)) |
1143 | #else | 1142 | #else |
@@ -3470,7 +3469,7 @@ static inline bool f2fs_encrypted_file(struct inode *inode) | |||
3470 | 3469 | ||
3471 | static inline void f2fs_set_encrypted_inode(struct inode *inode) | 3470 | static inline void f2fs_set_encrypted_inode(struct inode *inode) |
3472 | { | 3471 | { |
3473 | #ifdef CONFIG_F2FS_FS_ENCRYPTION | 3472 | #ifdef CONFIG_FS_ENCRYPTION |
3474 | file_set_encrypt(inode); | 3473 | file_set_encrypt(inode); |
3475 | f2fs_set_inode_flags(inode); | 3474 | f2fs_set_inode_flags(inode); |
3476 | #endif | 3475 | #endif |
@@ -3549,7 +3548,7 @@ static inline void set_opt_mode(struct f2fs_sb_info *sbi, unsigned int mt) | |||
3549 | 3548 | ||
3550 | static inline bool f2fs_may_encrypt(struct inode *inode) | 3549 | static inline bool f2fs_may_encrypt(struct inode *inode) |
3551 | { | 3550 | { |
3552 | #ifdef CONFIG_F2FS_FS_ENCRYPTION | 3551 | #ifdef CONFIG_FS_ENCRYPTION |
3553 | umode_t mode = inode->i_mode; | 3552 | umode_t mode = inode->i_mode; |
3554 | 3553 | ||
3555 | return (S_ISREG(mode) || S_ISDIR(mode) || S_ISLNK(mode)); | 3554 | return (S_ISREG(mode) || S_ISDIR(mode) || S_ISLNK(mode)); |
diff --git a/fs/f2fs/super.c b/fs/f2fs/super.c index c46a1d4318d4..0f3db3a8e5cb 100644 --- a/fs/f2fs/super.c +++ b/fs/f2fs/super.c | |||
@@ -757,7 +757,7 @@ static int parse_options(struct super_block *sb, char *options) | |||
757 | kvfree(name); | 757 | kvfree(name); |
758 | break; | 758 | break; |
759 | case Opt_test_dummy_encryption: | 759 | case Opt_test_dummy_encryption: |
760 | #ifdef CONFIG_F2FS_FS_ENCRYPTION | 760 | #ifdef CONFIG_FS_ENCRYPTION |
761 | if (!f2fs_sb_has_encrypt(sbi)) { | 761 | if (!f2fs_sb_has_encrypt(sbi)) { |
762 | f2fs_msg(sb, KERN_ERR, "Encrypt feature is off"); | 762 | f2fs_msg(sb, KERN_ERR, "Encrypt feature is off"); |
763 | return -EINVAL; | 763 | return -EINVAL; |
@@ -1390,7 +1390,7 @@ static int f2fs_show_options(struct seq_file *seq, struct dentry *root) | |||
1390 | seq_printf(seq, ",whint_mode=%s", "user-based"); | 1390 | seq_printf(seq, ",whint_mode=%s", "user-based"); |
1391 | else if (F2FS_OPTION(sbi).whint_mode == WHINT_MODE_FS) | 1391 | else if (F2FS_OPTION(sbi).whint_mode == WHINT_MODE_FS) |
1392 | seq_printf(seq, ",whint_mode=%s", "fs-based"); | 1392 | seq_printf(seq, ",whint_mode=%s", "fs-based"); |
1393 | #ifdef CONFIG_F2FS_FS_ENCRYPTION | 1393 | #ifdef CONFIG_FS_ENCRYPTION |
1394 | if (F2FS_OPTION(sbi).test_dummy_encryption) | 1394 | if (F2FS_OPTION(sbi).test_dummy_encryption) |
1395 | seq_puts(seq, ",test_dummy_encryption"); | 1395 | seq_puts(seq, ",test_dummy_encryption"); |
1396 | #endif | 1396 | #endif |
@@ -2154,7 +2154,7 @@ static const struct super_operations f2fs_sops = { | |||
2154 | .remount_fs = f2fs_remount, | 2154 | .remount_fs = f2fs_remount, |
2155 | }; | 2155 | }; |
2156 | 2156 | ||
2157 | #ifdef CONFIG_F2FS_FS_ENCRYPTION | 2157 | #ifdef CONFIG_FS_ENCRYPTION |
2158 | static int f2fs_get_context(struct inode *inode, void *ctx, size_t len) | 2158 | static int f2fs_get_context(struct inode *inode, void *ctx, size_t len) |
2159 | { | 2159 | { |
2160 | return f2fs_getxattr(inode, F2FS_XATTR_INDEX_ENCRYPTION, | 2160 | return f2fs_getxattr(inode, F2FS_XATTR_INDEX_ENCRYPTION, |
@@ -3116,7 +3116,7 @@ try_onemore: | |||
3116 | #endif | 3116 | #endif |
3117 | 3117 | ||
3118 | sb->s_op = &f2fs_sops; | 3118 | sb->s_op = &f2fs_sops; |
3119 | #ifdef CONFIG_F2FS_FS_ENCRYPTION | 3119 | #ifdef CONFIG_FS_ENCRYPTION |
3120 | sb->s_cop = &f2fs_cryptops; | 3120 | sb->s_cop = &f2fs_cryptops; |
3121 | #endif | 3121 | #endif |
3122 | sb->s_xattr = f2fs_xattr_handlers; | 3122 | sb->s_xattr = f2fs_xattr_handlers; |
diff --git a/fs/f2fs/sysfs.c b/fs/f2fs/sysfs.c index 0575edbe3ed6..70da6801c86f 100644 --- a/fs/f2fs/sysfs.c +++ b/fs/f2fs/sysfs.c | |||
@@ -431,7 +431,7 @@ F2FS_GENERAL_RO_ATTR(lifetime_write_kbytes); | |||
431 | F2FS_GENERAL_RO_ATTR(features); | 431 | F2FS_GENERAL_RO_ATTR(features); |
432 | F2FS_GENERAL_RO_ATTR(current_reserved_blocks); | 432 | F2FS_GENERAL_RO_ATTR(current_reserved_blocks); |
433 | 433 | ||
434 | #ifdef CONFIG_F2FS_FS_ENCRYPTION | 434 | #ifdef CONFIG_FS_ENCRYPTION |
435 | F2FS_FEATURE_RO_ATTR(encryption, FEAT_CRYPTO); | 435 | F2FS_FEATURE_RO_ATTR(encryption, FEAT_CRYPTO); |
436 | #endif | 436 | #endif |
437 | #ifdef CONFIG_BLK_DEV_ZONED | 437 | #ifdef CONFIG_BLK_DEV_ZONED |
@@ -492,7 +492,7 @@ static struct attribute *f2fs_attrs[] = { | |||
492 | }; | 492 | }; |
493 | 493 | ||
494 | static struct attribute *f2fs_feat_attrs[] = { | 494 | static struct attribute *f2fs_feat_attrs[] = { |
495 | #ifdef CONFIG_F2FS_FS_ENCRYPTION | 495 | #ifdef CONFIG_FS_ENCRYPTION |
496 | ATTR_LIST(encryption), | 496 | ATTR_LIST(encryption), |
497 | #endif | 497 | #endif |
498 | #ifdef CONFIG_BLK_DEV_ZONED | 498 | #ifdef CONFIG_BLK_DEV_ZONED |
diff --git a/fs/ubifs/Kconfig b/fs/ubifs/Kconfig index bc1e082d921d..9da2f135121b 100644 --- a/fs/ubifs/Kconfig +++ b/fs/ubifs/Kconfig | |||
@@ -8,6 +8,7 @@ config UBIFS_FS | |||
8 | select CRYPTO_LZO if UBIFS_FS_LZO | 8 | select CRYPTO_LZO if UBIFS_FS_LZO |
9 | select CRYPTO_DEFLATE if UBIFS_FS_ZLIB | 9 | select CRYPTO_DEFLATE if UBIFS_FS_ZLIB |
10 | select CRYPTO_HASH_INFO | 10 | select CRYPTO_HASH_INFO |
11 | select UBIFS_FS_XATTR if FS_ENCRYPTION | ||
11 | depends on MTD_UBI | 12 | depends on MTD_UBI |
12 | help | 13 | help |
13 | UBIFS is a file system for flash devices which works on top of UBI. | 14 | UBIFS is a file system for flash devices which works on top of UBI. |
@@ -60,17 +61,6 @@ config UBIFS_FS_XATTR | |||
60 | 61 | ||
61 | If unsure, say Y. | 62 | If unsure, say Y. |
62 | 63 | ||
63 | config UBIFS_FS_ENCRYPTION | ||
64 | bool "UBIFS Encryption" | ||
65 | depends on UBIFS_FS_XATTR && BLOCK | ||
66 | select FS_ENCRYPTION | ||
67 | default n | ||
68 | help | ||
69 | Enable encryption of UBIFS files and directories. This | ||
70 | feature is similar to ecryptfs, but it is more memory | ||
71 | efficient since it avoids caching the encrypted and | ||
72 | decrypted pages in the page cache. | ||
73 | |||
74 | config UBIFS_FS_SECURITY | 64 | config UBIFS_FS_SECURITY |
75 | bool "UBIFS Security Labels" | 65 | bool "UBIFS Security Labels" |
76 | depends on UBIFS_FS_XATTR | 66 | depends on UBIFS_FS_XATTR |
diff --git a/fs/ubifs/Makefile b/fs/ubifs/Makefile index 5f838319c8d5..5c4b845754a7 100644 --- a/fs/ubifs/Makefile +++ b/fs/ubifs/Makefile | |||
@@ -6,6 +6,6 @@ ubifs-y += tnc.o master.o scan.o replay.o log.o commit.o gc.o orphan.o | |||
6 | ubifs-y += budget.o find.o tnc_commit.o compress.o lpt.o lprops.o | 6 | ubifs-y += budget.o find.o tnc_commit.o compress.o lpt.o lprops.o |
7 | ubifs-y += recovery.o ioctl.o lpt_commit.o tnc_misc.o debug.o | 7 | ubifs-y += recovery.o ioctl.o lpt_commit.o tnc_misc.o debug.o |
8 | ubifs-y += misc.o | 8 | ubifs-y += misc.o |
9 | ubifs-$(CONFIG_UBIFS_FS_ENCRYPTION) += crypto.o | 9 | ubifs-$(CONFIG_FS_ENCRYPTION) += crypto.o |
10 | ubifs-$(CONFIG_UBIFS_FS_XATTR) += xattr.o | 10 | ubifs-$(CONFIG_UBIFS_FS_XATTR) += xattr.o |
11 | ubifs-$(CONFIG_UBIFS_FS_AUTHENTICATION) += auth.o | 11 | ubifs-$(CONFIG_UBIFS_FS_AUTHENTICATION) += auth.o |
diff --git a/fs/ubifs/ioctl.c b/fs/ubifs/ioctl.c index 0164bcc827f8..0f9c362a3402 100644 --- a/fs/ubifs/ioctl.c +++ b/fs/ubifs/ioctl.c | |||
@@ -185,7 +185,7 @@ long ubifs_ioctl(struct file *file, unsigned int cmd, unsigned long arg) | |||
185 | return err; | 185 | return err; |
186 | } | 186 | } |
187 | case FS_IOC_SET_ENCRYPTION_POLICY: { | 187 | case FS_IOC_SET_ENCRYPTION_POLICY: { |
188 | #ifdef CONFIG_UBIFS_FS_ENCRYPTION | 188 | #ifdef CONFIG_FS_ENCRYPTION |
189 | struct ubifs_info *c = inode->i_sb->s_fs_info; | 189 | struct ubifs_info *c = inode->i_sb->s_fs_info; |
190 | 190 | ||
191 | err = ubifs_enable_encryption(c); | 191 | err = ubifs_enable_encryption(c); |
@@ -198,7 +198,7 @@ long ubifs_ioctl(struct file *file, unsigned int cmd, unsigned long arg) | |||
198 | #endif | 198 | #endif |
199 | } | 199 | } |
200 | case FS_IOC_GET_ENCRYPTION_POLICY: { | 200 | case FS_IOC_GET_ENCRYPTION_POLICY: { |
201 | #ifdef CONFIG_UBIFS_FS_ENCRYPTION | 201 | #ifdef CONFIG_FS_ENCRYPTION |
202 | return fscrypt_ioctl_get_policy(file, (void __user *)arg); | 202 | return fscrypt_ioctl_get_policy(file, (void __user *)arg); |
203 | #else | 203 | #else |
204 | return -EOPNOTSUPP; | 204 | return -EOPNOTSUPP; |
diff --git a/fs/ubifs/sb.c b/fs/ubifs/sb.c index 3da90c951c23..67fac1e8adfb 100644 --- a/fs/ubifs/sb.c +++ b/fs/ubifs/sb.c | |||
@@ -748,7 +748,7 @@ int ubifs_read_superblock(struct ubifs_info *c) | |||
748 | goto out; | 748 | goto out; |
749 | } | 749 | } |
750 | 750 | ||
751 | #ifndef CONFIG_UBIFS_FS_ENCRYPTION | 751 | #ifndef CONFIG_FS_ENCRYPTION |
752 | if (c->encrypted) { | 752 | if (c->encrypted) { |
753 | ubifs_err(c, "file system contains encrypted files but UBIFS" | 753 | ubifs_err(c, "file system contains encrypted files but UBIFS" |
754 | " was built without crypto support."); | 754 | " was built without crypto support."); |
diff --git a/fs/ubifs/super.c b/fs/ubifs/super.c index 1fac1133dadd..8dc2818fdd84 100644 --- a/fs/ubifs/super.c +++ b/fs/ubifs/super.c | |||
@@ -2146,7 +2146,7 @@ static int ubifs_fill_super(struct super_block *sb, void *data, int silent) | |||
2146 | #ifdef CONFIG_UBIFS_FS_XATTR | 2146 | #ifdef CONFIG_UBIFS_FS_XATTR |
2147 | sb->s_xattr = ubifs_xattr_handlers; | 2147 | sb->s_xattr = ubifs_xattr_handlers; |
2148 | #endif | 2148 | #endif |
2149 | #ifdef CONFIG_UBIFS_FS_ENCRYPTION | 2149 | #ifdef CONFIG_FS_ENCRYPTION |
2150 | sb->s_cop = &ubifs_crypt_operations; | 2150 | sb->s_cop = &ubifs_crypt_operations; |
2151 | #endif | 2151 | #endif |
2152 | 2152 | ||
diff --git a/fs/ubifs/ubifs.h b/fs/ubifs/ubifs.h index 38401adaa00d..1ae12900e01d 100644 --- a/fs/ubifs/ubifs.h +++ b/fs/ubifs/ubifs.h | |||
@@ -43,7 +43,6 @@ | |||
43 | #include <crypto/hash.h> | 43 | #include <crypto/hash.h> |
44 | #include <crypto/algapi.h> | 44 | #include <crypto/algapi.h> |
45 | 45 | ||
46 | #define __FS_HAS_ENCRYPTION IS_ENABLED(CONFIG_UBIFS_FS_ENCRYPTION) | ||
47 | #include <linux/fscrypt.h> | 46 | #include <linux/fscrypt.h> |
48 | 47 | ||
49 | #include "ubifs-media.h" | 48 | #include "ubifs-media.h" |
@@ -142,7 +141,7 @@ | |||
142 | */ | 141 | */ |
143 | #define WORST_COMPR_FACTOR 2 | 142 | #define WORST_COMPR_FACTOR 2 |
144 | 143 | ||
145 | #ifdef CONFIG_UBIFS_FS_ENCRYPTION | 144 | #ifdef CONFIG_FS_ENCRYPTION |
146 | #define UBIFS_CIPHER_BLOCK_SIZE FS_CRYPTO_BLOCK_SIZE | 145 | #define UBIFS_CIPHER_BLOCK_SIZE FS_CRYPTO_BLOCK_SIZE |
147 | #else | 146 | #else |
148 | #define UBIFS_CIPHER_BLOCK_SIZE 0 | 147 | #define UBIFS_CIPHER_BLOCK_SIZE 0 |
@@ -2072,7 +2071,7 @@ int ubifs_decompress(const struct ubifs_info *c, const void *buf, int len, | |||
2072 | #include "misc.h" | 2071 | #include "misc.h" |
2073 | #include "key.h" | 2072 | #include "key.h" |
2074 | 2073 | ||
2075 | #ifndef CONFIG_UBIFS_FS_ENCRYPTION | 2074 | #ifndef CONFIG_FS_ENCRYPTION |
2076 | static inline int ubifs_encrypt(const struct inode *inode, | 2075 | static inline int ubifs_encrypt(const struct inode *inode, |
2077 | struct ubifs_data_node *dn, | 2076 | struct ubifs_data_node *dn, |
2078 | unsigned int in_len, unsigned int *out_len, | 2077 | unsigned int in_len, unsigned int *out_len, |
diff --git a/include/linux/fs.h b/include/linux/fs.h index 811c77743dad..ba7889bb9ef6 100644 --- a/include/linux/fs.h +++ b/include/linux/fs.h | |||
@@ -698,7 +698,7 @@ struct inode { | |||
698 | struct fsnotify_mark_connector __rcu *i_fsnotify_marks; | 698 | struct fsnotify_mark_connector __rcu *i_fsnotify_marks; |
699 | #endif | 699 | #endif |
700 | 700 | ||
701 | #if IS_ENABLED(CONFIG_FS_ENCRYPTION) | 701 | #ifdef CONFIG_FS_ENCRYPTION |
702 | struct fscrypt_info *i_crypt_info; | 702 | struct fscrypt_info *i_crypt_info; |
703 | #endif | 703 | #endif |
704 | 704 | ||
@@ -1403,7 +1403,7 @@ struct super_block { | |||
1403 | void *s_security; | 1403 | void *s_security; |
1404 | #endif | 1404 | #endif |
1405 | const struct xattr_handler **s_xattr; | 1405 | const struct xattr_handler **s_xattr; |
1406 | #if IS_ENABLED(CONFIG_FS_ENCRYPTION) | 1406 | #ifdef CONFIG_FS_ENCRYPTION |
1407 | const struct fscrypt_operations *s_cop; | 1407 | const struct fscrypt_operations *s_cop; |
1408 | #endif | 1408 | #endif |
1409 | struct hlist_bl_head s_roots; /* alternate root dentries for NFS */ | 1409 | struct hlist_bl_head s_roots; /* alternate root dentries for NFS */ |
diff --git a/include/linux/fscrypt.h b/include/linux/fscrypt.h index 952ab97af325..eec604840568 100644 --- a/include/linux/fscrypt.h +++ b/include/linux/fscrypt.h | |||
@@ -2,9 +2,8 @@ | |||
2 | /* | 2 | /* |
3 | * fscrypt.h: declarations for per-file encryption | 3 | * fscrypt.h: declarations for per-file encryption |
4 | * | 4 | * |
5 | * Filesystems that implement per-file encryption include this header | 5 | * Filesystems that implement per-file encryption must include this header |
6 | * file with the __FS_HAS_ENCRYPTION set according to whether that filesystem | 6 | * file. |
7 | * is being built with encryption support or not. | ||
8 | * | 7 | * |
9 | * Copyright (C) 2015, Google, Inc. | 8 | * Copyright (C) 2015, Google, Inc. |
10 | * | 9 | * |
@@ -15,6 +14,8 @@ | |||
15 | #define _LINUX_FSCRYPT_H | 14 | #define _LINUX_FSCRYPT_H |
16 | 15 | ||
17 | #include <linux/fs.h> | 16 | #include <linux/fs.h> |
17 | #include <linux/mm.h> | ||
18 | #include <linux/slab.h> | ||
18 | 19 | ||
19 | #define FS_CRYPTO_BLOCK_SIZE 16 | 20 | #define FS_CRYPTO_BLOCK_SIZE 16 |
20 | 21 | ||
@@ -42,11 +43,410 @@ struct fscrypt_name { | |||
42 | /* Maximum value for the third parameter of fscrypt_operations.set_context(). */ | 43 | /* Maximum value for the third parameter of fscrypt_operations.set_context(). */ |
43 | #define FSCRYPT_SET_CONTEXT_MAX_SIZE 28 | 44 | #define FSCRYPT_SET_CONTEXT_MAX_SIZE 28 |
44 | 45 | ||
45 | #if __FS_HAS_ENCRYPTION | 46 | #ifdef CONFIG_FS_ENCRYPTION |
46 | #include <linux/fscrypt_supp.h> | 47 | /* |
47 | #else | 48 | * fscrypt superblock flags |
48 | #include <linux/fscrypt_notsupp.h> | 49 | */ |
49 | #endif | 50 | #define FS_CFLG_OWN_PAGES (1U << 1) |
51 | |||
52 | /* | ||
53 | * crypto operations for filesystems | ||
54 | */ | ||
55 | struct fscrypt_operations { | ||
56 | unsigned int flags; | ||
57 | const char *key_prefix; | ||
58 | int (*get_context)(struct inode *, void *, size_t); | ||
59 | int (*set_context)(struct inode *, const void *, size_t, void *); | ||
60 | bool (*dummy_context)(struct inode *); | ||
61 | bool (*empty_dir)(struct inode *); | ||
62 | unsigned int max_namelen; | ||
63 | }; | ||
64 | |||
65 | struct fscrypt_ctx { | ||
66 | union { | ||
67 | struct { | ||
68 | struct page *bounce_page; /* Ciphertext page */ | ||
69 | struct page *control_page; /* Original page */ | ||
70 | } w; | ||
71 | struct { | ||
72 | struct bio *bio; | ||
73 | struct work_struct work; | ||
74 | } r; | ||
75 | struct list_head free_list; /* Free list */ | ||
76 | }; | ||
77 | u8 flags; /* Flags */ | ||
78 | }; | ||
79 | |||
80 | static inline bool fscrypt_has_encryption_key(const struct inode *inode) | ||
81 | { | ||
82 | return (inode->i_crypt_info != NULL); | ||
83 | } | ||
84 | |||
85 | static inline bool fscrypt_dummy_context_enabled(struct inode *inode) | ||
86 | { | ||
87 | return inode->i_sb->s_cop->dummy_context && | ||
88 | inode->i_sb->s_cop->dummy_context(inode); | ||
89 | } | ||
90 | |||
91 | /* crypto.c */ | ||
92 | extern void fscrypt_enqueue_decrypt_work(struct work_struct *); | ||
93 | extern struct fscrypt_ctx *fscrypt_get_ctx(const struct inode *, gfp_t); | ||
94 | extern void fscrypt_release_ctx(struct fscrypt_ctx *); | ||
95 | extern struct page *fscrypt_encrypt_page(const struct inode *, struct page *, | ||
96 | unsigned int, unsigned int, | ||
97 | u64, gfp_t); | ||
98 | extern int fscrypt_decrypt_page(const struct inode *, struct page *, unsigned int, | ||
99 | unsigned int, u64); | ||
100 | |||
101 | static inline struct page *fscrypt_control_page(struct page *page) | ||
102 | { | ||
103 | return ((struct fscrypt_ctx *)page_private(page))->w.control_page; | ||
104 | } | ||
105 | |||
106 | extern void fscrypt_restore_control_page(struct page *); | ||
107 | |||
108 | /* policy.c */ | ||
109 | extern int fscrypt_ioctl_set_policy(struct file *, const void __user *); | ||
110 | extern int fscrypt_ioctl_get_policy(struct file *, void __user *); | ||
111 | extern int fscrypt_has_permitted_context(struct inode *, struct inode *); | ||
112 | extern int fscrypt_inherit_context(struct inode *, struct inode *, | ||
113 | void *, bool); | ||
114 | /* keyinfo.c */ | ||
115 | extern int fscrypt_get_encryption_info(struct inode *); | ||
116 | extern void fscrypt_put_encryption_info(struct inode *); | ||
117 | |||
118 | /* fname.c */ | ||
119 | extern int fscrypt_setup_filename(struct inode *, const struct qstr *, | ||
120 | int lookup, struct fscrypt_name *); | ||
121 | |||
122 | static inline void fscrypt_free_filename(struct fscrypt_name *fname) | ||
123 | { | ||
124 | kfree(fname->crypto_buf.name); | ||
125 | } | ||
126 | |||
127 | extern int fscrypt_fname_alloc_buffer(const struct inode *, u32, | ||
128 | struct fscrypt_str *); | ||
129 | extern void fscrypt_fname_free_buffer(struct fscrypt_str *); | ||
130 | extern int fscrypt_fname_disk_to_usr(struct inode *, u32, u32, | ||
131 | const struct fscrypt_str *, struct fscrypt_str *); | ||
132 | |||
133 | #define FSCRYPT_FNAME_MAX_UNDIGESTED_SIZE 32 | ||
134 | |||
135 | /* Extracts the second-to-last ciphertext block; see explanation below */ | ||
136 | #define FSCRYPT_FNAME_DIGEST(name, len) \ | ||
137 | ((name) + round_down((len) - FS_CRYPTO_BLOCK_SIZE - 1, \ | ||
138 | FS_CRYPTO_BLOCK_SIZE)) | ||
139 | |||
140 | #define FSCRYPT_FNAME_DIGEST_SIZE FS_CRYPTO_BLOCK_SIZE | ||
141 | |||
142 | /** | ||
143 | * fscrypt_digested_name - alternate identifier for an on-disk filename | ||
144 | * | ||
145 | * When userspace lists an encrypted directory without access to the key, | ||
146 | * filenames whose ciphertext is longer than FSCRYPT_FNAME_MAX_UNDIGESTED_SIZE | ||
147 | * bytes are shown in this abbreviated form (base64-encoded) rather than as the | ||
148 | * full ciphertext (base64-encoded). This is necessary to allow supporting | ||
149 | * filenames up to NAME_MAX bytes, since base64 encoding expands the length. | ||
150 | * | ||
151 | * To make it possible for filesystems to still find the correct directory entry | ||
152 | * despite not knowing the full on-disk name, we encode any filesystem-specific | ||
153 | * 'hash' and/or 'minor_hash' which the filesystem may need for its lookups, | ||
154 | * followed by the second-to-last ciphertext block of the filename. Due to the | ||
155 | * use of the CBC-CTS encryption mode, the second-to-last ciphertext block | ||
156 | * depends on the full plaintext. (Note that ciphertext stealing causes the | ||
157 | * last two blocks to appear "flipped".) This makes accidental collisions very | ||
158 | * unlikely: just a 1 in 2^128 chance for two filenames to collide even if they | ||
159 | * share the same filesystem-specific hashes. | ||
160 | * | ||
161 | * However, this scheme isn't immune to intentional collisions, which can be | ||
162 | * created by anyone able to create arbitrary plaintext filenames and view them | ||
163 | * without the key. Making the "digest" be a real cryptographic hash like | ||
164 | * SHA-256 over the full ciphertext would prevent this, although it would be | ||
165 | * less efficient and harder to implement, especially since the filesystem would | ||
166 | * need to calculate it for each directory entry examined during a search. | ||
167 | */ | ||
168 | struct fscrypt_digested_name { | ||
169 | u32 hash; | ||
170 | u32 minor_hash; | ||
171 | u8 digest[FSCRYPT_FNAME_DIGEST_SIZE]; | ||
172 | }; | ||
173 | |||
174 | /** | ||
175 | * fscrypt_match_name() - test whether the given name matches a directory entry | ||
176 | * @fname: the name being searched for | ||
177 | * @de_name: the name from the directory entry | ||
178 | * @de_name_len: the length of @de_name in bytes | ||
179 | * | ||
180 | * Normally @fname->disk_name will be set, and in that case we simply compare | ||
181 | * that to the name stored in the directory entry. The only exception is that | ||
182 | * if we don't have the key for an encrypted directory and a filename in it is | ||
183 | * very long, then we won't have the full disk_name and we'll instead need to | ||
184 | * match against the fscrypt_digested_name. | ||
185 | * | ||
186 | * Return: %true if the name matches, otherwise %false. | ||
187 | */ | ||
188 | static inline bool fscrypt_match_name(const struct fscrypt_name *fname, | ||
189 | const u8 *de_name, u32 de_name_len) | ||
190 | { | ||
191 | if (unlikely(!fname->disk_name.name)) { | ||
192 | const struct fscrypt_digested_name *n = | ||
193 | (const void *)fname->crypto_buf.name; | ||
194 | if (WARN_ON_ONCE(fname->usr_fname->name[0] != '_')) | ||
195 | return false; | ||
196 | if (de_name_len <= FSCRYPT_FNAME_MAX_UNDIGESTED_SIZE) | ||
197 | return false; | ||
198 | return !memcmp(FSCRYPT_FNAME_DIGEST(de_name, de_name_len), | ||
199 | n->digest, FSCRYPT_FNAME_DIGEST_SIZE); | ||
200 | } | ||
201 | |||
202 | if (de_name_len != fname->disk_name.len) | ||
203 | return false; | ||
204 | return !memcmp(de_name, fname->disk_name.name, fname->disk_name.len); | ||
205 | } | ||
206 | |||
207 | /* bio.c */ | ||
208 | extern void fscrypt_decrypt_bio(struct bio *); | ||
209 | extern void fscrypt_enqueue_decrypt_bio(struct fscrypt_ctx *ctx, | ||
210 | struct bio *bio); | ||
211 | extern void fscrypt_pullback_bio_page(struct page **, bool); | ||
212 | extern int fscrypt_zeroout_range(const struct inode *, pgoff_t, sector_t, | ||
213 | unsigned int); | ||
214 | |||
215 | /* hooks.c */ | ||
216 | extern int fscrypt_file_open(struct inode *inode, struct file *filp); | ||
217 | extern int __fscrypt_prepare_link(struct inode *inode, struct inode *dir); | ||
218 | extern int __fscrypt_prepare_rename(struct inode *old_dir, | ||
219 | struct dentry *old_dentry, | ||
220 | struct inode *new_dir, | ||
221 | struct dentry *new_dentry, | ||
222 | unsigned int flags); | ||
223 | extern int __fscrypt_prepare_lookup(struct inode *dir, struct dentry *dentry); | ||
224 | extern int __fscrypt_prepare_symlink(struct inode *dir, unsigned int len, | ||
225 | unsigned int max_len, | ||
226 | struct fscrypt_str *disk_link); | ||
227 | extern int __fscrypt_encrypt_symlink(struct inode *inode, const char *target, | ||
228 | unsigned int len, | ||
229 | struct fscrypt_str *disk_link); | ||
230 | extern const char *fscrypt_get_symlink(struct inode *inode, const void *caddr, | ||
231 | unsigned int max_size, | ||
232 | struct delayed_call *done); | ||
233 | #else /* !CONFIG_FS_ENCRYPTION */ | ||
234 | |||
235 | static inline bool fscrypt_has_encryption_key(const struct inode *inode) | ||
236 | { | ||
237 | return false; | ||
238 | } | ||
239 | |||
240 | static inline bool fscrypt_dummy_context_enabled(struct inode *inode) | ||
241 | { | ||
242 | return false; | ||
243 | } | ||
244 | |||
245 | /* crypto.c */ | ||
246 | static inline void fscrypt_enqueue_decrypt_work(struct work_struct *work) | ||
247 | { | ||
248 | } | ||
249 | |||
250 | static inline struct fscrypt_ctx *fscrypt_get_ctx(const struct inode *inode, | ||
251 | gfp_t gfp_flags) | ||
252 | { | ||
253 | return ERR_PTR(-EOPNOTSUPP); | ||
254 | } | ||
255 | |||
256 | static inline void fscrypt_release_ctx(struct fscrypt_ctx *ctx) | ||
257 | { | ||
258 | return; | ||
259 | } | ||
260 | |||
261 | static inline struct page *fscrypt_encrypt_page(const struct inode *inode, | ||
262 | struct page *page, | ||
263 | unsigned int len, | ||
264 | unsigned int offs, | ||
265 | u64 lblk_num, gfp_t gfp_flags) | ||
266 | { | ||
267 | return ERR_PTR(-EOPNOTSUPP); | ||
268 | } | ||
269 | |||
270 | static inline int fscrypt_decrypt_page(const struct inode *inode, | ||
271 | struct page *page, | ||
272 | unsigned int len, unsigned int offs, | ||
273 | u64 lblk_num) | ||
274 | { | ||
275 | return -EOPNOTSUPP; | ||
276 | } | ||
277 | |||
278 | static inline struct page *fscrypt_control_page(struct page *page) | ||
279 | { | ||
280 | WARN_ON_ONCE(1); | ||
281 | return ERR_PTR(-EINVAL); | ||
282 | } | ||
283 | |||
284 | static inline void fscrypt_restore_control_page(struct page *page) | ||
285 | { | ||
286 | return; | ||
287 | } | ||
288 | |||
289 | /* policy.c */ | ||
290 | static inline int fscrypt_ioctl_set_policy(struct file *filp, | ||
291 | const void __user *arg) | ||
292 | { | ||
293 | return -EOPNOTSUPP; | ||
294 | } | ||
295 | |||
296 | static inline int fscrypt_ioctl_get_policy(struct file *filp, void __user *arg) | ||
297 | { | ||
298 | return -EOPNOTSUPP; | ||
299 | } | ||
300 | |||
301 | static inline int fscrypt_has_permitted_context(struct inode *parent, | ||
302 | struct inode *child) | ||
303 | { | ||
304 | return 0; | ||
305 | } | ||
306 | |||
307 | static inline int fscrypt_inherit_context(struct inode *parent, | ||
308 | struct inode *child, | ||
309 | void *fs_data, bool preload) | ||
310 | { | ||
311 | return -EOPNOTSUPP; | ||
312 | } | ||
313 | |||
314 | /* keyinfo.c */ | ||
315 | static inline int fscrypt_get_encryption_info(struct inode *inode) | ||
316 | { | ||
317 | return -EOPNOTSUPP; | ||
318 | } | ||
319 | |||
320 | static inline void fscrypt_put_encryption_info(struct inode *inode) | ||
321 | { | ||
322 | return; | ||
323 | } | ||
324 | |||
325 | /* fname.c */ | ||
326 | static inline int fscrypt_setup_filename(struct inode *dir, | ||
327 | const struct qstr *iname, | ||
328 | int lookup, struct fscrypt_name *fname) | ||
329 | { | ||
330 | if (IS_ENCRYPTED(dir)) | ||
331 | return -EOPNOTSUPP; | ||
332 | |||
333 | memset(fname, 0, sizeof(struct fscrypt_name)); | ||
334 | fname->usr_fname = iname; | ||
335 | fname->disk_name.name = (unsigned char *)iname->name; | ||
336 | fname->disk_name.len = iname->len; | ||
337 | return 0; | ||
338 | } | ||
339 | |||
340 | static inline void fscrypt_free_filename(struct fscrypt_name *fname) | ||
341 | { | ||
342 | return; | ||
343 | } | ||
344 | |||
345 | static inline int fscrypt_fname_alloc_buffer(const struct inode *inode, | ||
346 | u32 max_encrypted_len, | ||
347 | struct fscrypt_str *crypto_str) | ||
348 | { | ||
349 | return -EOPNOTSUPP; | ||
350 | } | ||
351 | |||
352 | static inline void fscrypt_fname_free_buffer(struct fscrypt_str *crypto_str) | ||
353 | { | ||
354 | return; | ||
355 | } | ||
356 | |||
357 | static inline int fscrypt_fname_disk_to_usr(struct inode *inode, | ||
358 | u32 hash, u32 minor_hash, | ||
359 | const struct fscrypt_str *iname, | ||
360 | struct fscrypt_str *oname) | ||
361 | { | ||
362 | return -EOPNOTSUPP; | ||
363 | } | ||
364 | |||
365 | static inline bool fscrypt_match_name(const struct fscrypt_name *fname, | ||
366 | const u8 *de_name, u32 de_name_len) | ||
367 | { | ||
368 | /* Encryption support disabled; use standard comparison */ | ||
369 | if (de_name_len != fname->disk_name.len) | ||
370 | return false; | ||
371 | return !memcmp(de_name, fname->disk_name.name, fname->disk_name.len); | ||
372 | } | ||
373 | |||
374 | /* bio.c */ | ||
375 | static inline void fscrypt_decrypt_bio(struct bio *bio) | ||
376 | { | ||
377 | } | ||
378 | |||
379 | static inline void fscrypt_enqueue_decrypt_bio(struct fscrypt_ctx *ctx, | ||
380 | struct bio *bio) | ||
381 | { | ||
382 | } | ||
383 | |||
384 | static inline void fscrypt_pullback_bio_page(struct page **page, bool restore) | ||
385 | { | ||
386 | return; | ||
387 | } | ||
388 | |||
389 | static inline int fscrypt_zeroout_range(const struct inode *inode, pgoff_t lblk, | ||
390 | sector_t pblk, unsigned int len) | ||
391 | { | ||
392 | return -EOPNOTSUPP; | ||
393 | } | ||
394 | |||
395 | /* hooks.c */ | ||
396 | |||
397 | static inline int fscrypt_file_open(struct inode *inode, struct file *filp) | ||
398 | { | ||
399 | if (IS_ENCRYPTED(inode)) | ||
400 | return -EOPNOTSUPP; | ||
401 | return 0; | ||
402 | } | ||
403 | |||
404 | static inline int __fscrypt_prepare_link(struct inode *inode, | ||
405 | struct inode *dir) | ||
406 | { | ||
407 | return -EOPNOTSUPP; | ||
408 | } | ||
409 | |||
410 | static inline int __fscrypt_prepare_rename(struct inode *old_dir, | ||
411 | struct dentry *old_dentry, | ||
412 | struct inode *new_dir, | ||
413 | struct dentry *new_dentry, | ||
414 | unsigned int flags) | ||
415 | { | ||
416 | return -EOPNOTSUPP; | ||
417 | } | ||
418 | |||
419 | static inline int __fscrypt_prepare_lookup(struct inode *dir, | ||
420 | struct dentry *dentry) | ||
421 | { | ||
422 | return -EOPNOTSUPP; | ||
423 | } | ||
424 | |||
425 | static inline int __fscrypt_prepare_symlink(struct inode *dir, | ||
426 | unsigned int len, | ||
427 | unsigned int max_len, | ||
428 | struct fscrypt_str *disk_link) | ||
429 | { | ||
430 | return -EOPNOTSUPP; | ||
431 | } | ||
432 | |||
433 | |||
434 | static inline int __fscrypt_encrypt_symlink(struct inode *inode, | ||
435 | const char *target, | ||
436 | unsigned int len, | ||
437 | struct fscrypt_str *disk_link) | ||
438 | { | ||
439 | return -EOPNOTSUPP; | ||
440 | } | ||
441 | |||
442 | static inline const char *fscrypt_get_symlink(struct inode *inode, | ||
443 | const void *caddr, | ||
444 | unsigned int max_size, | ||
445 | struct delayed_call *done) | ||
446 | { | ||
447 | return ERR_PTR(-EOPNOTSUPP); | ||
448 | } | ||
449 | #endif /* !CONFIG_FS_ENCRYPTION */ | ||
50 | 450 | ||
51 | /** | 451 | /** |
52 | * fscrypt_require_key - require an inode's encryption key | 452 | * fscrypt_require_key - require an inode's encryption key |
diff --git a/include/linux/fscrypt_notsupp.h b/include/linux/fscrypt_notsupp.h deleted file mode 100644 index ee8b43e4c15a..000000000000 --- a/include/linux/fscrypt_notsupp.h +++ /dev/null | |||
@@ -1,231 +0,0 @@ | |||
1 | /* SPDX-License-Identifier: GPL-2.0 */ | ||
2 | /* | ||
3 | * fscrypt_notsupp.h | ||
4 | * | ||
5 | * This stubs out the fscrypt functions for filesystems configured without | ||
6 | * encryption support. | ||
7 | * | ||
8 | * Do not include this file directly. Use fscrypt.h instead! | ||
9 | */ | ||
10 | #ifndef _LINUX_FSCRYPT_H | ||
11 | #error "Incorrect include of linux/fscrypt_notsupp.h!" | ||
12 | #endif | ||
13 | |||
14 | #ifndef _LINUX_FSCRYPT_NOTSUPP_H | ||
15 | #define _LINUX_FSCRYPT_NOTSUPP_H | ||
16 | |||
17 | static inline bool fscrypt_has_encryption_key(const struct inode *inode) | ||
18 | { | ||
19 | return false; | ||
20 | } | ||
21 | |||
22 | static inline bool fscrypt_dummy_context_enabled(struct inode *inode) | ||
23 | { | ||
24 | return false; | ||
25 | } | ||
26 | |||
27 | /* crypto.c */ | ||
28 | static inline void fscrypt_enqueue_decrypt_work(struct work_struct *work) | ||
29 | { | ||
30 | } | ||
31 | |||
32 | static inline struct fscrypt_ctx *fscrypt_get_ctx(const struct inode *inode, | ||
33 | gfp_t gfp_flags) | ||
34 | { | ||
35 | return ERR_PTR(-EOPNOTSUPP); | ||
36 | } | ||
37 | |||
38 | static inline void fscrypt_release_ctx(struct fscrypt_ctx *ctx) | ||
39 | { | ||
40 | return; | ||
41 | } | ||
42 | |||
43 | static inline struct page *fscrypt_encrypt_page(const struct inode *inode, | ||
44 | struct page *page, | ||
45 | unsigned int len, | ||
46 | unsigned int offs, | ||
47 | u64 lblk_num, gfp_t gfp_flags) | ||
48 | { | ||
49 | return ERR_PTR(-EOPNOTSUPP); | ||
50 | } | ||
51 | |||
52 | static inline int fscrypt_decrypt_page(const struct inode *inode, | ||
53 | struct page *page, | ||
54 | unsigned int len, unsigned int offs, | ||
55 | u64 lblk_num) | ||
56 | { | ||
57 | return -EOPNOTSUPP; | ||
58 | } | ||
59 | |||
60 | static inline struct page *fscrypt_control_page(struct page *page) | ||
61 | { | ||
62 | WARN_ON_ONCE(1); | ||
63 | return ERR_PTR(-EINVAL); | ||
64 | } | ||
65 | |||
66 | static inline void fscrypt_restore_control_page(struct page *page) | ||
67 | { | ||
68 | return; | ||
69 | } | ||
70 | |||
71 | /* policy.c */ | ||
72 | static inline int fscrypt_ioctl_set_policy(struct file *filp, | ||
73 | const void __user *arg) | ||
74 | { | ||
75 | return -EOPNOTSUPP; | ||
76 | } | ||
77 | |||
78 | static inline int fscrypt_ioctl_get_policy(struct file *filp, void __user *arg) | ||
79 | { | ||
80 | return -EOPNOTSUPP; | ||
81 | } | ||
82 | |||
83 | static inline int fscrypt_has_permitted_context(struct inode *parent, | ||
84 | struct inode *child) | ||
85 | { | ||
86 | return 0; | ||
87 | } | ||
88 | |||
89 | static inline int fscrypt_inherit_context(struct inode *parent, | ||
90 | struct inode *child, | ||
91 | void *fs_data, bool preload) | ||
92 | { | ||
93 | return -EOPNOTSUPP; | ||
94 | } | ||
95 | |||
96 | /* keyinfo.c */ | ||
97 | static inline int fscrypt_get_encryption_info(struct inode *inode) | ||
98 | { | ||
99 | return -EOPNOTSUPP; | ||
100 | } | ||
101 | |||
102 | static inline void fscrypt_put_encryption_info(struct inode *inode) | ||
103 | { | ||
104 | return; | ||
105 | } | ||
106 | |||
107 | /* fname.c */ | ||
108 | static inline int fscrypt_setup_filename(struct inode *dir, | ||
109 | const struct qstr *iname, | ||
110 | int lookup, struct fscrypt_name *fname) | ||
111 | { | ||
112 | if (IS_ENCRYPTED(dir)) | ||
113 | return -EOPNOTSUPP; | ||
114 | |||
115 | memset(fname, 0, sizeof(struct fscrypt_name)); | ||
116 | fname->usr_fname = iname; | ||
117 | fname->disk_name.name = (unsigned char *)iname->name; | ||
118 | fname->disk_name.len = iname->len; | ||
119 | return 0; | ||
120 | } | ||
121 | |||
122 | static inline void fscrypt_free_filename(struct fscrypt_name *fname) | ||
123 | { | ||
124 | return; | ||
125 | } | ||
126 | |||
127 | static inline int fscrypt_fname_alloc_buffer(const struct inode *inode, | ||
128 | u32 max_encrypted_len, | ||
129 | struct fscrypt_str *crypto_str) | ||
130 | { | ||
131 | return -EOPNOTSUPP; | ||
132 | } | ||
133 | |||
134 | static inline void fscrypt_fname_free_buffer(struct fscrypt_str *crypto_str) | ||
135 | { | ||
136 | return; | ||
137 | } | ||
138 | |||
139 | static inline int fscrypt_fname_disk_to_usr(struct inode *inode, | ||
140 | u32 hash, u32 minor_hash, | ||
141 | const struct fscrypt_str *iname, | ||
142 | struct fscrypt_str *oname) | ||
143 | { | ||
144 | return -EOPNOTSUPP; | ||
145 | } | ||
146 | |||
147 | static inline bool fscrypt_match_name(const struct fscrypt_name *fname, | ||
148 | const u8 *de_name, u32 de_name_len) | ||
149 | { | ||
150 | /* Encryption support disabled; use standard comparison */ | ||
151 | if (de_name_len != fname->disk_name.len) | ||
152 | return false; | ||
153 | return !memcmp(de_name, fname->disk_name.name, fname->disk_name.len); | ||
154 | } | ||
155 | |||
156 | /* bio.c */ | ||
157 | static inline void fscrypt_decrypt_bio(struct bio *bio) | ||
158 | { | ||
159 | } | ||
160 | |||
161 | static inline void fscrypt_enqueue_decrypt_bio(struct fscrypt_ctx *ctx, | ||
162 | struct bio *bio) | ||
163 | { | ||
164 | } | ||
165 | |||
166 | static inline void fscrypt_pullback_bio_page(struct page **page, bool restore) | ||
167 | { | ||
168 | return; | ||
169 | } | ||
170 | |||
171 | static inline int fscrypt_zeroout_range(const struct inode *inode, pgoff_t lblk, | ||
172 | sector_t pblk, unsigned int len) | ||
173 | { | ||
174 | return -EOPNOTSUPP; | ||
175 | } | ||
176 | |||
177 | /* hooks.c */ | ||
178 | |||
179 | static inline int fscrypt_file_open(struct inode *inode, struct file *filp) | ||
180 | { | ||
181 | if (IS_ENCRYPTED(inode)) | ||
182 | return -EOPNOTSUPP; | ||
183 | return 0; | ||
184 | } | ||
185 | |||
186 | static inline int __fscrypt_prepare_link(struct inode *inode, | ||
187 | struct inode *dir) | ||
188 | { | ||
189 | return -EOPNOTSUPP; | ||
190 | } | ||
191 | |||
192 | static inline int __fscrypt_prepare_rename(struct inode *old_dir, | ||
193 | struct dentry *old_dentry, | ||
194 | struct inode *new_dir, | ||
195 | struct dentry *new_dentry, | ||
196 | unsigned int flags) | ||
197 | { | ||
198 | return -EOPNOTSUPP; | ||
199 | } | ||
200 | |||
201 | static inline int __fscrypt_prepare_lookup(struct inode *dir, | ||
202 | struct dentry *dentry) | ||
203 | { | ||
204 | return -EOPNOTSUPP; | ||
205 | } | ||
206 | |||
207 | static inline int __fscrypt_prepare_symlink(struct inode *dir, | ||
208 | unsigned int len, | ||
209 | unsigned int max_len, | ||
210 | struct fscrypt_str *disk_link) | ||
211 | { | ||
212 | return -EOPNOTSUPP; | ||
213 | } | ||
214 | |||
215 | static inline int __fscrypt_encrypt_symlink(struct inode *inode, | ||
216 | const char *target, | ||
217 | unsigned int len, | ||
218 | struct fscrypt_str *disk_link) | ||
219 | { | ||
220 | return -EOPNOTSUPP; | ||
221 | } | ||
222 | |||
223 | static inline const char *fscrypt_get_symlink(struct inode *inode, | ||
224 | const void *caddr, | ||
225 | unsigned int max_size, | ||
226 | struct delayed_call *done) | ||
227 | { | ||
228 | return ERR_PTR(-EOPNOTSUPP); | ||
229 | } | ||
230 | |||
231 | #endif /* _LINUX_FSCRYPT_NOTSUPP_H */ | ||
diff --git a/include/linux/fscrypt_supp.h b/include/linux/fscrypt_supp.h deleted file mode 100644 index 6456c6b2005f..000000000000 --- a/include/linux/fscrypt_supp.h +++ /dev/null | |||
@@ -1,204 +0,0 @@ | |||
1 | /* SPDX-License-Identifier: GPL-2.0 */ | ||
2 | /* | ||
3 | * fscrypt_supp.h | ||
4 | * | ||
5 | * Do not include this file directly. Use fscrypt.h instead! | ||
6 | */ | ||
7 | #ifndef _LINUX_FSCRYPT_H | ||
8 | #error "Incorrect include of linux/fscrypt_supp.h!" | ||
9 | #endif | ||
10 | |||
11 | #ifndef _LINUX_FSCRYPT_SUPP_H | ||
12 | #define _LINUX_FSCRYPT_SUPP_H | ||
13 | |||
14 | #include <linux/mm.h> | ||
15 | #include <linux/slab.h> | ||
16 | |||
17 | /* | ||
18 | * fscrypt superblock flags | ||
19 | */ | ||
20 | #define FS_CFLG_OWN_PAGES (1U << 1) | ||
21 | |||
22 | /* | ||
23 | * crypto operations for filesystems | ||
24 | */ | ||
25 | struct fscrypt_operations { | ||
26 | unsigned int flags; | ||
27 | const char *key_prefix; | ||
28 | int (*get_context)(struct inode *, void *, size_t); | ||
29 | int (*set_context)(struct inode *, const void *, size_t, void *); | ||
30 | bool (*dummy_context)(struct inode *); | ||
31 | bool (*empty_dir)(struct inode *); | ||
32 | unsigned int max_namelen; | ||
33 | }; | ||
34 | |||
35 | struct fscrypt_ctx { | ||
36 | union { | ||
37 | struct { | ||
38 | struct page *bounce_page; /* Ciphertext page */ | ||
39 | struct page *control_page; /* Original page */ | ||
40 | } w; | ||
41 | struct { | ||
42 | struct bio *bio; | ||
43 | struct work_struct work; | ||
44 | } r; | ||
45 | struct list_head free_list; /* Free list */ | ||
46 | }; | ||
47 | u8 flags; /* Flags */ | ||
48 | }; | ||
49 | |||
50 | static inline bool fscrypt_has_encryption_key(const struct inode *inode) | ||
51 | { | ||
52 | return (inode->i_crypt_info != NULL); | ||
53 | } | ||
54 | |||
55 | static inline bool fscrypt_dummy_context_enabled(struct inode *inode) | ||
56 | { | ||
57 | return inode->i_sb->s_cop->dummy_context && | ||
58 | inode->i_sb->s_cop->dummy_context(inode); | ||
59 | } | ||
60 | |||
61 | /* crypto.c */ | ||
62 | extern void fscrypt_enqueue_decrypt_work(struct work_struct *); | ||
63 | extern struct fscrypt_ctx *fscrypt_get_ctx(const struct inode *, gfp_t); | ||
64 | extern void fscrypt_release_ctx(struct fscrypt_ctx *); | ||
65 | extern struct page *fscrypt_encrypt_page(const struct inode *, struct page *, | ||
66 | unsigned int, unsigned int, | ||
67 | u64, gfp_t); | ||
68 | extern int fscrypt_decrypt_page(const struct inode *, struct page *, unsigned int, | ||
69 | unsigned int, u64); | ||
70 | |||
71 | static inline struct page *fscrypt_control_page(struct page *page) | ||
72 | { | ||
73 | return ((struct fscrypt_ctx *)page_private(page))->w.control_page; | ||
74 | } | ||
75 | |||
76 | extern void fscrypt_restore_control_page(struct page *); | ||
77 | |||
78 | /* policy.c */ | ||
79 | extern int fscrypt_ioctl_set_policy(struct file *, const void __user *); | ||
80 | extern int fscrypt_ioctl_get_policy(struct file *, void __user *); | ||
81 | extern int fscrypt_has_permitted_context(struct inode *, struct inode *); | ||
82 | extern int fscrypt_inherit_context(struct inode *, struct inode *, | ||
83 | void *, bool); | ||
84 | /* keyinfo.c */ | ||
85 | extern int fscrypt_get_encryption_info(struct inode *); | ||
86 | extern void fscrypt_put_encryption_info(struct inode *); | ||
87 | |||
88 | /* fname.c */ | ||
89 | extern int fscrypt_setup_filename(struct inode *, const struct qstr *, | ||
90 | int lookup, struct fscrypt_name *); | ||
91 | |||
92 | static inline void fscrypt_free_filename(struct fscrypt_name *fname) | ||
93 | { | ||
94 | kfree(fname->crypto_buf.name); | ||
95 | } | ||
96 | |||
97 | extern int fscrypt_fname_alloc_buffer(const struct inode *, u32, | ||
98 | struct fscrypt_str *); | ||
99 | extern void fscrypt_fname_free_buffer(struct fscrypt_str *); | ||
100 | extern int fscrypt_fname_disk_to_usr(struct inode *, u32, u32, | ||
101 | const struct fscrypt_str *, struct fscrypt_str *); | ||
102 | |||
103 | #define FSCRYPT_FNAME_MAX_UNDIGESTED_SIZE 32 | ||
104 | |||
105 | /* Extracts the second-to-last ciphertext block; see explanation below */ | ||
106 | #define FSCRYPT_FNAME_DIGEST(name, len) \ | ||
107 | ((name) + round_down((len) - FS_CRYPTO_BLOCK_SIZE - 1, \ | ||
108 | FS_CRYPTO_BLOCK_SIZE)) | ||
109 | |||
110 | #define FSCRYPT_FNAME_DIGEST_SIZE FS_CRYPTO_BLOCK_SIZE | ||
111 | |||
112 | /** | ||
113 | * fscrypt_digested_name - alternate identifier for an on-disk filename | ||
114 | * | ||
115 | * When userspace lists an encrypted directory without access to the key, | ||
116 | * filenames whose ciphertext is longer than FSCRYPT_FNAME_MAX_UNDIGESTED_SIZE | ||
117 | * bytes are shown in this abbreviated form (base64-encoded) rather than as the | ||
118 | * full ciphertext (base64-encoded). This is necessary to allow supporting | ||
119 | * filenames up to NAME_MAX bytes, since base64 encoding expands the length. | ||
120 | * | ||
121 | * To make it possible for filesystems to still find the correct directory entry | ||
122 | * despite not knowing the full on-disk name, we encode any filesystem-specific | ||
123 | * 'hash' and/or 'minor_hash' which the filesystem may need for its lookups, | ||
124 | * followed by the second-to-last ciphertext block of the filename. Due to the | ||
125 | * use of the CBC-CTS encryption mode, the second-to-last ciphertext block | ||
126 | * depends on the full plaintext. (Note that ciphertext stealing causes the | ||
127 | * last two blocks to appear "flipped".) This makes accidental collisions very | ||
128 | * unlikely: just a 1 in 2^128 chance for two filenames to collide even if they | ||
129 | * share the same filesystem-specific hashes. | ||
130 | * | ||
131 | * However, this scheme isn't immune to intentional collisions, which can be | ||
132 | * created by anyone able to create arbitrary plaintext filenames and view them | ||
133 | * without the key. Making the "digest" be a real cryptographic hash like | ||
134 | * SHA-256 over the full ciphertext would prevent this, although it would be | ||
135 | * less efficient and harder to implement, especially since the filesystem would | ||
136 | * need to calculate it for each directory entry examined during a search. | ||
137 | */ | ||
138 | struct fscrypt_digested_name { | ||
139 | u32 hash; | ||
140 | u32 minor_hash; | ||
141 | u8 digest[FSCRYPT_FNAME_DIGEST_SIZE]; | ||
142 | }; | ||
143 | |||
144 | /** | ||
145 | * fscrypt_match_name() - test whether the given name matches a directory entry | ||
146 | * @fname: the name being searched for | ||
147 | * @de_name: the name from the directory entry | ||
148 | * @de_name_len: the length of @de_name in bytes | ||
149 | * | ||
150 | * Normally @fname->disk_name will be set, and in that case we simply compare | ||
151 | * that to the name stored in the directory entry. The only exception is that | ||
152 | * if we don't have the key for an encrypted directory and a filename in it is | ||
153 | * very long, then we won't have the full disk_name and we'll instead need to | ||
154 | * match against the fscrypt_digested_name. | ||
155 | * | ||
156 | * Return: %true if the name matches, otherwise %false. | ||
157 | */ | ||
158 | static inline bool fscrypt_match_name(const struct fscrypt_name *fname, | ||
159 | const u8 *de_name, u32 de_name_len) | ||
160 | { | ||
161 | if (unlikely(!fname->disk_name.name)) { | ||
162 | const struct fscrypt_digested_name *n = | ||
163 | (const void *)fname->crypto_buf.name; | ||
164 | if (WARN_ON_ONCE(fname->usr_fname->name[0] != '_')) | ||
165 | return false; | ||
166 | if (de_name_len <= FSCRYPT_FNAME_MAX_UNDIGESTED_SIZE) | ||
167 | return false; | ||
168 | return !memcmp(FSCRYPT_FNAME_DIGEST(de_name, de_name_len), | ||
169 | n->digest, FSCRYPT_FNAME_DIGEST_SIZE); | ||
170 | } | ||
171 | |||
172 | if (de_name_len != fname->disk_name.len) | ||
173 | return false; | ||
174 | return !memcmp(de_name, fname->disk_name.name, fname->disk_name.len); | ||
175 | } | ||
176 | |||
177 | /* bio.c */ | ||
178 | extern void fscrypt_decrypt_bio(struct bio *); | ||
179 | extern void fscrypt_enqueue_decrypt_bio(struct fscrypt_ctx *ctx, | ||
180 | struct bio *bio); | ||
181 | extern void fscrypt_pullback_bio_page(struct page **, bool); | ||
182 | extern int fscrypt_zeroout_range(const struct inode *, pgoff_t, sector_t, | ||
183 | unsigned int); | ||
184 | |||
185 | /* hooks.c */ | ||
186 | extern int fscrypt_file_open(struct inode *inode, struct file *filp); | ||
187 | extern int __fscrypt_prepare_link(struct inode *inode, struct inode *dir); | ||
188 | extern int __fscrypt_prepare_rename(struct inode *old_dir, | ||
189 | struct dentry *old_dentry, | ||
190 | struct inode *new_dir, | ||
191 | struct dentry *new_dentry, | ||
192 | unsigned int flags); | ||
193 | extern int __fscrypt_prepare_lookup(struct inode *dir, struct dentry *dentry); | ||
194 | extern int __fscrypt_prepare_symlink(struct inode *dir, unsigned int len, | ||
195 | unsigned int max_len, | ||
196 | struct fscrypt_str *disk_link); | ||
197 | extern int __fscrypt_encrypt_symlink(struct inode *inode, const char *target, | ||
198 | unsigned int len, | ||
199 | struct fscrypt_str *disk_link); | ||
200 | extern const char *fscrypt_get_symlink(struct inode *inode, const void *caddr, | ||
201 | unsigned int max_size, | ||
202 | struct delayed_call *done); | ||
203 | |||
204 | #endif /* _LINUX_FSCRYPT_SUPP_H */ | ||