/src/wolfssl/wolfcrypt/src/misc.c
Line | Count | Source (jump to first uncovered line) |
1 | | /* misc.c |
2 | | * |
3 | | * Copyright (C) 2006-2025 wolfSSL Inc. |
4 | | * |
5 | | * This file is part of wolfSSL. |
6 | | * |
7 | | * wolfSSL is free software; you can redistribute it and/or modify |
8 | | * it under the terms of the GNU General Public License as published by |
9 | | * the Free Software Foundation; either version 2 of the License, or |
10 | | * (at your option) any later version. |
11 | | * |
12 | | * wolfSSL is distributed in the hope that it will be useful, |
13 | | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
14 | | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
15 | | * GNU General Public License for more details. |
16 | | * |
17 | | * You should have received a copy of the GNU General Public License |
18 | | * along with this program; if not, write to the Free Software |
19 | | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1335, USA |
20 | | */ |
21 | | /* |
22 | | |
23 | | DESCRIPTION |
24 | | This module implements the arithmetic-shift right, left, byte swapping, XOR, |
25 | | masking and clearing memory logic. |
26 | | |
27 | | */ |
28 | | |
29 | | #ifdef WOLFSSL_VIS_FOR_TESTS |
30 | | #ifdef HAVE_CONFIG_H |
31 | | #include <config.h> |
32 | | #endif |
33 | | #include <wolfssl/wolfcrypt/settings.h> |
34 | | #else |
35 | | #include <wolfssl/wolfcrypt/libwolfssl_sources.h> |
36 | | #endif |
37 | | |
38 | | #ifndef WOLF_CRYPT_MISC_C |
39 | | #define WOLF_CRYPT_MISC_C |
40 | | |
41 | | #include <wolfssl/wolfcrypt/misc.h> |
42 | | |
43 | | /* inlining these functions is a huge speed increase and a small size decrease, |
44 | | because the functions are smaller than function call setup/cleanup, e.g., |
45 | | md5 benchmark is twice as fast with inline. If you don't want it, then |
46 | | define NO_INLINE and compile this file into wolfssl, otherwise it's used as |
47 | | a source header |
48 | | */ |
49 | | |
50 | | /* Check for if compiling misc.c when not needed. */ |
51 | | #if !defined(WOLFSSL_MISC_INCLUDED) && !defined(NO_INLINE) |
52 | | #ifndef WOLFSSL_IGNORE_FILE_WARN |
53 | | #warning misc.c does not need to be compiled when using inline (NO_INLINE not defined) |
54 | | #endif |
55 | | |
56 | | #else |
57 | | |
58 | | |
59 | | #if defined(__ICCARM__) |
60 | | #include <intrinsics.h> |
61 | | #endif |
62 | | |
63 | | |
64 | | #ifdef INTEL_INTRINSICS |
65 | | |
66 | | #include <stdlib.h> /* get intrinsic definitions */ |
67 | | |
68 | | /* for non visual studio probably need no long version, 32 bit only |
69 | | * i.e., _rotl and _rotr */ |
70 | | #pragma intrinsic(_lrotl, _lrotr) |
71 | | |
72 | | WC_MISC_STATIC WC_INLINE word32 rotlFixed(word32 x, word32 y) |
73 | | { |
74 | | return y ? _lrotl(x, y) : x; |
75 | | } |
76 | | |
77 | | WC_MISC_STATIC WC_INLINE word32 rotrFixed(word32 x, word32 y) |
78 | | { |
79 | | return y ? _lrotr(x, y) : x; |
80 | | } |
81 | | |
82 | | #elif defined(__CCRX__) |
83 | | |
84 | | #include <builtin.h> /* get intrinsic definitions */ |
85 | | |
86 | | #if !defined(NO_INLINE) |
87 | | |
88 | | #define rotlFixed(x, y) _builtin_rotl(x, y) |
89 | | |
90 | | #define rotrFixed(x, y) _builtin_rotr(x, y) |
91 | | |
92 | | #else /* create real function */ |
93 | | |
94 | | WC_MISC_STATIC WC_INLINE word32 rotlFixed(word32 x, word32 y) |
95 | | { |
96 | | return _builtin_rotl(x, y); |
97 | | } |
98 | | |
99 | | WC_MISC_STATIC WC_INLINE word32 rotrFixed(word32 x, word32 y) |
100 | | { |
101 | | return _builtin_rotr(x, y); |
102 | | } |
103 | | |
104 | | #endif |
105 | | |
106 | | #else /* generic */ |
107 | | /* This routine performs a left circular arithmetic shift of <x> by <y> value. */ |
108 | | |
109 | | WC_MISC_STATIC WC_INLINE word32 rotlFixed(word32 x, word32 y) |
110 | 0 | { |
111 | 0 | return (x << y) | (x >> (sizeof(x) * 8 - y)); |
112 | 0 | } Unexecuted instantiation: ssl.c:rotlFixed Unexecuted instantiation: tls.c:rotlFixed Unexecuted instantiation: tls13.c:rotlFixed Unexecuted instantiation: hmac.c:rotlFixed Unexecuted instantiation: hash.c:rotlFixed Unexecuted instantiation: kdf.c:rotlFixed Unexecuted instantiation: random.c:rotlFixed Unexecuted instantiation: sha256.c:rotlFixed Unexecuted instantiation: rsa.c:rotlFixed Unexecuted instantiation: sp_int.c:rotlFixed Unexecuted instantiation: aes.c:rotlFixed Unexecuted instantiation: sha.c:rotlFixed Unexecuted instantiation: sha512.c:rotlFixed Unexecuted instantiation: sha3.c:rotlFixed Unexecuted instantiation: wolfmath.c:rotlFixed Unexecuted instantiation: dh.c:rotlFixed Unexecuted instantiation: asn.c:rotlFixed Unexecuted instantiation: coding.c:rotlFixed Unexecuted instantiation: poly1305.c:rotlFixed Unexecuted instantiation: md5.c:rotlFixed Unexecuted instantiation: chacha.c:rotlFixed Unexecuted instantiation: ecc.c:rotlFixed Unexecuted instantiation: internal.c:rotlFixed Unexecuted instantiation: wc_encrypt.c:rotlFixed Unexecuted instantiation: pwdbased.c:rotlFixed |
113 | | |
114 | | /* This routine performs a right circular arithmetic shift of <x> by <y> value. */ |
115 | | WC_MISC_STATIC WC_INLINE word32 rotrFixed(word32 x, word32 y) |
116 | 0 | { |
117 | 0 | return (x >> y) | (x << (sizeof(x) * 8 - y)); |
118 | 0 | } Unexecuted instantiation: ssl.c:rotrFixed Unexecuted instantiation: tls.c:rotrFixed Unexecuted instantiation: tls13.c:rotrFixed Unexecuted instantiation: hmac.c:rotrFixed Unexecuted instantiation: hash.c:rotrFixed Unexecuted instantiation: kdf.c:rotrFixed Unexecuted instantiation: random.c:rotrFixed Unexecuted instantiation: sha256.c:rotrFixed Unexecuted instantiation: rsa.c:rotrFixed Unexecuted instantiation: sp_int.c:rotrFixed Unexecuted instantiation: aes.c:rotrFixed Unexecuted instantiation: sha.c:rotrFixed Unexecuted instantiation: sha512.c:rotrFixed Unexecuted instantiation: sha3.c:rotrFixed Unexecuted instantiation: wolfmath.c:rotrFixed Unexecuted instantiation: dh.c:rotrFixed Unexecuted instantiation: asn.c:rotrFixed Unexecuted instantiation: coding.c:rotrFixed Unexecuted instantiation: poly1305.c:rotrFixed Unexecuted instantiation: md5.c:rotrFixed Unexecuted instantiation: chacha.c:rotrFixed Unexecuted instantiation: ecc.c:rotrFixed Unexecuted instantiation: internal.c:rotrFixed Unexecuted instantiation: wc_encrypt.c:rotrFixed Unexecuted instantiation: pwdbased.c:rotrFixed |
119 | | |
120 | | #endif |
121 | | |
122 | | /* This routine performs a left circular arithmetic shift of <x> by <y> value */ |
123 | | WC_MISC_STATIC WC_INLINE word16 rotlFixed16(word16 x, word16 y) |
124 | 0 | { |
125 | 0 | return (word16)((x << y) | (x >> (sizeof(x) * 8U - y))); |
126 | 0 | } Unexecuted instantiation: ssl.c:rotlFixed16 Unexecuted instantiation: tls.c:rotlFixed16 Unexecuted instantiation: tls13.c:rotlFixed16 Unexecuted instantiation: hmac.c:rotlFixed16 Unexecuted instantiation: hash.c:rotlFixed16 Unexecuted instantiation: kdf.c:rotlFixed16 Unexecuted instantiation: random.c:rotlFixed16 Unexecuted instantiation: sha256.c:rotlFixed16 Unexecuted instantiation: rsa.c:rotlFixed16 Unexecuted instantiation: sp_int.c:rotlFixed16 Unexecuted instantiation: aes.c:rotlFixed16 Unexecuted instantiation: sha.c:rotlFixed16 Unexecuted instantiation: sha512.c:rotlFixed16 Unexecuted instantiation: sha3.c:rotlFixed16 Unexecuted instantiation: wolfmath.c:rotlFixed16 Unexecuted instantiation: dh.c:rotlFixed16 Unexecuted instantiation: asn.c:rotlFixed16 Unexecuted instantiation: coding.c:rotlFixed16 Unexecuted instantiation: poly1305.c:rotlFixed16 Unexecuted instantiation: md5.c:rotlFixed16 Unexecuted instantiation: chacha.c:rotlFixed16 Unexecuted instantiation: ecc.c:rotlFixed16 Unexecuted instantiation: internal.c:rotlFixed16 Unexecuted instantiation: wc_encrypt.c:rotlFixed16 Unexecuted instantiation: pwdbased.c:rotlFixed16 |
127 | | |
128 | | |
129 | | /* This routine performs a right circular arithmetic shift of <x> by <y> value */ |
130 | | WC_MISC_STATIC WC_INLINE word16 rotrFixed16(word16 x, word16 y) |
131 | 0 | { |
132 | 0 | return (word16)((x >> y) | (x << (sizeof(x) * 8U - y))); |
133 | 0 | } Unexecuted instantiation: ssl.c:rotrFixed16 Unexecuted instantiation: tls.c:rotrFixed16 Unexecuted instantiation: tls13.c:rotrFixed16 Unexecuted instantiation: hmac.c:rotrFixed16 Unexecuted instantiation: hash.c:rotrFixed16 Unexecuted instantiation: kdf.c:rotrFixed16 Unexecuted instantiation: random.c:rotrFixed16 Unexecuted instantiation: sha256.c:rotrFixed16 Unexecuted instantiation: rsa.c:rotrFixed16 Unexecuted instantiation: sp_int.c:rotrFixed16 Unexecuted instantiation: aes.c:rotrFixed16 Unexecuted instantiation: sha.c:rotrFixed16 Unexecuted instantiation: sha512.c:rotrFixed16 Unexecuted instantiation: sha3.c:rotrFixed16 Unexecuted instantiation: wolfmath.c:rotrFixed16 Unexecuted instantiation: dh.c:rotrFixed16 Unexecuted instantiation: asn.c:rotrFixed16 Unexecuted instantiation: coding.c:rotrFixed16 Unexecuted instantiation: poly1305.c:rotrFixed16 Unexecuted instantiation: md5.c:rotrFixed16 Unexecuted instantiation: chacha.c:rotrFixed16 Unexecuted instantiation: ecc.c:rotrFixed16 Unexecuted instantiation: internal.c:rotrFixed16 Unexecuted instantiation: wc_encrypt.c:rotrFixed16 Unexecuted instantiation: pwdbased.c:rotrFixed16 |
134 | | |
135 | | /* This routine performs a byte swap of 32-bit word value. */ |
136 | | #if defined(__CCRX__) && !defined(NO_INLINE) /* shortest version for CC-RX */ |
137 | | #define ByteReverseWord32(value) _builtin_revl(value) |
138 | | #else |
139 | | WC_MISC_STATIC WC_INLINE word32 ByteReverseWord32(word32 value) |
140 | 0 | { |
141 | | #ifdef PPC_INTRINSICS |
142 | | /* PPC: load reverse indexed instruction */ |
143 | | return (word32)__lwbrx(&value,0); |
144 | | #elif defined(__ICCARM__) |
145 | | return (word32)__REV(value); |
146 | | #elif defined(KEIL_INTRINSICS) |
147 | | return (word32)__rev(value); |
148 | | #elif defined(__CCRX__) |
149 | | return (word32)_builtin_revl(value); |
150 | | #elif defined(WOLF_ALLOW_BUILTIN) && \ |
151 | | defined(__GNUC_PREREQ) && __GNUC_PREREQ(4, 3) |
152 | | return (word32)__builtin_bswap32(value); |
153 | | #elif defined(WOLFSSL_BYTESWAP32_ASM) && defined(__GNUC__) && \ |
154 | | defined(__aarch64__) |
155 | | __asm__ volatile ( |
156 | | "REV32 %0, %0 \n" |
157 | | : "+r" (value) |
158 | | : |
159 | | ); |
160 | | return value; |
161 | | #elif defined(WOLFSSL_BYTESWAP32_ASM) && defined(__GNUC__) && \ |
162 | | (defined(__thumb__) || defined(__arm__)) |
163 | | __asm__ volatile ( |
164 | | "REV %0, %0 \n" |
165 | | : "+r" (value) |
166 | | : |
167 | | ); |
168 | | return value; |
169 | | #elif defined(FAST_ROTATE) |
170 | | /* 5 instructions with rotate instruction, 9 without */ |
171 | 0 | return (rotrFixed(value, 8U) & 0xff00ff00) | |
172 | 0 | (rotlFixed(value, 8U) & 0x00ff00ff); |
173 | | #else |
174 | | /* 6 instructions with rotate instruction, 8 without */ |
175 | | value = ((value & 0xFF00FF00) >> 8) | ((value & 0x00FF00FF) << 8); |
176 | | return rotlFixed(value, 16U); |
177 | | #endif |
178 | 0 | } Unexecuted instantiation: ssl.c:ByteReverseWord32 Unexecuted instantiation: tls.c:ByteReverseWord32 Unexecuted instantiation: tls13.c:ByteReverseWord32 Unexecuted instantiation: hmac.c:ByteReverseWord32 Unexecuted instantiation: hash.c:ByteReverseWord32 Unexecuted instantiation: kdf.c:ByteReverseWord32 Unexecuted instantiation: random.c:ByteReverseWord32 Unexecuted instantiation: sha256.c:ByteReverseWord32 Unexecuted instantiation: rsa.c:ByteReverseWord32 Unexecuted instantiation: sp_int.c:ByteReverseWord32 Unexecuted instantiation: aes.c:ByteReverseWord32 Unexecuted instantiation: sha.c:ByteReverseWord32 Unexecuted instantiation: sha512.c:ByteReverseWord32 Unexecuted instantiation: sha3.c:ByteReverseWord32 Unexecuted instantiation: wolfmath.c:ByteReverseWord32 Unexecuted instantiation: dh.c:ByteReverseWord32 Unexecuted instantiation: asn.c:ByteReverseWord32 Unexecuted instantiation: coding.c:ByteReverseWord32 Unexecuted instantiation: poly1305.c:ByteReverseWord32 Unexecuted instantiation: md5.c:ByteReverseWord32 Unexecuted instantiation: chacha.c:ByteReverseWord32 Unexecuted instantiation: ecc.c:ByteReverseWord32 Unexecuted instantiation: internal.c:ByteReverseWord32 Unexecuted instantiation: wc_encrypt.c:ByteReverseWord32 Unexecuted instantiation: pwdbased.c:ByteReverseWord32 |
179 | | #endif /* __CCRX__ */ |
180 | | /* This routine performs a byte swap of words array of a given count. */ |
181 | | WC_MISC_STATIC WC_INLINE void ByteReverseWords(word32* out, const word32* in, |
182 | | word32 byteCount) |
183 | 0 | { |
184 | 0 | word32 i; |
185 | |
|
186 | 0 | #ifdef WOLFSSL_USE_ALIGN |
187 | 0 | if ((((size_t)in & 0x3) == 0) && |
188 | 0 | (((size_t)out & 0x3) == 0)) |
189 | 0 | #endif |
190 | 0 | { |
191 | 0 | word32 count = byteCount/(word32)sizeof(word32); |
192 | 0 | for (i = 0; i < count; i++) |
193 | 0 | out[i] = ByteReverseWord32(in[i]); |
194 | 0 | } |
195 | 0 | #ifdef WOLFSSL_USE_ALIGN |
196 | 0 | else if (((size_t)in & 0x3) == 0) { |
197 | 0 | byte *out_bytes = (byte *)out; |
198 | 0 | word32 scratch; |
199 | |
|
200 | 0 | byteCount &= ~0x3U; |
201 | |
|
202 | 0 | for (i = 0; i < byteCount; i += (word32)sizeof(word32)) { |
203 | 0 | scratch = ByteReverseWord32(*in++); |
204 | 0 | XMEMCPY(out_bytes + i, &scratch, sizeof(scratch)); |
205 | 0 | } |
206 | 0 | } |
207 | 0 | else if (((size_t)out & 0x3) == 0) { |
208 | 0 | byte *in_bytes = (byte *)in; |
209 | 0 | word32 scratch; |
210 | |
|
211 | 0 | byteCount &= ~0x3U; |
212 | |
|
213 | 0 | for (i = 0; i < byteCount; i += (word32)sizeof(word32)) { |
214 | 0 | XMEMCPY(&scratch, in_bytes + i, sizeof(scratch)); |
215 | 0 | *out++ = ByteReverseWord32(scratch); |
216 | 0 | } |
217 | 0 | } |
218 | 0 | else { |
219 | 0 | byte *in_bytes = (byte *)in; |
220 | 0 | byte *out_bytes = (byte *)out; |
221 | 0 | word32 scratch; |
222 | |
|
223 | 0 | byteCount &= ~0x3U; |
224 | |
|
225 | 0 | for (i = 0; i < byteCount; i += (word32)sizeof(word32)) { |
226 | 0 | XMEMCPY(&scratch, in_bytes + i, sizeof(scratch)); |
227 | 0 | scratch = ByteReverseWord32(scratch); |
228 | 0 | XMEMCPY(out_bytes + i, &scratch, sizeof(scratch)); |
229 | 0 | } |
230 | 0 | } |
231 | 0 | #endif |
232 | 0 | } Unexecuted instantiation: ssl.c:ByteReverseWords Unexecuted instantiation: tls.c:ByteReverseWords Unexecuted instantiation: tls13.c:ByteReverseWords Unexecuted instantiation: hmac.c:ByteReverseWords Unexecuted instantiation: hash.c:ByteReverseWords Unexecuted instantiation: kdf.c:ByteReverseWords Unexecuted instantiation: random.c:ByteReverseWords Unexecuted instantiation: sha256.c:ByteReverseWords Unexecuted instantiation: rsa.c:ByteReverseWords Unexecuted instantiation: sp_int.c:ByteReverseWords Unexecuted instantiation: aes.c:ByteReverseWords Unexecuted instantiation: sha.c:ByteReverseWords Unexecuted instantiation: sha512.c:ByteReverseWords Unexecuted instantiation: sha3.c:ByteReverseWords Unexecuted instantiation: wolfmath.c:ByteReverseWords Unexecuted instantiation: dh.c:ByteReverseWords Unexecuted instantiation: asn.c:ByteReverseWords Unexecuted instantiation: coding.c:ByteReverseWords Unexecuted instantiation: poly1305.c:ByteReverseWords Unexecuted instantiation: md5.c:ByteReverseWords Unexecuted instantiation: chacha.c:ByteReverseWords Unexecuted instantiation: ecc.c:ByteReverseWords Unexecuted instantiation: internal.c:ByteReverseWords Unexecuted instantiation: wc_encrypt.c:ByteReverseWords Unexecuted instantiation: pwdbased.c:ByteReverseWords |
233 | | |
234 | | WC_MISC_STATIC WC_INLINE word32 readUnalignedWord32(const byte *in) |
235 | 0 | { |
236 | 0 | if (((wc_ptr_t)in & (wc_ptr_t)(sizeof(word32) - 1U)) == (wc_ptr_t)0) |
237 | 0 | return *(word32 *)in; |
238 | 0 | else { |
239 | 0 | word32 out = 0; /* else CONFIG_FORTIFY_SOURCE -Wmaybe-uninitialized */ |
240 | 0 | XMEMCPY(&out, in, sizeof(out)); |
241 | 0 | return out; |
242 | 0 | } |
243 | 0 | } Unexecuted instantiation: ssl.c:readUnalignedWord32 Unexecuted instantiation: tls.c:readUnalignedWord32 Unexecuted instantiation: tls13.c:readUnalignedWord32 Unexecuted instantiation: hmac.c:readUnalignedWord32 Unexecuted instantiation: hash.c:readUnalignedWord32 Unexecuted instantiation: kdf.c:readUnalignedWord32 Unexecuted instantiation: random.c:readUnalignedWord32 Unexecuted instantiation: sha256.c:readUnalignedWord32 Unexecuted instantiation: rsa.c:readUnalignedWord32 Unexecuted instantiation: sp_int.c:readUnalignedWord32 Unexecuted instantiation: aes.c:readUnalignedWord32 Unexecuted instantiation: sha.c:readUnalignedWord32 Unexecuted instantiation: sha512.c:readUnalignedWord32 Unexecuted instantiation: sha3.c:readUnalignedWord32 Unexecuted instantiation: wolfmath.c:readUnalignedWord32 Unexecuted instantiation: dh.c:readUnalignedWord32 Unexecuted instantiation: asn.c:readUnalignedWord32 Unexecuted instantiation: coding.c:readUnalignedWord32 Unexecuted instantiation: poly1305.c:readUnalignedWord32 Unexecuted instantiation: md5.c:readUnalignedWord32 Unexecuted instantiation: chacha.c:readUnalignedWord32 Unexecuted instantiation: ecc.c:readUnalignedWord32 Unexecuted instantiation: internal.c:readUnalignedWord32 Unexecuted instantiation: wc_encrypt.c:readUnalignedWord32 Unexecuted instantiation: pwdbased.c:readUnalignedWord32 |
244 | | |
245 | | WC_MISC_STATIC WC_INLINE word32 writeUnalignedWord32(void *out, word32 in) |
246 | 0 | { |
247 | 0 | if (((wc_ptr_t)out & (wc_ptr_t)(sizeof(word32) - 1U)) == (wc_ptr_t)0) |
248 | 0 | *(word32 *)out = in; |
249 | 0 | else { |
250 | 0 | XMEMCPY(out, &in, sizeof(in)); |
251 | 0 | } |
252 | 0 | return in; |
253 | 0 | } Unexecuted instantiation: ssl.c:writeUnalignedWord32 Unexecuted instantiation: tls.c:writeUnalignedWord32 Unexecuted instantiation: tls13.c:writeUnalignedWord32 Unexecuted instantiation: hmac.c:writeUnalignedWord32 Unexecuted instantiation: hash.c:writeUnalignedWord32 Unexecuted instantiation: kdf.c:writeUnalignedWord32 Unexecuted instantiation: random.c:writeUnalignedWord32 Unexecuted instantiation: sha256.c:writeUnalignedWord32 Unexecuted instantiation: rsa.c:writeUnalignedWord32 Unexecuted instantiation: sp_int.c:writeUnalignedWord32 Unexecuted instantiation: aes.c:writeUnalignedWord32 Unexecuted instantiation: sha.c:writeUnalignedWord32 Unexecuted instantiation: sha512.c:writeUnalignedWord32 Unexecuted instantiation: sha3.c:writeUnalignedWord32 Unexecuted instantiation: wolfmath.c:writeUnalignedWord32 Unexecuted instantiation: dh.c:writeUnalignedWord32 Unexecuted instantiation: asn.c:writeUnalignedWord32 Unexecuted instantiation: coding.c:writeUnalignedWord32 Unexecuted instantiation: poly1305.c:writeUnalignedWord32 Unexecuted instantiation: md5.c:writeUnalignedWord32 Unexecuted instantiation: chacha.c:writeUnalignedWord32 Unexecuted instantiation: ecc.c:writeUnalignedWord32 Unexecuted instantiation: internal.c:writeUnalignedWord32 Unexecuted instantiation: wc_encrypt.c:writeUnalignedWord32 Unexecuted instantiation: pwdbased.c:writeUnalignedWord32 |
254 | | |
255 | | WC_MISC_STATIC WC_INLINE void readUnalignedWords32(word32 *out, const byte *in, |
256 | | size_t count) |
257 | 0 | { |
258 | 0 | if (((wc_ptr_t)in & (wc_ptr_t)(sizeof(word32) - 1U)) == (wc_ptr_t)0) { |
259 | 0 | const word32 *in_word32 = (const word32 *)in; |
260 | 0 | while (count-- > 0) |
261 | 0 | *out++ = *in_word32++; |
262 | 0 | } |
263 | 0 | else { |
264 | 0 | XMEMCPY(out, in, count * sizeof(*out)); |
265 | 0 | } |
266 | 0 | } Unexecuted instantiation: ssl.c:readUnalignedWords32 Unexecuted instantiation: tls.c:readUnalignedWords32 Unexecuted instantiation: tls13.c:readUnalignedWords32 Unexecuted instantiation: hmac.c:readUnalignedWords32 Unexecuted instantiation: hash.c:readUnalignedWords32 Unexecuted instantiation: kdf.c:readUnalignedWords32 Unexecuted instantiation: random.c:readUnalignedWords32 Unexecuted instantiation: sha256.c:readUnalignedWords32 Unexecuted instantiation: rsa.c:readUnalignedWords32 Unexecuted instantiation: sp_int.c:readUnalignedWords32 Unexecuted instantiation: aes.c:readUnalignedWords32 Unexecuted instantiation: sha.c:readUnalignedWords32 Unexecuted instantiation: sha512.c:readUnalignedWords32 Unexecuted instantiation: sha3.c:readUnalignedWords32 Unexecuted instantiation: wolfmath.c:readUnalignedWords32 Unexecuted instantiation: dh.c:readUnalignedWords32 Unexecuted instantiation: asn.c:readUnalignedWords32 Unexecuted instantiation: coding.c:readUnalignedWords32 Unexecuted instantiation: poly1305.c:readUnalignedWords32 Unexecuted instantiation: md5.c:readUnalignedWords32 Unexecuted instantiation: chacha.c:readUnalignedWords32 Unexecuted instantiation: ecc.c:readUnalignedWords32 Unexecuted instantiation: internal.c:readUnalignedWords32 Unexecuted instantiation: wc_encrypt.c:readUnalignedWords32 Unexecuted instantiation: pwdbased.c:readUnalignedWords32 |
267 | | |
268 | | WC_MISC_STATIC WC_INLINE void writeUnalignedWords32(byte *out, const word32 *in, |
269 | | size_t count) |
270 | 0 | { |
271 | 0 | if (((wc_ptr_t)out & (wc_ptr_t)(sizeof(word32) - 1U)) == (wc_ptr_t)0) { |
272 | 0 | word32 *out_word32 = (word32 *)out; |
273 | 0 | while (count-- > 0) |
274 | 0 | *out_word32++ = *in++; |
275 | 0 | } |
276 | 0 | else { |
277 | 0 | XMEMCPY(out, in, count * sizeof(*in)); |
278 | 0 | } |
279 | 0 | } Unexecuted instantiation: ssl.c:writeUnalignedWords32 Unexecuted instantiation: tls.c:writeUnalignedWords32 Unexecuted instantiation: tls13.c:writeUnalignedWords32 Unexecuted instantiation: hmac.c:writeUnalignedWords32 Unexecuted instantiation: hash.c:writeUnalignedWords32 Unexecuted instantiation: kdf.c:writeUnalignedWords32 Unexecuted instantiation: random.c:writeUnalignedWords32 Unexecuted instantiation: sha256.c:writeUnalignedWords32 Unexecuted instantiation: rsa.c:writeUnalignedWords32 Unexecuted instantiation: sp_int.c:writeUnalignedWords32 Unexecuted instantiation: aes.c:writeUnalignedWords32 Unexecuted instantiation: sha.c:writeUnalignedWords32 Unexecuted instantiation: sha512.c:writeUnalignedWords32 Unexecuted instantiation: sha3.c:writeUnalignedWords32 Unexecuted instantiation: wolfmath.c:writeUnalignedWords32 Unexecuted instantiation: dh.c:writeUnalignedWords32 Unexecuted instantiation: asn.c:writeUnalignedWords32 Unexecuted instantiation: coding.c:writeUnalignedWords32 Unexecuted instantiation: poly1305.c:writeUnalignedWords32 Unexecuted instantiation: md5.c:writeUnalignedWords32 Unexecuted instantiation: chacha.c:writeUnalignedWords32 Unexecuted instantiation: ecc.c:writeUnalignedWords32 Unexecuted instantiation: internal.c:writeUnalignedWords32 Unexecuted instantiation: wc_encrypt.c:writeUnalignedWords32 Unexecuted instantiation: pwdbased.c:writeUnalignedWords32 |
280 | | |
281 | | #if defined(WORD64_AVAILABLE) && !defined(WOLFSSL_NO_WORD64_OPS) |
282 | | |
283 | | WC_MISC_STATIC WC_INLINE word64 readUnalignedWord64(const byte *in) |
284 | 0 | { |
285 | 0 | if (((wc_ptr_t)in & (wc_ptr_t)(sizeof(word64) - 1U)) == (wc_ptr_t)0) |
286 | 0 | return *(word64 *)in; |
287 | 0 | else { |
288 | 0 | word64 out = 0; /* else CONFIG_FORTIFY_SOURCE -Wmaybe-uninitialized */ |
289 | 0 | XMEMCPY(&out, in, sizeof(out)); |
290 | 0 | return out; |
291 | 0 | } |
292 | 0 | } Unexecuted instantiation: ssl.c:readUnalignedWord64 Unexecuted instantiation: tls.c:readUnalignedWord64 Unexecuted instantiation: tls13.c:readUnalignedWord64 Unexecuted instantiation: hmac.c:readUnalignedWord64 Unexecuted instantiation: hash.c:readUnalignedWord64 Unexecuted instantiation: kdf.c:readUnalignedWord64 Unexecuted instantiation: random.c:readUnalignedWord64 Unexecuted instantiation: sha256.c:readUnalignedWord64 Unexecuted instantiation: rsa.c:readUnalignedWord64 Unexecuted instantiation: sp_int.c:readUnalignedWord64 Unexecuted instantiation: aes.c:readUnalignedWord64 Unexecuted instantiation: sha.c:readUnalignedWord64 Unexecuted instantiation: sha512.c:readUnalignedWord64 Unexecuted instantiation: sha3.c:readUnalignedWord64 Unexecuted instantiation: wolfmath.c:readUnalignedWord64 Unexecuted instantiation: dh.c:readUnalignedWord64 Unexecuted instantiation: asn.c:readUnalignedWord64 Unexecuted instantiation: coding.c:readUnalignedWord64 Unexecuted instantiation: poly1305.c:readUnalignedWord64 Unexecuted instantiation: md5.c:readUnalignedWord64 Unexecuted instantiation: chacha.c:readUnalignedWord64 Unexecuted instantiation: ecc.c:readUnalignedWord64 Unexecuted instantiation: internal.c:readUnalignedWord64 Unexecuted instantiation: wc_encrypt.c:readUnalignedWord64 Unexecuted instantiation: pwdbased.c:readUnalignedWord64 |
293 | | |
294 | | WC_MISC_STATIC WC_INLINE word64 writeUnalignedWord64(void *out, word64 in) |
295 | 0 | { |
296 | 0 | if (((wc_ptr_t)out & (wc_ptr_t)(sizeof(word64) - 1U)) == (wc_ptr_t)0) |
297 | 0 | *(word64 *)out = in; |
298 | 0 | else { |
299 | 0 | XMEMCPY(out, &in, sizeof(in)); |
300 | 0 | } |
301 | 0 | return in; |
302 | 0 | } Unexecuted instantiation: ssl.c:writeUnalignedWord64 Unexecuted instantiation: tls.c:writeUnalignedWord64 Unexecuted instantiation: tls13.c:writeUnalignedWord64 Unexecuted instantiation: hmac.c:writeUnalignedWord64 Unexecuted instantiation: hash.c:writeUnalignedWord64 Unexecuted instantiation: kdf.c:writeUnalignedWord64 Unexecuted instantiation: random.c:writeUnalignedWord64 Unexecuted instantiation: sha256.c:writeUnalignedWord64 Unexecuted instantiation: rsa.c:writeUnalignedWord64 Unexecuted instantiation: sp_int.c:writeUnalignedWord64 Unexecuted instantiation: aes.c:writeUnalignedWord64 Unexecuted instantiation: sha.c:writeUnalignedWord64 Unexecuted instantiation: sha512.c:writeUnalignedWord64 Unexecuted instantiation: sha3.c:writeUnalignedWord64 Unexecuted instantiation: wolfmath.c:writeUnalignedWord64 Unexecuted instantiation: dh.c:writeUnalignedWord64 Unexecuted instantiation: asn.c:writeUnalignedWord64 Unexecuted instantiation: coding.c:writeUnalignedWord64 Unexecuted instantiation: poly1305.c:writeUnalignedWord64 Unexecuted instantiation: md5.c:writeUnalignedWord64 Unexecuted instantiation: chacha.c:writeUnalignedWord64 Unexecuted instantiation: ecc.c:writeUnalignedWord64 Unexecuted instantiation: internal.c:writeUnalignedWord64 Unexecuted instantiation: wc_encrypt.c:writeUnalignedWord64 Unexecuted instantiation: pwdbased.c:writeUnalignedWord64 |
303 | | |
304 | | WC_MISC_STATIC WC_INLINE void readUnalignedWords64(word64 *out, const byte *in, |
305 | | size_t count) |
306 | 0 | { |
307 | 0 | if (((wc_ptr_t)in & (wc_ptr_t)(sizeof(word64) - 1U)) == (wc_ptr_t)0) { |
308 | 0 | const word64 *in_word64 = (const word64 *)in; |
309 | 0 | while (count-- > 0) |
310 | 0 | *out++ = *in_word64++; |
311 | 0 | } |
312 | 0 | else { |
313 | 0 | XMEMCPY(out, in, count * sizeof(*out)); |
314 | 0 | } |
315 | 0 | } Unexecuted instantiation: ssl.c:readUnalignedWords64 Unexecuted instantiation: tls.c:readUnalignedWords64 Unexecuted instantiation: tls13.c:readUnalignedWords64 Unexecuted instantiation: hmac.c:readUnalignedWords64 Unexecuted instantiation: hash.c:readUnalignedWords64 Unexecuted instantiation: kdf.c:readUnalignedWords64 Unexecuted instantiation: random.c:readUnalignedWords64 Unexecuted instantiation: sha256.c:readUnalignedWords64 Unexecuted instantiation: rsa.c:readUnalignedWords64 Unexecuted instantiation: sp_int.c:readUnalignedWords64 Unexecuted instantiation: aes.c:readUnalignedWords64 Unexecuted instantiation: sha.c:readUnalignedWords64 Unexecuted instantiation: sha512.c:readUnalignedWords64 Unexecuted instantiation: sha3.c:readUnalignedWords64 Unexecuted instantiation: wolfmath.c:readUnalignedWords64 Unexecuted instantiation: dh.c:readUnalignedWords64 Unexecuted instantiation: asn.c:readUnalignedWords64 Unexecuted instantiation: coding.c:readUnalignedWords64 Unexecuted instantiation: poly1305.c:readUnalignedWords64 Unexecuted instantiation: md5.c:readUnalignedWords64 Unexecuted instantiation: chacha.c:readUnalignedWords64 Unexecuted instantiation: ecc.c:readUnalignedWords64 Unexecuted instantiation: internal.c:readUnalignedWords64 Unexecuted instantiation: wc_encrypt.c:readUnalignedWords64 Unexecuted instantiation: pwdbased.c:readUnalignedWords64 |
316 | | |
317 | | WC_MISC_STATIC WC_INLINE void writeUnalignedWords64(byte *out, const word64 *in, |
318 | | size_t count) |
319 | 0 | { |
320 | 0 | if (((wc_ptr_t)out & (wc_ptr_t)(sizeof(word64) - 1U)) == (wc_ptr_t)0) { |
321 | 0 | word64 *out_word64 = (word64 *)out; |
322 | 0 | while (count-- > 0) |
323 | 0 | *out_word64++ = *in++; |
324 | 0 | } |
325 | 0 | else { |
326 | 0 | XMEMCPY(out, in, count * sizeof(*in)); |
327 | 0 | } |
328 | 0 | } Unexecuted instantiation: ssl.c:writeUnalignedWords64 Unexecuted instantiation: tls.c:writeUnalignedWords64 Unexecuted instantiation: tls13.c:writeUnalignedWords64 Unexecuted instantiation: hmac.c:writeUnalignedWords64 Unexecuted instantiation: hash.c:writeUnalignedWords64 Unexecuted instantiation: kdf.c:writeUnalignedWords64 Unexecuted instantiation: random.c:writeUnalignedWords64 Unexecuted instantiation: sha256.c:writeUnalignedWords64 Unexecuted instantiation: rsa.c:writeUnalignedWords64 Unexecuted instantiation: sp_int.c:writeUnalignedWords64 Unexecuted instantiation: aes.c:writeUnalignedWords64 Unexecuted instantiation: sha.c:writeUnalignedWords64 Unexecuted instantiation: sha512.c:writeUnalignedWords64 Unexecuted instantiation: sha3.c:writeUnalignedWords64 Unexecuted instantiation: wolfmath.c:writeUnalignedWords64 Unexecuted instantiation: dh.c:writeUnalignedWords64 Unexecuted instantiation: asn.c:writeUnalignedWords64 Unexecuted instantiation: coding.c:writeUnalignedWords64 Unexecuted instantiation: poly1305.c:writeUnalignedWords64 Unexecuted instantiation: md5.c:writeUnalignedWords64 Unexecuted instantiation: chacha.c:writeUnalignedWords64 Unexecuted instantiation: ecc.c:writeUnalignedWords64 Unexecuted instantiation: internal.c:writeUnalignedWords64 Unexecuted instantiation: wc_encrypt.c:writeUnalignedWords64 Unexecuted instantiation: pwdbased.c:writeUnalignedWords64 |
329 | | |
330 | | WC_MISC_STATIC WC_INLINE word64 rotlFixed64(word64 x, word64 y) |
331 | 0 | { |
332 | 0 | return (x << y) | (x >> (sizeof(y) * 8 - y)); |
333 | 0 | } Unexecuted instantiation: ssl.c:rotlFixed64 Unexecuted instantiation: tls.c:rotlFixed64 Unexecuted instantiation: tls13.c:rotlFixed64 Unexecuted instantiation: hmac.c:rotlFixed64 Unexecuted instantiation: hash.c:rotlFixed64 Unexecuted instantiation: kdf.c:rotlFixed64 Unexecuted instantiation: random.c:rotlFixed64 Unexecuted instantiation: sha256.c:rotlFixed64 Unexecuted instantiation: rsa.c:rotlFixed64 Unexecuted instantiation: sp_int.c:rotlFixed64 Unexecuted instantiation: aes.c:rotlFixed64 Unexecuted instantiation: sha.c:rotlFixed64 Unexecuted instantiation: sha512.c:rotlFixed64 Unexecuted instantiation: sha3.c:rotlFixed64 Unexecuted instantiation: wolfmath.c:rotlFixed64 Unexecuted instantiation: dh.c:rotlFixed64 Unexecuted instantiation: asn.c:rotlFixed64 Unexecuted instantiation: coding.c:rotlFixed64 Unexecuted instantiation: poly1305.c:rotlFixed64 Unexecuted instantiation: md5.c:rotlFixed64 Unexecuted instantiation: chacha.c:rotlFixed64 Unexecuted instantiation: ecc.c:rotlFixed64 Unexecuted instantiation: internal.c:rotlFixed64 Unexecuted instantiation: wc_encrypt.c:rotlFixed64 Unexecuted instantiation: pwdbased.c:rotlFixed64 |
334 | | |
335 | | |
336 | | WC_MISC_STATIC WC_INLINE word64 rotrFixed64(word64 x, word64 y) |
337 | 0 | { |
338 | 0 | return (x >> y) | (x << (sizeof(y) * 8 - y)); |
339 | 0 | } Unexecuted instantiation: ssl.c:rotrFixed64 Unexecuted instantiation: tls.c:rotrFixed64 Unexecuted instantiation: tls13.c:rotrFixed64 Unexecuted instantiation: hmac.c:rotrFixed64 Unexecuted instantiation: hash.c:rotrFixed64 Unexecuted instantiation: kdf.c:rotrFixed64 Unexecuted instantiation: random.c:rotrFixed64 Unexecuted instantiation: sha256.c:rotrFixed64 Unexecuted instantiation: rsa.c:rotrFixed64 Unexecuted instantiation: sp_int.c:rotrFixed64 Unexecuted instantiation: aes.c:rotrFixed64 Unexecuted instantiation: sha.c:rotrFixed64 Unexecuted instantiation: sha512.c:rotrFixed64 Unexecuted instantiation: sha3.c:rotrFixed64 Unexecuted instantiation: wolfmath.c:rotrFixed64 Unexecuted instantiation: dh.c:rotrFixed64 Unexecuted instantiation: asn.c:rotrFixed64 Unexecuted instantiation: coding.c:rotrFixed64 Unexecuted instantiation: poly1305.c:rotrFixed64 Unexecuted instantiation: md5.c:rotrFixed64 Unexecuted instantiation: chacha.c:rotrFixed64 Unexecuted instantiation: ecc.c:rotrFixed64 Unexecuted instantiation: internal.c:rotrFixed64 Unexecuted instantiation: wc_encrypt.c:rotrFixed64 Unexecuted instantiation: pwdbased.c:rotrFixed64 |
340 | | |
341 | | |
342 | | WC_MISC_STATIC WC_INLINE word64 ByteReverseWord64(word64 value) |
343 | 0 | { |
344 | | #if defined(WOLF_ALLOW_BUILTIN) && defined(__GNUC_PREREQ) && __GNUC_PREREQ(4, 3) |
345 | | return (word64)__builtin_bswap64(value); |
346 | | #elif defined(WOLFCRYPT_SLOW_WORD64) |
347 | | return (word64)((word64)ByteReverseWord32((word32) value)) << 32 | |
348 | | (word64)ByteReverseWord32((word32)(value >> 32)); |
349 | | #else |
350 | 0 | value = ((value & W64LIT(0xFF00FF00FF00FF00)) >> 8) | |
351 | 0 | ((value & W64LIT(0x00FF00FF00FF00FF)) << 8); |
352 | 0 | value = ((value & W64LIT(0xFFFF0000FFFF0000)) >> 16) | |
353 | 0 | ((value & W64LIT(0x0000FFFF0000FFFF)) << 16); |
354 | 0 | return rotlFixed64(value, 32U); |
355 | 0 | #endif |
356 | 0 | } Unexecuted instantiation: ssl.c:ByteReverseWord64 Unexecuted instantiation: tls.c:ByteReverseWord64 Unexecuted instantiation: tls13.c:ByteReverseWord64 Unexecuted instantiation: hmac.c:ByteReverseWord64 Unexecuted instantiation: hash.c:ByteReverseWord64 Unexecuted instantiation: kdf.c:ByteReverseWord64 Unexecuted instantiation: random.c:ByteReverseWord64 Unexecuted instantiation: sha256.c:ByteReverseWord64 Unexecuted instantiation: rsa.c:ByteReverseWord64 Unexecuted instantiation: sp_int.c:ByteReverseWord64 Unexecuted instantiation: aes.c:ByteReverseWord64 Unexecuted instantiation: sha.c:ByteReverseWord64 Unexecuted instantiation: sha512.c:ByteReverseWord64 Unexecuted instantiation: sha3.c:ByteReverseWord64 Unexecuted instantiation: wolfmath.c:ByteReverseWord64 Unexecuted instantiation: dh.c:ByteReverseWord64 Unexecuted instantiation: asn.c:ByteReverseWord64 Unexecuted instantiation: coding.c:ByteReverseWord64 Unexecuted instantiation: poly1305.c:ByteReverseWord64 Unexecuted instantiation: md5.c:ByteReverseWord64 Unexecuted instantiation: chacha.c:ByteReverseWord64 Unexecuted instantiation: ecc.c:ByteReverseWord64 Unexecuted instantiation: internal.c:ByteReverseWord64 Unexecuted instantiation: wc_encrypt.c:ByteReverseWord64 Unexecuted instantiation: pwdbased.c:ByteReverseWord64 |
357 | | |
358 | | |
359 | | WC_MISC_STATIC WC_INLINE void ByteReverseWords64(word64* out, const word64* in, |
360 | | word32 byteCount) |
361 | 0 | { |
362 | 0 | word32 count = byteCount/(word32)sizeof(word64), i; |
363 | |
|
364 | 0 | #ifdef WOLFSSL_USE_ALIGN |
365 | 0 | if ((((size_t)in & 0x7) == 0) && |
366 | 0 | (((size_t)out & 0x7) == 0)) |
367 | 0 | #endif |
368 | 0 | { |
369 | 0 | for (i = 0; i < count; i++) |
370 | 0 | out[i] = ByteReverseWord64(in[i]); |
371 | 0 | } |
372 | 0 | #ifdef WOLFSSL_USE_ALIGN |
373 | 0 | else if (((size_t)in & 0x7) == 0) { |
374 | 0 | byte *out_bytes = (byte *)out; |
375 | 0 | word64 scratch; |
376 | |
|
377 | 0 | byteCount &= ~0x7U; |
378 | |
|
379 | 0 | for (i = 0; i < byteCount; i += (word32)sizeof(word64)) { |
380 | 0 | scratch = ByteReverseWord64(*in++); |
381 | 0 | XMEMCPY(out_bytes + i, &scratch, sizeof(scratch)); |
382 | 0 | } |
383 | 0 | } |
384 | 0 | else if (((size_t)out & 0x7) == 0) { |
385 | 0 | byte *in_bytes = (byte *)in; |
386 | 0 | word64 scratch; |
387 | |
|
388 | 0 | byteCount &= ~0x7U; |
389 | |
|
390 | 0 | for (i = 0; i < byteCount; i += (word32)sizeof(word64)) { |
391 | 0 | XMEMCPY(&scratch, in_bytes + i, sizeof(scratch)); |
392 | 0 | *out++ = ByteReverseWord64(scratch); |
393 | 0 | } |
394 | 0 | } |
395 | 0 | else { |
396 | 0 | byte *in_bytes = (byte *)in; |
397 | 0 | byte *out_bytes = (byte *)out; |
398 | 0 | word64 scratch; |
399 | |
|
400 | 0 | byteCount &= ~0x7U; |
401 | |
|
402 | 0 | for (i = 0; i < byteCount; i += (word32)sizeof(word64)) { |
403 | 0 | XMEMCPY(&scratch, in_bytes + i, sizeof(scratch)); |
404 | 0 | scratch = ByteReverseWord64(scratch); |
405 | 0 | XMEMCPY(out_bytes + i, &scratch, sizeof(scratch)); |
406 | 0 | } |
407 | 0 | } |
408 | 0 | #endif |
409 | 0 | } Unexecuted instantiation: ssl.c:ByteReverseWords64 Unexecuted instantiation: tls.c:ByteReverseWords64 Unexecuted instantiation: tls13.c:ByteReverseWords64 Unexecuted instantiation: hmac.c:ByteReverseWords64 Unexecuted instantiation: hash.c:ByteReverseWords64 Unexecuted instantiation: kdf.c:ByteReverseWords64 Unexecuted instantiation: random.c:ByteReverseWords64 Unexecuted instantiation: sha256.c:ByteReverseWords64 Unexecuted instantiation: rsa.c:ByteReverseWords64 Unexecuted instantiation: sp_int.c:ByteReverseWords64 Unexecuted instantiation: aes.c:ByteReverseWords64 Unexecuted instantiation: sha.c:ByteReverseWords64 Unexecuted instantiation: sha512.c:ByteReverseWords64 Unexecuted instantiation: sha3.c:ByteReverseWords64 Unexecuted instantiation: wolfmath.c:ByteReverseWords64 Unexecuted instantiation: dh.c:ByteReverseWords64 Unexecuted instantiation: asn.c:ByteReverseWords64 Unexecuted instantiation: coding.c:ByteReverseWords64 Unexecuted instantiation: poly1305.c:ByteReverseWords64 Unexecuted instantiation: md5.c:ByteReverseWords64 Unexecuted instantiation: chacha.c:ByteReverseWords64 Unexecuted instantiation: ecc.c:ByteReverseWords64 Unexecuted instantiation: internal.c:ByteReverseWords64 Unexecuted instantiation: wc_encrypt.c:ByteReverseWords64 Unexecuted instantiation: pwdbased.c:ByteReverseWords64 |
410 | | |
411 | | #endif /* WORD64_AVAILABLE && !WOLFSSL_NO_WORD64_OPS */ |
412 | | |
413 | | #ifndef WOLFSSL_NO_XOR_OPS |
414 | | |
415 | | /* Leave no doubt that WOLFSSL_WORD_SIZE is a power of 2. */ |
416 | | wc_static_assert((WOLFSSL_WORD_SIZE & (WOLFSSL_WORD_SIZE - 1)) == 0); |
417 | | |
418 | | /* This routine performs a bitwise XOR operation of <*r> and <*a> for <n> number |
419 | | of wolfssl_words, placing the result in <*r>. */ |
420 | | WC_MISC_STATIC WC_INLINE void XorWordsOut(wolfssl_word** r, |
421 | | const wolfssl_word** a, const wolfssl_word** b, word32 n) |
422 | 0 | { |
423 | 0 | const wolfssl_word *e = *a + n; |
424 | |
|
425 | 0 | while (*a < e) |
426 | 0 | *((*r)++) = *((*a)++) ^ *((*b)++); |
427 | 0 | } Unexecuted instantiation: ssl.c:XorWordsOut Unexecuted instantiation: tls.c:XorWordsOut Unexecuted instantiation: tls13.c:XorWordsOut Unexecuted instantiation: hmac.c:XorWordsOut Unexecuted instantiation: hash.c:XorWordsOut Unexecuted instantiation: kdf.c:XorWordsOut Unexecuted instantiation: random.c:XorWordsOut Unexecuted instantiation: sha256.c:XorWordsOut Unexecuted instantiation: rsa.c:XorWordsOut Unexecuted instantiation: sp_int.c:XorWordsOut Unexecuted instantiation: aes.c:XorWordsOut Unexecuted instantiation: sha.c:XorWordsOut Unexecuted instantiation: sha512.c:XorWordsOut Unexecuted instantiation: sha3.c:XorWordsOut Unexecuted instantiation: wolfmath.c:XorWordsOut Unexecuted instantiation: dh.c:XorWordsOut Unexecuted instantiation: asn.c:XorWordsOut Unexecuted instantiation: coding.c:XorWordsOut Unexecuted instantiation: poly1305.c:XorWordsOut Unexecuted instantiation: md5.c:XorWordsOut Unexecuted instantiation: chacha.c:XorWordsOut Unexecuted instantiation: ecc.c:XorWordsOut Unexecuted instantiation: internal.c:XorWordsOut Unexecuted instantiation: wc_encrypt.c:XorWordsOut Unexecuted instantiation: pwdbased.c:XorWordsOut |
428 | | |
429 | | /* This routine performs a bitwise XOR operation of <*buf> and <*mask> of n |
430 | | counts, placing the result in <*buf>. */ |
431 | | |
432 | | WC_MISC_STATIC WC_INLINE void xorbufout(void* out, const void* buf, |
433 | | const void* mask, word32 count) |
434 | 0 | { |
435 | 0 | byte* o = (byte*)out; |
436 | 0 | const byte* b = (const byte*)buf; |
437 | 0 | const byte* m = (const byte*)mask; |
438 | | |
439 | | /* type-punning helpers */ |
440 | 0 | union { |
441 | 0 | byte* bp; |
442 | 0 | wolfssl_word* wp; |
443 | 0 | } tpo; |
444 | 0 | union { |
445 | 0 | const byte* bp; |
446 | 0 | const wolfssl_word* wp; |
447 | 0 | } tpb, tpm; |
448 | |
|
449 | 0 | if (((((wc_ptr_t)o) & (WOLFSSL_WORD_SIZE - 1)) == 0) && |
450 | 0 | ((((wc_ptr_t)b) & (WOLFSSL_WORD_SIZE - 1)) == 0) && |
451 | 0 | ((((wc_ptr_t)m) & (WOLFSSL_WORD_SIZE - 1)) == 0)) |
452 | 0 | { |
453 | | /* All buffers are already aligned. Possible to XOR by words without |
454 | | * fixup. |
455 | | */ |
456 | |
|
457 | 0 | tpo.bp = o; |
458 | 0 | tpb.bp = b; |
459 | 0 | tpm.bp = m; |
460 | 0 | XorWordsOut(&tpo.wp, &tpb.wp, &tpm.wp, count >> WOLFSSL_WORD_SIZE_LOG2); |
461 | 0 | o = tpo.bp; |
462 | 0 | b = tpb.bp; |
463 | 0 | m = tpm.bp; |
464 | 0 | count &= (WOLFSSL_WORD_SIZE - 1); |
465 | 0 | } |
466 | 0 | else if ((((wc_ptr_t)o) & (WOLFSSL_WORD_SIZE - 1)) == |
467 | 0 | (((wc_ptr_t)b) & (WOLFSSL_WORD_SIZE - 1)) && |
468 | 0 | (((wc_ptr_t)b) & (WOLFSSL_WORD_SIZE - 1)) == |
469 | 0 | (((wc_ptr_t)m) & (WOLFSSL_WORD_SIZE - 1))) |
470 | 0 | { |
471 | | /* Alignment can be fixed up to allow XOR by words. */ |
472 | | |
473 | | /* Perform bytewise xor until pointers are aligned to |
474 | | * WOLFSSL_WORD_SIZE. |
475 | | */ |
476 | 0 | while ((((wc_ptr_t)b & (WOLFSSL_WORD_SIZE - 1)) != 0) && (count > 0)) |
477 | 0 | { |
478 | 0 | *o++ = (byte)(*b++ ^ *m++); |
479 | 0 | count--; |
480 | 0 | } |
481 | |
|
482 | 0 | tpo.bp = o; |
483 | 0 | tpb.bp = b; |
484 | 0 | tpm.bp = m; |
485 | 0 | XorWordsOut(&tpo.wp, &tpb.wp, &tpm.wp, count >> WOLFSSL_WORD_SIZE_LOG2); |
486 | 0 | o = tpo.bp; |
487 | 0 | b = tpb.bp; |
488 | 0 | m = tpm.bp; |
489 | 0 | count &= (WOLFSSL_WORD_SIZE - 1); |
490 | 0 | } |
491 | |
|
492 | 0 | while (count > 0) { |
493 | 0 | *o++ = (byte)(*b++ ^ *m++); |
494 | 0 | count--; |
495 | 0 | } |
496 | |
|
497 | 0 | } Unexecuted instantiation: ssl.c:xorbufout Unexecuted instantiation: tls.c:xorbufout Unexecuted instantiation: tls13.c:xorbufout Unexecuted instantiation: hmac.c:xorbufout Unexecuted instantiation: hash.c:xorbufout Unexecuted instantiation: kdf.c:xorbufout Unexecuted instantiation: random.c:xorbufout Unexecuted instantiation: sha256.c:xorbufout Unexecuted instantiation: rsa.c:xorbufout Unexecuted instantiation: sp_int.c:xorbufout Unexecuted instantiation: aes.c:xorbufout Unexecuted instantiation: sha.c:xorbufout Unexecuted instantiation: sha512.c:xorbufout Unexecuted instantiation: sha3.c:xorbufout Unexecuted instantiation: wolfmath.c:xorbufout Unexecuted instantiation: dh.c:xorbufout Unexecuted instantiation: asn.c:xorbufout Unexecuted instantiation: coding.c:xorbufout Unexecuted instantiation: poly1305.c:xorbufout Unexecuted instantiation: md5.c:xorbufout Unexecuted instantiation: chacha.c:xorbufout Unexecuted instantiation: ecc.c:xorbufout Unexecuted instantiation: internal.c:xorbufout Unexecuted instantiation: wc_encrypt.c:xorbufout Unexecuted instantiation: pwdbased.c:xorbufout |
498 | | |
499 | | /* This routine performs a bitwise XOR operation of <*r> and <*a> for <n> number |
500 | | of wolfssl_words, placing the result in <*r>. */ |
501 | | WC_MISC_STATIC WC_INLINE void XorWords(wolfssl_word** r, const wolfssl_word** a, |
502 | | word32 n) |
503 | 0 | { |
504 | 0 | const wolfssl_word *e = *a + n; |
505 | |
|
506 | 0 | while (*a < e) |
507 | 0 | *((*r)++) ^= *((*a)++); |
508 | 0 | } Unexecuted instantiation: ssl.c:XorWords Unexecuted instantiation: tls.c:XorWords Unexecuted instantiation: tls13.c:XorWords Unexecuted instantiation: hmac.c:XorWords Unexecuted instantiation: hash.c:XorWords Unexecuted instantiation: kdf.c:XorWords Unexecuted instantiation: random.c:XorWords Unexecuted instantiation: sha256.c:XorWords Unexecuted instantiation: rsa.c:XorWords Unexecuted instantiation: sp_int.c:XorWords Unexecuted instantiation: aes.c:XorWords Unexecuted instantiation: sha.c:XorWords Unexecuted instantiation: sha512.c:XorWords Unexecuted instantiation: sha3.c:XorWords Unexecuted instantiation: wolfmath.c:XorWords Unexecuted instantiation: dh.c:XorWords Unexecuted instantiation: asn.c:XorWords Unexecuted instantiation: coding.c:XorWords Unexecuted instantiation: poly1305.c:XorWords Unexecuted instantiation: md5.c:XorWords Unexecuted instantiation: chacha.c:XorWords Unexecuted instantiation: ecc.c:XorWords Unexecuted instantiation: internal.c:XorWords Unexecuted instantiation: wc_encrypt.c:XorWords Unexecuted instantiation: pwdbased.c:XorWords |
509 | | |
510 | | /* This routine performs a bitwise XOR operation of <*buf> and <*mask> of n |
511 | | counts, placing the result in <*buf>. */ |
512 | | |
513 | | WC_MISC_STATIC WC_INLINE void xorbuf(void* buf, const void* mask, word32 count) |
514 | 0 | { |
515 | 0 | byte* b = (byte*)buf; |
516 | 0 | const byte* m = (const byte*)mask; |
517 | | |
518 | | /* type-punning helpers */ |
519 | 0 | union { |
520 | 0 | byte* bp; |
521 | 0 | wolfssl_word* wp; |
522 | 0 | } tpb; |
523 | 0 | union { |
524 | 0 | const byte* bp; |
525 | 0 | const wolfssl_word* wp; |
526 | 0 | } tpm; |
527 | |
|
528 | 0 | if ((((wc_ptr_t)buf & (WOLFSSL_WORD_SIZE - 1)) == 0) && |
529 | 0 | (((wc_ptr_t)mask & (WOLFSSL_WORD_SIZE - 1)) == 0)) |
530 | 0 | { |
531 | | /* Both buffers are already aligned. Possible to XOR by words without |
532 | | * fixup. |
533 | | */ |
534 | |
|
535 | 0 | tpb.bp = b; |
536 | 0 | tpm.bp = m; |
537 | | /* Work around false positives from linuxkm CONFIG_FORTIFY_SOURCE. */ |
538 | | #if defined(WOLFSSL_LINUXKM) && defined(CONFIG_FORTIFY_SOURCE) |
539 | | PRAGMA_GCC_DIAG_PUSH; |
540 | | PRAGMA_GCC("GCC diagnostic ignored \"-Wmaybe-uninitialized\"") |
541 | | #endif |
542 | 0 | XorWords(&tpb.wp, &tpm.wp, count >> WOLFSSL_WORD_SIZE_LOG2); |
543 | | #if defined(WOLFSSL_LINUXKM) && defined(CONFIG_FORTIFY_SOURCE) |
544 | | PRAGMA_GCC_DIAG_POP; |
545 | | #endif |
546 | 0 | b = tpb.bp; |
547 | 0 | m = tpm.bp; |
548 | 0 | count &= (WOLFSSL_WORD_SIZE - 1); |
549 | 0 | } |
550 | 0 | else if (((wc_ptr_t)buf & (WOLFSSL_WORD_SIZE - 1)) == |
551 | 0 | ((wc_ptr_t)mask & (WOLFSSL_WORD_SIZE - 1))) |
552 | 0 | { |
553 | | /* Alignment can be fixed up to allow XOR by words. */ |
554 | | |
555 | | /* Perform bytewise xor until pointers are aligned to |
556 | | * WOLFSSL_WORD_SIZE. |
557 | | */ |
558 | 0 | while ((((wc_ptr_t)b & (WOLFSSL_WORD_SIZE - 1)) != 0) && (count > 0)) |
559 | 0 | { |
560 | 0 | *(b++) ^= *(m++); |
561 | 0 | count--; |
562 | 0 | } |
563 | |
|
564 | 0 | tpb.bp = b; |
565 | 0 | tpm.bp = m; |
566 | | /* Work around false positives from linuxkm CONFIG_FORTIFY_SOURCE. */ |
567 | | #if defined(WOLFSSL_LINUXKM) && defined(CONFIG_FORTIFY_SOURCE) |
568 | | PRAGMA_GCC_DIAG_PUSH; |
569 | | PRAGMA_GCC("GCC diagnostic ignored \"-Wmaybe-uninitialized\"") |
570 | | #endif |
571 | 0 | XorWords(&tpb.wp, &tpm.wp, count >> WOLFSSL_WORD_SIZE_LOG2); |
572 | | #if defined(WOLFSSL_LINUXKM) && defined(CONFIG_FORTIFY_SOURCE) |
573 | | PRAGMA_GCC_DIAG_POP; |
574 | | #endif |
575 | 0 | b = tpb.bp; |
576 | 0 | m = tpm.bp; |
577 | 0 | count &= (WOLFSSL_WORD_SIZE - 1); |
578 | 0 | } |
579 | |
|
580 | 0 | while (count > 0) { |
581 | 0 | *b++ ^= *m++; |
582 | 0 | count--; |
583 | 0 | } |
584 | 0 | } Unexecuted instantiation: ssl.c:xorbuf Unexecuted instantiation: tls.c:xorbuf Unexecuted instantiation: tls13.c:xorbuf Unexecuted instantiation: hmac.c:xorbuf Unexecuted instantiation: hash.c:xorbuf Unexecuted instantiation: kdf.c:xorbuf Unexecuted instantiation: random.c:xorbuf Unexecuted instantiation: sha256.c:xorbuf Unexecuted instantiation: rsa.c:xorbuf Unexecuted instantiation: sp_int.c:xorbuf Unexecuted instantiation: aes.c:xorbuf Unexecuted instantiation: sha.c:xorbuf Unexecuted instantiation: sha512.c:xorbuf Unexecuted instantiation: sha3.c:xorbuf Unexecuted instantiation: wolfmath.c:xorbuf Unexecuted instantiation: dh.c:xorbuf Unexecuted instantiation: asn.c:xorbuf Unexecuted instantiation: coding.c:xorbuf Unexecuted instantiation: poly1305.c:xorbuf Unexecuted instantiation: md5.c:xorbuf Unexecuted instantiation: chacha.c:xorbuf Unexecuted instantiation: ecc.c:xorbuf Unexecuted instantiation: internal.c:xorbuf Unexecuted instantiation: wc_encrypt.c:xorbuf Unexecuted instantiation: pwdbased.c:xorbuf |
585 | | |
586 | | #endif /* !WOLFSSL_NO_XOR_OPS */ |
587 | | |
588 | | #ifndef WOLFSSL_NO_FORCE_ZERO |
589 | | /* This routine fills the first len bytes of the memory area pointed by mem |
590 | | with zeros. It ensures compiler optimization doesn't skip it */ |
591 | | WC_MISC_STATIC WC_INLINE void ForceZero(void* mem, word32 len) |
592 | 0 | { |
593 | 0 | volatile byte* z = (volatile byte*)mem; |
594 | |
|
595 | 0 | #if (defined(WOLFSSL_X86_64_BUILD) || defined(WOLFSSL_AARCH64_BUILD)) \ |
596 | 0 | && defined(WORD64_AVAILABLE) |
597 | 0 | volatile word64* w; |
598 | 0 | #ifndef WOLFSSL_UNALIGNED_64BIT_ACCESS |
599 | 0 | word32 l = (sizeof(word64) - ((size_t)z & (sizeof(word64)-1))) & |
600 | 0 | (sizeof(word64)-1); |
601 | |
|
602 | 0 | if (len < l) l = len; |
603 | 0 | len -= l; |
604 | 0 | while (l--) *z++ = 0; |
605 | 0 | #endif |
606 | 0 | for (w = (volatile word64*)z; |
607 | 0 | len >= sizeof(*w); |
608 | 0 | len -= (word32)sizeof(*w)) |
609 | 0 | { |
610 | 0 | *w++ = 0; |
611 | 0 | } |
612 | 0 | z = (volatile byte*)w; |
613 | 0 | #endif |
614 | |
|
615 | 0 | while (len--) *z++ = 0; |
616 | 0 | } Unexecuted instantiation: ssl.c:ForceZero Unexecuted instantiation: tls.c:ForceZero Unexecuted instantiation: tls13.c:ForceZero Unexecuted instantiation: hmac.c:ForceZero Unexecuted instantiation: hash.c:ForceZero Unexecuted instantiation: kdf.c:ForceZero Unexecuted instantiation: random.c:ForceZero Unexecuted instantiation: sha256.c:ForceZero Unexecuted instantiation: rsa.c:ForceZero Unexecuted instantiation: sp_int.c:ForceZero Unexecuted instantiation: aes.c:ForceZero Unexecuted instantiation: sha.c:ForceZero Unexecuted instantiation: sha512.c:ForceZero Unexecuted instantiation: sha3.c:ForceZero Unexecuted instantiation: wolfmath.c:ForceZero Unexecuted instantiation: dh.c:ForceZero Unexecuted instantiation: asn.c:ForceZero Unexecuted instantiation: coding.c:ForceZero Unexecuted instantiation: poly1305.c:ForceZero Unexecuted instantiation: md5.c:ForceZero Unexecuted instantiation: chacha.c:ForceZero Unexecuted instantiation: ecc.c:ForceZero Unexecuted instantiation: internal.c:ForceZero Unexecuted instantiation: wc_encrypt.c:ForceZero Unexecuted instantiation: pwdbased.c:ForceZero |
617 | | #endif |
618 | | |
619 | | |
620 | | #ifndef WOLFSSL_NO_CONST_CMP |
621 | | /* check all length bytes for equality, return 0 on success */ |
622 | | WC_MISC_STATIC WC_INLINE int ConstantCompare(const byte* a, const byte* b, |
623 | | int length) |
624 | 0 | { |
625 | 0 | int i; |
626 | 0 | int compareSum = 0; |
627 | |
|
628 | 0 | for (i = 0; i < length; i++) { |
629 | 0 | compareSum |= a[i] ^ b[i]; |
630 | 0 | } |
631 | |
|
632 | 0 | return compareSum; |
633 | 0 | } Unexecuted instantiation: ssl.c:ConstantCompare Unexecuted instantiation: tls.c:ConstantCompare Unexecuted instantiation: tls13.c:ConstantCompare Unexecuted instantiation: hmac.c:ConstantCompare Unexecuted instantiation: hash.c:ConstantCompare Unexecuted instantiation: kdf.c:ConstantCompare Unexecuted instantiation: random.c:ConstantCompare Unexecuted instantiation: sha256.c:ConstantCompare Unexecuted instantiation: rsa.c:ConstantCompare Unexecuted instantiation: sp_int.c:ConstantCompare Unexecuted instantiation: aes.c:ConstantCompare Unexecuted instantiation: sha.c:ConstantCompare Unexecuted instantiation: sha512.c:ConstantCompare Unexecuted instantiation: sha3.c:ConstantCompare Unexecuted instantiation: wolfmath.c:ConstantCompare Unexecuted instantiation: dh.c:ConstantCompare Unexecuted instantiation: asn.c:ConstantCompare Unexecuted instantiation: coding.c:ConstantCompare Unexecuted instantiation: poly1305.c:ConstantCompare Unexecuted instantiation: md5.c:ConstantCompare Unexecuted instantiation: chacha.c:ConstantCompare Unexecuted instantiation: ecc.c:ConstantCompare Unexecuted instantiation: internal.c:ConstantCompare Unexecuted instantiation: wc_encrypt.c:ConstantCompare Unexecuted instantiation: pwdbased.c:ConstantCompare |
634 | | #endif |
635 | | |
636 | | #ifndef WOLFSSL_NO_CT_OPS |
637 | | /* Constant time - mask set when a > b. */ |
638 | | WC_MISC_STATIC WC_INLINE byte ctMaskGT(int a, int b) |
639 | 0 | { |
640 | 0 | return (byte)((((word32)a - (word32)b - 1) >> 31) - 1); |
641 | 0 | } Unexecuted instantiation: ssl.c:ctMaskGT Unexecuted instantiation: tls.c:ctMaskGT Unexecuted instantiation: tls13.c:ctMaskGT Unexecuted instantiation: hmac.c:ctMaskGT Unexecuted instantiation: hash.c:ctMaskGT Unexecuted instantiation: kdf.c:ctMaskGT Unexecuted instantiation: random.c:ctMaskGT Unexecuted instantiation: sha256.c:ctMaskGT Unexecuted instantiation: rsa.c:ctMaskGT Unexecuted instantiation: sp_int.c:ctMaskGT Unexecuted instantiation: aes.c:ctMaskGT Unexecuted instantiation: sha.c:ctMaskGT Unexecuted instantiation: sha512.c:ctMaskGT Unexecuted instantiation: sha3.c:ctMaskGT Unexecuted instantiation: wolfmath.c:ctMaskGT Unexecuted instantiation: dh.c:ctMaskGT Unexecuted instantiation: asn.c:ctMaskGT Unexecuted instantiation: coding.c:ctMaskGT Unexecuted instantiation: poly1305.c:ctMaskGT Unexecuted instantiation: md5.c:ctMaskGT Unexecuted instantiation: chacha.c:ctMaskGT Unexecuted instantiation: ecc.c:ctMaskGT Unexecuted instantiation: internal.c:ctMaskGT Unexecuted instantiation: wc_encrypt.c:ctMaskGT Unexecuted instantiation: pwdbased.c:ctMaskGT |
642 | | |
643 | | /* Constant time - mask set when a >= b. */ |
644 | | WC_MISC_STATIC WC_INLINE byte ctMaskGTE(int a, int b) |
645 | 0 | { |
646 | 0 | return (byte)((((word32)a - (word32)b) >> 31) - 1); |
647 | 0 | } Unexecuted instantiation: ssl.c:ctMaskGTE Unexecuted instantiation: tls.c:ctMaskGTE Unexecuted instantiation: tls13.c:ctMaskGTE Unexecuted instantiation: hmac.c:ctMaskGTE Unexecuted instantiation: hash.c:ctMaskGTE Unexecuted instantiation: kdf.c:ctMaskGTE Unexecuted instantiation: random.c:ctMaskGTE Unexecuted instantiation: sha256.c:ctMaskGTE Unexecuted instantiation: rsa.c:ctMaskGTE Unexecuted instantiation: sp_int.c:ctMaskGTE Unexecuted instantiation: aes.c:ctMaskGTE Unexecuted instantiation: sha.c:ctMaskGTE Unexecuted instantiation: sha512.c:ctMaskGTE Unexecuted instantiation: sha3.c:ctMaskGTE Unexecuted instantiation: wolfmath.c:ctMaskGTE Unexecuted instantiation: dh.c:ctMaskGTE Unexecuted instantiation: asn.c:ctMaskGTE Unexecuted instantiation: coding.c:ctMaskGTE Unexecuted instantiation: poly1305.c:ctMaskGTE Unexecuted instantiation: md5.c:ctMaskGTE Unexecuted instantiation: chacha.c:ctMaskGTE Unexecuted instantiation: ecc.c:ctMaskGTE Unexecuted instantiation: internal.c:ctMaskGTE Unexecuted instantiation: wc_encrypt.c:ctMaskGTE Unexecuted instantiation: pwdbased.c:ctMaskGTE |
648 | | |
649 | | /* Constant time - mask set when a >= b. */ |
650 | | WC_MISC_STATIC WC_INLINE int ctMaskIntGTE(int a, int b) |
651 | 0 | { |
652 | 0 | return (int)((((word32)a - (word32)b) >> 31) - 1); |
653 | 0 | } Unexecuted instantiation: ssl.c:ctMaskIntGTE Unexecuted instantiation: tls.c:ctMaskIntGTE Unexecuted instantiation: tls13.c:ctMaskIntGTE Unexecuted instantiation: hmac.c:ctMaskIntGTE Unexecuted instantiation: hash.c:ctMaskIntGTE Unexecuted instantiation: kdf.c:ctMaskIntGTE Unexecuted instantiation: random.c:ctMaskIntGTE Unexecuted instantiation: sha256.c:ctMaskIntGTE Unexecuted instantiation: rsa.c:ctMaskIntGTE Unexecuted instantiation: sp_int.c:ctMaskIntGTE Unexecuted instantiation: aes.c:ctMaskIntGTE Unexecuted instantiation: sha.c:ctMaskIntGTE Unexecuted instantiation: sha512.c:ctMaskIntGTE Unexecuted instantiation: sha3.c:ctMaskIntGTE Unexecuted instantiation: wolfmath.c:ctMaskIntGTE Unexecuted instantiation: dh.c:ctMaskIntGTE Unexecuted instantiation: asn.c:ctMaskIntGTE Unexecuted instantiation: coding.c:ctMaskIntGTE Unexecuted instantiation: poly1305.c:ctMaskIntGTE Unexecuted instantiation: md5.c:ctMaskIntGTE Unexecuted instantiation: chacha.c:ctMaskIntGTE Unexecuted instantiation: ecc.c:ctMaskIntGTE Unexecuted instantiation: internal.c:ctMaskIntGTE Unexecuted instantiation: wc_encrypt.c:ctMaskIntGTE Unexecuted instantiation: pwdbased.c:ctMaskIntGTE |
654 | | |
655 | | #ifdef WORD64_AVAILABLE |
656 | | /* Constant time - mask set when a >= b. */ |
657 | | WC_MISC_STATIC WC_INLINE word32 ctMaskWord32GTE(word32 a, word32 b) |
658 | 0 | { |
659 | 0 | return (word32)((((word64)a - (word64)b) >> 63) - 1); |
660 | 0 | } Unexecuted instantiation: ssl.c:ctMaskWord32GTE Unexecuted instantiation: tls.c:ctMaskWord32GTE Unexecuted instantiation: tls13.c:ctMaskWord32GTE Unexecuted instantiation: hmac.c:ctMaskWord32GTE Unexecuted instantiation: hash.c:ctMaskWord32GTE Unexecuted instantiation: kdf.c:ctMaskWord32GTE Unexecuted instantiation: random.c:ctMaskWord32GTE Unexecuted instantiation: sha256.c:ctMaskWord32GTE Unexecuted instantiation: rsa.c:ctMaskWord32GTE Unexecuted instantiation: sp_int.c:ctMaskWord32GTE Unexecuted instantiation: aes.c:ctMaskWord32GTE Unexecuted instantiation: sha.c:ctMaskWord32GTE Unexecuted instantiation: sha512.c:ctMaskWord32GTE Unexecuted instantiation: sha3.c:ctMaskWord32GTE Unexecuted instantiation: wolfmath.c:ctMaskWord32GTE Unexecuted instantiation: dh.c:ctMaskWord32GTE Unexecuted instantiation: asn.c:ctMaskWord32GTE Unexecuted instantiation: coding.c:ctMaskWord32GTE Unexecuted instantiation: poly1305.c:ctMaskWord32GTE Unexecuted instantiation: md5.c:ctMaskWord32GTE Unexecuted instantiation: chacha.c:ctMaskWord32GTE Unexecuted instantiation: ecc.c:ctMaskWord32GTE Unexecuted instantiation: internal.c:ctMaskWord32GTE Unexecuted instantiation: wc_encrypt.c:ctMaskWord32GTE Unexecuted instantiation: pwdbased.c:ctMaskWord32GTE |
661 | | #endif |
662 | | |
663 | | /* Constant time - mask set when a < b. */ |
664 | | WC_MISC_STATIC WC_INLINE byte ctMaskLT(int a, int b) |
665 | 0 | { |
666 | 0 | return (byte)((((word32)b - (word32)a - 1) >> 31) - 1); |
667 | 0 | } Unexecuted instantiation: ssl.c:ctMaskLT Unexecuted instantiation: tls.c:ctMaskLT Unexecuted instantiation: tls13.c:ctMaskLT Unexecuted instantiation: hmac.c:ctMaskLT Unexecuted instantiation: hash.c:ctMaskLT Unexecuted instantiation: kdf.c:ctMaskLT Unexecuted instantiation: random.c:ctMaskLT Unexecuted instantiation: sha256.c:ctMaskLT Unexecuted instantiation: rsa.c:ctMaskLT Unexecuted instantiation: sp_int.c:ctMaskLT Unexecuted instantiation: aes.c:ctMaskLT Unexecuted instantiation: sha.c:ctMaskLT Unexecuted instantiation: sha512.c:ctMaskLT Unexecuted instantiation: sha3.c:ctMaskLT Unexecuted instantiation: wolfmath.c:ctMaskLT Unexecuted instantiation: dh.c:ctMaskLT Unexecuted instantiation: asn.c:ctMaskLT Unexecuted instantiation: coding.c:ctMaskLT Unexecuted instantiation: poly1305.c:ctMaskLT Unexecuted instantiation: md5.c:ctMaskLT Unexecuted instantiation: chacha.c:ctMaskLT Unexecuted instantiation: ecc.c:ctMaskLT Unexecuted instantiation: internal.c:ctMaskLT Unexecuted instantiation: wc_encrypt.c:ctMaskLT Unexecuted instantiation: pwdbased.c:ctMaskLT |
668 | | |
669 | | /* Constant time - mask set when a <= b. */ |
670 | | WC_MISC_STATIC WC_INLINE byte ctMaskLTE(int a, int b) |
671 | 0 | { |
672 | 0 | return (byte)((((word32)b - (word32)a) >> 31) - 1); |
673 | 0 | } Unexecuted instantiation: ssl.c:ctMaskLTE Unexecuted instantiation: tls.c:ctMaskLTE Unexecuted instantiation: tls13.c:ctMaskLTE Unexecuted instantiation: hmac.c:ctMaskLTE Unexecuted instantiation: hash.c:ctMaskLTE Unexecuted instantiation: kdf.c:ctMaskLTE Unexecuted instantiation: random.c:ctMaskLTE Unexecuted instantiation: sha256.c:ctMaskLTE Unexecuted instantiation: rsa.c:ctMaskLTE Unexecuted instantiation: sp_int.c:ctMaskLTE Unexecuted instantiation: aes.c:ctMaskLTE Unexecuted instantiation: sha.c:ctMaskLTE Unexecuted instantiation: sha512.c:ctMaskLTE Unexecuted instantiation: sha3.c:ctMaskLTE Unexecuted instantiation: wolfmath.c:ctMaskLTE Unexecuted instantiation: dh.c:ctMaskLTE Unexecuted instantiation: asn.c:ctMaskLTE Unexecuted instantiation: coding.c:ctMaskLTE Unexecuted instantiation: poly1305.c:ctMaskLTE Unexecuted instantiation: md5.c:ctMaskLTE Unexecuted instantiation: chacha.c:ctMaskLTE Unexecuted instantiation: ecc.c:ctMaskLTE Unexecuted instantiation: internal.c:ctMaskLTE Unexecuted instantiation: wc_encrypt.c:ctMaskLTE Unexecuted instantiation: pwdbased.c:ctMaskLTE |
674 | | |
675 | | /* Constant time - mask set when a == b. */ |
676 | | WC_MISC_STATIC WC_INLINE byte ctMaskEq(int a, int b) |
677 | 0 | { |
678 | 0 | return (byte)((byte)(~ctMaskGT(a, b)) & (byte)(~ctMaskLT(a, b))); |
679 | 0 | } Unexecuted instantiation: ssl.c:ctMaskEq Unexecuted instantiation: tls.c:ctMaskEq Unexecuted instantiation: tls13.c:ctMaskEq Unexecuted instantiation: hmac.c:ctMaskEq Unexecuted instantiation: hash.c:ctMaskEq Unexecuted instantiation: kdf.c:ctMaskEq Unexecuted instantiation: random.c:ctMaskEq Unexecuted instantiation: sha256.c:ctMaskEq Unexecuted instantiation: rsa.c:ctMaskEq Unexecuted instantiation: sp_int.c:ctMaskEq Unexecuted instantiation: aes.c:ctMaskEq Unexecuted instantiation: sha.c:ctMaskEq Unexecuted instantiation: sha512.c:ctMaskEq Unexecuted instantiation: sha3.c:ctMaskEq Unexecuted instantiation: wolfmath.c:ctMaskEq Unexecuted instantiation: dh.c:ctMaskEq Unexecuted instantiation: asn.c:ctMaskEq Unexecuted instantiation: coding.c:ctMaskEq Unexecuted instantiation: poly1305.c:ctMaskEq Unexecuted instantiation: md5.c:ctMaskEq Unexecuted instantiation: chacha.c:ctMaskEq Unexecuted instantiation: ecc.c:ctMaskEq Unexecuted instantiation: internal.c:ctMaskEq Unexecuted instantiation: wc_encrypt.c:ctMaskEq Unexecuted instantiation: pwdbased.c:ctMaskEq |
680 | | |
681 | | /* Constant time - sets 16 bit integer mask when a > b */ |
682 | | WC_MISC_STATIC WC_INLINE word16 ctMask16GT(int a, int b) |
683 | 0 | { |
684 | 0 | return (word16)((((word32)a - (word32)b - 1) >> 31) - 1); |
685 | 0 | } Unexecuted instantiation: ssl.c:ctMask16GT Unexecuted instantiation: tls.c:ctMask16GT Unexecuted instantiation: tls13.c:ctMask16GT Unexecuted instantiation: hmac.c:ctMask16GT Unexecuted instantiation: hash.c:ctMask16GT Unexecuted instantiation: kdf.c:ctMask16GT Unexecuted instantiation: random.c:ctMask16GT Unexecuted instantiation: sha256.c:ctMask16GT Unexecuted instantiation: rsa.c:ctMask16GT Unexecuted instantiation: sp_int.c:ctMask16GT Unexecuted instantiation: aes.c:ctMask16GT Unexecuted instantiation: sha.c:ctMask16GT Unexecuted instantiation: sha512.c:ctMask16GT Unexecuted instantiation: sha3.c:ctMask16GT Unexecuted instantiation: wolfmath.c:ctMask16GT Unexecuted instantiation: dh.c:ctMask16GT Unexecuted instantiation: asn.c:ctMask16GT Unexecuted instantiation: coding.c:ctMask16GT Unexecuted instantiation: poly1305.c:ctMask16GT Unexecuted instantiation: md5.c:ctMask16GT Unexecuted instantiation: chacha.c:ctMask16GT Unexecuted instantiation: ecc.c:ctMask16GT Unexecuted instantiation: internal.c:ctMask16GT Unexecuted instantiation: wc_encrypt.c:ctMask16GT Unexecuted instantiation: pwdbased.c:ctMask16GT |
686 | | |
687 | | /* Constant time - sets 16 bit integer mask when a >= b */ |
688 | | WC_MISC_STATIC WC_INLINE word16 ctMask16GTE(int a, int b) |
689 | 0 | { |
690 | 0 | return (word16)((((word32)a - (word32)b) >> 31) - 1); |
691 | 0 | } Unexecuted instantiation: ssl.c:ctMask16GTE Unexecuted instantiation: tls.c:ctMask16GTE Unexecuted instantiation: tls13.c:ctMask16GTE Unexecuted instantiation: hmac.c:ctMask16GTE Unexecuted instantiation: hash.c:ctMask16GTE Unexecuted instantiation: kdf.c:ctMask16GTE Unexecuted instantiation: random.c:ctMask16GTE Unexecuted instantiation: sha256.c:ctMask16GTE Unexecuted instantiation: rsa.c:ctMask16GTE Unexecuted instantiation: sp_int.c:ctMask16GTE Unexecuted instantiation: aes.c:ctMask16GTE Unexecuted instantiation: sha.c:ctMask16GTE Unexecuted instantiation: sha512.c:ctMask16GTE Unexecuted instantiation: sha3.c:ctMask16GTE Unexecuted instantiation: wolfmath.c:ctMask16GTE Unexecuted instantiation: dh.c:ctMask16GTE Unexecuted instantiation: asn.c:ctMask16GTE Unexecuted instantiation: coding.c:ctMask16GTE Unexecuted instantiation: poly1305.c:ctMask16GTE Unexecuted instantiation: md5.c:ctMask16GTE Unexecuted instantiation: chacha.c:ctMask16GTE Unexecuted instantiation: ecc.c:ctMask16GTE Unexecuted instantiation: internal.c:ctMask16GTE Unexecuted instantiation: wc_encrypt.c:ctMask16GTE Unexecuted instantiation: pwdbased.c:ctMask16GTE |
692 | | |
693 | | /* Constant time - sets 16 bit integer mask when a < b. */ |
694 | | WC_MISC_STATIC WC_INLINE word16 ctMask16LT(int a, int b) |
695 | 0 | { |
696 | 0 | return (word16)((((word32)b - (word32)a - 1) >> 31) - 1); |
697 | 0 | } Unexecuted instantiation: ssl.c:ctMask16LT Unexecuted instantiation: tls.c:ctMask16LT Unexecuted instantiation: tls13.c:ctMask16LT Unexecuted instantiation: hmac.c:ctMask16LT Unexecuted instantiation: hash.c:ctMask16LT Unexecuted instantiation: kdf.c:ctMask16LT Unexecuted instantiation: random.c:ctMask16LT Unexecuted instantiation: sha256.c:ctMask16LT Unexecuted instantiation: rsa.c:ctMask16LT Unexecuted instantiation: sp_int.c:ctMask16LT Unexecuted instantiation: aes.c:ctMask16LT Unexecuted instantiation: sha.c:ctMask16LT Unexecuted instantiation: sha512.c:ctMask16LT Unexecuted instantiation: sha3.c:ctMask16LT Unexecuted instantiation: wolfmath.c:ctMask16LT Unexecuted instantiation: dh.c:ctMask16LT Unexecuted instantiation: asn.c:ctMask16LT Unexecuted instantiation: coding.c:ctMask16LT Unexecuted instantiation: poly1305.c:ctMask16LT Unexecuted instantiation: md5.c:ctMask16LT Unexecuted instantiation: chacha.c:ctMask16LT Unexecuted instantiation: ecc.c:ctMask16LT Unexecuted instantiation: internal.c:ctMask16LT Unexecuted instantiation: wc_encrypt.c:ctMask16LT Unexecuted instantiation: pwdbased.c:ctMask16LT |
698 | | |
699 | | /* Constant time - sets 16 bit integer mask when a <= b. */ |
700 | | WC_MISC_STATIC WC_INLINE word16 ctMask16LTE(int a, int b) |
701 | 0 | { |
702 | 0 | return (word16)((((word32)b - (word32)a) >> 31) - 1); |
703 | 0 | } Unexecuted instantiation: ssl.c:ctMask16LTE Unexecuted instantiation: tls.c:ctMask16LTE Unexecuted instantiation: tls13.c:ctMask16LTE Unexecuted instantiation: hmac.c:ctMask16LTE Unexecuted instantiation: hash.c:ctMask16LTE Unexecuted instantiation: kdf.c:ctMask16LTE Unexecuted instantiation: random.c:ctMask16LTE Unexecuted instantiation: sha256.c:ctMask16LTE Unexecuted instantiation: rsa.c:ctMask16LTE Unexecuted instantiation: sp_int.c:ctMask16LTE Unexecuted instantiation: aes.c:ctMask16LTE Unexecuted instantiation: sha.c:ctMask16LTE Unexecuted instantiation: sha512.c:ctMask16LTE Unexecuted instantiation: sha3.c:ctMask16LTE Unexecuted instantiation: wolfmath.c:ctMask16LTE Unexecuted instantiation: dh.c:ctMask16LTE Unexecuted instantiation: asn.c:ctMask16LTE Unexecuted instantiation: coding.c:ctMask16LTE Unexecuted instantiation: poly1305.c:ctMask16LTE Unexecuted instantiation: md5.c:ctMask16LTE Unexecuted instantiation: chacha.c:ctMask16LTE Unexecuted instantiation: ecc.c:ctMask16LTE Unexecuted instantiation: internal.c:ctMask16LTE Unexecuted instantiation: wc_encrypt.c:ctMask16LTE Unexecuted instantiation: pwdbased.c:ctMask16LTE |
704 | | |
705 | | /* Constant time - sets 16 bit integer mask when a == b. */ |
706 | | WC_MISC_STATIC WC_INLINE word16 ctMask16Eq(int a, int b) |
707 | 0 | { |
708 | 0 | return (word16)((word16)(~ctMask16GT(a, b)) & (word16)(~ctMask16LT(a, b))); |
709 | 0 | } Unexecuted instantiation: ssl.c:ctMask16Eq Unexecuted instantiation: tls.c:ctMask16Eq Unexecuted instantiation: tls13.c:ctMask16Eq Unexecuted instantiation: hmac.c:ctMask16Eq Unexecuted instantiation: hash.c:ctMask16Eq Unexecuted instantiation: kdf.c:ctMask16Eq Unexecuted instantiation: random.c:ctMask16Eq Unexecuted instantiation: sha256.c:ctMask16Eq Unexecuted instantiation: rsa.c:ctMask16Eq Unexecuted instantiation: sp_int.c:ctMask16Eq Unexecuted instantiation: aes.c:ctMask16Eq Unexecuted instantiation: sha.c:ctMask16Eq Unexecuted instantiation: sha512.c:ctMask16Eq Unexecuted instantiation: sha3.c:ctMask16Eq Unexecuted instantiation: wolfmath.c:ctMask16Eq Unexecuted instantiation: dh.c:ctMask16Eq Unexecuted instantiation: asn.c:ctMask16Eq Unexecuted instantiation: coding.c:ctMask16Eq Unexecuted instantiation: poly1305.c:ctMask16Eq Unexecuted instantiation: md5.c:ctMask16Eq Unexecuted instantiation: chacha.c:ctMask16Eq Unexecuted instantiation: ecc.c:ctMask16Eq Unexecuted instantiation: internal.c:ctMask16Eq Unexecuted instantiation: wc_encrypt.c:ctMask16Eq Unexecuted instantiation: pwdbased.c:ctMask16Eq |
710 | | |
711 | | /* Constant time - mask set when a != b. */ |
712 | | WC_MISC_STATIC WC_INLINE byte ctMaskNotEq(int a, int b) |
713 | 0 | { |
714 | 0 | return (byte)((byte)ctMaskGT(a, b) | (byte)ctMaskLT(a, b)); |
715 | 0 | } Unexecuted instantiation: ssl.c:ctMaskNotEq Unexecuted instantiation: tls.c:ctMaskNotEq Unexecuted instantiation: tls13.c:ctMaskNotEq Unexecuted instantiation: hmac.c:ctMaskNotEq Unexecuted instantiation: hash.c:ctMaskNotEq Unexecuted instantiation: kdf.c:ctMaskNotEq Unexecuted instantiation: random.c:ctMaskNotEq Unexecuted instantiation: sha256.c:ctMaskNotEq Unexecuted instantiation: rsa.c:ctMaskNotEq Unexecuted instantiation: sp_int.c:ctMaskNotEq Unexecuted instantiation: aes.c:ctMaskNotEq Unexecuted instantiation: sha.c:ctMaskNotEq Unexecuted instantiation: sha512.c:ctMaskNotEq Unexecuted instantiation: sha3.c:ctMaskNotEq Unexecuted instantiation: wolfmath.c:ctMaskNotEq Unexecuted instantiation: dh.c:ctMaskNotEq Unexecuted instantiation: asn.c:ctMaskNotEq Unexecuted instantiation: coding.c:ctMaskNotEq Unexecuted instantiation: poly1305.c:ctMaskNotEq Unexecuted instantiation: md5.c:ctMaskNotEq Unexecuted instantiation: chacha.c:ctMaskNotEq Unexecuted instantiation: ecc.c:ctMaskNotEq Unexecuted instantiation: internal.c:ctMaskNotEq Unexecuted instantiation: wc_encrypt.c:ctMaskNotEq Unexecuted instantiation: pwdbased.c:ctMaskNotEq |
716 | | |
717 | | /* Constant time - select a when mask is set and b otherwise. */ |
718 | | WC_MISC_STATIC WC_INLINE byte ctMaskSel(byte m, byte a, byte b) |
719 | 0 | { |
720 | 0 | return (byte)((b & ((byte)~(word32)m)) | (a & m)); |
721 | 0 | } Unexecuted instantiation: ssl.c:ctMaskSel Unexecuted instantiation: tls.c:ctMaskSel Unexecuted instantiation: tls13.c:ctMaskSel Unexecuted instantiation: hmac.c:ctMaskSel Unexecuted instantiation: hash.c:ctMaskSel Unexecuted instantiation: kdf.c:ctMaskSel Unexecuted instantiation: random.c:ctMaskSel Unexecuted instantiation: sha256.c:ctMaskSel Unexecuted instantiation: rsa.c:ctMaskSel Unexecuted instantiation: sp_int.c:ctMaskSel Unexecuted instantiation: aes.c:ctMaskSel Unexecuted instantiation: sha.c:ctMaskSel Unexecuted instantiation: sha512.c:ctMaskSel Unexecuted instantiation: sha3.c:ctMaskSel Unexecuted instantiation: wolfmath.c:ctMaskSel Unexecuted instantiation: dh.c:ctMaskSel Unexecuted instantiation: asn.c:ctMaskSel Unexecuted instantiation: coding.c:ctMaskSel Unexecuted instantiation: poly1305.c:ctMaskSel Unexecuted instantiation: md5.c:ctMaskSel Unexecuted instantiation: chacha.c:ctMaskSel Unexecuted instantiation: ecc.c:ctMaskSel Unexecuted instantiation: internal.c:ctMaskSel Unexecuted instantiation: wc_encrypt.c:ctMaskSel Unexecuted instantiation: pwdbased.c:ctMaskSel |
722 | | |
723 | | /* Constant time - select integer a when mask is set and integer b otherwise. */ |
724 | | WC_MISC_STATIC WC_INLINE int ctMaskSelInt(byte m, int a, int b) |
725 | 0 | { |
726 | 0 | return (b & (~(signed int)(signed char)m)) | |
727 | 0 | (a & ( (signed int)(signed char)m)); |
728 | 0 | } Unexecuted instantiation: ssl.c:ctMaskSelInt Unexecuted instantiation: tls.c:ctMaskSelInt Unexecuted instantiation: tls13.c:ctMaskSelInt Unexecuted instantiation: hmac.c:ctMaskSelInt Unexecuted instantiation: hash.c:ctMaskSelInt Unexecuted instantiation: kdf.c:ctMaskSelInt Unexecuted instantiation: random.c:ctMaskSelInt Unexecuted instantiation: sha256.c:ctMaskSelInt Unexecuted instantiation: rsa.c:ctMaskSelInt Unexecuted instantiation: sp_int.c:ctMaskSelInt Unexecuted instantiation: aes.c:ctMaskSelInt Unexecuted instantiation: sha.c:ctMaskSelInt Unexecuted instantiation: sha512.c:ctMaskSelInt Unexecuted instantiation: sha3.c:ctMaskSelInt Unexecuted instantiation: wolfmath.c:ctMaskSelInt Unexecuted instantiation: dh.c:ctMaskSelInt Unexecuted instantiation: asn.c:ctMaskSelInt Unexecuted instantiation: coding.c:ctMaskSelInt Unexecuted instantiation: poly1305.c:ctMaskSelInt Unexecuted instantiation: md5.c:ctMaskSelInt Unexecuted instantiation: chacha.c:ctMaskSelInt Unexecuted instantiation: ecc.c:ctMaskSelInt Unexecuted instantiation: internal.c:ctMaskSelInt Unexecuted instantiation: wc_encrypt.c:ctMaskSelInt Unexecuted instantiation: pwdbased.c:ctMaskSelInt |
729 | | |
730 | | /* Constant time - select word32 a when mask is set and word32 b otherwise. */ |
731 | | WC_MISC_STATIC WC_INLINE word32 ctMaskSelWord32(byte m, word32 a, word32 b) |
732 | 0 | { |
733 | 0 | return (((word32)b & (word32)(~(signed int)(signed char)m)) | |
734 | 0 | ((word32)a & (word32)( (signed int)(signed char)m))); |
735 | 0 | } Unexecuted instantiation: ssl.c:ctMaskSelWord32 Unexecuted instantiation: tls.c:ctMaskSelWord32 Unexecuted instantiation: tls13.c:ctMaskSelWord32 Unexecuted instantiation: hmac.c:ctMaskSelWord32 Unexecuted instantiation: hash.c:ctMaskSelWord32 Unexecuted instantiation: kdf.c:ctMaskSelWord32 Unexecuted instantiation: random.c:ctMaskSelWord32 Unexecuted instantiation: sha256.c:ctMaskSelWord32 Unexecuted instantiation: rsa.c:ctMaskSelWord32 Unexecuted instantiation: sp_int.c:ctMaskSelWord32 Unexecuted instantiation: aes.c:ctMaskSelWord32 Unexecuted instantiation: sha.c:ctMaskSelWord32 Unexecuted instantiation: sha512.c:ctMaskSelWord32 Unexecuted instantiation: sha3.c:ctMaskSelWord32 Unexecuted instantiation: wolfmath.c:ctMaskSelWord32 Unexecuted instantiation: dh.c:ctMaskSelWord32 Unexecuted instantiation: asn.c:ctMaskSelWord32 Unexecuted instantiation: coding.c:ctMaskSelWord32 Unexecuted instantiation: poly1305.c:ctMaskSelWord32 Unexecuted instantiation: md5.c:ctMaskSelWord32 Unexecuted instantiation: chacha.c:ctMaskSelWord32 Unexecuted instantiation: ecc.c:ctMaskSelWord32 Unexecuted instantiation: internal.c:ctMaskSelWord32 Unexecuted instantiation: wc_encrypt.c:ctMaskSelWord32 Unexecuted instantiation: pwdbased.c:ctMaskSelWord32 |
736 | | |
737 | | /* Constant time - bit set when a <= b. */ |
738 | | WC_MISC_STATIC WC_INLINE byte ctSetLTE(int a, int b) |
739 | 0 | { |
740 | 0 | return (byte)(((word32)a - (word32)b - 1) >> 31); |
741 | 0 | } Unexecuted instantiation: ssl.c:ctSetLTE Unexecuted instantiation: tls.c:ctSetLTE Unexecuted instantiation: tls13.c:ctSetLTE Unexecuted instantiation: hmac.c:ctSetLTE Unexecuted instantiation: hash.c:ctSetLTE Unexecuted instantiation: kdf.c:ctSetLTE Unexecuted instantiation: random.c:ctSetLTE Unexecuted instantiation: sha256.c:ctSetLTE Unexecuted instantiation: rsa.c:ctSetLTE Unexecuted instantiation: sp_int.c:ctSetLTE Unexecuted instantiation: aes.c:ctSetLTE Unexecuted instantiation: sha.c:ctSetLTE Unexecuted instantiation: sha512.c:ctSetLTE Unexecuted instantiation: sha3.c:ctSetLTE Unexecuted instantiation: wolfmath.c:ctSetLTE Unexecuted instantiation: dh.c:ctSetLTE Unexecuted instantiation: asn.c:ctSetLTE Unexecuted instantiation: coding.c:ctSetLTE Unexecuted instantiation: poly1305.c:ctSetLTE Unexecuted instantiation: md5.c:ctSetLTE Unexecuted instantiation: chacha.c:ctSetLTE Unexecuted instantiation: ecc.c:ctSetLTE Unexecuted instantiation: internal.c:ctSetLTE Unexecuted instantiation: wc_encrypt.c:ctSetLTE Unexecuted instantiation: pwdbased.c:ctSetLTE |
742 | | |
743 | | /* Constant time - conditionally copy size bytes from src to dst if mask is set |
744 | | */ |
745 | | WC_MISC_STATIC WC_INLINE void ctMaskCopy(byte mask, byte* dst, byte* src, |
746 | | word16 size) |
747 | 0 | { |
748 | 0 | int i; |
749 | 0 | for (i = 0; i < size; ++i) { |
750 | 0 | dst[i] ^= (dst[i] ^ src[i]) & mask; |
751 | 0 | } |
752 | 0 | } Unexecuted instantiation: ssl.c:ctMaskCopy Unexecuted instantiation: tls.c:ctMaskCopy Unexecuted instantiation: tls13.c:ctMaskCopy Unexecuted instantiation: hmac.c:ctMaskCopy Unexecuted instantiation: hash.c:ctMaskCopy Unexecuted instantiation: kdf.c:ctMaskCopy Unexecuted instantiation: random.c:ctMaskCopy Unexecuted instantiation: sha256.c:ctMaskCopy Unexecuted instantiation: rsa.c:ctMaskCopy Unexecuted instantiation: sp_int.c:ctMaskCopy Unexecuted instantiation: aes.c:ctMaskCopy Unexecuted instantiation: sha.c:ctMaskCopy Unexecuted instantiation: sha512.c:ctMaskCopy Unexecuted instantiation: sha3.c:ctMaskCopy Unexecuted instantiation: wolfmath.c:ctMaskCopy Unexecuted instantiation: dh.c:ctMaskCopy Unexecuted instantiation: asn.c:ctMaskCopy Unexecuted instantiation: coding.c:ctMaskCopy Unexecuted instantiation: poly1305.c:ctMaskCopy Unexecuted instantiation: md5.c:ctMaskCopy Unexecuted instantiation: chacha.c:ctMaskCopy Unexecuted instantiation: ecc.c:ctMaskCopy Unexecuted instantiation: internal.c:ctMaskCopy Unexecuted instantiation: wc_encrypt.c:ctMaskCopy Unexecuted instantiation: pwdbased.c:ctMaskCopy |
753 | | |
754 | | #endif /* !WOLFSSL_NO_CT_OPS */ |
755 | | |
756 | | #ifndef WOLFSSL_HAVE_MIN |
757 | | #define WOLFSSL_HAVE_MIN |
758 | | #if defined(HAVE_FIPS) && !defined(min) /* so ifdef check passes */ |
759 | | #define min min |
760 | | #endif |
761 | | /* returns the smaller of a and b */ |
762 | | WC_MISC_STATIC WC_INLINE word32 min(word32 a, word32 b) |
763 | 0 | { |
764 | 0 | #if !defined(WOLFSSL_NO_CT_OPS) && defined(WORD64_AVAILABLE) |
765 | 0 | word32 gte_mask = (word32)ctMaskWord32GTE(a, b); |
766 | 0 | return (a & ~gte_mask) | (b & gte_mask); |
767 | | #else /* WOLFSSL_NO_CT_OPS */ |
768 | | return a > b ? b : a; |
769 | | #endif /* WOLFSSL_NO_CT_OPS */ |
770 | 0 | } Unexecuted instantiation: ssl.c:min Unexecuted instantiation: tls.c:min Unexecuted instantiation: tls13.c:min Unexecuted instantiation: hmac.c:min Unexecuted instantiation: hash.c:min Unexecuted instantiation: kdf.c:min Unexecuted instantiation: random.c:min Unexecuted instantiation: sha256.c:min Unexecuted instantiation: rsa.c:min Unexecuted instantiation: sp_int.c:min Unexecuted instantiation: aes.c:min Unexecuted instantiation: sha.c:min Unexecuted instantiation: sha512.c:min Unexecuted instantiation: sha3.c:min Unexecuted instantiation: wolfmath.c:min Unexecuted instantiation: dh.c:min Unexecuted instantiation: asn.c:min Unexecuted instantiation: coding.c:min Unexecuted instantiation: poly1305.c:min Unexecuted instantiation: md5.c:min Unexecuted instantiation: chacha.c:min Unexecuted instantiation: ecc.c:min Unexecuted instantiation: internal.c:min Unexecuted instantiation: wc_encrypt.c:min Unexecuted instantiation: pwdbased.c:min |
771 | | #endif /* !WOLFSSL_HAVE_MIN */ |
772 | | |
773 | | #ifndef WOLFSSL_HAVE_MAX |
774 | | #define WOLFSSL_HAVE_MAX |
775 | | #if defined(HAVE_FIPS) && !defined(max) /* so ifdef check passes */ |
776 | | #define max max |
777 | | #endif |
778 | | WC_MISC_STATIC WC_INLINE word32 max(word32 a, word32 b) |
779 | 0 | { |
780 | 0 | #if !defined(WOLFSSL_NO_CT_OPS) && defined(WORD64_AVAILABLE) |
781 | 0 | word32 gte_mask = (word32)ctMaskWord32GTE(a, b); |
782 | 0 | return (a & gte_mask) | (b & ~gte_mask); |
783 | 0 | #else /* WOLFSSL_NO_CT_OPS */ |
784 | 0 | return a > b ? a : b; |
785 | 0 | #endif /* WOLFSSL_NO_CT_OPS */ |
786 | 0 | } Unexecuted instantiation: ssl.c:max Unexecuted instantiation: tls.c:max Unexecuted instantiation: tls13.c:max Unexecuted instantiation: hmac.c:max Unexecuted instantiation: hash.c:max Unexecuted instantiation: kdf.c:max Unexecuted instantiation: random.c:max Unexecuted instantiation: sha256.c:max Unexecuted instantiation: rsa.c:max Unexecuted instantiation: sp_int.c:max Unexecuted instantiation: aes.c:max Unexecuted instantiation: sha.c:max Unexecuted instantiation: sha512.c:max Unexecuted instantiation: sha3.c:max Unexecuted instantiation: wolfmath.c:max Unexecuted instantiation: dh.c:max Unexecuted instantiation: asn.c:max Unexecuted instantiation: coding.c:max Unexecuted instantiation: poly1305.c:max Unexecuted instantiation: md5.c:max Unexecuted instantiation: chacha.c:max Unexecuted instantiation: ecc.c:max Unexecuted instantiation: internal.c:max Unexecuted instantiation: wc_encrypt.c:max Unexecuted instantiation: pwdbased.c:max |
787 | | #endif /* !WOLFSSL_HAVE_MAX */ |
788 | | |
789 | | #ifndef WOLFSSL_NO_INT_ENCODE |
790 | | /* converts a 32 bit integer to 24 bit */ |
791 | | WC_MISC_STATIC WC_INLINE void c32to24(word32 in, word24 out) |
792 | 0 | { |
793 | 0 | out[0] = (byte)((in >> 16) & 0xff); |
794 | 0 | out[1] = (byte)((in >> 8) & 0xff); |
795 | 0 | out[2] = (byte)(in & 0xff); |
796 | 0 | } Unexecuted instantiation: ssl.c:c32to24 Unexecuted instantiation: tls.c:c32to24 Unexecuted instantiation: tls13.c:c32to24 Unexecuted instantiation: hmac.c:c32to24 Unexecuted instantiation: hash.c:c32to24 Unexecuted instantiation: kdf.c:c32to24 Unexecuted instantiation: random.c:c32to24 Unexecuted instantiation: sha256.c:c32to24 Unexecuted instantiation: rsa.c:c32to24 Unexecuted instantiation: sp_int.c:c32to24 Unexecuted instantiation: aes.c:c32to24 Unexecuted instantiation: sha.c:c32to24 Unexecuted instantiation: sha512.c:c32to24 Unexecuted instantiation: sha3.c:c32to24 Unexecuted instantiation: wolfmath.c:c32to24 Unexecuted instantiation: dh.c:c32to24 Unexecuted instantiation: asn.c:c32to24 Unexecuted instantiation: coding.c:c32to24 Unexecuted instantiation: poly1305.c:c32to24 Unexecuted instantiation: md5.c:c32to24 Unexecuted instantiation: chacha.c:c32to24 Unexecuted instantiation: ecc.c:c32to24 Unexecuted instantiation: internal.c:c32to24 Unexecuted instantiation: wc_encrypt.c:c32to24 Unexecuted instantiation: pwdbased.c:c32to24 |
797 | | |
798 | | /* convert 16 bit integer to opaque */ |
799 | | WC_MISC_STATIC WC_INLINE void c16toa(word16 wc_u16, byte* c) |
800 | 0 | { |
801 | 0 | c[0] = (byte)((wc_u16 >> 8) & 0xff); |
802 | 0 | c[1] = (byte)(wc_u16 & 0xff); |
803 | 0 | } Unexecuted instantiation: ssl.c:c16toa Unexecuted instantiation: tls.c:c16toa Unexecuted instantiation: tls13.c:c16toa Unexecuted instantiation: hmac.c:c16toa Unexecuted instantiation: hash.c:c16toa Unexecuted instantiation: kdf.c:c16toa Unexecuted instantiation: random.c:c16toa Unexecuted instantiation: sha256.c:c16toa Unexecuted instantiation: rsa.c:c16toa Unexecuted instantiation: sp_int.c:c16toa Unexecuted instantiation: aes.c:c16toa Unexecuted instantiation: sha.c:c16toa Unexecuted instantiation: sha512.c:c16toa Unexecuted instantiation: sha3.c:c16toa Unexecuted instantiation: wolfmath.c:c16toa Unexecuted instantiation: dh.c:c16toa Unexecuted instantiation: asn.c:c16toa Unexecuted instantiation: coding.c:c16toa Unexecuted instantiation: poly1305.c:c16toa Unexecuted instantiation: md5.c:c16toa Unexecuted instantiation: chacha.c:c16toa Unexecuted instantiation: ecc.c:c16toa Unexecuted instantiation: internal.c:c16toa Unexecuted instantiation: wc_encrypt.c:c16toa Unexecuted instantiation: pwdbased.c:c16toa |
804 | | |
805 | | /* convert 32 bit integer to opaque */ |
806 | | WC_MISC_STATIC WC_INLINE void c32toa(word32 wc_u32, byte* c) |
807 | 0 | { |
808 | 0 | #ifdef WOLFSSL_USE_ALIGN |
809 | 0 | c[0] = (byte)((wc_u32 >> 24) & 0xff); |
810 | 0 | c[1] = (byte)((wc_u32 >> 16) & 0xff); |
811 | 0 | c[2] = (byte)((wc_u32 >> 8) & 0xff); |
812 | 0 | c[3] = (byte)(wc_u32 & 0xff); |
813 | | #elif defined(LITTLE_ENDIAN_ORDER) |
814 | | *(word32*)c = ByteReverseWord32(wc_u32); |
815 | | #else |
816 | | *(word32*)c = wc_u32; |
817 | | #endif |
818 | 0 | } Unexecuted instantiation: ssl.c:c32toa Unexecuted instantiation: tls.c:c32toa Unexecuted instantiation: tls13.c:c32toa Unexecuted instantiation: hmac.c:c32toa Unexecuted instantiation: hash.c:c32toa Unexecuted instantiation: kdf.c:c32toa Unexecuted instantiation: random.c:c32toa Unexecuted instantiation: sha256.c:c32toa Unexecuted instantiation: rsa.c:c32toa Unexecuted instantiation: sp_int.c:c32toa Unexecuted instantiation: aes.c:c32toa Unexecuted instantiation: sha.c:c32toa Unexecuted instantiation: sha512.c:c32toa Unexecuted instantiation: sha3.c:c32toa Unexecuted instantiation: wolfmath.c:c32toa Unexecuted instantiation: dh.c:c32toa Unexecuted instantiation: asn.c:c32toa Unexecuted instantiation: coding.c:c32toa Unexecuted instantiation: poly1305.c:c32toa Unexecuted instantiation: md5.c:c32toa Unexecuted instantiation: chacha.c:c32toa Unexecuted instantiation: ecc.c:c32toa Unexecuted instantiation: internal.c:c32toa Unexecuted instantiation: wc_encrypt.c:c32toa Unexecuted instantiation: pwdbased.c:c32toa |
819 | | #endif |
820 | | |
821 | | #ifndef WOLFSSL_NO_INT_DECODE |
822 | | /* convert a 24 bit integer into a 32 bit one */ |
823 | | WC_MISC_STATIC WC_INLINE void c24to32(const word24 wc_u24, word32* wc_u32) |
824 | 0 | { |
825 | 0 | *wc_u32 = ((word32)wc_u24[0] << 16) | |
826 | 0 | ((word32)wc_u24[1] << 8) | |
827 | 0 | (word32)wc_u24[2]; |
828 | 0 | } Unexecuted instantiation: ssl.c:c24to32 Unexecuted instantiation: tls.c:c24to32 Unexecuted instantiation: tls13.c:c24to32 Unexecuted instantiation: hmac.c:c24to32 Unexecuted instantiation: hash.c:c24to32 Unexecuted instantiation: kdf.c:c24to32 Unexecuted instantiation: random.c:c24to32 Unexecuted instantiation: sha256.c:c24to32 Unexecuted instantiation: rsa.c:c24to32 Unexecuted instantiation: sp_int.c:c24to32 Unexecuted instantiation: aes.c:c24to32 Unexecuted instantiation: sha.c:c24to32 Unexecuted instantiation: sha512.c:c24to32 Unexecuted instantiation: sha3.c:c24to32 Unexecuted instantiation: wolfmath.c:c24to32 Unexecuted instantiation: dh.c:c24to32 Unexecuted instantiation: asn.c:c24to32 Unexecuted instantiation: coding.c:c24to32 Unexecuted instantiation: poly1305.c:c24to32 Unexecuted instantiation: md5.c:c24to32 Unexecuted instantiation: chacha.c:c24to32 Unexecuted instantiation: ecc.c:c24to32 Unexecuted instantiation: internal.c:c24to32 Unexecuted instantiation: wc_encrypt.c:c24to32 Unexecuted instantiation: pwdbased.c:c24to32 |
829 | | |
830 | | |
831 | | /* convert opaque to 24 bit integer */ |
832 | | WC_MISC_STATIC WC_INLINE void ato24(const byte* c, word32* wc_u24) |
833 | 0 | { |
834 | 0 | *wc_u24 = ((word32)c[0] << 16) | ((word32)c[1] << 8) | c[2]; |
835 | 0 | } Unexecuted instantiation: ssl.c:ato24 Unexecuted instantiation: tls.c:ato24 Unexecuted instantiation: tls13.c:ato24 Unexecuted instantiation: hmac.c:ato24 Unexecuted instantiation: hash.c:ato24 Unexecuted instantiation: kdf.c:ato24 Unexecuted instantiation: random.c:ato24 Unexecuted instantiation: sha256.c:ato24 Unexecuted instantiation: rsa.c:ato24 Unexecuted instantiation: sp_int.c:ato24 Unexecuted instantiation: aes.c:ato24 Unexecuted instantiation: sha.c:ato24 Unexecuted instantiation: sha512.c:ato24 Unexecuted instantiation: sha3.c:ato24 Unexecuted instantiation: wolfmath.c:ato24 Unexecuted instantiation: dh.c:ato24 Unexecuted instantiation: asn.c:ato24 Unexecuted instantiation: coding.c:ato24 Unexecuted instantiation: poly1305.c:ato24 Unexecuted instantiation: md5.c:ato24 Unexecuted instantiation: chacha.c:ato24 Unexecuted instantiation: ecc.c:ato24 Unexecuted instantiation: internal.c:ato24 Unexecuted instantiation: wc_encrypt.c:ato24 Unexecuted instantiation: pwdbased.c:ato24 |
836 | | |
837 | | /* convert opaque to 16 bit integer */ |
838 | | WC_MISC_STATIC WC_INLINE void ato16(const byte* c, word16* wc_u16) |
839 | 0 | { |
840 | 0 | *wc_u16 = (word16) ((c[0] << 8) | (c[1])); |
841 | 0 | } Unexecuted instantiation: ssl.c:ato16 Unexecuted instantiation: tls.c:ato16 Unexecuted instantiation: tls13.c:ato16 Unexecuted instantiation: hmac.c:ato16 Unexecuted instantiation: hash.c:ato16 Unexecuted instantiation: kdf.c:ato16 Unexecuted instantiation: random.c:ato16 Unexecuted instantiation: sha256.c:ato16 Unexecuted instantiation: rsa.c:ato16 Unexecuted instantiation: sp_int.c:ato16 Unexecuted instantiation: aes.c:ato16 Unexecuted instantiation: sha.c:ato16 Unexecuted instantiation: sha512.c:ato16 Unexecuted instantiation: sha3.c:ato16 Unexecuted instantiation: wolfmath.c:ato16 Unexecuted instantiation: dh.c:ato16 Unexecuted instantiation: asn.c:ato16 Unexecuted instantiation: coding.c:ato16 Unexecuted instantiation: poly1305.c:ato16 Unexecuted instantiation: md5.c:ato16 Unexecuted instantiation: chacha.c:ato16 Unexecuted instantiation: ecc.c:ato16 Unexecuted instantiation: internal.c:ato16 Unexecuted instantiation: wc_encrypt.c:ato16 Unexecuted instantiation: pwdbased.c:ato16 |
842 | | |
843 | | /* convert opaque to 32 bit integer */ |
844 | | WC_MISC_STATIC WC_INLINE void ato32(const byte* c, word32* wc_u32) |
845 | 0 | { |
846 | 0 | #ifdef WOLFSSL_USE_ALIGN |
847 | 0 | *wc_u32 = ((word32)c[0] << 24) | |
848 | 0 | ((word32)c[1] << 16) | |
849 | 0 | ((word32)c[2] << 8) | |
850 | 0 | (word32)c[3]; |
851 | 0 | #elif defined(LITTLE_ENDIAN_ORDER) |
852 | 0 | *wc_u32 = ByteReverseWord32(*(word32*)c); |
853 | 0 | #else |
854 | 0 | *wc_u32 = *(word32*)c; |
855 | 0 | #endif |
856 | 0 | } Unexecuted instantiation: ssl.c:ato32 Unexecuted instantiation: tls.c:ato32 Unexecuted instantiation: tls13.c:ato32 Unexecuted instantiation: hmac.c:ato32 Unexecuted instantiation: hash.c:ato32 Unexecuted instantiation: kdf.c:ato32 Unexecuted instantiation: random.c:ato32 Unexecuted instantiation: sha256.c:ato32 Unexecuted instantiation: rsa.c:ato32 Unexecuted instantiation: sp_int.c:ato32 Unexecuted instantiation: aes.c:ato32 Unexecuted instantiation: sha.c:ato32 Unexecuted instantiation: sha512.c:ato32 Unexecuted instantiation: sha3.c:ato32 Unexecuted instantiation: wolfmath.c:ato32 Unexecuted instantiation: dh.c:ato32 Unexecuted instantiation: asn.c:ato32 Unexecuted instantiation: coding.c:ato32 Unexecuted instantiation: poly1305.c:ato32 Unexecuted instantiation: md5.c:ato32 Unexecuted instantiation: chacha.c:ato32 Unexecuted instantiation: ecc.c:ato32 Unexecuted instantiation: internal.c:ato32 Unexecuted instantiation: wc_encrypt.c:ato32 Unexecuted instantiation: pwdbased.c:ato32 |
857 | | |
858 | | /* convert opaque to 32 bit integer. Interpret as little endian. */ |
859 | | WC_MISC_STATIC WC_INLINE void ato32le(const byte* c, word32* wc_u32) |
860 | 0 | { |
861 | 0 | *wc_u32 = (word32)c[0] | |
862 | 0 | ((word32)c[1] << 8) | |
863 | 0 | ((word32)c[2] << 16) | |
864 | 0 | ((word32)c[3] << 24); |
865 | 0 | } Unexecuted instantiation: ssl.c:ato32le Unexecuted instantiation: tls.c:ato32le Unexecuted instantiation: tls13.c:ato32le Unexecuted instantiation: hmac.c:ato32le Unexecuted instantiation: hash.c:ato32le Unexecuted instantiation: kdf.c:ato32le Unexecuted instantiation: random.c:ato32le Unexecuted instantiation: sha256.c:ato32le Unexecuted instantiation: rsa.c:ato32le Unexecuted instantiation: sp_int.c:ato32le Unexecuted instantiation: aes.c:ato32le Unexecuted instantiation: sha.c:ato32le Unexecuted instantiation: sha512.c:ato32le Unexecuted instantiation: sha3.c:ato32le Unexecuted instantiation: wolfmath.c:ato32le Unexecuted instantiation: dh.c:ato32le Unexecuted instantiation: asn.c:ato32le Unexecuted instantiation: coding.c:ato32le Unexecuted instantiation: poly1305.c:ato32le Unexecuted instantiation: md5.c:ato32le Unexecuted instantiation: chacha.c:ato32le Unexecuted instantiation: ecc.c:ato32le Unexecuted instantiation: internal.c:ato32le Unexecuted instantiation: wc_encrypt.c:ato32le Unexecuted instantiation: pwdbased.c:ato32le |
866 | | |
867 | | |
868 | | WC_MISC_STATIC WC_INLINE word32 btoi(byte b) |
869 | 0 | { |
870 | 0 | return (word32)(b - 0x30); |
871 | 0 | } Unexecuted instantiation: ssl.c:btoi Unexecuted instantiation: tls.c:btoi Unexecuted instantiation: tls13.c:btoi Unexecuted instantiation: hmac.c:btoi Unexecuted instantiation: hash.c:btoi Unexecuted instantiation: kdf.c:btoi Unexecuted instantiation: random.c:btoi Unexecuted instantiation: sha256.c:btoi Unexecuted instantiation: rsa.c:btoi Unexecuted instantiation: sp_int.c:btoi Unexecuted instantiation: aes.c:btoi Unexecuted instantiation: sha.c:btoi Unexecuted instantiation: sha512.c:btoi Unexecuted instantiation: sha3.c:btoi Unexecuted instantiation: wolfmath.c:btoi Unexecuted instantiation: dh.c:btoi Unexecuted instantiation: asn.c:btoi Unexecuted instantiation: coding.c:btoi Unexecuted instantiation: poly1305.c:btoi Unexecuted instantiation: md5.c:btoi Unexecuted instantiation: chacha.c:btoi Unexecuted instantiation: ecc.c:btoi Unexecuted instantiation: internal.c:btoi Unexecuted instantiation: wc_encrypt.c:btoi Unexecuted instantiation: pwdbased.c:btoi |
872 | | #endif |
873 | | |
874 | | WC_MISC_STATIC WC_INLINE signed char HexCharToByte(char ch) |
875 | 0 | { |
876 | 0 | signed char ret = (signed char)ch; |
877 | 0 | if (ret >= '0' && ret <= '9') |
878 | 0 | ret = (signed char)(ret - '0'); |
879 | 0 | else if (ret >= 'A' && ret <= 'F') |
880 | 0 | ret = (signed char)(ret - ('A' - 10)); |
881 | 0 | else if (ret >= 'a' && ret <= 'f') |
882 | 0 | ret = (signed char)(ret - ('a' - 10)); |
883 | 0 | else |
884 | 0 | ret = -1; /* error case - return code must be signed */ |
885 | 0 | return ret; |
886 | 0 | } Unexecuted instantiation: ssl.c:HexCharToByte Unexecuted instantiation: tls.c:HexCharToByte Unexecuted instantiation: tls13.c:HexCharToByte Unexecuted instantiation: hmac.c:HexCharToByte Unexecuted instantiation: hash.c:HexCharToByte Unexecuted instantiation: kdf.c:HexCharToByte Unexecuted instantiation: random.c:HexCharToByte Unexecuted instantiation: sha256.c:HexCharToByte Unexecuted instantiation: rsa.c:HexCharToByte Unexecuted instantiation: sp_int.c:HexCharToByte Unexecuted instantiation: aes.c:HexCharToByte Unexecuted instantiation: sha.c:HexCharToByte Unexecuted instantiation: sha512.c:HexCharToByte Unexecuted instantiation: sha3.c:HexCharToByte Unexecuted instantiation: wolfmath.c:HexCharToByte Unexecuted instantiation: dh.c:HexCharToByte Unexecuted instantiation: asn.c:HexCharToByte Unexecuted instantiation: coding.c:HexCharToByte Unexecuted instantiation: poly1305.c:HexCharToByte Unexecuted instantiation: md5.c:HexCharToByte Unexecuted instantiation: chacha.c:HexCharToByte Unexecuted instantiation: ecc.c:HexCharToByte Unexecuted instantiation: internal.c:HexCharToByte Unexecuted instantiation: wc_encrypt.c:HexCharToByte Unexecuted instantiation: pwdbased.c:HexCharToByte |
887 | | |
888 | | WC_MISC_STATIC WC_INLINE char ByteToHex(byte in) |
889 | 0 | { |
890 | 0 | static ALIGN64 const char kHexChar[] = { |
891 | 0 | '0', '1', '2', '3', '4', '5', '6', '7', |
892 | 0 | '8', '9', 'A', 'B', 'C', 'D', 'E', 'F' |
893 | 0 | }; |
894 | 0 | return (char)(kHexChar[in & 0xF]); |
895 | 0 | } Unexecuted instantiation: ssl.c:ByteToHex Unexecuted instantiation: tls.c:ByteToHex Unexecuted instantiation: tls13.c:ByteToHex Unexecuted instantiation: hmac.c:ByteToHex Unexecuted instantiation: hash.c:ByteToHex Unexecuted instantiation: kdf.c:ByteToHex Unexecuted instantiation: random.c:ByteToHex Unexecuted instantiation: sha256.c:ByteToHex Unexecuted instantiation: rsa.c:ByteToHex Unexecuted instantiation: sp_int.c:ByteToHex Unexecuted instantiation: aes.c:ByteToHex Unexecuted instantiation: sha.c:ByteToHex Unexecuted instantiation: sha512.c:ByteToHex Unexecuted instantiation: sha3.c:ByteToHex Unexecuted instantiation: wolfmath.c:ByteToHex Unexecuted instantiation: dh.c:ByteToHex Unexecuted instantiation: asn.c:ByteToHex Unexecuted instantiation: coding.c:ByteToHex Unexecuted instantiation: poly1305.c:ByteToHex Unexecuted instantiation: md5.c:ByteToHex Unexecuted instantiation: chacha.c:ByteToHex Unexecuted instantiation: ecc.c:ByteToHex Unexecuted instantiation: internal.c:ByteToHex Unexecuted instantiation: wc_encrypt.c:ByteToHex Unexecuted instantiation: pwdbased.c:ByteToHex |
896 | | |
897 | | WC_MISC_STATIC WC_INLINE int ByteToHexStr(byte in, char* out) |
898 | 0 | { |
899 | 0 | if (out == NULL) |
900 | 0 | return -1; |
901 | 0 |
|
902 | 0 | out[0] = ByteToHex((byte)(in >> 4)); |
903 | 0 | out[1] = ByteToHex((byte)(in & 0xf)); |
904 | 0 | return 0; |
905 | 0 | } Unexecuted instantiation: ssl.c:ByteToHexStr Unexecuted instantiation: tls.c:ByteToHexStr Unexecuted instantiation: tls13.c:ByteToHexStr Unexecuted instantiation: hmac.c:ByteToHexStr Unexecuted instantiation: hash.c:ByteToHexStr Unexecuted instantiation: kdf.c:ByteToHexStr Unexecuted instantiation: random.c:ByteToHexStr Unexecuted instantiation: sha256.c:ByteToHexStr Unexecuted instantiation: rsa.c:ByteToHexStr Unexecuted instantiation: sp_int.c:ByteToHexStr Unexecuted instantiation: aes.c:ByteToHexStr Unexecuted instantiation: sha.c:ByteToHexStr Unexecuted instantiation: sha512.c:ByteToHexStr Unexecuted instantiation: sha3.c:ByteToHexStr Unexecuted instantiation: wolfmath.c:ByteToHexStr Unexecuted instantiation: dh.c:ByteToHexStr Unexecuted instantiation: asn.c:ByteToHexStr Unexecuted instantiation: coding.c:ByteToHexStr Unexecuted instantiation: poly1305.c:ByteToHexStr Unexecuted instantiation: md5.c:ByteToHexStr Unexecuted instantiation: chacha.c:ByteToHexStr Unexecuted instantiation: ecc.c:ByteToHexStr Unexecuted instantiation: internal.c:ByteToHexStr Unexecuted instantiation: wc_encrypt.c:ByteToHexStr Unexecuted instantiation: pwdbased.c:ByteToHexStr |
906 | | |
907 | | WC_MISC_STATIC WC_INLINE int CharIsWhiteSpace(char ch) |
908 | 0 | { |
909 | 0 | #ifndef WOLFSSL_NO_CT_OPS |
910 | 0 | return (ctMaskEq(ch, ' ') | |
911 | 0 | ctMaskEq(ch, '\t') | |
912 | 0 | ctMaskEq(ch, '\n')) & 1; |
913 | | #else /* WOLFSSL_NO_CT_OPS */ |
914 | | switch (ch) { |
915 | | case ' ': |
916 | | case '\t': |
917 | | case '\n': |
918 | | return 1; |
919 | | default: |
920 | | return 0; |
921 | | } |
922 | | #endif /* WOLFSSL_NO_CT_OPS */ |
923 | 0 | } Unexecuted instantiation: ssl.c:CharIsWhiteSpace Unexecuted instantiation: tls.c:CharIsWhiteSpace Unexecuted instantiation: tls13.c:CharIsWhiteSpace Unexecuted instantiation: hmac.c:CharIsWhiteSpace Unexecuted instantiation: hash.c:CharIsWhiteSpace Unexecuted instantiation: kdf.c:CharIsWhiteSpace Unexecuted instantiation: random.c:CharIsWhiteSpace Unexecuted instantiation: sha256.c:CharIsWhiteSpace Unexecuted instantiation: rsa.c:CharIsWhiteSpace Unexecuted instantiation: sp_int.c:CharIsWhiteSpace Unexecuted instantiation: aes.c:CharIsWhiteSpace Unexecuted instantiation: sha.c:CharIsWhiteSpace Unexecuted instantiation: sha512.c:CharIsWhiteSpace Unexecuted instantiation: sha3.c:CharIsWhiteSpace Unexecuted instantiation: wolfmath.c:CharIsWhiteSpace Unexecuted instantiation: dh.c:CharIsWhiteSpace Unexecuted instantiation: asn.c:CharIsWhiteSpace Unexecuted instantiation: coding.c:CharIsWhiteSpace Unexecuted instantiation: poly1305.c:CharIsWhiteSpace Unexecuted instantiation: md5.c:CharIsWhiteSpace Unexecuted instantiation: chacha.c:CharIsWhiteSpace Unexecuted instantiation: ecc.c:CharIsWhiteSpace Unexecuted instantiation: internal.c:CharIsWhiteSpace Unexecuted instantiation: wc_encrypt.c:CharIsWhiteSpace Unexecuted instantiation: pwdbased.c:CharIsWhiteSpace |
924 | | |
925 | | #if defined(WOLFSSL_W64_WRAPPER) |
926 | | #if defined(WORD64_AVAILABLE) && !defined(WOLFSSL_W64_WRAPPER_TEST) |
927 | 0 | WC_MISC_STATIC WC_INLINE void w64Increment(w64wrapper *n) { |
928 | 0 | n->n++; |
929 | 0 | } Unexecuted instantiation: ssl.c:w64Increment Unexecuted instantiation: tls.c:w64Increment Unexecuted instantiation: tls13.c:w64Increment Unexecuted instantiation: hmac.c:w64Increment Unexecuted instantiation: hash.c:w64Increment Unexecuted instantiation: kdf.c:w64Increment Unexecuted instantiation: random.c:w64Increment Unexecuted instantiation: sha256.c:w64Increment Unexecuted instantiation: rsa.c:w64Increment Unexecuted instantiation: sp_int.c:w64Increment Unexecuted instantiation: aes.c:w64Increment Unexecuted instantiation: sha.c:w64Increment Unexecuted instantiation: sha512.c:w64Increment Unexecuted instantiation: sha3.c:w64Increment Unexecuted instantiation: wolfmath.c:w64Increment Unexecuted instantiation: dh.c:w64Increment Unexecuted instantiation: asn.c:w64Increment Unexecuted instantiation: coding.c:w64Increment Unexecuted instantiation: poly1305.c:w64Increment Unexecuted instantiation: md5.c:w64Increment Unexecuted instantiation: chacha.c:w64Increment Unexecuted instantiation: ecc.c:w64Increment Unexecuted instantiation: internal.c:w64Increment Unexecuted instantiation: wc_encrypt.c:w64Increment Unexecuted instantiation: pwdbased.c:w64Increment |
930 | | |
931 | 0 | WC_MISC_STATIC WC_INLINE void w64Decrement(w64wrapper *n) { |
932 | 0 | n->n--; |
933 | 0 | } Unexecuted instantiation: ssl.c:w64Decrement Unexecuted instantiation: tls.c:w64Decrement Unexecuted instantiation: tls13.c:w64Decrement Unexecuted instantiation: hmac.c:w64Decrement Unexecuted instantiation: hash.c:w64Decrement Unexecuted instantiation: kdf.c:w64Decrement Unexecuted instantiation: random.c:w64Decrement Unexecuted instantiation: sha256.c:w64Decrement Unexecuted instantiation: rsa.c:w64Decrement Unexecuted instantiation: sp_int.c:w64Decrement Unexecuted instantiation: aes.c:w64Decrement Unexecuted instantiation: sha.c:w64Decrement Unexecuted instantiation: sha512.c:w64Decrement Unexecuted instantiation: sha3.c:w64Decrement Unexecuted instantiation: wolfmath.c:w64Decrement Unexecuted instantiation: dh.c:w64Decrement Unexecuted instantiation: asn.c:w64Decrement Unexecuted instantiation: coding.c:w64Decrement Unexecuted instantiation: poly1305.c:w64Decrement Unexecuted instantiation: md5.c:w64Decrement Unexecuted instantiation: chacha.c:w64Decrement Unexecuted instantiation: ecc.c:w64Decrement Unexecuted instantiation: internal.c:w64Decrement Unexecuted instantiation: wc_encrypt.c:w64Decrement Unexecuted instantiation: pwdbased.c:w64Decrement |
934 | | |
935 | 0 | WC_MISC_STATIC WC_INLINE byte w64Equal(w64wrapper a, w64wrapper b) { |
936 | 0 | return (a.n == b.n); |
937 | 0 | } Unexecuted instantiation: ssl.c:w64Equal Unexecuted instantiation: tls.c:w64Equal Unexecuted instantiation: tls13.c:w64Equal Unexecuted instantiation: hmac.c:w64Equal Unexecuted instantiation: hash.c:w64Equal Unexecuted instantiation: kdf.c:w64Equal Unexecuted instantiation: random.c:w64Equal Unexecuted instantiation: sha256.c:w64Equal Unexecuted instantiation: rsa.c:w64Equal Unexecuted instantiation: sp_int.c:w64Equal Unexecuted instantiation: aes.c:w64Equal Unexecuted instantiation: sha.c:w64Equal Unexecuted instantiation: sha512.c:w64Equal Unexecuted instantiation: sha3.c:w64Equal Unexecuted instantiation: wolfmath.c:w64Equal Unexecuted instantiation: dh.c:w64Equal Unexecuted instantiation: asn.c:w64Equal Unexecuted instantiation: coding.c:w64Equal Unexecuted instantiation: poly1305.c:w64Equal Unexecuted instantiation: md5.c:w64Equal Unexecuted instantiation: chacha.c:w64Equal Unexecuted instantiation: ecc.c:w64Equal Unexecuted instantiation: internal.c:w64Equal Unexecuted instantiation: wc_encrypt.c:w64Equal Unexecuted instantiation: pwdbased.c:w64Equal |
938 | | |
939 | 0 | WC_MISC_STATIC WC_INLINE word32 w64GetLow32(w64wrapper n) { |
940 | 0 | return (word32)n.n; |
941 | 0 | } Unexecuted instantiation: ssl.c:w64GetLow32 Unexecuted instantiation: tls.c:w64GetLow32 Unexecuted instantiation: tls13.c:w64GetLow32 Unexecuted instantiation: hmac.c:w64GetLow32 Unexecuted instantiation: hash.c:w64GetLow32 Unexecuted instantiation: kdf.c:w64GetLow32 Unexecuted instantiation: random.c:w64GetLow32 Unexecuted instantiation: sha256.c:w64GetLow32 Unexecuted instantiation: rsa.c:w64GetLow32 Unexecuted instantiation: sp_int.c:w64GetLow32 Unexecuted instantiation: aes.c:w64GetLow32 Unexecuted instantiation: sha.c:w64GetLow32 Unexecuted instantiation: sha512.c:w64GetLow32 Unexecuted instantiation: sha3.c:w64GetLow32 Unexecuted instantiation: wolfmath.c:w64GetLow32 Unexecuted instantiation: dh.c:w64GetLow32 Unexecuted instantiation: asn.c:w64GetLow32 Unexecuted instantiation: coding.c:w64GetLow32 Unexecuted instantiation: poly1305.c:w64GetLow32 Unexecuted instantiation: md5.c:w64GetLow32 Unexecuted instantiation: chacha.c:w64GetLow32 Unexecuted instantiation: ecc.c:w64GetLow32 Unexecuted instantiation: internal.c:w64GetLow32 Unexecuted instantiation: wc_encrypt.c:w64GetLow32 Unexecuted instantiation: pwdbased.c:w64GetLow32 |
942 | | |
943 | 0 | WC_MISC_STATIC WC_INLINE word32 w64GetHigh32(w64wrapper n) { |
944 | 0 | return (word32)(n.n >> 32); |
945 | 0 | } Unexecuted instantiation: ssl.c:w64GetHigh32 Unexecuted instantiation: tls.c:w64GetHigh32 Unexecuted instantiation: tls13.c:w64GetHigh32 Unexecuted instantiation: hmac.c:w64GetHigh32 Unexecuted instantiation: hash.c:w64GetHigh32 Unexecuted instantiation: kdf.c:w64GetHigh32 Unexecuted instantiation: random.c:w64GetHigh32 Unexecuted instantiation: sha256.c:w64GetHigh32 Unexecuted instantiation: rsa.c:w64GetHigh32 Unexecuted instantiation: sp_int.c:w64GetHigh32 Unexecuted instantiation: aes.c:w64GetHigh32 Unexecuted instantiation: sha.c:w64GetHigh32 Unexecuted instantiation: sha512.c:w64GetHigh32 Unexecuted instantiation: sha3.c:w64GetHigh32 Unexecuted instantiation: wolfmath.c:w64GetHigh32 Unexecuted instantiation: dh.c:w64GetHigh32 Unexecuted instantiation: asn.c:w64GetHigh32 Unexecuted instantiation: coding.c:w64GetHigh32 Unexecuted instantiation: poly1305.c:w64GetHigh32 Unexecuted instantiation: md5.c:w64GetHigh32 Unexecuted instantiation: chacha.c:w64GetHigh32 Unexecuted instantiation: ecc.c:w64GetHigh32 Unexecuted instantiation: internal.c:w64GetHigh32 Unexecuted instantiation: wc_encrypt.c:w64GetHigh32 Unexecuted instantiation: pwdbased.c:w64GetHigh32 |
946 | | |
947 | 0 | WC_MISC_STATIC WC_INLINE void w64SetLow32(w64wrapper *n, word32 low) { |
948 | 0 | n->n = (n->n & (~(word64)(0xffffffff))) | low; |
949 | 0 | } Unexecuted instantiation: ssl.c:w64SetLow32 Unexecuted instantiation: tls.c:w64SetLow32 Unexecuted instantiation: tls13.c:w64SetLow32 Unexecuted instantiation: hmac.c:w64SetLow32 Unexecuted instantiation: hash.c:w64SetLow32 Unexecuted instantiation: kdf.c:w64SetLow32 Unexecuted instantiation: random.c:w64SetLow32 Unexecuted instantiation: sha256.c:w64SetLow32 Unexecuted instantiation: rsa.c:w64SetLow32 Unexecuted instantiation: sp_int.c:w64SetLow32 Unexecuted instantiation: aes.c:w64SetLow32 Unexecuted instantiation: sha.c:w64SetLow32 Unexecuted instantiation: sha512.c:w64SetLow32 Unexecuted instantiation: sha3.c:w64SetLow32 Unexecuted instantiation: wolfmath.c:w64SetLow32 Unexecuted instantiation: dh.c:w64SetLow32 Unexecuted instantiation: asn.c:w64SetLow32 Unexecuted instantiation: coding.c:w64SetLow32 Unexecuted instantiation: poly1305.c:w64SetLow32 Unexecuted instantiation: md5.c:w64SetLow32 Unexecuted instantiation: chacha.c:w64SetLow32 Unexecuted instantiation: ecc.c:w64SetLow32 Unexecuted instantiation: internal.c:w64SetLow32 Unexecuted instantiation: wc_encrypt.c:w64SetLow32 Unexecuted instantiation: pwdbased.c:w64SetLow32 |
950 | | |
951 | | WC_MISC_STATIC WC_INLINE w64wrapper w64Add32(w64wrapper a, word32 b, byte *wrap) |
952 | 0 | { |
953 | 0 | a.n += b; |
954 | 0 | if (a.n < b && wrap != NULL) |
955 | 0 | *wrap = 1; |
956 | 0 |
|
957 | 0 | return a; |
958 | 0 | } Unexecuted instantiation: ssl.c:w64Add32 Unexecuted instantiation: tls.c:w64Add32 Unexecuted instantiation: tls13.c:w64Add32 Unexecuted instantiation: hmac.c:w64Add32 Unexecuted instantiation: hash.c:w64Add32 Unexecuted instantiation: kdf.c:w64Add32 Unexecuted instantiation: random.c:w64Add32 Unexecuted instantiation: sha256.c:w64Add32 Unexecuted instantiation: rsa.c:w64Add32 Unexecuted instantiation: sp_int.c:w64Add32 Unexecuted instantiation: aes.c:w64Add32 Unexecuted instantiation: sha.c:w64Add32 Unexecuted instantiation: sha512.c:w64Add32 Unexecuted instantiation: sha3.c:w64Add32 Unexecuted instantiation: wolfmath.c:w64Add32 Unexecuted instantiation: dh.c:w64Add32 Unexecuted instantiation: asn.c:w64Add32 Unexecuted instantiation: coding.c:w64Add32 Unexecuted instantiation: poly1305.c:w64Add32 Unexecuted instantiation: md5.c:w64Add32 Unexecuted instantiation: chacha.c:w64Add32 Unexecuted instantiation: ecc.c:w64Add32 Unexecuted instantiation: internal.c:w64Add32 Unexecuted instantiation: wc_encrypt.c:w64Add32 Unexecuted instantiation: pwdbased.c:w64Add32 |
959 | | |
960 | | WC_MISC_STATIC WC_INLINE w64wrapper w64Add(w64wrapper a, w64wrapper b, |
961 | | byte *wrap) |
962 | 0 | { |
963 | 0 | a.n += b.n; |
964 | 0 | if (a.n < b.n && wrap != NULL) |
965 | 0 | *wrap = 1; |
966 | 0 |
|
967 | 0 | return a; |
968 | 0 | } Unexecuted instantiation: ssl.c:w64Add Unexecuted instantiation: tls.c:w64Add Unexecuted instantiation: tls13.c:w64Add Unexecuted instantiation: hmac.c:w64Add Unexecuted instantiation: hash.c:w64Add Unexecuted instantiation: kdf.c:w64Add Unexecuted instantiation: random.c:w64Add Unexecuted instantiation: sha256.c:w64Add Unexecuted instantiation: rsa.c:w64Add Unexecuted instantiation: sp_int.c:w64Add Unexecuted instantiation: aes.c:w64Add Unexecuted instantiation: sha.c:w64Add Unexecuted instantiation: sha512.c:w64Add Unexecuted instantiation: sha3.c:w64Add Unexecuted instantiation: wolfmath.c:w64Add Unexecuted instantiation: dh.c:w64Add Unexecuted instantiation: asn.c:w64Add Unexecuted instantiation: coding.c:w64Add Unexecuted instantiation: poly1305.c:w64Add Unexecuted instantiation: md5.c:w64Add Unexecuted instantiation: chacha.c:w64Add Unexecuted instantiation: ecc.c:w64Add Unexecuted instantiation: internal.c:w64Add Unexecuted instantiation: wc_encrypt.c:w64Add Unexecuted instantiation: pwdbased.c:w64Add |
969 | | |
970 | | WC_MISC_STATIC WC_INLINE w64wrapper w64Sub32(w64wrapper a, word32 b, byte *wrap) |
971 | 0 | { |
972 | 0 | if (a.n < b && wrap != NULL) |
973 | 0 | *wrap = 1; |
974 | 0 | a.n = a.n - b; |
975 | 0 | return a; |
976 | 0 | } Unexecuted instantiation: ssl.c:w64Sub32 Unexecuted instantiation: tls.c:w64Sub32 Unexecuted instantiation: tls13.c:w64Sub32 Unexecuted instantiation: hmac.c:w64Sub32 Unexecuted instantiation: hash.c:w64Sub32 Unexecuted instantiation: kdf.c:w64Sub32 Unexecuted instantiation: random.c:w64Sub32 Unexecuted instantiation: sha256.c:w64Sub32 Unexecuted instantiation: rsa.c:w64Sub32 Unexecuted instantiation: sp_int.c:w64Sub32 Unexecuted instantiation: aes.c:w64Sub32 Unexecuted instantiation: sha.c:w64Sub32 Unexecuted instantiation: sha512.c:w64Sub32 Unexecuted instantiation: sha3.c:w64Sub32 Unexecuted instantiation: wolfmath.c:w64Sub32 Unexecuted instantiation: dh.c:w64Sub32 Unexecuted instantiation: asn.c:w64Sub32 Unexecuted instantiation: coding.c:w64Sub32 Unexecuted instantiation: poly1305.c:w64Sub32 Unexecuted instantiation: md5.c:w64Sub32 Unexecuted instantiation: chacha.c:w64Sub32 Unexecuted instantiation: ecc.c:w64Sub32 Unexecuted instantiation: internal.c:w64Sub32 Unexecuted instantiation: wc_encrypt.c:w64Sub32 Unexecuted instantiation: pwdbased.c:w64Sub32 |
977 | | |
978 | | WC_MISC_STATIC WC_INLINE byte w64GT(w64wrapper a, w64wrapper b) |
979 | 0 | { |
980 | 0 | return a.n > b.n; |
981 | 0 | } Unexecuted instantiation: ssl.c:w64GT Unexecuted instantiation: tls.c:w64GT Unexecuted instantiation: tls13.c:w64GT Unexecuted instantiation: hmac.c:w64GT Unexecuted instantiation: hash.c:w64GT Unexecuted instantiation: kdf.c:w64GT Unexecuted instantiation: random.c:w64GT Unexecuted instantiation: sha256.c:w64GT Unexecuted instantiation: rsa.c:w64GT Unexecuted instantiation: sp_int.c:w64GT Unexecuted instantiation: aes.c:w64GT Unexecuted instantiation: sha.c:w64GT Unexecuted instantiation: sha512.c:w64GT Unexecuted instantiation: sha3.c:w64GT Unexecuted instantiation: wolfmath.c:w64GT Unexecuted instantiation: dh.c:w64GT Unexecuted instantiation: asn.c:w64GT Unexecuted instantiation: coding.c:w64GT Unexecuted instantiation: poly1305.c:w64GT Unexecuted instantiation: md5.c:w64GT Unexecuted instantiation: chacha.c:w64GT Unexecuted instantiation: ecc.c:w64GT Unexecuted instantiation: internal.c:w64GT Unexecuted instantiation: wc_encrypt.c:w64GT Unexecuted instantiation: pwdbased.c:w64GT |
982 | | |
983 | | WC_MISC_STATIC WC_INLINE byte w64IsZero(w64wrapper a) |
984 | 0 | { |
985 | 0 | return a.n == 0; |
986 | 0 | } Unexecuted instantiation: ssl.c:w64IsZero Unexecuted instantiation: tls.c:w64IsZero Unexecuted instantiation: tls13.c:w64IsZero Unexecuted instantiation: hmac.c:w64IsZero Unexecuted instantiation: hash.c:w64IsZero Unexecuted instantiation: kdf.c:w64IsZero Unexecuted instantiation: random.c:w64IsZero Unexecuted instantiation: sha256.c:w64IsZero Unexecuted instantiation: rsa.c:w64IsZero Unexecuted instantiation: sp_int.c:w64IsZero Unexecuted instantiation: aes.c:w64IsZero Unexecuted instantiation: sha.c:w64IsZero Unexecuted instantiation: sha512.c:w64IsZero Unexecuted instantiation: sha3.c:w64IsZero Unexecuted instantiation: wolfmath.c:w64IsZero Unexecuted instantiation: dh.c:w64IsZero Unexecuted instantiation: asn.c:w64IsZero Unexecuted instantiation: coding.c:w64IsZero Unexecuted instantiation: poly1305.c:w64IsZero Unexecuted instantiation: md5.c:w64IsZero Unexecuted instantiation: chacha.c:w64IsZero Unexecuted instantiation: ecc.c:w64IsZero Unexecuted instantiation: internal.c:w64IsZero Unexecuted instantiation: wc_encrypt.c:w64IsZero Unexecuted instantiation: pwdbased.c:w64IsZero |
987 | | |
988 | | WC_MISC_STATIC WC_INLINE void c64toa(const w64wrapper *a, byte *out) |
989 | 0 | { |
990 | 0 | #ifdef BIG_ENDIAN_ORDER |
991 | 0 | XMEMCPY(out, &a->n, sizeof(a->n)); |
992 | 0 | #else |
993 | 0 | word64 _out; |
994 | 0 | _out = ByteReverseWord64(a->n); |
995 | 0 | XMEMCPY(out, &_out, sizeof(_out)); |
996 | 0 | #endif /* BIG_ENDIAN_ORDER */ |
997 | 0 | } Unexecuted instantiation: ssl.c:c64toa Unexecuted instantiation: tls.c:c64toa Unexecuted instantiation: tls13.c:c64toa Unexecuted instantiation: hmac.c:c64toa Unexecuted instantiation: hash.c:c64toa Unexecuted instantiation: kdf.c:c64toa Unexecuted instantiation: random.c:c64toa Unexecuted instantiation: sha256.c:c64toa Unexecuted instantiation: rsa.c:c64toa Unexecuted instantiation: sp_int.c:c64toa Unexecuted instantiation: aes.c:c64toa Unexecuted instantiation: sha.c:c64toa Unexecuted instantiation: sha512.c:c64toa Unexecuted instantiation: sha3.c:c64toa Unexecuted instantiation: wolfmath.c:c64toa Unexecuted instantiation: dh.c:c64toa Unexecuted instantiation: asn.c:c64toa Unexecuted instantiation: coding.c:c64toa Unexecuted instantiation: poly1305.c:c64toa Unexecuted instantiation: md5.c:c64toa Unexecuted instantiation: chacha.c:c64toa Unexecuted instantiation: ecc.c:c64toa Unexecuted instantiation: internal.c:c64toa Unexecuted instantiation: wc_encrypt.c:c64toa Unexecuted instantiation: pwdbased.c:c64toa |
998 | | |
999 | | WC_MISC_STATIC WC_INLINE void ato64(const byte *in, w64wrapper *w64) |
1000 | 0 | { |
1001 | 0 | #ifdef BIG_ENDIAN_ORDER |
1002 | 0 | XMEMCPY(&w64->n, in, sizeof(w64->n)); |
1003 | 0 | #else |
1004 | 0 | word64 _in; |
1005 | 0 | XMEMCPY(&_in, in, sizeof(_in)); |
1006 | 0 | w64->n = ByteReverseWord64(_in); |
1007 | 0 | #endif /* BIG_ENDIAN_ORDER */ |
1008 | 0 | } Unexecuted instantiation: ssl.c:ato64 Unexecuted instantiation: tls.c:ato64 Unexecuted instantiation: tls13.c:ato64 Unexecuted instantiation: hmac.c:ato64 Unexecuted instantiation: hash.c:ato64 Unexecuted instantiation: kdf.c:ato64 Unexecuted instantiation: random.c:ato64 Unexecuted instantiation: sha256.c:ato64 Unexecuted instantiation: rsa.c:ato64 Unexecuted instantiation: sp_int.c:ato64 Unexecuted instantiation: aes.c:ato64 Unexecuted instantiation: sha.c:ato64 Unexecuted instantiation: sha512.c:ato64 Unexecuted instantiation: sha3.c:ato64 Unexecuted instantiation: wolfmath.c:ato64 Unexecuted instantiation: dh.c:ato64 Unexecuted instantiation: asn.c:ato64 Unexecuted instantiation: coding.c:ato64 Unexecuted instantiation: poly1305.c:ato64 Unexecuted instantiation: md5.c:ato64 Unexecuted instantiation: chacha.c:ato64 Unexecuted instantiation: ecc.c:ato64 Unexecuted instantiation: internal.c:ato64 Unexecuted instantiation: wc_encrypt.c:ato64 Unexecuted instantiation: pwdbased.c:ato64 |
1009 | | |
1010 | | WC_MISC_STATIC WC_INLINE w64wrapper w64From32(word32 hi, word32 lo) |
1011 | 0 | { |
1012 | 0 | w64wrapper ret; |
1013 | 0 | ret.n = ((word64)hi << 32) | lo; |
1014 | 0 | return ret; |
1015 | 0 | } Unexecuted instantiation: ssl.c:w64From32 Unexecuted instantiation: tls.c:w64From32 Unexecuted instantiation: tls13.c:w64From32 Unexecuted instantiation: hmac.c:w64From32 Unexecuted instantiation: hash.c:w64From32 Unexecuted instantiation: kdf.c:w64From32 Unexecuted instantiation: random.c:w64From32 Unexecuted instantiation: sha256.c:w64From32 Unexecuted instantiation: rsa.c:w64From32 Unexecuted instantiation: sp_int.c:w64From32 Unexecuted instantiation: aes.c:w64From32 Unexecuted instantiation: sha.c:w64From32 Unexecuted instantiation: sha512.c:w64From32 Unexecuted instantiation: sha3.c:w64From32 Unexecuted instantiation: wolfmath.c:w64From32 Unexecuted instantiation: dh.c:w64From32 Unexecuted instantiation: asn.c:w64From32 Unexecuted instantiation: coding.c:w64From32 Unexecuted instantiation: poly1305.c:w64From32 Unexecuted instantiation: md5.c:w64From32 Unexecuted instantiation: chacha.c:w64From32 Unexecuted instantiation: ecc.c:w64From32 Unexecuted instantiation: internal.c:w64From32 Unexecuted instantiation: wc_encrypt.c:w64From32 Unexecuted instantiation: pwdbased.c:w64From32 |
1016 | | |
1017 | | WC_MISC_STATIC WC_INLINE byte w64GTE(w64wrapper a, w64wrapper b) |
1018 | 0 | { |
1019 | 0 | return a.n >= b.n; |
1020 | 0 | } Unexecuted instantiation: ssl.c:w64GTE Unexecuted instantiation: tls.c:w64GTE Unexecuted instantiation: tls13.c:w64GTE Unexecuted instantiation: hmac.c:w64GTE Unexecuted instantiation: hash.c:w64GTE Unexecuted instantiation: kdf.c:w64GTE Unexecuted instantiation: random.c:w64GTE Unexecuted instantiation: sha256.c:w64GTE Unexecuted instantiation: rsa.c:w64GTE Unexecuted instantiation: sp_int.c:w64GTE Unexecuted instantiation: aes.c:w64GTE Unexecuted instantiation: sha.c:w64GTE Unexecuted instantiation: sha512.c:w64GTE Unexecuted instantiation: sha3.c:w64GTE Unexecuted instantiation: wolfmath.c:w64GTE Unexecuted instantiation: dh.c:w64GTE Unexecuted instantiation: asn.c:w64GTE Unexecuted instantiation: coding.c:w64GTE Unexecuted instantiation: poly1305.c:w64GTE Unexecuted instantiation: md5.c:w64GTE Unexecuted instantiation: chacha.c:w64GTE Unexecuted instantiation: ecc.c:w64GTE Unexecuted instantiation: internal.c:w64GTE Unexecuted instantiation: wc_encrypt.c:w64GTE Unexecuted instantiation: pwdbased.c:w64GTE |
1021 | | |
1022 | | WC_MISC_STATIC WC_INLINE byte w64LT(w64wrapper a, w64wrapper b) |
1023 | 0 | { |
1024 | 0 | return a.n < b.n; |
1025 | 0 | } Unexecuted instantiation: ssl.c:w64LT Unexecuted instantiation: tls.c:w64LT Unexecuted instantiation: tls13.c:w64LT Unexecuted instantiation: hmac.c:w64LT Unexecuted instantiation: hash.c:w64LT Unexecuted instantiation: kdf.c:w64LT Unexecuted instantiation: random.c:w64LT Unexecuted instantiation: sha256.c:w64LT Unexecuted instantiation: rsa.c:w64LT Unexecuted instantiation: sp_int.c:w64LT Unexecuted instantiation: aes.c:w64LT Unexecuted instantiation: sha.c:w64LT Unexecuted instantiation: sha512.c:w64LT Unexecuted instantiation: sha3.c:w64LT Unexecuted instantiation: wolfmath.c:w64LT Unexecuted instantiation: dh.c:w64LT Unexecuted instantiation: asn.c:w64LT Unexecuted instantiation: coding.c:w64LT Unexecuted instantiation: poly1305.c:w64LT Unexecuted instantiation: md5.c:w64LT Unexecuted instantiation: chacha.c:w64LT Unexecuted instantiation: ecc.c:w64LT Unexecuted instantiation: internal.c:w64LT Unexecuted instantiation: wc_encrypt.c:w64LT Unexecuted instantiation: pwdbased.c:w64LT |
1026 | | |
1027 | | WC_MISC_STATIC WC_INLINE w64wrapper w64Sub(w64wrapper a, w64wrapper b) |
1028 | 0 | { |
1029 | 0 | a.n -= b.n; |
1030 | 0 | return a; |
1031 | 0 | } Unexecuted instantiation: ssl.c:w64Sub Unexecuted instantiation: tls.c:w64Sub Unexecuted instantiation: tls13.c:w64Sub Unexecuted instantiation: hmac.c:w64Sub Unexecuted instantiation: hash.c:w64Sub Unexecuted instantiation: kdf.c:w64Sub Unexecuted instantiation: random.c:w64Sub Unexecuted instantiation: sha256.c:w64Sub Unexecuted instantiation: rsa.c:w64Sub Unexecuted instantiation: sp_int.c:w64Sub Unexecuted instantiation: aes.c:w64Sub Unexecuted instantiation: sha.c:w64Sub Unexecuted instantiation: sha512.c:w64Sub Unexecuted instantiation: sha3.c:w64Sub Unexecuted instantiation: wolfmath.c:w64Sub Unexecuted instantiation: dh.c:w64Sub Unexecuted instantiation: asn.c:w64Sub Unexecuted instantiation: coding.c:w64Sub Unexecuted instantiation: poly1305.c:w64Sub Unexecuted instantiation: md5.c:w64Sub Unexecuted instantiation: chacha.c:w64Sub Unexecuted instantiation: ecc.c:w64Sub Unexecuted instantiation: internal.c:w64Sub Unexecuted instantiation: wc_encrypt.c:w64Sub Unexecuted instantiation: pwdbased.c:w64Sub |
1032 | | |
1033 | | WC_MISC_STATIC WC_INLINE void w64Zero(w64wrapper *a) |
1034 | 0 | { |
1035 | 0 | a->n = 0; |
1036 | 0 | } Unexecuted instantiation: ssl.c:w64Zero Unexecuted instantiation: tls.c:w64Zero Unexecuted instantiation: tls13.c:w64Zero Unexecuted instantiation: hmac.c:w64Zero Unexecuted instantiation: hash.c:w64Zero Unexecuted instantiation: kdf.c:w64Zero Unexecuted instantiation: random.c:w64Zero Unexecuted instantiation: sha256.c:w64Zero Unexecuted instantiation: rsa.c:w64Zero Unexecuted instantiation: sp_int.c:w64Zero Unexecuted instantiation: aes.c:w64Zero Unexecuted instantiation: sha.c:w64Zero Unexecuted instantiation: sha512.c:w64Zero Unexecuted instantiation: sha3.c:w64Zero Unexecuted instantiation: wolfmath.c:w64Zero Unexecuted instantiation: dh.c:w64Zero Unexecuted instantiation: asn.c:w64Zero Unexecuted instantiation: coding.c:w64Zero Unexecuted instantiation: poly1305.c:w64Zero Unexecuted instantiation: md5.c:w64Zero Unexecuted instantiation: chacha.c:w64Zero Unexecuted instantiation: ecc.c:w64Zero Unexecuted instantiation: internal.c:w64Zero Unexecuted instantiation: wc_encrypt.c:w64Zero Unexecuted instantiation: pwdbased.c:w64Zero |
1037 | | |
1038 | | WC_MISC_STATIC WC_INLINE w64wrapper w64ShiftRight(w64wrapper a, int shift) |
1039 | 0 | { |
1040 | 0 | a.n >>= shift; |
1041 | 0 | return a; |
1042 | 0 | } Unexecuted instantiation: ssl.c:w64ShiftRight Unexecuted instantiation: tls.c:w64ShiftRight Unexecuted instantiation: tls13.c:w64ShiftRight Unexecuted instantiation: hmac.c:w64ShiftRight Unexecuted instantiation: hash.c:w64ShiftRight Unexecuted instantiation: kdf.c:w64ShiftRight Unexecuted instantiation: random.c:w64ShiftRight Unexecuted instantiation: sha256.c:w64ShiftRight Unexecuted instantiation: rsa.c:w64ShiftRight Unexecuted instantiation: sp_int.c:w64ShiftRight Unexecuted instantiation: aes.c:w64ShiftRight Unexecuted instantiation: sha.c:w64ShiftRight Unexecuted instantiation: sha512.c:w64ShiftRight Unexecuted instantiation: sha3.c:w64ShiftRight Unexecuted instantiation: wolfmath.c:w64ShiftRight Unexecuted instantiation: dh.c:w64ShiftRight Unexecuted instantiation: asn.c:w64ShiftRight Unexecuted instantiation: coding.c:w64ShiftRight Unexecuted instantiation: poly1305.c:w64ShiftRight Unexecuted instantiation: md5.c:w64ShiftRight Unexecuted instantiation: chacha.c:w64ShiftRight Unexecuted instantiation: ecc.c:w64ShiftRight Unexecuted instantiation: internal.c:w64ShiftRight Unexecuted instantiation: wc_encrypt.c:w64ShiftRight Unexecuted instantiation: pwdbased.c:w64ShiftRight |
1043 | | |
1044 | | WC_MISC_STATIC WC_INLINE w64wrapper w64ShiftLeft(w64wrapper a, int shift) |
1045 | 0 | { |
1046 | 0 | a.n <<= shift; |
1047 | 0 | return a; |
1048 | 0 | } Unexecuted instantiation: ssl.c:w64ShiftLeft Unexecuted instantiation: tls.c:w64ShiftLeft Unexecuted instantiation: tls13.c:w64ShiftLeft Unexecuted instantiation: hmac.c:w64ShiftLeft Unexecuted instantiation: hash.c:w64ShiftLeft Unexecuted instantiation: kdf.c:w64ShiftLeft Unexecuted instantiation: random.c:w64ShiftLeft Unexecuted instantiation: sha256.c:w64ShiftLeft Unexecuted instantiation: rsa.c:w64ShiftLeft Unexecuted instantiation: sp_int.c:w64ShiftLeft Unexecuted instantiation: aes.c:w64ShiftLeft Unexecuted instantiation: sha.c:w64ShiftLeft Unexecuted instantiation: sha512.c:w64ShiftLeft Unexecuted instantiation: sha3.c:w64ShiftLeft Unexecuted instantiation: wolfmath.c:w64ShiftLeft Unexecuted instantiation: dh.c:w64ShiftLeft Unexecuted instantiation: asn.c:w64ShiftLeft Unexecuted instantiation: coding.c:w64ShiftLeft Unexecuted instantiation: poly1305.c:w64ShiftLeft Unexecuted instantiation: md5.c:w64ShiftLeft Unexecuted instantiation: chacha.c:w64ShiftLeft Unexecuted instantiation: ecc.c:w64ShiftLeft Unexecuted instantiation: internal.c:w64ShiftLeft Unexecuted instantiation: wc_encrypt.c:w64ShiftLeft Unexecuted instantiation: pwdbased.c:w64ShiftLeft |
1049 | | |
1050 | | WC_MISC_STATIC WC_INLINE w64wrapper w64Mul(word32 a, word32 b) |
1051 | 0 | { |
1052 | 0 | w64wrapper ret; |
1053 | 0 | ret.n = (word64)a * (word64)b; |
1054 | 0 | return ret; |
1055 | 0 | } Unexecuted instantiation: ssl.c:w64Mul Unexecuted instantiation: tls.c:w64Mul Unexecuted instantiation: tls13.c:w64Mul Unexecuted instantiation: hmac.c:w64Mul Unexecuted instantiation: hash.c:w64Mul Unexecuted instantiation: kdf.c:w64Mul Unexecuted instantiation: random.c:w64Mul Unexecuted instantiation: sha256.c:w64Mul Unexecuted instantiation: rsa.c:w64Mul Unexecuted instantiation: sp_int.c:w64Mul Unexecuted instantiation: aes.c:w64Mul Unexecuted instantiation: sha.c:w64Mul Unexecuted instantiation: sha512.c:w64Mul Unexecuted instantiation: sha3.c:w64Mul Unexecuted instantiation: wolfmath.c:w64Mul Unexecuted instantiation: dh.c:w64Mul Unexecuted instantiation: asn.c:w64Mul Unexecuted instantiation: coding.c:w64Mul Unexecuted instantiation: poly1305.c:w64Mul Unexecuted instantiation: md5.c:w64Mul Unexecuted instantiation: chacha.c:w64Mul Unexecuted instantiation: ecc.c:w64Mul Unexecuted instantiation: internal.c:w64Mul Unexecuted instantiation: wc_encrypt.c:w64Mul Unexecuted instantiation: pwdbased.c:w64Mul |
1056 | | |
1057 | | #else |
1058 | | |
1059 | | WC_MISC_STATIC WC_INLINE void w64Increment(w64wrapper *n) |
1060 | | { |
1061 | | n->n[1]++; |
1062 | | if (n->n[1] == 0) |
1063 | | n->n[0]++; |
1064 | | } |
1065 | | |
1066 | | WC_MISC_STATIC WC_INLINE void w64Decrement(w64wrapper *n) { |
1067 | | if (n->n[1] == 0) |
1068 | | n->n[0]--; |
1069 | | n->n[1]--; |
1070 | | } |
1071 | | |
1072 | | WC_MISC_STATIC WC_INLINE byte w64Equal(w64wrapper a, w64wrapper b) |
1073 | | { |
1074 | | return (a.n[0] == b.n[0] && a.n[1] == b.n[1]); |
1075 | | } |
1076 | | |
1077 | | WC_MISC_STATIC WC_INLINE word32 w64GetLow32(w64wrapper n) { |
1078 | | return n.n[1]; |
1079 | | } |
1080 | | |
1081 | | WC_MISC_STATIC WC_INLINE word32 w64GetHigh32(w64wrapper n) { |
1082 | | return n.n[0]; |
1083 | | } |
1084 | | |
1085 | | WC_MISC_STATIC WC_INLINE void w64SetLow32(w64wrapper *n, word32 low) |
1086 | | { |
1087 | | n->n[1] = low; |
1088 | | } |
1089 | | |
1090 | | WC_MISC_STATIC WC_INLINE w64wrapper w64Add32(w64wrapper a, word32 b, byte *wrap) |
1091 | | { |
1092 | | a.n[1] += b; |
1093 | | if (a.n[1] < b) { |
1094 | | a.n[0]++; |
1095 | | if (wrap != NULL && a.n[0] == 0) |
1096 | | *wrap = 1; |
1097 | | } |
1098 | | |
1099 | | return a; |
1100 | | } |
1101 | | |
1102 | | WC_MISC_STATIC WC_INLINE w64wrapper w64Add(w64wrapper a, w64wrapper b, |
1103 | | byte *wrap) |
1104 | | { |
1105 | | a.n[1] += b.n[1]; |
1106 | | if (a.n[1] < b.n[1]) { |
1107 | | a.n[0]++; |
1108 | | if (wrap != NULL && a.n[0] == 0) |
1109 | | *wrap = 1; |
1110 | | } |
1111 | | |
1112 | | a.n[0] += b.n[0]; |
1113 | | if (wrap != NULL && a.n[0] < b.n[0]) { |
1114 | | *wrap = 1; |
1115 | | } |
1116 | | |
1117 | | return a; |
1118 | | } |
1119 | | |
1120 | | WC_MISC_STATIC WC_INLINE w64wrapper w64Sub32(w64wrapper a, word32 b, byte *wrap) |
1121 | | { |
1122 | | byte _underflow = 0; |
1123 | | if (a.n[1] < b) |
1124 | | _underflow = 1; |
1125 | | |
1126 | | a.n[1] -= b; |
1127 | | if (_underflow) { |
1128 | | if (a.n[0] == 0 && wrap != NULL) |
1129 | | *wrap = 1; |
1130 | | a.n[0]--; |
1131 | | } |
1132 | | |
1133 | | return a; |
1134 | | } |
1135 | | |
1136 | | WC_MISC_STATIC WC_INLINE w64wrapper w64Sub(w64wrapper a, w64wrapper b) |
1137 | | { |
1138 | | if (a.n[1] < b.n[1]) |
1139 | | a.n[0]--; |
1140 | | a.n[1] -= b.n[1]; |
1141 | | a.n[0] -= b.n[0]; |
1142 | | return a; |
1143 | | } |
1144 | | |
1145 | | WC_MISC_STATIC WC_INLINE void w64Zero(w64wrapper *a) |
1146 | | { |
1147 | | a->n[0] = a->n[1] = 0; |
1148 | | } |
1149 | | |
1150 | | WC_MISC_STATIC WC_INLINE byte w64GT(w64wrapper a, w64wrapper b) |
1151 | | { |
1152 | | if (a.n[0] > b.n[0]) |
1153 | | return 1; |
1154 | | if (a.n[0] == b.n[0]) |
1155 | | return a.n[1] > b.n[1]; |
1156 | | return 0; |
1157 | | } |
1158 | | |
1159 | | WC_MISC_STATIC WC_INLINE byte w64GTE(w64wrapper a, w64wrapper b) |
1160 | | { |
1161 | | if (a.n[0] > b.n[0]) |
1162 | | return 1; |
1163 | | if (a.n[0] == b.n[0]) |
1164 | | return a.n[1] >= b.n[1]; |
1165 | | return 0; |
1166 | | } |
1167 | | |
1168 | | WC_MISC_STATIC WC_INLINE byte w64IsZero(w64wrapper a) |
1169 | | { |
1170 | | return a.n[0] == 0 && a.n[1] == 0; |
1171 | | } |
1172 | | |
1173 | | WC_MISC_STATIC WC_INLINE void c64toa(const w64wrapper *a, byte *out) |
1174 | | { |
1175 | | #ifdef BIG_ENDIAN_ORDER |
1176 | | word32 *_out = (word32*)(out); |
1177 | | _out[0] = a->n[0]; |
1178 | | _out[1] = a->n[1]; |
1179 | | #else |
1180 | | c32toa(a->n[0], out); |
1181 | | c32toa(a->n[1], out + 4); |
1182 | | #endif /* BIG_ENDIAN_ORDER */ |
1183 | | } |
1184 | | |
1185 | | WC_MISC_STATIC WC_INLINE void ato64(const byte *in, w64wrapper *w64) |
1186 | | { |
1187 | | #ifdef BIG_ENDIAN_ORDER |
1188 | | const word32 *_in = (const word32*)(in); |
1189 | | w64->n[0] = *_in; |
1190 | | w64->n[1] = *(_in + 1); |
1191 | | #else |
1192 | | ato32(in, &w64->n[0]); |
1193 | | ato32(in + 4, &w64->n[1]); |
1194 | | #endif /* BIG_ENDIAN_ORDER */ |
1195 | | } |
1196 | | |
1197 | | WC_MISC_STATIC WC_INLINE w64wrapper w64From32(word32 hi, word32 lo) |
1198 | | { |
1199 | | w64wrapper w64; |
1200 | | w64.n[0] = hi; |
1201 | | w64.n[1] = lo; |
1202 | | return w64; |
1203 | | } |
1204 | | |
1205 | | WC_MISC_STATIC WC_INLINE byte w64LT(w64wrapper a, w64wrapper b) |
1206 | | { |
1207 | | if (a.n[0] < b.n[0]) |
1208 | | return 1; |
1209 | | if (a.n[0] == b.n[0]) |
1210 | | return a.n[1] < b.n[1]; |
1211 | | |
1212 | | return 0; |
1213 | | } |
1214 | | |
1215 | | WC_MISC_STATIC WC_INLINE w64wrapper w64ShiftRight(w64wrapper a, int shift) |
1216 | | { |
1217 | | if (shift < 32) { |
1218 | | a.n[1] = (a.n[1] >> shift) | (a.n[0] << (32 - shift)); |
1219 | | a.n[0] >>= shift; |
1220 | | } |
1221 | | else { |
1222 | | a.n[1] = a.n[0] >> (shift - 32); |
1223 | | a.n[0] = 0; |
1224 | | } |
1225 | | return a; |
1226 | | } |
1227 | | WC_MISC_STATIC WC_INLINE w64wrapper w64ShiftLeft(w64wrapper a, int shift) |
1228 | | { |
1229 | | if (shift < 32) { |
1230 | | a.n[0] = (a.n[0] << shift) | (a.n[1] >> (32 - shift)); |
1231 | | a.n[1] <<= shift; |
1232 | | } |
1233 | | else { |
1234 | | a.n[0] = a.n[1] << (shift - 32); |
1235 | | a.n[1] = 0; |
1236 | | } |
1237 | | return a; |
1238 | | } |
1239 | | |
1240 | | WC_MISC_STATIC WC_INLINE w64wrapper w64Mul(word32 a, word32 b) |
1241 | | { |
1242 | | w64wrapper ret; |
1243 | | word16 ltlA, ltlB, ltlC, ltlD; |
1244 | | word32 bigA, bigB, bigC, bigD; |
1245 | | |
1246 | | ltlA = a & 0xFFFF; |
1247 | | ltlB = (a >> 16) & 0xFFFF; |
1248 | | ltlC = b & 0xFFFF; |
1249 | | ltlD = (b >> 16) & 0xFFFF; |
1250 | | |
1251 | | bigA = (word32)ltlA * (word32)ltlC; |
1252 | | bigC = (word32)ltlB * (word32)ltlC; |
1253 | | bigD = (word32)ltlA * (word32)ltlD; |
1254 | | bigB = (word32)ltlB * (word32)ltlD; |
1255 | | |
1256 | | ret = w64From32(0, bigB); |
1257 | | ret = w64ShiftLeft(ret, 16); |
1258 | | ret = w64Add32(ret, bigD, NULL); |
1259 | | ret = w64Add32(ret, bigC, NULL); |
1260 | | ret = w64ShiftLeft(ret, 16); |
1261 | | return w64Add32(ret, bigA, NULL); |
1262 | | } |
1263 | | |
1264 | | #endif /* WORD64_AVAILABLE && !WOLFSSL_W64_WRAPPER_TEST */ |
1265 | | #endif /* WOLFSSL_W64_WRAPPER */ |
1266 | | |
1267 | | #if defined(HAVE_SESSION_TICKET) || !defined(NO_CERTS) || \ |
1268 | | !defined(NO_SESSION_CACHE) |
1269 | | /* Make a word from the front of random hash */ |
1270 | | WC_MISC_STATIC WC_INLINE word32 MakeWordFromHash(const byte* hashID) |
1271 | 0 | { |
1272 | 0 | return ((word32)hashID[0] << 24) | ((word32)hashID[1] << 16) | |
1273 | 0 | ((word32)hashID[2] << 8) | (word32)hashID[3]; |
1274 | 0 | } Unexecuted instantiation: ssl.c:MakeWordFromHash Unexecuted instantiation: tls.c:MakeWordFromHash Unexecuted instantiation: tls13.c:MakeWordFromHash Unexecuted instantiation: hmac.c:MakeWordFromHash Unexecuted instantiation: hash.c:MakeWordFromHash Unexecuted instantiation: kdf.c:MakeWordFromHash Unexecuted instantiation: random.c:MakeWordFromHash Unexecuted instantiation: sha256.c:MakeWordFromHash Unexecuted instantiation: rsa.c:MakeWordFromHash Unexecuted instantiation: sp_int.c:MakeWordFromHash Unexecuted instantiation: aes.c:MakeWordFromHash Unexecuted instantiation: sha.c:MakeWordFromHash Unexecuted instantiation: sha512.c:MakeWordFromHash Unexecuted instantiation: sha3.c:MakeWordFromHash Unexecuted instantiation: wolfmath.c:MakeWordFromHash Unexecuted instantiation: dh.c:MakeWordFromHash Unexecuted instantiation: asn.c:MakeWordFromHash Unexecuted instantiation: coding.c:MakeWordFromHash Unexecuted instantiation: poly1305.c:MakeWordFromHash Unexecuted instantiation: md5.c:MakeWordFromHash Unexecuted instantiation: chacha.c:MakeWordFromHash Unexecuted instantiation: ecc.c:MakeWordFromHash Unexecuted instantiation: internal.c:MakeWordFromHash Unexecuted instantiation: wc_encrypt.c:MakeWordFromHash Unexecuted instantiation: pwdbased.c:MakeWordFromHash |
1275 | | #endif /* HAVE_SESSION_TICKET || !NO_CERTS || !NO_SESSION_CACHE */ |
1276 | | |
1277 | | |
1278 | | #if !defined(WOLFCRYPT_ONLY) && !defined(NO_HASH_WRAPPER) && \ |
1279 | | (!defined(NO_SESSION_CACHE) || defined(HAVE_SESSION_TICKET)) |
1280 | | |
1281 | | #include <wolfssl/wolfcrypt/hash.h> |
1282 | | |
1283 | | /* some session IDs aren't random after all, let's make them random */ |
1284 | | WC_MISC_STATIC WC_INLINE word32 HashObject(const byte* o, word32 len, |
1285 | | int* error) |
1286 | 0 | { |
1287 | 0 | byte digest[WC_MAX_DIGEST_SIZE]; |
1288 | |
|
1289 | 0 | #ifndef NO_MD5 |
1290 | 0 | *error = wc_Md5Hash(o, len, digest); |
1291 | | #elif !defined(NO_SHA) |
1292 | | *error = wc_ShaHash(o, len, digest); |
1293 | | #elif !defined(NO_SHA256) |
1294 | | *error = wc_Sha256Hash(o, len, digest); |
1295 | | #else |
1296 | | #error "We need a digest to hash the session IDs" |
1297 | | #endif |
1298 | |
|
1299 | 0 | return *error == 0 ? MakeWordFromHash(digest) : 0; /* 0 on failure */ |
1300 | 0 | } Unexecuted instantiation: ssl.c:HashObject Unexecuted instantiation: tls.c:HashObject Unexecuted instantiation: tls13.c:HashObject Unexecuted instantiation: hmac.c:HashObject Unexecuted instantiation: hash.c:HashObject Unexecuted instantiation: kdf.c:HashObject Unexecuted instantiation: random.c:HashObject Unexecuted instantiation: sha256.c:HashObject Unexecuted instantiation: rsa.c:HashObject Unexecuted instantiation: sp_int.c:HashObject Unexecuted instantiation: aes.c:HashObject Unexecuted instantiation: sha.c:HashObject Unexecuted instantiation: sha512.c:HashObject Unexecuted instantiation: sha3.c:HashObject Unexecuted instantiation: wolfmath.c:HashObject Unexecuted instantiation: dh.c:HashObject Unexecuted instantiation: asn.c:HashObject Unexecuted instantiation: coding.c:HashObject Unexecuted instantiation: poly1305.c:HashObject Unexecuted instantiation: md5.c:HashObject Unexecuted instantiation: chacha.c:HashObject Unexecuted instantiation: ecc.c:HashObject Unexecuted instantiation: internal.c:HashObject Unexecuted instantiation: wc_encrypt.c:HashObject Unexecuted instantiation: pwdbased.c:HashObject |
1301 | | #endif /* WOLFCRYPT_ONLY && !NO_HASH_WRAPPER && |
1302 | | * (!NO_SESSION_CACHE || HAVE_SESSION_TICKET) */ |
1303 | | |
1304 | | WC_MISC_STATIC WC_INLINE char* CopyString(const char* src, int srcLen, |
1305 | 0 | void* heap, int type) { |
1306 | 0 | char* dst = NULL; |
1307 | |
|
1308 | 0 | if (src == NULL) |
1309 | 0 | return NULL; |
1310 | | |
1311 | 0 | if (srcLen <= 0) |
1312 | 0 | srcLen = (int)XSTRLEN(src); |
1313 | |
|
1314 | 0 | dst = (char*)XMALLOC((size_t)srcLen + 1, heap, type); |
1315 | 0 | if (dst != NULL) { |
1316 | 0 | XMEMCPY(dst, src, (size_t)srcLen); |
1317 | 0 | dst[srcLen] = '\0'; |
1318 | 0 | } |
1319 | |
|
1320 | 0 | return dst; |
1321 | 0 | } Unexecuted instantiation: ssl.c:CopyString Unexecuted instantiation: tls.c:CopyString Unexecuted instantiation: tls13.c:CopyString Unexecuted instantiation: hmac.c:CopyString Unexecuted instantiation: hash.c:CopyString Unexecuted instantiation: kdf.c:CopyString Unexecuted instantiation: random.c:CopyString Unexecuted instantiation: sha256.c:CopyString Unexecuted instantiation: rsa.c:CopyString Unexecuted instantiation: sp_int.c:CopyString Unexecuted instantiation: aes.c:CopyString Unexecuted instantiation: sha.c:CopyString Unexecuted instantiation: sha512.c:CopyString Unexecuted instantiation: sha3.c:CopyString Unexecuted instantiation: wolfmath.c:CopyString Unexecuted instantiation: dh.c:CopyString Unexecuted instantiation: asn.c:CopyString Unexecuted instantiation: coding.c:CopyString Unexecuted instantiation: poly1305.c:CopyString Unexecuted instantiation: md5.c:CopyString Unexecuted instantiation: chacha.c:CopyString Unexecuted instantiation: ecc.c:CopyString Unexecuted instantiation: internal.c:CopyString Unexecuted instantiation: wc_encrypt.c:CopyString Unexecuted instantiation: pwdbased.c:CopyString |
1322 | | |
1323 | | #endif /* !WOLFSSL_MISC_INCLUDED && !NO_INLINE */ |
1324 | | |
1325 | | #endif /* WOLF_CRYPT_MISC_C */ |