crypto: akcipher - pass instance to crypto_grab_akcipher()
authorEric Biggers <ebiggers@google.com>
Fri, 3 Jan 2020 03:58:47 +0000 (19:58 -0800)
committerHerbert Xu <herbert@gondor.apana.org.au>
Thu, 9 Jan 2020 03:30:54 +0000 (11:30 +0800)
commit73bed26f73a120f14cabf8d214ec5078bb42dea9
treec82fd171ae8bb7698531c82b0f4e8970866e4820
parentcd900f0cacd7601dabdd028e8cbdbf2a7041cee2
crypto: akcipher - pass instance to crypto_grab_akcipher()

Initializing a crypto_akcipher_spawn currently requires:

1. Set spawn->base.inst to point to the instance.
2. Call crypto_grab_akcipher().

But there's no reason for these steps to be separate, and in fact this
unneeded complication has caused at least one bug, the one fixed by
commit 6db43410179b ("crypto: adiantum - initialize crypto_spawn::inst")

So just make crypto_grab_akcipher() take the instance as an argument.

To keep the function call from getting too unwieldy due to this extra
argument, also introduce a 'mask' variable into pkcs1pad_create().

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