2019-06-09 20:44:26 +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.
|
|
|
|
*/
|
|
|
|
#ifndef DEMOS_COMMON_H_
|
|
|
|
#define DEMOS_COMMON_H_
|
|
|
|
|
|
|
|
#include <tomcrypt.h>
|
|
|
|
|
|
|
|
extern prng_state yarrow_prng;
|
|
|
|
|
|
|
|
#ifdef LTC_VERBOSE
|
|
|
|
#define DO(x) do { fprintf(stderr, "%s:\n", #x); run_cmd((x), __LINE__, __FILE__, #x, NULL); } while (0)
|
|
|
|
#define DOX(x, str) do { fprintf(stderr, "%s - %s:\n", #x, (str)); run_cmd((x), __LINE__, __FILE__, #x, (str)); } while (0)
|
2020-12-28 21:40:37 +00:00
|
|
|
#define SHOULD_FAIL(x) do { fprintf(stderr, "%s:\n", #x); run_cmd((x) != CRYPT_OK ? CRYPT_OK : CRYPT_FAIL_TESTVECTOR, __LINE__, __FILE__, #x, NULL); } while (0)
|
2019-06-09 20:44:26 +00:00
|
|
|
#else
|
|
|
|
#define DO(x) do { run_cmd((x), __LINE__, __FILE__, #x, NULL); } while (0)
|
|
|
|
#define DOX(x, str) do { run_cmd((x), __LINE__, __FILE__, #x, (str)); } while (0)
|
2020-12-28 21:40:37 +00:00
|
|
|
#define SHOULD_FAIL(x) do { run_cmd((x) != CRYPT_OK ? CRYPT_OK : CRYPT_FAIL_TESTVECTOR, __LINE__, __FILE__, #x, NULL); } while (0)
|
2019-06-09 20:44:26 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
void run_cmd(int res, int line, const char *file, const char *cmd, const char *algorithm);
|
|
|
|
|
|
|
|
void print_hex(const char* what, const void* v, const unsigned long l);
|
|
|
|
|
|
|
|
#endif /* DEMOS_COMMON_H_ */
|
|
|
|
|
|
|
|
/* ref: $Format:%D$ */
|
|
|
|
/* git commit: $Format:%H$ */
|
|
|
|
/* commit time: $Format:%ai$ */
|