Mercurial > dropbear
comparison libtomcrypt/src/misc/compare_testvector.c @ 1511:5916af64acd4 fuzz
merge from main
author | Matt Johnston <matt@ucc.asn.au> |
---|---|
date | Sat, 17 Feb 2018 19:29:51 +0800 |
parents | 6dba84798cd5 |
children |
comparison
equal
deleted
inserted
replaced
1457:32f990cc96b1 | 1511:5916af64acd4 |
---|---|
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 | |
10 #include "tomcrypt.h" | |
11 | |
12 /** | |
13 @file compare_testvector.c | |
14 Function to compare two testvectors and print a (detailed) error-message if required, Steffen Jaeckel | |
15 */ | |
16 | |
17 #if defined(LTC_TEST) && defined(LTC_TEST_DBG) | |
18 static void _print_hex(const char* what, const void* v, const unsigned long l) | |
19 { | |
20 const unsigned char* p = v; | |
21 unsigned long x, y = 0, z; | |
22 fprintf(stderr, "%s contents: \n", what); | |
23 for (x = 0; x < l; ) { | |
24 fprintf(stderr, "%02X ", p[x]); | |
25 if (!(++x % 16) || x == l) { | |
26 if((x % 16) != 0) { | |
27 z = 16 - (x % 16); | |
28 if(z >= 8) | |
29 fprintf(stderr, " "); | |
30 for (; z != 0; --z) { | |
31 fprintf(stderr, " "); | |
32 } | |
33 } | |
34 fprintf(stderr, " | "); | |
35 for(; y < x; y++) { | |
36 if((y % 8) == 0) | |
37 fprintf(stderr, " "); | |
38 if(isgraph(p[y])) | |
39 fprintf(stderr, "%c", p[y]); | |
40 else | |
41 fprintf(stderr, "."); | |
42 } | |
43 fprintf(stderr, "\n"); | |
44 } | |
45 else if((x % 8) == 0) { | |
46 fprintf(stderr, " "); | |
47 } | |
48 } | |
49 } | |
50 #endif | |
51 | |
52 /** | |
53 Compare two test-vectors | |
54 | |
55 @param is The data as it is | |
56 @param is_len The length of is | |
57 @param should The data as it should | |
58 @param should_len The length of should | |
59 @param what The type of the data | |
60 @param which The iteration count | |
61 @return 0 on equality, -1 or 1 on difference | |
62 */ | |
63 int compare_testvector(const void* is, const unsigned long is_len, const void* should, const unsigned long should_len, const char* what, int which) | |
64 { | |
65 int res = 0; | |
66 if(is_len != should_len) | |
67 res = is_len > should_len ? -1 : 1; | |
68 else | |
69 res = XMEMCMP(is, should, is_len); | |
70 | |
71 #if defined(LTC_TEST) && defined(LTC_TEST_DBG) | |
72 if (res != 0) { | |
73 fprintf(stderr, "Testvector #%i of %s failed:\n", which, what); | |
74 _print_hex("SHOULD", should, should_len); | |
75 _print_hex("IS ", is, is_len); | |
76 } | |
77 #else | |
78 LTC_UNUSED_PARAM(which); | |
79 LTC_UNUSED_PARAM(what); | |
80 #endif | |
81 | |
82 return res; | |
83 } | |
84 | |
85 /* ref: $Format:%D$ */ | |
86 /* git commit: $Format:%H$ */ | |
87 /* commit time: $Format:%ai$ */ |