fscrypt: remove the "write" part of struct fscrypt_ctx
authorEric Biggers <ebiggers@google.com>
Mon, 20 May 2019 16:29:40 +0000 (09:29 -0700)
committerEric Biggers <ebiggers@google.com>
Tue, 28 May 2019 17:27:52 +0000 (10:27 -0700)
Now that fscrypt_ctx is not used for writes, remove the 'w' fields.

Reviewed-by: Chandan Rajendra <chandan@linux.ibm.com>
Signed-off-by: Eric Biggers <ebiggers@google.com>
fs/crypto/bio.c
fs/crypto/crypto.c
include/linux/fscrypt.h

index c857b70b5328cc7324d228a856cc3c2488e86e29..c5342534838747d31b1682d94084d483d50329b7 100644 (file)
@@ -53,9 +53,8 @@ EXPORT_SYMBOL(fscrypt_decrypt_bio);
 
 static void completion_pages(struct work_struct *work)
 {
-       struct fscrypt_ctx *ctx =
-               container_of(work, struct fscrypt_ctx, r.work);
-       struct bio *bio = ctx->r.bio;
+       struct fscrypt_ctx *ctx = container_of(work, struct fscrypt_ctx, work);
+       struct bio *bio = ctx->bio;
 
        __fscrypt_decrypt_bio(bio, true);
        fscrypt_release_ctx(ctx);
@@ -64,9 +63,9 @@ static void completion_pages(struct work_struct *work)
 
 void fscrypt_enqueue_decrypt_bio(struct fscrypt_ctx *ctx, struct bio *bio)
 {
-       INIT_WORK(&ctx->r.work, completion_pages);
-       ctx->r.bio = bio;
-       fscrypt_enqueue_decrypt_work(&ctx->r.work);
+       INIT_WORK(&ctx->work, completion_pages);
+       ctx->bio = bio;
+       fscrypt_enqueue_decrypt_work(&ctx->work);
 }
 EXPORT_SYMBOL(fscrypt_enqueue_decrypt_bio);
 
index 881e2a69f8a6cfe437d03b2b11ca0ab437c0903e..9dd7a643eae05728f7338d4a5f7ef259fe18780b 100644 (file)
@@ -59,11 +59,11 @@ void fscrypt_enqueue_decrypt_work(struct work_struct *work)
 EXPORT_SYMBOL(fscrypt_enqueue_decrypt_work);
 
 /**
- * fscrypt_release_ctx() - Releases an encryption context
- * @ctx: The encryption context to release.
+ * fscrypt_release_ctx() - Release a decryption context
+ * @ctx: The decryption context to release.
  *
- * If the encryption context was allocated from the pre-allocated pool, returns
- * it to that pool. Else, frees it.
+ * If the decryption context was allocated from the pre-allocated pool, return
+ * it to that pool.  Else, free it.
  */
 void fscrypt_release_ctx(struct fscrypt_ctx *ctx)
 {
@@ -80,12 +80,12 @@ void fscrypt_release_ctx(struct fscrypt_ctx *ctx)
 EXPORT_SYMBOL(fscrypt_release_ctx);
 
 /**
- * fscrypt_get_ctx() - Gets an encryption context
+ * fscrypt_get_ctx() - Get a decryption context
  * @gfp_flags:   The gfp flag for memory allocation
  *
- * Allocates and initializes an encryption context.
+ * Allocate and initialize a decryption context.
  *
- * Return: A new encryption context on success; an ERR_PTR() otherwise.
+ * Return: A new decryption context on success; an ERR_PTR() otherwise.
  */
 struct fscrypt_ctx *fscrypt_get_ctx(gfp_t gfp_flags)
 {
index d016fa384d607ee81eae1a42a03353b3a11f2737..1c7287f146a98804171c2e0d8455d4573c748c64 100644 (file)
@@ -63,16 +63,13 @@ struct fscrypt_operations {
        unsigned int max_namelen;
 };
 
+/* Decryption work */
 struct fscrypt_ctx {
        union {
-               struct {
-                       struct page *bounce_page;       /* Ciphertext page */
-                       struct page *control_page;      /* Original page  */
-               } w;
                struct {
                        struct bio *bio;
                        struct work_struct work;
-               } r;
+               };
                struct list_head free_list;     /* Free list */
        };
        u8 flags;                               /* Flags */