diff options
Diffstat (limited to 'fs/crypto/crypto.c')
| -rw-r--r-- | fs/crypto/crypto.c | 26 | 
1 files changed, 13 insertions, 13 deletions
| diff --git a/fs/crypto/crypto.c b/fs/crypto/crypto.c index c502c116924c..98f87fe8f186 100644 --- a/fs/crypto/crypto.c +++ b/fs/crypto/crypto.c @@ -28,7 +28,6 @@  #include <linux/dcache.h>  #include <linux/namei.h>  #include <linux/fscrypto.h> -#include <linux/ecryptfs.h>  static unsigned int num_prealloc_crypto_pages = 32;  static unsigned int num_prealloc_crypto_ctxs = 128; @@ -128,11 +127,11 @@ struct fscrypt_ctx *fscrypt_get_ctx(struct inode *inode, gfp_t gfp_flags)  EXPORT_SYMBOL(fscrypt_get_ctx);  /** - * fscrypt_complete() - The completion callback for page encryption - * @req: The asynchronous encryption request context - * @res: The result of the encryption operation + * page_crypt_complete() - completion callback for page crypto + * @req: The asynchronous cipher request context + * @res: The result of the cipher operation   */ -static void fscrypt_complete(struct crypto_async_request *req, int res) +static void page_crypt_complete(struct crypto_async_request *req, int res)  {  	struct fscrypt_completion_result *ecr = req->data; @@ -152,7 +151,10 @@ static int do_page_crypto(struct inode *inode,  			struct page *src_page, struct page *dest_page,  			gfp_t gfp_flags)  { -	u8 xts_tweak[FS_XTS_TWEAK_SIZE]; +	struct { +		__le64 index; +		u8 padding[FS_XTS_TWEAK_SIZE - sizeof(__le64)]; +	} xts_tweak;  	struct skcipher_request *req = NULL;  	DECLARE_FS_COMPLETION_RESULT(ecr);  	struct scatterlist dst, src; @@ -170,19 +172,17 @@ static int do_page_crypto(struct inode *inode,  	skcipher_request_set_callback(  		req, CRYPTO_TFM_REQ_MAY_BACKLOG | CRYPTO_TFM_REQ_MAY_SLEEP, -		fscrypt_complete, &ecr); +		page_crypt_complete, &ecr); -	BUILD_BUG_ON(FS_XTS_TWEAK_SIZE < sizeof(index)); -	memcpy(xts_tweak, &index, sizeof(index)); -	memset(&xts_tweak[sizeof(index)], 0, -			FS_XTS_TWEAK_SIZE - sizeof(index)); +	BUILD_BUG_ON(sizeof(xts_tweak) != FS_XTS_TWEAK_SIZE); +	xts_tweak.index = cpu_to_le64(index); +	memset(xts_tweak.padding, 0, sizeof(xts_tweak.padding));  	sg_init_table(&dst, 1);  	sg_set_page(&dst, dest_page, PAGE_SIZE, 0);  	sg_init_table(&src, 1);  	sg_set_page(&src, src_page, PAGE_SIZE, 0); -	skcipher_request_set_crypt(req, &src, &dst, PAGE_SIZE, -					xts_tweak); +	skcipher_request_set_crypt(req, &src, &dst, PAGE_SIZE, &xts_tweak);  	if (rw == FS_DECRYPT)  		res = crypto_skcipher_decrypt(req);  	else |