crypto: shash - Move null setkey check to registration time
authorHerbert Xu <herbert@gondor.apana.org.au>
Sat, 11 Jul 2009 14:17:39 +0000 (22:17 +0800)
committerHerbert Xu <herbert@gondor.apana.org.au>
Sun, 12 Jul 2009 02:46:02 +0000 (10:46 +0800)
This patch moves the run-time null setkey check to shash_prepare_alg
just like we did for finup/digest.

Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
crypto/shash.c

index f7fcc652ff3260996b1ec13afe8474a3b09e25b4..131e14d2b57215d4ac360b710e1013abbe5833e3 100644 (file)
 
 static const struct crypto_type crypto_shash_type;
 
+static int shash_no_setkey(struct crypto_shash *tfm, const u8 *key,
+                          unsigned int keylen)
+{
+       return -ENOSYS;
+}
+
 static int shash_setkey_unaligned(struct crypto_shash *tfm, const u8 *key,
                                  unsigned int keylen)
 {
@@ -50,9 +56,6 @@ int crypto_shash_setkey(struct crypto_shash *tfm, const u8 *key,
        struct shash_alg *shash = crypto_shash_alg(tfm);
        unsigned long alignmask = crypto_shash_alignmask(tfm);
 
-       if (!shash->setkey)
-               return -ENOSYS;
-
        if ((unsigned long)key & alignmask)
                return shash_setkey_unaligned(tfm, key, keylen);
 
@@ -494,6 +497,8 @@ static int shash_prepare_alg(struct shash_alg *alg)
                alg->import = shash_no_import;
        if (!alg->export)
                alg->export = shash_no_export;
+       if (!alg->setkey)
+               alg->setkey = shash_no_setkey;
 
        return 0;
 }