crypto: tiger - use crypto_[un]register_shashes
authorJussi Kivilinna <jussi.kivilinna@mbnet.fi>
Wed, 11 Jul 2012 11:20:25 +0000 (14:20 +0300)
committerHerbert Xu <herbert@gondor.apana.org.au>
Wed, 1 Aug 2012 09:47:26 +0000 (17:47 +0800)
Combine all shash algs to be registered and use new crypto_[un]register_shashes
functions. This simplifies init/exit code.

Signed-off-by: Jussi Kivilinna <jussi.kivilinna@mbnet.fi>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
crypto/tgr192.c

index cbca4f208c9f40017c8ff69c27c52f34862904fd..87403556fd0bfa5c3a4ecd40a5a707b6892fbc04 100644 (file)
@@ -628,7 +628,7 @@ static int tgr128_final(struct shash_desc *desc, u8 * out)
        return 0;
 }
 
-static struct shash_alg tgr192 = {
+static struct shash_alg tgr_algs[3] = { {
        .digestsize     =       TGR192_DIGEST_SIZE,
        .init           =       tgr192_init,
        .update         =       tgr192_update,
@@ -640,9 +640,7 @@ static struct shash_alg tgr192 = {
                .cra_blocksize  =       TGR192_BLOCK_SIZE,
                .cra_module     =       THIS_MODULE,
        }
-};
-
-static struct shash_alg tgr160 = {
+}, {
        .digestsize     =       TGR160_DIGEST_SIZE,
        .init           =       tgr192_init,
        .update         =       tgr192_update,
@@ -654,9 +652,7 @@ static struct shash_alg tgr160 = {
                .cra_blocksize  =       TGR192_BLOCK_SIZE,
                .cra_module     =       THIS_MODULE,
        }
-};
-
-static struct shash_alg tgr128 = {
+}, {
        .digestsize     =       TGR128_DIGEST_SIZE,
        .init           =       tgr192_init,
        .update         =       tgr192_update,
@@ -668,38 +664,16 @@ static struct shash_alg tgr128 = {
                .cra_blocksize  =       TGR192_BLOCK_SIZE,
                .cra_module     =       THIS_MODULE,
        }
-};
+} };
 
 static int __init tgr192_mod_init(void)
 {
-       int ret = 0;
-
-       ret = crypto_register_shash(&tgr192);
-
-       if (ret < 0) {
-               goto out;
-       }
-
-       ret = crypto_register_shash(&tgr160);
-       if (ret < 0) {
-               crypto_unregister_shash(&tgr192);
-               goto out;
-       }
-
-       ret = crypto_register_shash(&tgr128);
-       if (ret < 0) {
-               crypto_unregister_shash(&tgr192);
-               crypto_unregister_shash(&tgr160);
-       }
-      out:
-       return ret;
+       return crypto_register_shashes(tgr_algs, ARRAY_SIZE(tgr_algs));
 }
 
 static void __exit tgr192_mod_fini(void)
 {
-       crypto_unregister_shash(&tgr192);
-       crypto_unregister_shash(&tgr160);
-       crypto_unregister_shash(&tgr128);
+       crypto_unregister_shashes(tgr_algs, ARRAY_SIZE(tgr_algs));
 }
 
 MODULE_ALIAS("tgr160");