]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
crypto: skcipher - Set tfm in SYNC_SKCIPHER_REQUEST_ON_STACK
authorHerbert Xu <herbert@gondor.apana.org.au>
Fri, 14 Feb 2025 06:02:08 +0000 (14:02 +0800)
committerHerbert Xu <herbert@gondor.apana.org.au>
Sat, 22 Feb 2025 07:56:03 +0000 (15:56 +0800)
Set the request tfm directly in SYNC_SKCIPHER_REQUEST_ON_STACK since
the tfm is already available.

Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
include/crypto/skcipher.h

index 18a86e0af0168470c74205c4bb3ef92b76e59b53..9e5853464345bffae55103e79a276c7f614e2b62 100644 (file)
@@ -214,16 +214,17 @@ struct lskcipher_alg {
 
 #define MAX_SYNC_SKCIPHER_REQSIZE      384
 /*
- * This performs a type-check against the "tfm" argument to make sure
+ * This performs a type-check against the "_tfm" argument to make sure
  * all users have the correct skcipher tfm for doing on-stack requests.
  */
-#define SYNC_SKCIPHER_REQUEST_ON_STACK(name, tfm) \
+#define SYNC_SKCIPHER_REQUEST_ON_STACK(name, _tfm) \
        char __##name##_desc[sizeof(struct skcipher_request) + \
-                            MAX_SYNC_SKCIPHER_REQSIZE + \
-                            (!(sizeof((struct crypto_sync_skcipher *)1 == \
-                                      (typeof(tfm))1))) \
+                            MAX_SYNC_SKCIPHER_REQSIZE \
                            ] CRYPTO_MINALIGN_ATTR; \
-       struct skcipher_request *name = (void *)__##name##_desc
+       struct skcipher_request *name = \
+               (((struct skcipher_request *)__##name##_desc)->base.tfm = \
+                       crypto_sync_skcipher_tfm((_tfm)), \
+                (void *)__##name##_desc)
 
 /**
  * DOC: Symmetric Key Cipher API
@@ -311,6 +312,12 @@ static inline struct crypto_tfm *crypto_lskcipher_tfm(
        return &tfm->base;
 }
 
+static inline struct crypto_tfm *crypto_sync_skcipher_tfm(
+       struct crypto_sync_skcipher *tfm)
+{
+       return crypto_skcipher_tfm(&tfm->base);
+}
+
 /**
  * crypto_free_skcipher() - zeroize and free cipher handle
  * @tfm: cipher handle to be freed