]> pd.if.org Git - zpackage/blob - libtomcrypt/src/misc/crypt/crypt_register_prng.c
remove sha224 and sha512-224
[zpackage] / libtomcrypt / src / misc / crypt / crypt_register_prng.c
1 /* LibTomCrypt, modular cryptographic library -- Tom St Denis
2  *
3  * LibTomCrypt is a library that provides various cryptographic
4  * algorithms in a highly modular and flexible manner.
5  *
6  * The library is free for all purposes without any express
7  * guarantee it works.
8  */
9 #include "tomcrypt.h"
10
11 /**
12   @file crypt_register_prng.c
13   Register a PRNG, Tom St Denis
14 */
15
16 /**
17    Register a PRNG with the descriptor table
18    @param prng   The PRNG you wish to register
19    @return value >= 0 if successfully added (or already present), -1 if unsuccessful
20 */
21 int register_prng(const struct ltc_prng_descriptor *prng)
22 {
23    int x;
24
25    LTC_ARGCHK(prng != NULL);
26
27    /* is it already registered? */
28    LTC_MUTEX_LOCK(&ltc_prng_mutex);
29    for (x = 0; x < TAB_SIZE; x++) {
30        if (XMEMCMP(&prng_descriptor[x], prng, sizeof(struct ltc_prng_descriptor)) == 0) {
31           LTC_MUTEX_UNLOCK(&ltc_prng_mutex);
32           return x;
33        }
34    }
35
36    /* find a blank spot */
37    for (x = 0; x < TAB_SIZE; x++) {
38        if (prng_descriptor[x].name == NULL) {
39           XMEMCPY(&prng_descriptor[x], prng, sizeof(struct ltc_prng_descriptor));
40           LTC_MUTEX_UNLOCK(&ltc_prng_mutex);
41           return x;
42        }
43    }
44
45    /* no spot */
46    LTC_MUTEX_UNLOCK(&ltc_prng_mutex);
47    return -1;
48 }
49
50 /* ref:         $Format:%D$ */
51 /* git commit:  $Format:%H$ */
52 /* commit time: $Format:%ai$ */