comparison src/misc/crypt/crypt_register_hash.c @ 192:9cc34777b479 libtomcrypt

propagate from branch 'au.asn.ucc.matt.ltc-orig' (head 9ba8f01f44320e9cb9f19881105ae84f84a43ea9) to branch 'au.asn.ucc.matt.dropbear.ltc' (head dbf51c569bc34956ad948e4cc87a0eeb2170b768)
author Matt Johnston <matt@ucc.asn.au>
date Sun, 08 May 2005 06:36:47 +0000
parents 1c15b283127b
children 39d5d58461d6
comparison
equal deleted inserted replaced
164:cd1143579f00 192:9cc34777b479
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 * Tom St Denis, [email protected], http://libtomcrypt.org
10 */
11 #include "tomcrypt.h"
12
13 /**
14 @file crypt_register_hash.c
15 Register a HASH, Tom St Denis
16 */
17
18 /**
19 Register a hash with the descriptor table
20 @param hash The hash you wish to register
21 @return value >= 0 if successfully added (or already present), -1 if unsuccessful
22 */
23 int register_hash(const struct ltc_hash_descriptor *hash)
24 {
25 int x;
26
27 LTC_ARGCHK(hash != NULL);
28
29 /* is it already registered? */
30 for (x = 0; x < TAB_SIZE; x++) {
31 if (memcmp(&hash_descriptor[x], hash, sizeof(struct ltc_hash_descriptor)) == 0) {
32 return x;
33 }
34 }
35
36 /* find a blank spot */
37 for (x = 0; x < TAB_SIZE; x++) {
38 if (hash_descriptor[x].name == NULL) {
39 XMEMCPY(&hash_descriptor[x], hash, sizeof(struct ltc_hash_descriptor));
40 return x;
41 }
42 }
43
44 /* no spot */
45 return -1;
46 }