crypto: aesni-intel - Fix remaining leak in rfc4106_set_hash_key
authorJesper Juhl <jj@chaosbits.net>
Wed, 16 Feb 2011 02:04:09 +0000 (13:04 +1100)
committerHerbert Xu <herbert@gondor.apana.org.au>
Wed, 16 Feb 2011 02:04:09 +0000 (13:04 +1100)
Fix up previous patch that failed to properly fix mem leak in
rfc4106_set_hash_subkey(). This add-on patch; fixes the leak. moves
kfree() out of the error path, returns -ENOMEM rather than -EINVAL when
ablkcipher_request_alloc() fails.

Signed-off-by: Jesper Juhl <jj@chaosbits.net>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
arch/x86/crypto/aesni-intel_glue.c

index e0135526345dd542dc4177d0610d6d3393d76ec9..e0e6340c8dad35be4b4c922b96c44300ea301879 100644 (file)
@@ -874,19 +874,17 @@ rfc4106_set_hash_subkey(u8 *hash_subkey, const u8 *key, unsigned int key_len)
 
        ret = crypto_ablkcipher_setkey(ctr_tfm, key, key_len);
        if (ret)
-               goto out;
+               goto out_free_ablkcipher;
 
+       ret = -ENOMEM;
        req = ablkcipher_request_alloc(ctr_tfm, GFP_KERNEL);
-       if (!req) {
-               ret = -EINVAL;
+       if (!req)
                goto out_free_ablkcipher;
-       }
 
        req_data = kmalloc(sizeof(*req_data), GFP_KERNEL);
-       if (!req_data) {
-               ret = -ENOMEM;
+       if (!req_data)
                goto out_free_request;
-       }
+
        memset(req_data->iv, 0, sizeof(req_data->iv));
 
        /* Clear the data in the hash sub key container to zero.*/
@@ -911,12 +909,11 @@ rfc4106_set_hash_subkey(u8 *hash_subkey, const u8 *key, unsigned int key_len)
                if (!ret)
                        ret = req_data->result.err;
        }
+       kfree(req_data);
 out_free_request:
        ablkcipher_request_free(req);
-       kfree(req_data);
 out_free_ablkcipher:
        crypto_free_ablkcipher(ctr_tfm);
-out:
        return ret;
 }