2016-11-27 04:32:46 +03:00
/*
* fscrypt_private . h
*
* Copyright ( C ) 2015 , Google , Inc .
*
* This contains encryption key functions .
*
* Written by Michael Halcrow , Ildar Muslukhov , and Uday Savagaonkar , 2015.
*/
# ifndef _FSCRYPT_PRIVATE_H
# define _FSCRYPT_PRIVATE_H
2017-01-24 21:58:06 +03:00
# include <linux/fscrypt_supp.h>
2017-06-19 10:27:58 +03:00
# include <crypto/hash.h>
2016-11-27 04:32:46 +03:00
2016-11-27 06:05:18 +03:00
/* Encryption parameters */
2017-06-19 10:27:58 +03:00
# define FS_IV_SIZE 16
2016-11-27 06:05:18 +03:00
# define FS_AES_128_ECB_KEY_SIZE 16
2017-06-19 10:27:58 +03:00
# define FS_AES_128_CBC_KEY_SIZE 16
# define FS_AES_128_CTS_KEY_SIZE 16
2016-11-27 06:05:18 +03:00
# define FS_AES_256_GCM_KEY_SIZE 32
# define FS_AES_256_CBC_KEY_SIZE 32
# define FS_AES_256_CTS_KEY_SIZE 32
# define FS_AES_256_XTS_KEY_SIZE 64
# define FS_KEY_DERIVATION_NONCE_SIZE 16
/**
* Encryption context for inode
*
* Protector format :
* 1 byte : Protector format ( 1 = this version )
* 1 byte : File contents encryption mode
* 1 byte : File names encryption mode
* 1 byte : Flags
* 8 bytes : Master Key descriptor
* 16 bytes : Encryption Key derivation nonce
*/
struct fscrypt_context {
u8 format ;
u8 contents_encryption_mode ;
u8 filenames_encryption_mode ;
u8 flags ;
u8 master_key_descriptor [ FS_KEY_DESCRIPTOR_SIZE ] ;
u8 nonce [ FS_KEY_DERIVATION_NONCE_SIZE ] ;
} __packed ;
# define FS_ENCRYPTION_CONTEXT_FORMAT_V1 1
/*
* A pointer to this structure is stored in the file system ' s in - core
* representation of an inode .
*/
struct fscrypt_info {
u8 ci_data_mode ;
u8 ci_filename_mode ;
u8 ci_flags ;
struct crypto_skcipher * ci_ctfm ;
2017-06-19 10:27:58 +03:00
struct crypto_cipher * ci_essiv_tfm ;
2016-11-27 06:05:18 +03:00
u8 ci_master_key [ FS_KEY_DESCRIPTOR_SIZE ] ;
} ;
2016-12-19 14:25:32 +03:00
typedef enum {
FS_DECRYPT = 0 ,
FS_ENCRYPT ,
} fscrypt_direction_t ;
2016-11-27 06:05:18 +03:00
# define FS_CTX_REQUIRES_FREE_ENCRYPT_FL 0x00000001
2016-12-07 01:53:58 +03:00
# define FS_CTX_HAS_BOUNCE_BUFFER_FL 0x00000002
2016-11-27 06:05:18 +03:00
struct fscrypt_completion_result {
struct completion completion ;
int res ;
} ;
# define DECLARE_FS_COMPLETION_RESULT(ecr) \
struct fscrypt_completion_result ecr = { \
2017-02-01 23:32:09 +03:00
COMPLETION_INITIALIZER_ONSTACK ( ( ecr ) . completion ) , 0 }
2016-11-27 06:05:18 +03:00
2016-11-27 04:43:09 +03:00
/* crypto.c */
2016-12-19 14:25:32 +03:00
extern int fscrypt_initialize ( unsigned int cop_flags ) ;
extern struct workqueue_struct * fscrypt_read_workqueue ;
extern int fscrypt_do_page_crypto ( const struct inode * inode ,
fscrypt_direction_t rw , u64 lblk_num ,
struct page * src_page ,
struct page * dest_page ,
unsigned int len , unsigned int offs ,
gfp_t gfp_flags ) ;
extern struct page * fscrypt_alloc_bounce_page ( struct fscrypt_ctx * ctx ,
gfp_t gfp_flags ) ;
2016-11-27 04:43:09 +03:00
2017-06-19 10:27:58 +03:00
/* keyinfo.c */
extern void __exit fscrypt_essiv_cleanup ( void ) ;
2016-11-27 04:32:46 +03:00
# endif /* _FSCRYPT_PRIVATE_H */