diff mbox

fscrypt: inline fscrypt_free_filename()

Message ID 20170523011406.32718-1-ebiggers3@gmail.com (mailing list archive)
State Accepted
Headers show

Commit Message

Eric Biggers May 23, 2017, 1:14 a.m. UTC
From: Eric Biggers <ebiggers@google.com>

fscrypt_free_filename() only needs to do a kfree() of crypto_buf.name,
which works well as an inline function.  We can skip setting the various
pointers to NULL, since no user cares about it (the name is always freed
just before it goes out of scope).

Signed-off-by: Eric Biggers <ebiggers@google.com>
---
 fs/crypto/fname.c            | 9 ---------
 include/linux/fscrypt_supp.h | 7 ++++++-
 2 files changed, 6 insertions(+), 10 deletions(-)

Comments

David Gstir May 23, 2017, 6:01 a.m. UTC | #1
Hi Eric,

> On 23 May 2017, at 03:14, Eric Biggers <ebiggers3@gmail.com> wrote:
> 
> From: Eric Biggers <ebiggers@google.com>
> 
> fscrypt_free_filename() only needs to do a kfree() of crypto_buf.name,
> which works well as an inline function.  We can skip setting the various
> pointers to NULL, since no user cares about it (the name is always freed
> just before it goes out of scope).
> 
> Signed-off-by: Eric Biggers <ebiggers@google.com>
> ---
> fs/crypto/fname.c            | 9 ---------
> include/linux/fscrypt_supp.h | 7 ++++++-
> 2 files changed, 6 insertions(+), 10 deletions(-)
> 
> diff --git a/fs/crypto/fname.c b/fs/crypto/fname.c
> index d1bb02b1ee58..ad9f814fdead 100644
> --- a/fs/crypto/fname.c
> +++ b/fs/crypto/fname.c
> @@ -453,12 +453,3 @@ int fscrypt_setup_filename(struct inode *dir, const struct qstr *iname,
> 	return ret;
> }
> EXPORT_SYMBOL(fscrypt_setup_filename);
> -
> -void fscrypt_free_filename(struct fscrypt_name *fname)
> -{
> -	kfree(fname->crypto_buf.name);
> -	fname->crypto_buf.name = NULL;
> -	fname->usr_fname = NULL;
> -	fname->disk_name.name = NULL;
> -}
> -EXPORT_SYMBOL(fscrypt_free_filename);
> diff --git a/include/linux/fscrypt_supp.h b/include/linux/fscrypt_supp.h
> index cd4e82c17304..32e2fcf13b01 100644
> --- a/include/linux/fscrypt_supp.h
> +++ b/include/linux/fscrypt_supp.h
> @@ -47,7 +47,12 @@ extern void fscrypt_put_encryption_info(struct inode *, struct fscrypt_info *);
> /* fname.c */
> extern int fscrypt_setup_filename(struct inode *, const struct qstr *,
> 				int lookup, struct fscrypt_name *);
> -extern void fscrypt_free_filename(struct fscrypt_name *);
> +
> +static inline void fscrypt_free_filename(struct fscrypt_name *fname)
> +{
> +	kfree(fname->crypto_buf.name);
> +}
> +
> extern u32 fscrypt_fname_encrypted_size(const struct inode *, u32);
> extern int fscrypt_fname_alloc_buffer(const struct inode *, u32,
> 				struct fscrypt_str *);
> -- 
> 2.13.0.219.gdb65acc882-goog

LGTM.
Reviewed-by: David Gstir <david@sigma-star.at> 

David

--
To unsubscribe from this list: send the line "unsubscribe linux-fscrypt" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Theodore Ts'o June 24, 2017, 12:02 a.m. UTC | #2
On Mon, May 22, 2017 at 06:14:06PM -0700, Eric Biggers wrote:
> From: Eric Biggers <ebiggers@google.com>
> 
> fscrypt_free_filename() only needs to do a kfree() of crypto_buf.name,
> which works well as an inline function.  We can skip setting the various
> pointers to NULL, since no user cares about it (the name is always freed
> just before it goes out of scope).
> 
> Signed-off-by: Eric Biggers <ebiggers@google.com>

Thanks, applied.

					- Ted
--
To unsubscribe from this list: send the line "unsubscribe linux-fscrypt" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
diff mbox

Patch

diff --git a/fs/crypto/fname.c b/fs/crypto/fname.c
index d1bb02b1ee58..ad9f814fdead 100644
--- a/fs/crypto/fname.c
+++ b/fs/crypto/fname.c
@@ -453,12 +453,3 @@  int fscrypt_setup_filename(struct inode *dir, const struct qstr *iname,
 	return ret;
 }
 EXPORT_SYMBOL(fscrypt_setup_filename);
-
-void fscrypt_free_filename(struct fscrypt_name *fname)
-{
-	kfree(fname->crypto_buf.name);
-	fname->crypto_buf.name = NULL;
-	fname->usr_fname = NULL;
-	fname->disk_name.name = NULL;
-}
-EXPORT_SYMBOL(fscrypt_free_filename);
diff --git a/include/linux/fscrypt_supp.h b/include/linux/fscrypt_supp.h
index cd4e82c17304..32e2fcf13b01 100644
--- a/include/linux/fscrypt_supp.h
+++ b/include/linux/fscrypt_supp.h
@@ -47,7 +47,12 @@  extern void fscrypt_put_encryption_info(struct inode *, struct fscrypt_info *);
 /* fname.c */
 extern int fscrypt_setup_filename(struct inode *, const struct qstr *,
 				int lookup, struct fscrypt_name *);
-extern void fscrypt_free_filename(struct fscrypt_name *);
+
+static inline void fscrypt_free_filename(struct fscrypt_name *fname)
+{
+	kfree(fname->crypto_buf.name);
+}
+
 extern u32 fscrypt_fname_encrypted_size(const struct inode *, u32);
 extern int fscrypt_fname_alloc_buffer(const struct inode *, u32,
 				struct fscrypt_str *);