tomcrypt/src/misc/crypt/crypt_find_cipher_any.c

51 lines
1.4 KiB
C
Raw Normal View History

2004-05-12 20:42:16 +00:00
/* LibTomCrypt, modular cryptographic library -- Tom St Denis
*
* LibTomCrypt is a library that provides various cryptographic
* algorithms in a highly modular and flexible manner.
*
* The library is free for all purposes without any express
* guarantee it works.
*
2007-07-20 17:48:02 +00:00
* Tom St Denis, tomstdenis@gmail.com, http://libtom.org
2004-05-12 20:42:16 +00:00
*/
2004-12-30 23:55:53 +00:00
#include "tomcrypt.h"
2004-05-12 20:42:16 +00:00
2004-12-30 23:55:53 +00:00
/**
@file crypt_find_cipher_any.c
Find a cipher in the descriptor tables, Tom St Denis
*/
/**
2015-12-20 17:05:58 +01:00
Find a cipher flexibly. First by name then if not present by block and key size
2004-12-30 23:55:53 +00:00
@param name The name of the cipher desired
@param blocklen The minimum length of the block cipher desired (octets)
@param keylen The minimum length of the key size desired (octets)
@return >= 0 if found, -1 if not present
*/
2004-05-12 20:42:16 +00:00
int find_cipher_any(const char *name, int blocklen, int keylen)
{
int x;
2004-12-30 23:55:53 +00:00
LTC_ARGCHK(name != NULL);
2004-05-12 20:42:16 +00:00
x = find_cipher(name);
if (x != -1) return x;
2005-06-27 11:47:35 +00:00
LTC_MUTEX_LOCK(&ltc_cipher_mutex);
2004-05-12 20:42:16 +00:00
for (x = 0; x < TAB_SIZE; x++) {
if (cipher_descriptor[x].name == NULL) {
continue;
}
if (blocklen <= (int)cipher_descriptor[x].block_length && keylen <= (int)cipher_descriptor[x].max_key_length) {
2005-06-27 11:47:35 +00:00
LTC_MUTEX_UNLOCK(&ltc_cipher_mutex);
2004-05-12 20:42:16 +00:00
return x;
}
}
2005-06-27 11:47:35 +00:00
LTC_MUTEX_UNLOCK(&ltc_cipher_mutex);
2004-05-12 20:42:16 +00:00
return -1;
}
2005-06-09 00:08:13 +00:00
/* $Source$ */
/* $Revision$ */
/* $Date$ */