1 /**************************************************************************** 2 **************************************************************************** 3 *** 4 *** This header was automatically generated from a Linux kernel header 5 *** of the same name, to make information necessary for userspace to 6 *** call into the kernel available to libc. It contains only constants, 7 *** structures, and macros generated from the original header, and thus, 8 *** contains no copyrightable information. 9 *** 10 *** To edit the content of this header, modify the corresponding 11 *** source file (e.g. under external/kernel-headers/original/) then 12 *** run bionic/libc/kernel/tools/update_all.py 13 *** 14 *** Any manual change here will be lost the next time this script will 15 *** be run. You've been warned! 16 *** 17 **************************************************************************** 18 ****************************************************************************/ 19 #ifndef _UAPI_LINUX_FSCRYPT_H 20 #define _UAPI_LINUX_FSCRYPT_H 21 #include <linux/ioctl.h> 22 #include <linux/types.h> 23 #define FSCRYPT_POLICY_FLAGS_PAD_4 0x00 24 #define FSCRYPT_POLICY_FLAGS_PAD_8 0x01 25 #define FSCRYPT_POLICY_FLAGS_PAD_16 0x02 26 #define FSCRYPT_POLICY_FLAGS_PAD_32 0x03 27 #define FSCRYPT_POLICY_FLAGS_PAD_MASK 0x03 28 #define FSCRYPT_POLICY_FLAG_DIRECT_KEY 0x04 29 #define FSCRYPT_POLICY_FLAG_IV_INO_LBLK_64 0x08 30 #define FSCRYPT_POLICY_FLAG_IV_INO_LBLK_32 0x10 31 #define FSCRYPT_POLICY_FLAGS_VALID 0x1F 32 #define FSCRYPT_MODE_AES_256_XTS 1 33 #define FSCRYPT_MODE_AES_256_CTS 4 34 #define FSCRYPT_MODE_AES_128_CBC 5 35 #define FSCRYPT_MODE_AES_128_CTS 6 36 #define FSCRYPT_MODE_ADIANTUM 9 37 #define __FSCRYPT_MODE_MAX 9 38 #define FSCRYPT_POLICY_V1 0 39 #define FSCRYPT_KEY_DESCRIPTOR_SIZE 8 40 struct fscrypt_policy_v1 { 41 __u8 version; 42 __u8 contents_encryption_mode; 43 __u8 filenames_encryption_mode; 44 __u8 flags; 45 __u8 master_key_descriptor[FSCRYPT_KEY_DESCRIPTOR_SIZE]; 46 }; 47 #define FSCRYPT_KEY_DESC_PREFIX "fscrypt:" 48 #define FSCRYPT_KEY_DESC_PREFIX_SIZE 8 49 #define FSCRYPT_MAX_KEY_SIZE 64 50 struct fscrypt_key { 51 __u32 mode; 52 __u8 raw[FSCRYPT_MAX_KEY_SIZE]; 53 __u32 size; 54 }; 55 #define FSCRYPT_POLICY_V2 2 56 #define FSCRYPT_KEY_IDENTIFIER_SIZE 16 57 struct fscrypt_policy_v2 { 58 __u8 version; 59 __u8 contents_encryption_mode; 60 __u8 filenames_encryption_mode; 61 __u8 flags; 62 __u8 __reserved[4]; 63 __u8 master_key_identifier[FSCRYPT_KEY_IDENTIFIER_SIZE]; 64 }; 65 struct fscrypt_get_policy_ex_arg { 66 __u64 policy_size; 67 union { 68 __u8 version; 69 struct fscrypt_policy_v1 v1; 70 struct fscrypt_policy_v2 v2; 71 } policy; 72 }; 73 #define FSCRYPT_KEY_SPEC_TYPE_DESCRIPTOR 1 74 #define FSCRYPT_KEY_SPEC_TYPE_IDENTIFIER 2 75 struct fscrypt_key_specifier { 76 __u32 type; 77 __u32 __reserved; 78 union { 79 __u8 __reserved[32]; 80 __u8 descriptor[FSCRYPT_KEY_DESCRIPTOR_SIZE]; 81 __u8 identifier[FSCRYPT_KEY_IDENTIFIER_SIZE]; 82 } u; 83 }; 84 struct fscrypt_provisioning_key_payload { 85 __u32 type; 86 __u32 __reserved; 87 __u8 raw[]; 88 }; 89 struct fscrypt_add_key_arg { 90 struct fscrypt_key_specifier key_spec; 91 __u32 raw_size; 92 __u32 key_id; 93 __u32 __reserved[7]; 94 #define __FSCRYPT_ADD_KEY_FLAG_HW_WRAPPED 0x00000001 95 __u32 __flags; 96 __u8 raw[]; 97 }; 98 struct fscrypt_remove_key_arg { 99 struct fscrypt_key_specifier key_spec; 100 #define FSCRYPT_KEY_REMOVAL_STATUS_FLAG_FILES_BUSY 0x00000001 101 #define FSCRYPT_KEY_REMOVAL_STATUS_FLAG_OTHER_USERS 0x00000002 102 __u32 removal_status_flags; 103 __u32 __reserved[5]; 104 }; 105 struct fscrypt_get_key_status_arg { 106 struct fscrypt_key_specifier key_spec; 107 __u32 __reserved[6]; 108 #define FSCRYPT_KEY_STATUS_ABSENT 1 109 #define FSCRYPT_KEY_STATUS_PRESENT 2 110 #define FSCRYPT_KEY_STATUS_INCOMPLETELY_REMOVED 3 111 __u32 status; 112 #define FSCRYPT_KEY_STATUS_FLAG_ADDED_BY_SELF 0x00000001 113 __u32 status_flags; 114 __u32 user_count; 115 __u32 __out_reserved[13]; 116 }; 117 #define FS_IOC_SET_ENCRYPTION_POLICY _IOR('f', 19, struct fscrypt_policy_v1) 118 #define FS_IOC_GET_ENCRYPTION_PWSALT _IOW('f', 20, __u8[16]) 119 #define FS_IOC_GET_ENCRYPTION_POLICY _IOW('f', 21, struct fscrypt_policy_v1) 120 #define FS_IOC_GET_ENCRYPTION_POLICY_EX _IOWR('f', 22, __u8[9]) 121 #define FS_IOC_ADD_ENCRYPTION_KEY _IOWR('f', 23, struct fscrypt_add_key_arg) 122 #define FS_IOC_REMOVE_ENCRYPTION_KEY _IOWR('f', 24, struct fscrypt_remove_key_arg) 123 #define FS_IOC_REMOVE_ENCRYPTION_KEY_ALL_USERS _IOWR('f', 25, struct fscrypt_remove_key_arg) 124 #define FS_IOC_GET_ENCRYPTION_KEY_STATUS _IOWR('f', 26, struct fscrypt_get_key_status_arg) 125 #define FS_IOC_GET_ENCRYPTION_NONCE _IOR('f', 27, __u8[16]) 126 #define fscrypt_policy fscrypt_policy_v1 127 #define FS_KEY_DESCRIPTOR_SIZE FSCRYPT_KEY_DESCRIPTOR_SIZE 128 #define FS_POLICY_FLAGS_PAD_4 FSCRYPT_POLICY_FLAGS_PAD_4 129 #define FS_POLICY_FLAGS_PAD_8 FSCRYPT_POLICY_FLAGS_PAD_8 130 #define FS_POLICY_FLAGS_PAD_16 FSCRYPT_POLICY_FLAGS_PAD_16 131 #define FS_POLICY_FLAGS_PAD_32 FSCRYPT_POLICY_FLAGS_PAD_32 132 #define FS_POLICY_FLAGS_PAD_MASK FSCRYPT_POLICY_FLAGS_PAD_MASK 133 #define FS_POLICY_FLAG_DIRECT_KEY FSCRYPT_POLICY_FLAG_DIRECT_KEY 134 #define FS_POLICY_FLAGS_VALID FSCRYPT_POLICY_FLAGS_VALID 135 #define FS_ENCRYPTION_MODE_INVALID 0 136 #define FS_ENCRYPTION_MODE_AES_256_XTS FSCRYPT_MODE_AES_256_XTS 137 #define FS_ENCRYPTION_MODE_AES_256_GCM 2 138 #define FS_ENCRYPTION_MODE_AES_256_CBC 3 139 #define FS_ENCRYPTION_MODE_AES_256_CTS FSCRYPT_MODE_AES_256_CTS 140 #define FS_ENCRYPTION_MODE_AES_128_CBC FSCRYPT_MODE_AES_128_CBC 141 #define FS_ENCRYPTION_MODE_AES_128_CTS FSCRYPT_MODE_AES_128_CTS 142 #define FS_ENCRYPTION_MODE_SPECK128_256_XTS 7 143 #define FS_ENCRYPTION_MODE_SPECK128_256_CTS 8 144 #define FS_ENCRYPTION_MODE_ADIANTUM FSCRYPT_MODE_ADIANTUM 145 #define FS_KEY_DESC_PREFIX FSCRYPT_KEY_DESC_PREFIX 146 #define FS_KEY_DESC_PREFIX_SIZE FSCRYPT_KEY_DESC_PREFIX_SIZE 147 #define FS_MAX_KEY_SIZE FSCRYPT_MAX_KEY_SIZE 148 #endif 149