OSDN Git Service

crypto: ahash - make struct ahash_instance be the full size
authorEric Biggers <ebiggers@google.com>
Fri, 3 Jan 2020 03:58:44 +0000 (19:58 -0800)
committerHerbert Xu <herbert@gondor.apana.org.au>
Thu, 9 Jan 2020 03:30:54 +0000 (11:30 +0800)
Define struct ahash_instance in a way analogous to struct
skcipher_instance, struct aead_instance, and struct akcipher_instance,
where the struct is defined to include both the algorithm structure at
the beginning and the additional crypto_instance fields at the end.

This is needed to allow allocating ahash instances directly using
kzalloc(sizeof(*inst) + sizeof(*ictx), ...) in the same way as skcipher,
aead, and akcipher instances.  In turn, that's needed to make spawns be
initialized in a consistent way everywhere.

Also take advantage of the addition of the base instance to struct
ahash_instance by simplifying the ahash_crypto_instance() and
ahash_instance() functions.

Signed-off-by: Eric Biggers <ebiggers@google.com>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
include/crypto/internal/hash.h

index 7f25eff..3b426b0 100644 (file)
@@ -30,7 +30,13 @@ struct crypto_hash_walk {
 };
 
 struct ahash_instance {
-       struct ahash_alg alg;
+       union {
+               struct {
+                       char head[offsetof(struct ahash_alg, halg.base)];
+                       struct crypto_instance base;
+               } s;
+               struct ahash_alg alg;
+       };
 };
 
 struct shash_instance {
@@ -155,13 +161,13 @@ static inline void crypto_ahash_set_reqsize(struct crypto_ahash *tfm,
 static inline struct crypto_instance *ahash_crypto_instance(
        struct ahash_instance *inst)
 {
-       return container_of(&inst->alg.halg.base, struct crypto_instance, alg);
+       return &inst->s.base;
 }
 
 static inline struct ahash_instance *ahash_instance(
        struct crypto_instance *inst)
 {
-       return container_of(&inst->alg, struct ahash_instance, alg.halg.base);
+       return container_of(inst, struct ahash_instance, s.base);
 }
 
 static inline void *ahash_instance_ctx(struct ahash_instance *inst)