Coverage Report

Created: 2025-07-23 06:59

/src/wolfssl-sp-math-all-8bit/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 3 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
427M
    {
111
427M
        return (x << y) | (x >> (sizeof(x) * 8 - y));
112
427M
    }
aes.c:rotlFixed
Line
Count
Source
110
4.57M
    {
111
4.57M
        return (x << y) | (x >> (sizeof(x) * 8 - y));
112
4.57M
    }
Unexecuted instantiation: asn.c:rotlFixed
Unexecuted instantiation: camellia.c:rotlFixed
chacha.c:rotlFixed
Line
Count
Source
110
4.06M
    {
111
4.06M
        return (x << y) | (x >> (sizeof(x) * 8 - y));
112
4.06M
    }
Unexecuted instantiation: chacha20_poly1305.c:rotlFixed
Unexecuted instantiation: cmac.c:rotlFixed
Unexecuted instantiation: coding.c:rotlFixed
Unexecuted instantiation: curve25519.c:rotlFixed
Unexecuted instantiation: curve448.c:rotlFixed
des3.c:rotlFixed
Line
Count
Source
110
30.8k
    {
111
30.8k
        return (x << y) | (x >> (sizeof(x) * 8 - y));
112
30.8k
    }
Unexecuted instantiation: dh.c:rotlFixed
Unexecuted instantiation: ecc.c:rotlFixed
Unexecuted instantiation: eccsi.c:rotlFixed
Unexecuted instantiation: ed25519.c:rotlFixed
Unexecuted instantiation: ed448.c:rotlFixed
Unexecuted instantiation: fe_448.c:rotlFixed
Unexecuted instantiation: fe_operations.c:rotlFixed
Unexecuted instantiation: ge_448.c:rotlFixed
Unexecuted instantiation: ge_operations.c:rotlFixed
Unexecuted instantiation: hash.c:rotlFixed
Unexecuted instantiation: hmac.c:rotlFixed
Unexecuted instantiation: kdf.c:rotlFixed
Unexecuted instantiation: md2.c:rotlFixed
md4.c:rotlFixed
Line
Count
Source
110
75.6k
    {
111
75.6k
        return (x << y) | (x >> (sizeof(x) * 8 - y));
112
75.6k
    }
md5.c:rotlFixed
Line
Count
Source
110
51.7M
    {
111
51.7M
        return (x << y) | (x >> (sizeof(x) * 8 - y));
112
51.7M
    }
Unexecuted instantiation: poly1305.c:rotlFixed
Unexecuted instantiation: pwdbased.c:rotlFixed
random.c:rotlFixed
Line
Count
Source
110
671k
    {
111
671k
        return (x << y) | (x >> (sizeof(x) * 8 - y));
112
671k
    }
Unexecuted instantiation: ripemd.c:rotlFixed
Unexecuted instantiation: rsa.c:rotlFixed
sha.c:rotlFixed
Line
Count
Source
110
228M
    {
111
228M
        return (x << y) | (x >> (sizeof(x) * 8 - y));
112
228M
    }
sha256.c:rotlFixed
Line
Count
Source
110
137M
    {
111
137M
        return (x << y) | (x >> (sizeof(x) * 8 - y));
112
137M
    }
Unexecuted instantiation: sha3.c:rotlFixed
Unexecuted instantiation: sha512.c:rotlFixed
Unexecuted instantiation: siphash.c:rotlFixed
Unexecuted instantiation: sm2.c:rotlFixed
Unexecuted instantiation: sm3.c:rotlFixed
Unexecuted instantiation: sm4.c:rotlFixed
Unexecuted instantiation: sp_int.c:rotlFixed
Unexecuted instantiation: wc_encrypt.c:rotlFixed
Unexecuted instantiation: wolfmath.c:rotlFixed
Unexecuted instantiation: ssl.c:rotlFixed
Unexecuted instantiation: tls.c:rotlFixed
Unexecuted instantiation: tls13.c:rotlFixed
Unexecuted instantiation: internal.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
4.11G
    {
117
4.11G
        return (x >> y) | (x << (sizeof(x) * 8 - y));
118
4.11G
    }
aes.c:rotrFixed
Line
Count
Source
116
4.57M
    {
117
4.57M
        return (x >> y) | (x << (sizeof(x) * 8 - y));
118
4.57M
    }
Unexecuted instantiation: asn.c:rotrFixed
Unexecuted instantiation: camellia.c:rotrFixed
Unexecuted instantiation: chacha.c:rotrFixed
Unexecuted instantiation: chacha20_poly1305.c:rotrFixed
Unexecuted instantiation: cmac.c:rotrFixed
Unexecuted instantiation: coding.c:rotrFixed
Unexecuted instantiation: curve25519.c:rotrFixed
Unexecuted instantiation: curve448.c:rotrFixed
des3.c:rotrFixed
Line
Count
Source
116
106k
    {
117
106k
        return (x >> y) | (x << (sizeof(x) * 8 - y));
118
106k
    }
Unexecuted instantiation: dh.c:rotrFixed
Unexecuted instantiation: ecc.c:rotrFixed
Unexecuted instantiation: eccsi.c:rotrFixed
Unexecuted instantiation: ed25519.c:rotrFixed
Unexecuted instantiation: ed448.c:rotrFixed
Unexecuted instantiation: fe_448.c:rotrFixed
Unexecuted instantiation: fe_operations.c:rotrFixed
Unexecuted instantiation: ge_448.c:rotrFixed
Unexecuted instantiation: ge_operations.c:rotrFixed
Unexecuted instantiation: hash.c:rotrFixed
Unexecuted instantiation: hmac.c:rotrFixed
Unexecuted instantiation: kdf.c:rotrFixed
Unexecuted instantiation: md2.c:rotrFixed
Unexecuted instantiation: md4.c:rotrFixed
Unexecuted instantiation: md5.c:rotrFixed
Unexecuted instantiation: poly1305.c:rotrFixed
Unexecuted instantiation: pwdbased.c:rotrFixed
random.c:rotrFixed
Line
Count
Source
116
671k
    {
117
671k
        return (x >> y) | (x << (sizeof(x) * 8 - y));
118
671k
    }
Unexecuted instantiation: ripemd.c:rotrFixed
Unexecuted instantiation: rsa.c:rotrFixed
sha.c:rotrFixed
Line
Count
Source
116
15.8M
    {
117
15.8M
        return (x >> y) | (x << (sizeof(x) * 8 - y));
118
15.8M
    }
sha256.c:rotrFixed
Line
Count
Source
116
4.09G
    {
117
4.09G
        return (x >> y) | (x << (sizeof(x) * 8 - y));
118
4.09G
    }
Unexecuted instantiation: sha3.c:rotrFixed
Unexecuted instantiation: sha512.c:rotrFixed
Unexecuted instantiation: siphash.c:rotrFixed
Unexecuted instantiation: sm2.c:rotrFixed
Unexecuted instantiation: sm3.c:rotrFixed
Unexecuted instantiation: sm4.c:rotrFixed
Unexecuted instantiation: sp_int.c:rotrFixed
Unexecuted instantiation: wc_encrypt.c:rotrFixed
Unexecuted instantiation: wolfmath.c:rotrFixed
Unexecuted instantiation: ssl.c:rotrFixed
Unexecuted instantiation: tls.c:rotrFixed
Unexecuted instantiation: tls13.c:rotrFixed
Unexecuted instantiation: internal.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: aes.c:rotlFixed16
Unexecuted instantiation: asn.c:rotlFixed16
Unexecuted instantiation: camellia.c:rotlFixed16
Unexecuted instantiation: chacha.c:rotlFixed16
Unexecuted instantiation: chacha20_poly1305.c:rotlFixed16
Unexecuted instantiation: cmac.c:rotlFixed16
Unexecuted instantiation: coding.c:rotlFixed16
Unexecuted instantiation: curve25519.c:rotlFixed16
Unexecuted instantiation: curve448.c:rotlFixed16
Unexecuted instantiation: des3.c:rotlFixed16
Unexecuted instantiation: dh.c:rotlFixed16
Unexecuted instantiation: ecc.c:rotlFixed16
Unexecuted instantiation: eccsi.c:rotlFixed16
Unexecuted instantiation: ed25519.c:rotlFixed16
Unexecuted instantiation: ed448.c:rotlFixed16
Unexecuted instantiation: fe_448.c:rotlFixed16
Unexecuted instantiation: fe_operations.c:rotlFixed16
Unexecuted instantiation: ge_448.c:rotlFixed16
Unexecuted instantiation: ge_operations.c:rotlFixed16
Unexecuted instantiation: hash.c:rotlFixed16
Unexecuted instantiation: hmac.c:rotlFixed16
Unexecuted instantiation: kdf.c:rotlFixed16
Unexecuted instantiation: md2.c:rotlFixed16
Unexecuted instantiation: md4.c:rotlFixed16
Unexecuted instantiation: md5.c:rotlFixed16
Unexecuted instantiation: poly1305.c:rotlFixed16
Unexecuted instantiation: pwdbased.c:rotlFixed16
Unexecuted instantiation: random.c:rotlFixed16
Unexecuted instantiation: ripemd.c:rotlFixed16
Unexecuted instantiation: rsa.c:rotlFixed16
Unexecuted instantiation: sha.c:rotlFixed16
Unexecuted instantiation: sha256.c:rotlFixed16
Unexecuted instantiation: sha3.c:rotlFixed16
Unexecuted instantiation: sha512.c:rotlFixed16
Unexecuted instantiation: siphash.c:rotlFixed16
Unexecuted instantiation: sm2.c:rotlFixed16
Unexecuted instantiation: sm3.c:rotlFixed16
Unexecuted instantiation: sm4.c:rotlFixed16
Unexecuted instantiation: sp_int.c:rotlFixed16
Unexecuted instantiation: wc_encrypt.c:rotlFixed16
Unexecuted instantiation: wolfmath.c:rotlFixed16
Unexecuted instantiation: ssl.c:rotlFixed16
Unexecuted instantiation: tls.c:rotlFixed16
Unexecuted instantiation: tls13.c:rotlFixed16
Unexecuted instantiation: internal.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: aes.c:rotrFixed16
Unexecuted instantiation: asn.c:rotrFixed16
Unexecuted instantiation: camellia.c:rotrFixed16
Unexecuted instantiation: chacha.c:rotrFixed16
Unexecuted instantiation: chacha20_poly1305.c:rotrFixed16
Unexecuted instantiation: cmac.c:rotrFixed16
Unexecuted instantiation: coding.c:rotrFixed16
Unexecuted instantiation: curve25519.c:rotrFixed16
Unexecuted instantiation: curve448.c:rotrFixed16
Unexecuted instantiation: des3.c:rotrFixed16
Unexecuted instantiation: dh.c:rotrFixed16
Unexecuted instantiation: ecc.c:rotrFixed16
Unexecuted instantiation: eccsi.c:rotrFixed16
Unexecuted instantiation: ed25519.c:rotrFixed16
Unexecuted instantiation: ed448.c:rotrFixed16
Unexecuted instantiation: fe_448.c:rotrFixed16
Unexecuted instantiation: fe_operations.c:rotrFixed16
Unexecuted instantiation: ge_448.c:rotrFixed16
Unexecuted instantiation: ge_operations.c:rotrFixed16
Unexecuted instantiation: hash.c:rotrFixed16
Unexecuted instantiation: hmac.c:rotrFixed16
Unexecuted instantiation: kdf.c:rotrFixed16
Unexecuted instantiation: md2.c:rotrFixed16
Unexecuted instantiation: md4.c:rotrFixed16
Unexecuted instantiation: md5.c:rotrFixed16
Unexecuted instantiation: poly1305.c:rotrFixed16
Unexecuted instantiation: pwdbased.c:rotrFixed16
Unexecuted instantiation: random.c:rotrFixed16
Unexecuted instantiation: ripemd.c:rotrFixed16
Unexecuted instantiation: rsa.c:rotrFixed16
Unexecuted instantiation: sha.c:rotrFixed16
Unexecuted instantiation: sha256.c:rotrFixed16
Unexecuted instantiation: sha3.c:rotrFixed16
Unexecuted instantiation: sha512.c:rotrFixed16
Unexecuted instantiation: siphash.c:rotrFixed16
Unexecuted instantiation: sm2.c:rotrFixed16
Unexecuted instantiation: sm3.c:rotrFixed16
Unexecuted instantiation: sm4.c:rotrFixed16
Unexecuted instantiation: sp_int.c:rotrFixed16
Unexecuted instantiation: wc_encrypt.c:rotrFixed16
Unexecuted instantiation: wolfmath.c:rotrFixed16
Unexecuted instantiation: ssl.c:rotrFixed16
Unexecuted instantiation: tls.c:rotrFixed16
Unexecuted instantiation: tls13.c:rotrFixed16
Unexecuted instantiation: internal.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
158M
{
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
158M
    return (rotrFixed(value, 8U) & 0xff00ff00) |
172
158M
           (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
158M
}
aes.c:ByteReverseWord32
Line
Count
Source
140
4.57M
{
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
4.57M
    return (rotrFixed(value, 8U) & 0xff00ff00) |
172
4.57M
           (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
4.57M
}
Unexecuted instantiation: asn.c:ByteReverseWord32
Unexecuted instantiation: camellia.c:ByteReverseWord32
Unexecuted instantiation: chacha.c:ByteReverseWord32
Unexecuted instantiation: chacha20_poly1305.c:ByteReverseWord32
Unexecuted instantiation: cmac.c:ByteReverseWord32
Unexecuted instantiation: coding.c:ByteReverseWord32
Unexecuted instantiation: curve25519.c:ByteReverseWord32
Unexecuted instantiation: curve448.c:ByteReverseWord32
des3.c:ByteReverseWord32
Line
Count
Source
140
12.3k
{
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
12.3k
    return (rotrFixed(value, 8U) & 0xff00ff00) |
172
12.3k
           (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
12.3k
}
Unexecuted instantiation: dh.c:ByteReverseWord32
Unexecuted instantiation: ecc.c:ByteReverseWord32
Unexecuted instantiation: eccsi.c:ByteReverseWord32
Unexecuted instantiation: ed25519.c:ByteReverseWord32
Unexecuted instantiation: ed448.c:ByteReverseWord32
Unexecuted instantiation: fe_448.c:ByteReverseWord32
Unexecuted instantiation: fe_operations.c:ByteReverseWord32
Unexecuted instantiation: ge_448.c:ByteReverseWord32
Unexecuted instantiation: ge_operations.c:ByteReverseWord32
Unexecuted instantiation: hash.c:ByteReverseWord32
Unexecuted instantiation: hmac.c:ByteReverseWord32
Unexecuted instantiation: kdf.c:ByteReverseWord32
Unexecuted instantiation: md2.c:ByteReverseWord32
Unexecuted instantiation: md4.c:ByteReverseWord32
Unexecuted instantiation: md5.c:ByteReverseWord32
Unexecuted instantiation: poly1305.c:ByteReverseWord32
Unexecuted instantiation: pwdbased.c:ByteReverseWord32
random.c:ByteReverseWord32
Line
Count
Source
140
671k
{
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
671k
    return (rotrFixed(value, 8U) & 0xff00ff00) |
172
671k
           (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
671k
}
Unexecuted instantiation: ripemd.c:ByteReverseWord32
Unexecuted instantiation: rsa.c:ByteReverseWord32
sha.c:ByteReverseWord32
Line
Count
Source
140
15.8M
{
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
15.8M
    return (rotrFixed(value, 8U) & 0xff00ff00) |
172
15.8M
           (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
15.8M
}
sha256.c:ByteReverseWord32
Line
Count
Source
140
137M
{
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
137M
    return (rotrFixed(value, 8U) & 0xff00ff00) |
172
137M
           (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
137M
}
Unexecuted instantiation: sha3.c:ByteReverseWord32
Unexecuted instantiation: sha512.c:ByteReverseWord32
Unexecuted instantiation: siphash.c:ByteReverseWord32
Unexecuted instantiation: sm2.c:ByteReverseWord32
Unexecuted instantiation: sm3.c:ByteReverseWord32
Unexecuted instantiation: sm4.c:ByteReverseWord32
Unexecuted instantiation: sp_int.c:ByteReverseWord32
Unexecuted instantiation: wc_encrypt.c:ByteReverseWord32
Unexecuted instantiation: wolfmath.c:ByteReverseWord32
Unexecuted instantiation: ssl.c:ByteReverseWord32
Unexecuted instantiation: tls.c:ByteReverseWord32
Unexecuted instantiation: tls13.c:ByteReverseWord32
Unexecuted instantiation: internal.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
12.5M
{
184
12.5M
    word32 i;
185
186
12.5M
#ifdef WOLFSSL_USE_ALIGN
187
12.5M
    if ((((size_t)in & 0x3) == 0) &&
188
12.5M
        (((size_t)out & 0x3) == 0))
189
12.5M
#endif
190
12.5M
    {
191
12.5M
        word32 count = byteCount/(word32)sizeof(word32);
192
166M
        for (i = 0; i < count; i++)
193
153M
            out[i] = ByteReverseWord32(in[i]);
194
12.5M
    }
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
12.5M
#endif
232
12.5M
}
aes.c:ByteReverseWords
Line
Count
Source
183
10.9k
{
184
10.9k
    word32 i;
185
186
10.9k
#ifdef WOLFSSL_USE_ALIGN
187
10.9k
    if ((((size_t)in & 0x3) == 0) &&
188
10.9k
        (((size_t)out & 0x3) == 0))
189
10.9k
#endif
190
10.9k
    {
191
10.9k
        word32 count = byteCount/(word32)sizeof(word32);
192
71.9k
        for (i = 0; i < count; i++)
193
61.0k
            out[i] = ByteReverseWord32(in[i]);
194
10.9k
    }
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
10.9k
#endif
232
10.9k
}
Unexecuted instantiation: asn.c:ByteReverseWords
Unexecuted instantiation: camellia.c:ByteReverseWords
Unexecuted instantiation: chacha.c:ByteReverseWords
Unexecuted instantiation: chacha20_poly1305.c:ByteReverseWords
Unexecuted instantiation: cmac.c:ByteReverseWords
Unexecuted instantiation: coding.c:ByteReverseWords
Unexecuted instantiation: curve25519.c:ByteReverseWords
Unexecuted instantiation: curve448.c:ByteReverseWords
Unexecuted instantiation: des3.c:ByteReverseWords
Unexecuted instantiation: dh.c:ByteReverseWords
Unexecuted instantiation: ecc.c:ByteReverseWords
Unexecuted instantiation: eccsi.c:ByteReverseWords
Unexecuted instantiation: ed25519.c:ByteReverseWords
Unexecuted instantiation: ed448.c:ByteReverseWords
Unexecuted instantiation: fe_448.c:ByteReverseWords
Unexecuted instantiation: fe_operations.c:ByteReverseWords
Unexecuted instantiation: ge_448.c:ByteReverseWords
Unexecuted instantiation: ge_operations.c:ByteReverseWords
Unexecuted instantiation: hash.c:ByteReverseWords
Unexecuted instantiation: hmac.c:ByteReverseWords
Unexecuted instantiation: kdf.c:ByteReverseWords
Unexecuted instantiation: md2.c:ByteReverseWords
Unexecuted instantiation: md4.c:ByteReverseWords
Unexecuted instantiation: md5.c:ByteReverseWords
Unexecuted instantiation: poly1305.c:ByteReverseWords
Unexecuted instantiation: pwdbased.c:ByteReverseWords
Unexecuted instantiation: random.c:ByteReverseWords
Unexecuted instantiation: ripemd.c:ByteReverseWords
Unexecuted instantiation: rsa.c:ByteReverseWords
sha.c:ByteReverseWords
Line
Count
Source
183
1.08M
{
184
1.08M
    word32 i;
185
186
1.08M
#ifdef WOLFSSL_USE_ALIGN
187
1.08M
    if ((((size_t)in & 0x3) == 0) &&
188
1.08M
        (((size_t)out & 0x3) == 0))
189
1.08M
#endif
190
1.08M
    {
191
1.08M
        word32 count = byteCount/(word32)sizeof(word32);
192
16.9M
        for (i = 0; i < count; i++)
193
15.8M
            out[i] = ByteReverseWord32(in[i]);
194
1.08M
    }
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
1.08M
#endif
232
1.08M
}
sha256.c:ByteReverseWords
Line
Count
Source
183
11.4M
{
184
11.4M
    word32 i;
185
186
11.4M
#ifdef WOLFSSL_USE_ALIGN
187
11.4M
    if ((((size_t)in & 0x3) == 0) &&
188
11.4M
        (((size_t)out & 0x3) == 0))
189
11.4M
#endif
190
11.4M
    {
191
11.4M
        word32 count = byteCount/(word32)sizeof(word32);
192
149M
        for (i = 0; i < count; i++)
193
137M
            out[i] = ByteReverseWord32(in[i]);
194
11.4M
    }
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
11.4M
#endif
232
11.4M
}
Unexecuted instantiation: sha3.c:ByteReverseWords
Unexecuted instantiation: sha512.c:ByteReverseWords
Unexecuted instantiation: siphash.c:ByteReverseWords
Unexecuted instantiation: sm2.c:ByteReverseWords
Unexecuted instantiation: sm3.c:ByteReverseWords
Unexecuted instantiation: sm4.c:ByteReverseWords
Unexecuted instantiation: sp_int.c:ByteReverseWords
Unexecuted instantiation: wc_encrypt.c:ByteReverseWords
Unexecuted instantiation: wolfmath.c:ByteReverseWords
Unexecuted instantiation: ssl.c:ByteReverseWords
Unexecuted instantiation: tls.c:ByteReverseWords
Unexecuted instantiation: tls13.c:ByteReverseWords
Unexecuted instantiation: internal.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: aes.c:readUnalignedWord32
Unexecuted instantiation: asn.c:readUnalignedWord32
Unexecuted instantiation: camellia.c:readUnalignedWord32
Unexecuted instantiation: chacha.c:readUnalignedWord32
Unexecuted instantiation: chacha20_poly1305.c:readUnalignedWord32
Unexecuted instantiation: cmac.c:readUnalignedWord32
Unexecuted instantiation: coding.c:readUnalignedWord32
Unexecuted instantiation: curve25519.c:readUnalignedWord32
Unexecuted instantiation: curve448.c:readUnalignedWord32
Unexecuted instantiation: des3.c:readUnalignedWord32
Unexecuted instantiation: dh.c:readUnalignedWord32
Unexecuted instantiation: ecc.c:readUnalignedWord32
Unexecuted instantiation: eccsi.c:readUnalignedWord32
Unexecuted instantiation: ed25519.c:readUnalignedWord32
Unexecuted instantiation: ed448.c:readUnalignedWord32
Unexecuted instantiation: fe_448.c:readUnalignedWord32
Unexecuted instantiation: fe_operations.c:readUnalignedWord32
Unexecuted instantiation: ge_448.c:readUnalignedWord32
Unexecuted instantiation: ge_operations.c:readUnalignedWord32
Unexecuted instantiation: hash.c:readUnalignedWord32
Unexecuted instantiation: hmac.c:readUnalignedWord32
Unexecuted instantiation: kdf.c:readUnalignedWord32
Unexecuted instantiation: md2.c:readUnalignedWord32
Unexecuted instantiation: md4.c:readUnalignedWord32
Unexecuted instantiation: md5.c:readUnalignedWord32
Unexecuted instantiation: poly1305.c:readUnalignedWord32
Unexecuted instantiation: pwdbased.c:readUnalignedWord32
Unexecuted instantiation: random.c:readUnalignedWord32
Unexecuted instantiation: ripemd.c:readUnalignedWord32
Unexecuted instantiation: rsa.c:readUnalignedWord32
Unexecuted instantiation: sha.c:readUnalignedWord32
Unexecuted instantiation: sha256.c:readUnalignedWord32
Unexecuted instantiation: sha3.c:readUnalignedWord32
Unexecuted instantiation: sha512.c:readUnalignedWord32
Unexecuted instantiation: siphash.c:readUnalignedWord32
Unexecuted instantiation: sm2.c:readUnalignedWord32
Unexecuted instantiation: sm3.c:readUnalignedWord32
Unexecuted instantiation: sm4.c:readUnalignedWord32
Unexecuted instantiation: sp_int.c:readUnalignedWord32
Unexecuted instantiation: wc_encrypt.c:readUnalignedWord32
Unexecuted instantiation: wolfmath.c:readUnalignedWord32
Unexecuted instantiation: ssl.c:readUnalignedWord32
Unexecuted instantiation: tls.c:readUnalignedWord32
Unexecuted instantiation: tls13.c:readUnalignedWord32
Unexecuted instantiation: internal.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: aes.c:writeUnalignedWord32
Unexecuted instantiation: asn.c:writeUnalignedWord32
Unexecuted instantiation: camellia.c:writeUnalignedWord32
Unexecuted instantiation: chacha.c:writeUnalignedWord32
Unexecuted instantiation: chacha20_poly1305.c:writeUnalignedWord32
Unexecuted instantiation: cmac.c:writeUnalignedWord32
Unexecuted instantiation: coding.c:writeUnalignedWord32
Unexecuted instantiation: curve25519.c:writeUnalignedWord32
Unexecuted instantiation: curve448.c:writeUnalignedWord32
Unexecuted instantiation: des3.c:writeUnalignedWord32
Unexecuted instantiation: dh.c:writeUnalignedWord32
Unexecuted instantiation: ecc.c:writeUnalignedWord32
Unexecuted instantiation: eccsi.c:writeUnalignedWord32
Unexecuted instantiation: ed25519.c:writeUnalignedWord32
Unexecuted instantiation: ed448.c:writeUnalignedWord32
Unexecuted instantiation: fe_448.c:writeUnalignedWord32
Unexecuted instantiation: fe_operations.c:writeUnalignedWord32
Unexecuted instantiation: ge_448.c:writeUnalignedWord32
Unexecuted instantiation: ge_operations.c:writeUnalignedWord32
Unexecuted instantiation: hash.c:writeUnalignedWord32
Unexecuted instantiation: hmac.c:writeUnalignedWord32
Unexecuted instantiation: kdf.c:writeUnalignedWord32
Unexecuted instantiation: md2.c:writeUnalignedWord32
Unexecuted instantiation: md4.c:writeUnalignedWord32
Unexecuted instantiation: md5.c:writeUnalignedWord32
Unexecuted instantiation: poly1305.c:writeUnalignedWord32
Unexecuted instantiation: pwdbased.c:writeUnalignedWord32
Unexecuted instantiation: random.c:writeUnalignedWord32
Unexecuted instantiation: ripemd.c:writeUnalignedWord32
Unexecuted instantiation: rsa.c:writeUnalignedWord32
Unexecuted instantiation: sha.c:writeUnalignedWord32
Unexecuted instantiation: sha256.c:writeUnalignedWord32
Unexecuted instantiation: sha3.c:writeUnalignedWord32
Unexecuted instantiation: sha512.c:writeUnalignedWord32
Unexecuted instantiation: siphash.c:writeUnalignedWord32
Unexecuted instantiation: sm2.c:writeUnalignedWord32
Unexecuted instantiation: sm3.c:writeUnalignedWord32
Unexecuted instantiation: sm4.c:writeUnalignedWord32
Unexecuted instantiation: sp_int.c:writeUnalignedWord32
Unexecuted instantiation: wc_encrypt.c:writeUnalignedWord32
Unexecuted instantiation: wolfmath.c:writeUnalignedWord32
Unexecuted instantiation: ssl.c:writeUnalignedWord32
Unexecuted instantiation: tls.c:writeUnalignedWord32
Unexecuted instantiation: tls13.c:writeUnalignedWord32
Unexecuted instantiation: internal.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: aes.c:readUnalignedWords32
Unexecuted instantiation: asn.c:readUnalignedWords32
Unexecuted instantiation: camellia.c:readUnalignedWords32
Unexecuted instantiation: chacha.c:readUnalignedWords32
Unexecuted instantiation: chacha20_poly1305.c:readUnalignedWords32
Unexecuted instantiation: cmac.c:readUnalignedWords32
Unexecuted instantiation: coding.c:readUnalignedWords32
Unexecuted instantiation: curve25519.c:readUnalignedWords32
Unexecuted instantiation: curve448.c:readUnalignedWords32
Unexecuted instantiation: des3.c:readUnalignedWords32
Unexecuted instantiation: dh.c:readUnalignedWords32
Unexecuted instantiation: ecc.c:readUnalignedWords32
Unexecuted instantiation: eccsi.c:readUnalignedWords32
Unexecuted instantiation: ed25519.c:readUnalignedWords32
Unexecuted instantiation: ed448.c:readUnalignedWords32
Unexecuted instantiation: fe_448.c:readUnalignedWords32
Unexecuted instantiation: fe_operations.c:readUnalignedWords32
Unexecuted instantiation: ge_448.c:readUnalignedWords32
Unexecuted instantiation: ge_operations.c:readUnalignedWords32
Unexecuted instantiation: hash.c:readUnalignedWords32
Unexecuted instantiation: hmac.c:readUnalignedWords32
Unexecuted instantiation: kdf.c:readUnalignedWords32
Unexecuted instantiation: md2.c:readUnalignedWords32
Unexecuted instantiation: md4.c:readUnalignedWords32
Unexecuted instantiation: md5.c:readUnalignedWords32
Unexecuted instantiation: poly1305.c:readUnalignedWords32
Unexecuted instantiation: pwdbased.c:readUnalignedWords32
Unexecuted instantiation: random.c:readUnalignedWords32
Unexecuted instantiation: ripemd.c:readUnalignedWords32
Unexecuted instantiation: rsa.c:readUnalignedWords32
Unexecuted instantiation: sha.c:readUnalignedWords32
Unexecuted instantiation: sha256.c:readUnalignedWords32
Unexecuted instantiation: sha3.c:readUnalignedWords32
Unexecuted instantiation: sha512.c:readUnalignedWords32
Unexecuted instantiation: siphash.c:readUnalignedWords32
Unexecuted instantiation: sm2.c:readUnalignedWords32
Unexecuted instantiation: sm3.c:readUnalignedWords32
Unexecuted instantiation: sm4.c:readUnalignedWords32
Unexecuted instantiation: sp_int.c:readUnalignedWords32
Unexecuted instantiation: wc_encrypt.c:readUnalignedWords32
Unexecuted instantiation: wolfmath.c:readUnalignedWords32
Unexecuted instantiation: ssl.c:readUnalignedWords32
Unexecuted instantiation: tls.c:readUnalignedWords32
Unexecuted instantiation: tls13.c:readUnalignedWords32
Unexecuted instantiation: internal.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: aes.c:writeUnalignedWords32
Unexecuted instantiation: asn.c:writeUnalignedWords32
Unexecuted instantiation: camellia.c:writeUnalignedWords32
Unexecuted instantiation: chacha.c:writeUnalignedWords32
Unexecuted instantiation: chacha20_poly1305.c:writeUnalignedWords32
Unexecuted instantiation: cmac.c:writeUnalignedWords32
Unexecuted instantiation: coding.c:writeUnalignedWords32
Unexecuted instantiation: curve25519.c:writeUnalignedWords32
Unexecuted instantiation: curve448.c:writeUnalignedWords32
Unexecuted instantiation: des3.c:writeUnalignedWords32
Unexecuted instantiation: dh.c:writeUnalignedWords32
Unexecuted instantiation: ecc.c:writeUnalignedWords32
Unexecuted instantiation: eccsi.c:writeUnalignedWords32
Unexecuted instantiation: ed25519.c:writeUnalignedWords32
Unexecuted instantiation: ed448.c:writeUnalignedWords32
Unexecuted instantiation: fe_448.c:writeUnalignedWords32
Unexecuted instantiation: fe_operations.c:writeUnalignedWords32
Unexecuted instantiation: ge_448.c:writeUnalignedWords32
Unexecuted instantiation: ge_operations.c:writeUnalignedWords32
Unexecuted instantiation: hash.c:writeUnalignedWords32
Unexecuted instantiation: hmac.c:writeUnalignedWords32
Unexecuted instantiation: kdf.c:writeUnalignedWords32
Unexecuted instantiation: md2.c:writeUnalignedWords32
Unexecuted instantiation: md4.c:writeUnalignedWords32
Unexecuted instantiation: md5.c:writeUnalignedWords32
Unexecuted instantiation: poly1305.c:writeUnalignedWords32
Unexecuted instantiation: pwdbased.c:writeUnalignedWords32
Unexecuted instantiation: random.c:writeUnalignedWords32
Unexecuted instantiation: ripemd.c:writeUnalignedWords32
Unexecuted instantiation: rsa.c:writeUnalignedWords32
Unexecuted instantiation: sha.c:writeUnalignedWords32
Unexecuted instantiation: sha256.c:writeUnalignedWords32
Unexecuted instantiation: sha3.c:writeUnalignedWords32
Unexecuted instantiation: sha512.c:writeUnalignedWords32
Unexecuted instantiation: siphash.c:writeUnalignedWords32
Unexecuted instantiation: sm2.c:writeUnalignedWords32
Unexecuted instantiation: sm3.c:writeUnalignedWords32
Unexecuted instantiation: sm4.c:writeUnalignedWords32
Unexecuted instantiation: sp_int.c:writeUnalignedWords32
Unexecuted instantiation: wc_encrypt.c:writeUnalignedWords32
Unexecuted instantiation: wolfmath.c:writeUnalignedWords32
Unexecuted instantiation: ssl.c:writeUnalignedWords32
Unexecuted instantiation: tls.c:writeUnalignedWords32
Unexecuted instantiation: tls13.c:writeUnalignedWords32
Unexecuted instantiation: internal.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: aes.c:readUnalignedWord64
Unexecuted instantiation: asn.c:readUnalignedWord64
Unexecuted instantiation: camellia.c:readUnalignedWord64
Unexecuted instantiation: chacha.c:readUnalignedWord64
Unexecuted instantiation: chacha20_poly1305.c:readUnalignedWord64
Unexecuted instantiation: cmac.c:readUnalignedWord64
Unexecuted instantiation: coding.c:readUnalignedWord64
Unexecuted instantiation: curve25519.c:readUnalignedWord64
Unexecuted instantiation: curve448.c:readUnalignedWord64
Unexecuted instantiation: des3.c:readUnalignedWord64
Unexecuted instantiation: dh.c:readUnalignedWord64
Unexecuted instantiation: ecc.c:readUnalignedWord64
Unexecuted instantiation: eccsi.c:readUnalignedWord64
Unexecuted instantiation: ed25519.c:readUnalignedWord64
Unexecuted instantiation: ed448.c:readUnalignedWord64
Unexecuted instantiation: fe_448.c:readUnalignedWord64
Unexecuted instantiation: fe_operations.c:readUnalignedWord64
Unexecuted instantiation: ge_448.c:readUnalignedWord64
Unexecuted instantiation: ge_operations.c:readUnalignedWord64
Unexecuted instantiation: hash.c:readUnalignedWord64
Unexecuted instantiation: hmac.c:readUnalignedWord64
Unexecuted instantiation: kdf.c:readUnalignedWord64
Unexecuted instantiation: md2.c:readUnalignedWord64
Unexecuted instantiation: md4.c:readUnalignedWord64
Unexecuted instantiation: md5.c:readUnalignedWord64
Unexecuted instantiation: poly1305.c:readUnalignedWord64
Unexecuted instantiation: pwdbased.c:readUnalignedWord64
Unexecuted instantiation: random.c:readUnalignedWord64
Unexecuted instantiation: ripemd.c:readUnalignedWord64
Unexecuted instantiation: rsa.c:readUnalignedWord64
Unexecuted instantiation: sha.c:readUnalignedWord64
Unexecuted instantiation: sha256.c:readUnalignedWord64
Unexecuted instantiation: sha3.c:readUnalignedWord64
Unexecuted instantiation: sha512.c:readUnalignedWord64
Unexecuted instantiation: siphash.c:readUnalignedWord64
Unexecuted instantiation: sm2.c:readUnalignedWord64
Unexecuted instantiation: sm3.c:readUnalignedWord64
Unexecuted instantiation: sm4.c:readUnalignedWord64
Unexecuted instantiation: sp_int.c:readUnalignedWord64
Unexecuted instantiation: wc_encrypt.c:readUnalignedWord64
Unexecuted instantiation: wolfmath.c:readUnalignedWord64
Unexecuted instantiation: ssl.c:readUnalignedWord64
Unexecuted instantiation: tls.c:readUnalignedWord64
Unexecuted instantiation: tls13.c:readUnalignedWord64
Unexecuted instantiation: internal.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: aes.c:writeUnalignedWord64
Unexecuted instantiation: asn.c:writeUnalignedWord64
Unexecuted instantiation: camellia.c:writeUnalignedWord64
Unexecuted instantiation: chacha.c:writeUnalignedWord64
Unexecuted instantiation: chacha20_poly1305.c:writeUnalignedWord64
Unexecuted instantiation: cmac.c:writeUnalignedWord64
Unexecuted instantiation: coding.c:writeUnalignedWord64
Unexecuted instantiation: curve25519.c:writeUnalignedWord64
Unexecuted instantiation: curve448.c:writeUnalignedWord64
Unexecuted instantiation: des3.c:writeUnalignedWord64
Unexecuted instantiation: dh.c:writeUnalignedWord64
Unexecuted instantiation: ecc.c:writeUnalignedWord64
Unexecuted instantiation: eccsi.c:writeUnalignedWord64
Unexecuted instantiation: ed25519.c:writeUnalignedWord64
Unexecuted instantiation: ed448.c:writeUnalignedWord64
Unexecuted instantiation: fe_448.c:writeUnalignedWord64
Unexecuted instantiation: fe_operations.c:writeUnalignedWord64
Unexecuted instantiation: ge_448.c:writeUnalignedWord64
Unexecuted instantiation: ge_operations.c:writeUnalignedWord64
Unexecuted instantiation: hash.c:writeUnalignedWord64
Unexecuted instantiation: hmac.c:writeUnalignedWord64
Unexecuted instantiation: kdf.c:writeUnalignedWord64
Unexecuted instantiation: md2.c:writeUnalignedWord64
Unexecuted instantiation: md4.c:writeUnalignedWord64
Unexecuted instantiation: md5.c:writeUnalignedWord64
Unexecuted instantiation: poly1305.c:writeUnalignedWord64
Unexecuted instantiation: pwdbased.c:writeUnalignedWord64
Unexecuted instantiation: random.c:writeUnalignedWord64
Unexecuted instantiation: ripemd.c:writeUnalignedWord64
Unexecuted instantiation: rsa.c:writeUnalignedWord64
Unexecuted instantiation: sha.c:writeUnalignedWord64
Unexecuted instantiation: sha256.c:writeUnalignedWord64
Unexecuted instantiation: sha3.c:writeUnalignedWord64
Unexecuted instantiation: sha512.c:writeUnalignedWord64
Unexecuted instantiation: siphash.c:writeUnalignedWord64
Unexecuted instantiation: sm2.c:writeUnalignedWord64
Unexecuted instantiation: sm3.c:writeUnalignedWord64
Unexecuted instantiation: sm4.c:writeUnalignedWord64
Unexecuted instantiation: sp_int.c:writeUnalignedWord64
Unexecuted instantiation: wc_encrypt.c:writeUnalignedWord64
Unexecuted instantiation: wolfmath.c:writeUnalignedWord64
Unexecuted instantiation: ssl.c:writeUnalignedWord64
Unexecuted instantiation: tls.c:writeUnalignedWord64
Unexecuted instantiation: tls13.c:writeUnalignedWord64
Unexecuted instantiation: internal.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: aes.c:readUnalignedWords64
Unexecuted instantiation: asn.c:readUnalignedWords64
Unexecuted instantiation: camellia.c:readUnalignedWords64
Unexecuted instantiation: chacha.c:readUnalignedWords64
Unexecuted instantiation: chacha20_poly1305.c:readUnalignedWords64
Unexecuted instantiation: cmac.c:readUnalignedWords64
Unexecuted instantiation: coding.c:readUnalignedWords64
Unexecuted instantiation: curve25519.c:readUnalignedWords64
Unexecuted instantiation: curve448.c:readUnalignedWords64
Unexecuted instantiation: des3.c:readUnalignedWords64
Unexecuted instantiation: dh.c:readUnalignedWords64
Unexecuted instantiation: ecc.c:readUnalignedWords64
Unexecuted instantiation: eccsi.c:readUnalignedWords64
Unexecuted instantiation: ed25519.c:readUnalignedWords64
Unexecuted instantiation: ed448.c:readUnalignedWords64
Unexecuted instantiation: fe_448.c:readUnalignedWords64
Unexecuted instantiation: fe_operations.c:readUnalignedWords64
Unexecuted instantiation: ge_448.c:readUnalignedWords64
Unexecuted instantiation: ge_operations.c:readUnalignedWords64
Unexecuted instantiation: hash.c:readUnalignedWords64
Unexecuted instantiation: hmac.c:readUnalignedWords64
Unexecuted instantiation: kdf.c:readUnalignedWords64
Unexecuted instantiation: md2.c:readUnalignedWords64
Unexecuted instantiation: md4.c:readUnalignedWords64
Unexecuted instantiation: md5.c:readUnalignedWords64
Unexecuted instantiation: poly1305.c:readUnalignedWords64
Unexecuted instantiation: pwdbased.c:readUnalignedWords64
Unexecuted instantiation: random.c:readUnalignedWords64
Unexecuted instantiation: ripemd.c:readUnalignedWords64
Unexecuted instantiation: rsa.c:readUnalignedWords64
Unexecuted instantiation: sha.c:readUnalignedWords64
Unexecuted instantiation: sha256.c:readUnalignedWords64
Unexecuted instantiation: sha3.c:readUnalignedWords64
Unexecuted instantiation: sha512.c:readUnalignedWords64
Unexecuted instantiation: siphash.c:readUnalignedWords64
Unexecuted instantiation: sm2.c:readUnalignedWords64
Unexecuted instantiation: sm3.c:readUnalignedWords64
Unexecuted instantiation: sm4.c:readUnalignedWords64
Unexecuted instantiation: sp_int.c:readUnalignedWords64
Unexecuted instantiation: wc_encrypt.c:readUnalignedWords64
Unexecuted instantiation: wolfmath.c:readUnalignedWords64
Unexecuted instantiation: ssl.c:readUnalignedWords64
Unexecuted instantiation: tls.c:readUnalignedWords64
Unexecuted instantiation: tls13.c:readUnalignedWords64
Unexecuted instantiation: internal.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: aes.c:writeUnalignedWords64
Unexecuted instantiation: asn.c:writeUnalignedWords64
Unexecuted instantiation: camellia.c:writeUnalignedWords64
Unexecuted instantiation: chacha.c:writeUnalignedWords64
Unexecuted instantiation: chacha20_poly1305.c:writeUnalignedWords64
Unexecuted instantiation: cmac.c:writeUnalignedWords64
Unexecuted instantiation: coding.c:writeUnalignedWords64
Unexecuted instantiation: curve25519.c:writeUnalignedWords64
Unexecuted instantiation: curve448.c:writeUnalignedWords64
Unexecuted instantiation: des3.c:writeUnalignedWords64
Unexecuted instantiation: dh.c:writeUnalignedWords64
Unexecuted instantiation: ecc.c:writeUnalignedWords64
Unexecuted instantiation: eccsi.c:writeUnalignedWords64
Unexecuted instantiation: ed25519.c:writeUnalignedWords64
Unexecuted instantiation: ed448.c:writeUnalignedWords64
Unexecuted instantiation: fe_448.c:writeUnalignedWords64
Unexecuted instantiation: fe_operations.c:writeUnalignedWords64
Unexecuted instantiation: ge_448.c:writeUnalignedWords64
Unexecuted instantiation: ge_operations.c:writeUnalignedWords64
Unexecuted instantiation: hash.c:writeUnalignedWords64
Unexecuted instantiation: hmac.c:writeUnalignedWords64
Unexecuted instantiation: kdf.c:writeUnalignedWords64
Unexecuted instantiation: md2.c:writeUnalignedWords64
Unexecuted instantiation: md4.c:writeUnalignedWords64
Unexecuted instantiation: md5.c:writeUnalignedWords64
Unexecuted instantiation: poly1305.c:writeUnalignedWords64
Unexecuted instantiation: pwdbased.c:writeUnalignedWords64
Unexecuted instantiation: random.c:writeUnalignedWords64
Unexecuted instantiation: ripemd.c:writeUnalignedWords64
Unexecuted instantiation: rsa.c:writeUnalignedWords64
Unexecuted instantiation: sha.c:writeUnalignedWords64
Unexecuted instantiation: sha256.c:writeUnalignedWords64
Unexecuted instantiation: sha3.c:writeUnalignedWords64
Unexecuted instantiation: sha512.c:writeUnalignedWords64
Unexecuted instantiation: siphash.c:writeUnalignedWords64
Unexecuted instantiation: sm2.c:writeUnalignedWords64
Unexecuted instantiation: sm3.c:writeUnalignedWords64
Unexecuted instantiation: sm4.c:writeUnalignedWords64
Unexecuted instantiation: sp_int.c:writeUnalignedWords64
Unexecuted instantiation: wc_encrypt.c:writeUnalignedWords64
Unexecuted instantiation: wolfmath.c:writeUnalignedWords64
Unexecuted instantiation: ssl.c:writeUnalignedWords64
Unexecuted instantiation: tls.c:writeUnalignedWords64
Unexecuted instantiation: tls13.c:writeUnalignedWords64
Unexecuted instantiation: internal.c:writeUnalignedWords64
329
330
WC_MISC_STATIC WC_INLINE word64 rotlFixed64(word64 x, word64 y)
331
12.6M
{
332
12.6M
    return (x << y) | (x >> (sizeof(y) * 8 - y));
333
12.6M
}
Unexecuted instantiation: aes.c:rotlFixed64
Unexecuted instantiation: asn.c:rotlFixed64
Unexecuted instantiation: camellia.c:rotlFixed64
Unexecuted instantiation: chacha.c:rotlFixed64
Unexecuted instantiation: chacha20_poly1305.c:rotlFixed64
Unexecuted instantiation: cmac.c:rotlFixed64
Unexecuted instantiation: coding.c:rotlFixed64
Unexecuted instantiation: curve25519.c:rotlFixed64
Unexecuted instantiation: curve448.c:rotlFixed64
Unexecuted instantiation: des3.c:rotlFixed64
Unexecuted instantiation: dh.c:rotlFixed64
Unexecuted instantiation: ecc.c:rotlFixed64
Unexecuted instantiation: eccsi.c:rotlFixed64
Unexecuted instantiation: ed25519.c:rotlFixed64
Unexecuted instantiation: ed448.c:rotlFixed64
Unexecuted instantiation: fe_448.c:rotlFixed64
Unexecuted instantiation: fe_operations.c:rotlFixed64
Unexecuted instantiation: ge_448.c:rotlFixed64
Unexecuted instantiation: ge_operations.c:rotlFixed64
Unexecuted instantiation: hash.c:rotlFixed64
Unexecuted instantiation: hmac.c:rotlFixed64
Unexecuted instantiation: kdf.c:rotlFixed64
Unexecuted instantiation: md2.c:rotlFixed64
Unexecuted instantiation: md4.c:rotlFixed64
Unexecuted instantiation: md5.c:rotlFixed64
Unexecuted instantiation: poly1305.c:rotlFixed64
Unexecuted instantiation: pwdbased.c:rotlFixed64
random.c:rotlFixed64
Line
Count
Source
331
783k
{
332
783k
    return (x << y) | (x >> (sizeof(y) * 8 - y));
333
783k
}
Unexecuted instantiation: ripemd.c:rotlFixed64
Unexecuted instantiation: rsa.c:rotlFixed64
Unexecuted instantiation: sha.c:rotlFixed64
Unexecuted instantiation: sha256.c:rotlFixed64
Unexecuted instantiation: sha3.c:rotlFixed64
sha512.c:rotlFixed64
Line
Count
Source
331
11.8M
{
332
11.8M
    return (x << y) | (x >> (sizeof(y) * 8 - y));
333
11.8M
}
Unexecuted instantiation: siphash.c:rotlFixed64
Unexecuted instantiation: sm2.c:rotlFixed64
Unexecuted instantiation: sm3.c:rotlFixed64
Unexecuted instantiation: sm4.c:rotlFixed64
Unexecuted instantiation: sp_int.c:rotlFixed64
Unexecuted instantiation: wc_encrypt.c:rotlFixed64
Unexecuted instantiation: wolfmath.c:rotlFixed64
Unexecuted instantiation: ssl.c:rotlFixed64
Unexecuted instantiation: tls.c:rotlFixed64
Unexecuted instantiation: tls13.c:rotlFixed64
Unexecuted instantiation: internal.c:rotlFixed64
334
335
336
WC_MISC_STATIC WC_INLINE word64 rotrFixed64(word64 x, word64 y)
337
523M
{
338
523M
    return (x >> y) | (x << (sizeof(y) * 8 - y));
339
523M
}
Unexecuted instantiation: aes.c:rotrFixed64
Unexecuted instantiation: asn.c:rotrFixed64
Unexecuted instantiation: camellia.c:rotrFixed64
Unexecuted instantiation: chacha.c:rotrFixed64
Unexecuted instantiation: chacha20_poly1305.c:rotrFixed64
Unexecuted instantiation: cmac.c:rotrFixed64
Unexecuted instantiation: coding.c:rotrFixed64
Unexecuted instantiation: curve25519.c:rotrFixed64
Unexecuted instantiation: curve448.c:rotrFixed64
Unexecuted instantiation: des3.c:rotrFixed64
Unexecuted instantiation: dh.c:rotrFixed64
Unexecuted instantiation: ecc.c:rotrFixed64
Unexecuted instantiation: eccsi.c:rotrFixed64
Unexecuted instantiation: ed25519.c:rotrFixed64
Unexecuted instantiation: ed448.c:rotrFixed64
Unexecuted instantiation: fe_448.c:rotrFixed64
Unexecuted instantiation: fe_operations.c:rotrFixed64
Unexecuted instantiation: ge_448.c:rotrFixed64
Unexecuted instantiation: ge_operations.c:rotrFixed64
Unexecuted instantiation: hash.c:rotrFixed64
Unexecuted instantiation: hmac.c:rotrFixed64
Unexecuted instantiation: kdf.c:rotrFixed64
Unexecuted instantiation: md2.c:rotrFixed64
Unexecuted instantiation: md4.c:rotrFixed64
Unexecuted instantiation: md5.c:rotrFixed64
Unexecuted instantiation: poly1305.c:rotrFixed64
Unexecuted instantiation: pwdbased.c:rotrFixed64
Unexecuted instantiation: random.c:rotrFixed64
Unexecuted instantiation: ripemd.c:rotrFixed64
Unexecuted instantiation: rsa.c:rotrFixed64
Unexecuted instantiation: sha.c:rotrFixed64
Unexecuted instantiation: sha256.c:rotrFixed64
Unexecuted instantiation: sha3.c:rotrFixed64
sha512.c:rotrFixed64
Line
Count
Source
337
523M
{
338
523M
    return (x >> y) | (x << (sizeof(y) * 8 - y));
339
523M
}
Unexecuted instantiation: siphash.c:rotrFixed64
Unexecuted instantiation: sm2.c:rotrFixed64
Unexecuted instantiation: sm3.c:rotrFixed64
Unexecuted instantiation: sm4.c:rotrFixed64
Unexecuted instantiation: sp_int.c:rotrFixed64
Unexecuted instantiation: wc_encrypt.c:rotrFixed64
Unexecuted instantiation: wolfmath.c:rotrFixed64
Unexecuted instantiation: ssl.c:rotrFixed64
Unexecuted instantiation: tls.c:rotrFixed64
Unexecuted instantiation: tls13.c:rotrFixed64
Unexecuted instantiation: internal.c:rotrFixed64
340
341
342
WC_MISC_STATIC WC_INLINE word64 ByteReverseWord64(word64 value)
343
12.6M
{
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
12.6M
    value = ((value & W64LIT(0xFF00FF00FF00FF00)) >> 8) |
351
12.6M
        ((value & W64LIT(0x00FF00FF00FF00FF)) << 8);
352
12.6M
    value = ((value & W64LIT(0xFFFF0000FFFF0000)) >> 16) |
353
12.6M
        ((value & W64LIT(0x0000FFFF0000FFFF)) << 16);
354
12.6M
    return rotlFixed64(value, 32U);
355
12.6M
#endif
356
12.6M
}
Unexecuted instantiation: aes.c:ByteReverseWord64
Unexecuted instantiation: asn.c:ByteReverseWord64
Unexecuted instantiation: camellia.c:ByteReverseWord64
Unexecuted instantiation: chacha.c:ByteReverseWord64
Unexecuted instantiation: chacha20_poly1305.c:ByteReverseWord64
Unexecuted instantiation: cmac.c:ByteReverseWord64
Unexecuted instantiation: coding.c:ByteReverseWord64
Unexecuted instantiation: curve25519.c:ByteReverseWord64
Unexecuted instantiation: curve448.c:ByteReverseWord64
Unexecuted instantiation: des3.c:ByteReverseWord64
Unexecuted instantiation: dh.c:ByteReverseWord64
Unexecuted instantiation: ecc.c:ByteReverseWord64
Unexecuted instantiation: eccsi.c:ByteReverseWord64
Unexecuted instantiation: ed25519.c:ByteReverseWord64
Unexecuted instantiation: ed448.c:ByteReverseWord64
Unexecuted instantiation: fe_448.c:ByteReverseWord64
Unexecuted instantiation: fe_operations.c:ByteReverseWord64
Unexecuted instantiation: ge_448.c:ByteReverseWord64
Unexecuted instantiation: ge_operations.c:ByteReverseWord64
Unexecuted instantiation: hash.c:ByteReverseWord64
Unexecuted instantiation: hmac.c:ByteReverseWord64
Unexecuted instantiation: kdf.c:ByteReverseWord64
Unexecuted instantiation: md2.c:ByteReverseWord64
Unexecuted instantiation: md4.c:ByteReverseWord64
Unexecuted instantiation: md5.c:ByteReverseWord64
Unexecuted instantiation: poly1305.c:ByteReverseWord64
Unexecuted instantiation: pwdbased.c:ByteReverseWord64
random.c:ByteReverseWord64
Line
Count
Source
343
783k
{
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
783k
    value = ((value & W64LIT(0xFF00FF00FF00FF00)) >> 8) |
351
783k
        ((value & W64LIT(0x00FF00FF00FF00FF)) << 8);
352
783k
    value = ((value & W64LIT(0xFFFF0000FFFF0000)) >> 16) |
353
783k
        ((value & W64LIT(0x0000FFFF0000FFFF)) << 16);
354
783k
    return rotlFixed64(value, 32U);
355
783k
#endif
356
783k
}
Unexecuted instantiation: ripemd.c:ByteReverseWord64
Unexecuted instantiation: rsa.c:ByteReverseWord64
Unexecuted instantiation: sha.c:ByteReverseWord64
Unexecuted instantiation: sha256.c:ByteReverseWord64
Unexecuted instantiation: sha3.c:ByteReverseWord64
sha512.c:ByteReverseWord64
Line
Count
Source
343
11.8M
{
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
11.8M
    value = ((value & W64LIT(0xFF00FF00FF00FF00)) >> 8) |
351
11.8M
        ((value & W64LIT(0x00FF00FF00FF00FF)) << 8);
352
11.8M
    value = ((value & W64LIT(0xFFFF0000FFFF0000)) >> 16) |
353
11.8M
        ((value & W64LIT(0x0000FFFF0000FFFF)) << 16);
354
11.8M
    return rotlFixed64(value, 32U);
355
11.8M
#endif
356
11.8M
}
Unexecuted instantiation: siphash.c:ByteReverseWord64
Unexecuted instantiation: sm2.c:ByteReverseWord64
Unexecuted instantiation: sm3.c:ByteReverseWord64
Unexecuted instantiation: sm4.c:ByteReverseWord64
Unexecuted instantiation: sp_int.c:ByteReverseWord64
Unexecuted instantiation: wc_encrypt.c:ByteReverseWord64
Unexecuted instantiation: wolfmath.c:ByteReverseWord64
Unexecuted instantiation: ssl.c:ByteReverseWord64
Unexecuted instantiation: tls.c:ByteReverseWord64
Unexecuted instantiation: tls13.c:ByteReverseWord64
Unexecuted instantiation: internal.c:ByteReverseWord64
357
358
359
WC_MISC_STATIC WC_INLINE void ByteReverseWords64(word64* out, const word64* in,
360
                                      word32 byteCount)
361
788k
{
362
788k
    word32 count = byteCount/(word32)sizeof(word64), i;
363
364
788k
#ifdef WOLFSSL_USE_ALIGN
365
788k
    if ((((size_t)in & 0x7) == 0) &&
366
788k
        (((size_t)out & 0x7) == 0))
367
788k
#endif
368
788k
    {
369
12.6M
        for (i = 0; i < count; i++)
370
11.8M
            out[i] = ByteReverseWord64(in[i]);
371
788k
    }
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
788k
#endif
409
788k
}
Unexecuted instantiation: aes.c:ByteReverseWords64
Unexecuted instantiation: asn.c:ByteReverseWords64
Unexecuted instantiation: camellia.c:ByteReverseWords64
Unexecuted instantiation: chacha.c:ByteReverseWords64
Unexecuted instantiation: chacha20_poly1305.c:ByteReverseWords64
Unexecuted instantiation: cmac.c:ByteReverseWords64
Unexecuted instantiation: coding.c:ByteReverseWords64
Unexecuted instantiation: curve25519.c:ByteReverseWords64
Unexecuted instantiation: curve448.c:ByteReverseWords64
Unexecuted instantiation: des3.c:ByteReverseWords64
Unexecuted instantiation: dh.c:ByteReverseWords64
Unexecuted instantiation: ecc.c:ByteReverseWords64
Unexecuted instantiation: eccsi.c:ByteReverseWords64
Unexecuted instantiation: ed25519.c:ByteReverseWords64
Unexecuted instantiation: ed448.c:ByteReverseWords64
Unexecuted instantiation: fe_448.c:ByteReverseWords64
Unexecuted instantiation: fe_operations.c:ByteReverseWords64
Unexecuted instantiation: ge_448.c:ByteReverseWords64
Unexecuted instantiation: ge_operations.c:ByteReverseWords64
Unexecuted instantiation: hash.c:ByteReverseWords64
Unexecuted instantiation: hmac.c:ByteReverseWords64
Unexecuted instantiation: kdf.c:ByteReverseWords64
Unexecuted instantiation: md2.c:ByteReverseWords64
Unexecuted instantiation: md4.c:ByteReverseWords64
Unexecuted instantiation: md5.c:ByteReverseWords64
Unexecuted instantiation: poly1305.c:ByteReverseWords64
Unexecuted instantiation: pwdbased.c:ByteReverseWords64
Unexecuted instantiation: random.c:ByteReverseWords64
Unexecuted instantiation: ripemd.c:ByteReverseWords64
Unexecuted instantiation: rsa.c:ByteReverseWords64
Unexecuted instantiation: sha.c:ByteReverseWords64
Unexecuted instantiation: sha256.c:ByteReverseWords64
Unexecuted instantiation: sha3.c:ByteReverseWords64
sha512.c:ByteReverseWords64
Line
Count
Source
361
788k
{
362
788k
    word32 count = byteCount/(word32)sizeof(word64), i;
363
364
788k
#ifdef WOLFSSL_USE_ALIGN
365
788k
    if ((((size_t)in & 0x7) == 0) &&
366
788k
        (((size_t)out & 0x7) == 0))
367
788k
#endif
368
788k
    {
369
12.6M
        for (i = 0; i < count; i++)
370
11.8M
            out[i] = ByteReverseWord64(in[i]);
371
788k
    }
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
788k
#endif
409
788k
}
Unexecuted instantiation: siphash.c:ByteReverseWords64
Unexecuted instantiation: sm2.c:ByteReverseWords64
Unexecuted instantiation: sm3.c:ByteReverseWords64
Unexecuted instantiation: sm4.c:ByteReverseWords64
Unexecuted instantiation: sp_int.c:ByteReverseWords64
Unexecuted instantiation: wc_encrypt.c:ByteReverseWords64
Unexecuted instantiation: wolfmath.c:ByteReverseWords64
Unexecuted instantiation: ssl.c:ByteReverseWords64
Unexecuted instantiation: tls.c:ByteReverseWords64
Unexecuted instantiation: tls13.c:ByteReverseWords64
Unexecuted instantiation: internal.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
29.1k
{
423
29.1k
    const wolfssl_word *e = *a + n;
424
425
66.6k
    while (*a < e)
426
37.4k
        *((*r)++) = *((*a)++) ^ *((*b)++);
427
29.1k
}
aes.c:XorWordsOut
Line
Count
Source
422
25.5k
{
423
25.5k
    const wolfssl_word *e = *a + n;
424
425
48.3k
    while (*a < e)
426
22.8k
        *((*r)++) = *((*a)++) ^ *((*b)++);
427
25.5k
}
Unexecuted instantiation: asn.c:XorWordsOut
Unexecuted instantiation: camellia.c:XorWordsOut
chacha.c:XorWordsOut
Line
Count
Source
422
3.65k
{
423
3.65k
    const wolfssl_word *e = *a + n;
424
425
18.2k
    while (*a < e)
426
14.6k
        *((*r)++) = *((*a)++) ^ *((*b)++);
427
3.65k
}
Unexecuted instantiation: chacha20_poly1305.c:XorWordsOut
Unexecuted instantiation: cmac.c:XorWordsOut
Unexecuted instantiation: coding.c:XorWordsOut
Unexecuted instantiation: curve25519.c:XorWordsOut
Unexecuted instantiation: curve448.c:XorWordsOut
Unexecuted instantiation: des3.c:XorWordsOut
Unexecuted instantiation: dh.c:XorWordsOut
Unexecuted instantiation: ecc.c:XorWordsOut
Unexecuted instantiation: eccsi.c:XorWordsOut
Unexecuted instantiation: ed25519.c:XorWordsOut
Unexecuted instantiation: ed448.c:XorWordsOut
Unexecuted instantiation: fe_448.c:XorWordsOut
Unexecuted instantiation: fe_operations.c:XorWordsOut
Unexecuted instantiation: ge_448.c:XorWordsOut
Unexecuted instantiation: ge_operations.c:XorWordsOut
Unexecuted instantiation: hash.c:XorWordsOut
Unexecuted instantiation: hmac.c:XorWordsOut
Unexecuted instantiation: kdf.c:XorWordsOut
Unexecuted instantiation: md2.c:XorWordsOut
Unexecuted instantiation: md4.c:XorWordsOut
Unexecuted instantiation: md5.c:XorWordsOut
Unexecuted instantiation: poly1305.c:XorWordsOut
Unexecuted instantiation: pwdbased.c:XorWordsOut
Unexecuted instantiation: random.c:XorWordsOut
Unexecuted instantiation: ripemd.c:XorWordsOut
Unexecuted instantiation: rsa.c:XorWordsOut
Unexecuted instantiation: sha.c:XorWordsOut
Unexecuted instantiation: sha256.c:XorWordsOut
Unexecuted instantiation: sha3.c:XorWordsOut
Unexecuted instantiation: sha512.c:XorWordsOut
Unexecuted instantiation: siphash.c:XorWordsOut
Unexecuted instantiation: sm2.c:XorWordsOut
Unexecuted instantiation: sm3.c:XorWordsOut
Unexecuted instantiation: sm4.c:XorWordsOut
Unexecuted instantiation: sp_int.c:XorWordsOut
Unexecuted instantiation: wc_encrypt.c:XorWordsOut
Unexecuted instantiation: wolfmath.c:XorWordsOut
Unexecuted instantiation: ssl.c:XorWordsOut
Unexecuted instantiation: tls.c:XorWordsOut
Unexecuted instantiation: tls13.c:XorWordsOut
Unexecuted instantiation: internal.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
86.6k
{
435
86.6k
    byte*       o = (byte*)out;
436
86.6k
    const byte* b = (const byte*)buf;
437
86.6k
    const byte* m = (const byte*)mask;
438
439
    /* type-punning helpers */
440
86.6k
    union {
441
86.6k
        byte* bp;
442
86.6k
        wolfssl_word* wp;
443
86.6k
    } tpo;
444
86.6k
    union {
445
86.6k
        const byte* bp;
446
86.6k
        const wolfssl_word* wp;
447
86.6k
    } tpb, tpm;
448
449
86.6k
    if (((((wc_ptr_t)o) & (WOLFSSL_WORD_SIZE - 1)) == 0) &&
450
86.6k
        ((((wc_ptr_t)b) & (WOLFSSL_WORD_SIZE - 1)) == 0) &&
451
86.6k
        ((((wc_ptr_t)m) & (WOLFSSL_WORD_SIZE - 1)) == 0))
452
16.9k
    {
453
        /* All buffers are already aligned.  Possible to XOR by words without
454
         * fixup.
455
         */
456
457
16.9k
        tpo.bp = o;
458
16.9k
        tpb.bp = b;
459
16.9k
        tpm.bp = m;
460
16.9k
        XorWordsOut(&tpo.wp, &tpb.wp, &tpm.wp, count >> WOLFSSL_WORD_SIZE_LOG2);
461
16.9k
        o = tpo.bp;
462
16.9k
        b = tpb.bp;
463
16.9k
        m = tpm.bp;
464
16.9k
        count &= (WOLFSSL_WORD_SIZE - 1);
465
16.9k
    }
466
69.7k
    else if ((((wc_ptr_t)o) & (WOLFSSL_WORD_SIZE - 1)) ==
467
69.7k
             (((wc_ptr_t)b) & (WOLFSSL_WORD_SIZE - 1)) &&
468
69.7k
             (((wc_ptr_t)b) & (WOLFSSL_WORD_SIZE - 1)) ==
469
21.3k
             (((wc_ptr_t)m) & (WOLFSSL_WORD_SIZE - 1)))
470
12.2k
    {
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
17.2k
        while ((((wc_ptr_t)b & (WOLFSSL_WORD_SIZE - 1)) != 0) && (count > 0))
477
5.00k
        {
478
5.00k
            *o++ = (byte)(*b++ ^ *m++);
479
5.00k
            count--;
480
5.00k
        }
481
482
12.2k
        tpo.bp = o;
483
12.2k
        tpb.bp = b;
484
12.2k
        tpm.bp = m;
485
12.2k
        XorWordsOut(&tpo.wp, &tpb.wp, &tpm.wp, count >> WOLFSSL_WORD_SIZE_LOG2);
486
12.2k
        o = tpo.bp;
487
12.2k
        b = tpb.bp;
488
12.2k
        m = tpm.bp;
489
12.2k
        count &= (WOLFSSL_WORD_SIZE - 1);
490
12.2k
    }
491
492
1.40M
    while (count > 0) {
493
1.31M
        *o++ = (byte)(*b++ ^ *m++);
494
1.31M
        count--;
495
1.31M
    }
496
497
86.6k
}
aes.c:xorbufout
Line
Count
Source
434
73.9k
{
435
73.9k
    byte*       o = (byte*)out;
436
73.9k
    const byte* b = (const byte*)buf;
437
73.9k
    const byte* m = (const byte*)mask;
438
439
    /* type-punning helpers */
440
73.9k
    union {
441
73.9k
        byte* bp;
442
73.9k
        wolfssl_word* wp;
443
73.9k
    } tpo;
444
73.9k
    union {
445
73.9k
        const byte* bp;
446
73.9k
        const wolfssl_word* wp;
447
73.9k
    } tpb, tpm;
448
449
73.9k
    if (((((wc_ptr_t)o) & (WOLFSSL_WORD_SIZE - 1)) == 0) &&
450
73.9k
        ((((wc_ptr_t)b) & (WOLFSSL_WORD_SIZE - 1)) == 0) &&
451
73.9k
        ((((wc_ptr_t)m) & (WOLFSSL_WORD_SIZE - 1)) == 0))
452
13.2k
    {
453
        /* All buffers are already aligned.  Possible to XOR by words without
454
         * fixup.
455
         */
456
457
13.2k
        tpo.bp = o;
458
13.2k
        tpb.bp = b;
459
13.2k
        tpm.bp = m;
460
13.2k
        XorWordsOut(&tpo.wp, &tpb.wp, &tpm.wp, count >> WOLFSSL_WORD_SIZE_LOG2);
461
13.2k
        o = tpo.bp;
462
13.2k
        b = tpb.bp;
463
13.2k
        m = tpm.bp;
464
13.2k
        count &= (WOLFSSL_WORD_SIZE - 1);
465
13.2k
    }
466
60.6k
    else if ((((wc_ptr_t)o) & (WOLFSSL_WORD_SIZE - 1)) ==
467
60.6k
             (((wc_ptr_t)b) & (WOLFSSL_WORD_SIZE - 1)) &&
468
60.6k
             (((wc_ptr_t)b) & (WOLFSSL_WORD_SIZE - 1)) ==
469
12.2k
             (((wc_ptr_t)m) & (WOLFSSL_WORD_SIZE - 1)))
470
12.2k
    {
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
17.2k
        while ((((wc_ptr_t)b & (WOLFSSL_WORD_SIZE - 1)) != 0) && (count > 0))
477
5.00k
        {
478
5.00k
            *o++ = (byte)(*b++ ^ *m++);
479
5.00k
            count--;
480
5.00k
        }
481
482
12.2k
        tpo.bp = o;
483
12.2k
        tpb.bp = b;
484
12.2k
        tpm.bp = m;
485
12.2k
        XorWordsOut(&tpo.wp, &tpb.wp, &tpm.wp, count >> WOLFSSL_WORD_SIZE_LOG2);
486
12.2k
        o = tpo.bp;
487
12.2k
        b = tpb.bp;
488
12.2k
        m = tpm.bp;
489
12.2k
        count &= (WOLFSSL_WORD_SIZE - 1);
490
12.2k
    }
491
492
848k
    while (count > 0) {
493
774k
        *o++ = (byte)(*b++ ^ *m++);
494
774k
        count--;
495
774k
    }
496
497
73.9k
}
Unexecuted instantiation: asn.c:xorbufout
Unexecuted instantiation: camellia.c:xorbufout
chacha.c:xorbufout
Line
Count
Source
434
12.6k
{
435
12.6k
    byte*       o = (byte*)out;
436
12.6k
    const byte* b = (const byte*)buf;
437
12.6k
    const byte* m = (const byte*)mask;
438
439
    /* type-punning helpers */
440
12.6k
    union {
441
12.6k
        byte* bp;
442
12.6k
        wolfssl_word* wp;
443
12.6k
    } tpo;
444
12.6k
    union {
445
12.6k
        const byte* bp;
446
12.6k
        const wolfssl_word* wp;
447
12.6k
    } tpb, tpm;
448
449
12.6k
    if (((((wc_ptr_t)o) & (WOLFSSL_WORD_SIZE - 1)) == 0) &&
450
12.6k
        ((((wc_ptr_t)b) & (WOLFSSL_WORD_SIZE - 1)) == 0) &&
451
12.6k
        ((((wc_ptr_t)m) & (WOLFSSL_WORD_SIZE - 1)) == 0))
452
3.65k
    {
453
        /* All buffers are already aligned.  Possible to XOR by words without
454
         * fixup.
455
         */
456
457
3.65k
        tpo.bp = o;
458
3.65k
        tpb.bp = b;
459
3.65k
        tpm.bp = m;
460
3.65k
        XorWordsOut(&tpo.wp, &tpb.wp, &tpm.wp, count >> WOLFSSL_WORD_SIZE_LOG2);
461
3.65k
        o = tpo.bp;
462
3.65k
        b = tpb.bp;
463
3.65k
        m = tpm.bp;
464
3.65k
        count &= (WOLFSSL_WORD_SIZE - 1);
465
3.65k
    }
466
9.04k
    else if ((((wc_ptr_t)o) & (WOLFSSL_WORD_SIZE - 1)) ==
467
9.04k
             (((wc_ptr_t)b) & (WOLFSSL_WORD_SIZE - 1)) &&
468
9.04k
             (((wc_ptr_t)b) & (WOLFSSL_WORD_SIZE - 1)) ==
469
9.04k
             (((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
556k
    while (count > 0) {
493
543k
        *o++ = (byte)(*b++ ^ *m++);
494
543k
        count--;
495
543k
    }
496
497
12.6k
}
Unexecuted instantiation: chacha20_poly1305.c:xorbufout
Unexecuted instantiation: cmac.c:xorbufout
Unexecuted instantiation: coding.c:xorbufout
Unexecuted instantiation: curve25519.c:xorbufout
Unexecuted instantiation: curve448.c:xorbufout
Unexecuted instantiation: des3.c:xorbufout
Unexecuted instantiation: dh.c:xorbufout
Unexecuted instantiation: ecc.c:xorbufout
Unexecuted instantiation: eccsi.c:xorbufout
Unexecuted instantiation: ed25519.c:xorbufout
Unexecuted instantiation: ed448.c:xorbufout
Unexecuted instantiation: fe_448.c:xorbufout
Unexecuted instantiation: fe_operations.c:xorbufout
Unexecuted instantiation: ge_448.c:xorbufout
Unexecuted instantiation: ge_operations.c:xorbufout
Unexecuted instantiation: hash.c:xorbufout
Unexecuted instantiation: hmac.c:xorbufout
Unexecuted instantiation: kdf.c:xorbufout
Unexecuted instantiation: md2.c:xorbufout
Unexecuted instantiation: md4.c:xorbufout
Unexecuted instantiation: md5.c:xorbufout
Unexecuted instantiation: poly1305.c:xorbufout
Unexecuted instantiation: pwdbased.c:xorbufout
Unexecuted instantiation: random.c:xorbufout
Unexecuted instantiation: ripemd.c:xorbufout
Unexecuted instantiation: rsa.c:xorbufout
Unexecuted instantiation: sha.c:xorbufout
Unexecuted instantiation: sha256.c:xorbufout
Unexecuted instantiation: sha3.c:xorbufout
Unexecuted instantiation: sha512.c:xorbufout
Unexecuted instantiation: siphash.c:xorbufout
Unexecuted instantiation: sm2.c:xorbufout
Unexecuted instantiation: sm3.c:xorbufout
Unexecuted instantiation: sm4.c:xorbufout
Unexecuted instantiation: sp_int.c:xorbufout
Unexecuted instantiation: wc_encrypt.c:xorbufout
Unexecuted instantiation: wolfmath.c:xorbufout
Unexecuted instantiation: ssl.c:xorbufout
Unexecuted instantiation: tls.c:xorbufout
Unexecuted instantiation: tls13.c:xorbufout
Unexecuted instantiation: internal.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
112k
{
504
112k
    const wolfssl_word *e = *a + n;
505
506
355k
    while (*a < e)
507
242k
        *((*r)++) ^= *((*a)++);
508
112k
}
aes.c:XorWords
Line
Count
Source
503
95.0k
{
504
95.0k
    const wolfssl_word *e = *a + n;
505
506
285k
    while (*a < e)
507
190k
        *((*r)++) ^= *((*a)++);
508
95.0k
}
Unexecuted instantiation: asn.c:XorWords
Unexecuted instantiation: camellia.c:XorWords
Unexecuted instantiation: chacha.c:XorWords
Unexecuted instantiation: chacha20_poly1305.c:XorWords
cmac.c:XorWords
Line
Count
Source
503
1.80k
{
504
1.80k
    const wolfssl_word *e = *a + n;
505
506
5.42k
    while (*a < e)
507
3.61k
        *((*r)++) ^= *((*a)++);
508
1.80k
}
Unexecuted instantiation: coding.c:XorWords
Unexecuted instantiation: curve25519.c:XorWords
Unexecuted instantiation: curve448.c:XorWords
des3.c:XorWords
Line
Count
Source
503
2.18k
{
504
2.18k
    const wolfssl_word *e = *a + n;
505
506
4.37k
    while (*a < e)
507
2.18k
        *((*r)++) ^= *((*a)++);
508
2.18k
}
Unexecuted instantiation: dh.c:XorWords
Unexecuted instantiation: ecc.c:XorWords
Unexecuted instantiation: eccsi.c:XorWords
Unexecuted instantiation: ed25519.c:XorWords
Unexecuted instantiation: ed448.c:XorWords
Unexecuted instantiation: fe_448.c:XorWords
Unexecuted instantiation: fe_operations.c:XorWords
Unexecuted instantiation: ge_448.c:XorWords
Unexecuted instantiation: ge_operations.c:XorWords
Unexecuted instantiation: hash.c:XorWords
Unexecuted instantiation: hmac.c:XorWords
kdf.c:XorWords
Line
Count
Source
503
115
{
504
115
    const wolfssl_word *e = *a + n;
505
506
2.05k
    while (*a < e)
507
1.94k
        *((*r)++) ^= *((*a)++);
508
115
}
Unexecuted instantiation: md2.c:XorWords
Unexecuted instantiation: md4.c:XorWords
Unexecuted instantiation: md5.c:XorWords
Unexecuted instantiation: poly1305.c:XorWords
pwdbased.c:XorWords
Line
Count
Source
503
10.1k
{
504
10.1k
    const wolfssl_word *e = *a + n;
505
506
48.9k
    while (*a < e)
507
38.7k
        *((*r)++) ^= *((*a)++);
508
10.1k
}
Unexecuted instantiation: random.c:XorWords
Unexecuted instantiation: ripemd.c:XorWords
rsa.c:XorWords
Line
Count
Source
503
1.26k
{
504
1.26k
    const wolfssl_word *e = *a + n;
505
506
6.66k
    while (*a < e)
507
5.39k
        *((*r)++) ^= *((*a)++);
508
1.26k
}
Unexecuted instantiation: sha.c:XorWords
Unexecuted instantiation: sha256.c:XorWords
Unexecuted instantiation: sha3.c:XorWords
Unexecuted instantiation: sha512.c:XorWords
Unexecuted instantiation: siphash.c:XorWords
Unexecuted instantiation: sm2.c:XorWords
Unexecuted instantiation: sm3.c:XorWords
Unexecuted instantiation: sm4.c:XorWords
Unexecuted instantiation: sp_int.c:XorWords
Unexecuted instantiation: wc_encrypt.c:XorWords
Unexecuted instantiation: wolfmath.c:XorWords
Unexecuted instantiation: ssl.c:XorWords
Unexecuted instantiation: tls.c:XorWords
tls13.c:XorWords
Line
Count
Source
503
2.07k
{
504
2.07k
    const wolfssl_word *e = *a + n;
505
506
2.07k
    while (*a < e)
507
0
        *((*r)++) ^= *((*a)++);
508
2.07k
}
internal.c:XorWords
Line
Count
Source
503
252
{
504
252
    const wolfssl_word *e = *a + n;
505
506
504
    while (*a < e)
507
252
        *((*r)++) ^= *((*a)++);
508
252
}
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
242k
{
515
242k
    byte*       b = (byte*)buf;
516
242k
    const byte* m = (const byte*)mask;
517
518
    /* type-punning helpers */
519
242k
    union {
520
242k
        byte* bp;
521
242k
        wolfssl_word* wp;
522
242k
    } tpb;
523
242k
    union {
524
242k
        const byte* bp;
525
242k
        const wolfssl_word* wp;
526
242k
    } tpm;
527
528
242k
    if ((((wc_ptr_t)buf & (WOLFSSL_WORD_SIZE - 1)) == 0) &&
529
242k
        (((wc_ptr_t)mask & (WOLFSSL_WORD_SIZE - 1)) == 0))
530
110k
    {
531
        /* Both buffers are already aligned.  Possible to XOR by words without
532
         * fixup.
533
         */
534
535
110k
        tpb.bp = b;
536
110k
        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
110k
        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
110k
        b = tpb.bp;
547
110k
        m = tpm.bp;
548
110k
        count &= (WOLFSSL_WORD_SIZE - 1);
549
110k
    }
550
132k
    else if (((wc_ptr_t)buf & (WOLFSSL_WORD_SIZE - 1)) ==
551
132k
             ((wc_ptr_t)mask & (WOLFSSL_WORD_SIZE - 1)))
552
2.83k
    {
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
12.6k
        while ((((wc_ptr_t)b & (WOLFSSL_WORD_SIZE - 1)) != 0) && (count > 0))
559
9.82k
        {
560
9.82k
            *(b++) ^= *(m++);
561
9.82k
            count--;
562
9.82k
        }
563
564
2.83k
        tpb.bp = b;
565
2.83k
        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
2.83k
        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
2.83k
        b = tpb.bp;
576
2.83k
        m = tpm.bp;
577
2.83k
        count &= (WOLFSSL_WORD_SIZE - 1);
578
2.83k
    }
579
580
2.38M
    while (count > 0) {
581
2.14M
        *b++ ^= *m++;
582
2.14M
        count--;
583
2.14M
    }
584
242k
}
aes.c:xorbuf
Line
Count
Source
514
217k
{
515
217k
    byte*       b = (byte*)buf;
516
217k
    const byte* m = (const byte*)mask;
517
518
    /* type-punning helpers */
519
217k
    union {
520
217k
        byte* bp;
521
217k
        wolfssl_word* wp;
522
217k
    } tpb;
523
217k
    union {
524
217k
        const byte* bp;
525
217k
        const wolfssl_word* wp;
526
217k
    } tpm;
527
528
217k
    if ((((wc_ptr_t)buf & (WOLFSSL_WORD_SIZE - 1)) == 0) &&
529
217k
        (((wc_ptr_t)mask & (WOLFSSL_WORD_SIZE - 1)) == 0))
530
95.0k
    {
531
        /* Both buffers are already aligned.  Possible to XOR by words without
532
         * fixup.
533
         */
534
535
95.0k
        tpb.bp = b;
536
95.0k
        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
95.0k
        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
95.0k
        b = tpb.bp;
547
95.0k
        m = tpm.bp;
548
95.0k
        count &= (WOLFSSL_WORD_SIZE - 1);
549
95.0k
    }
550
122k
    else if (((wc_ptr_t)buf & (WOLFSSL_WORD_SIZE - 1)) ==
551
122k
             ((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
2.16M
    while (count > 0) {
581
1.94M
        *b++ ^= *m++;
582
1.94M
        count--;
583
1.94M
    }
584
217k
}
Unexecuted instantiation: asn.c:xorbuf
Unexecuted instantiation: camellia.c:xorbuf
Unexecuted instantiation: chacha.c:xorbuf
Unexecuted instantiation: chacha20_poly1305.c:xorbuf
cmac.c:xorbuf
Line
Count
Source
514
1.80k
{
515
1.80k
    byte*       b = (byte*)buf;
516
1.80k
    const byte* m = (const byte*)mask;
517
518
    /* type-punning helpers */
519
1.80k
    union {
520
1.80k
        byte* bp;
521
1.80k
        wolfssl_word* wp;
522
1.80k
    } tpb;
523
1.80k
    union {
524
1.80k
        const byte* bp;
525
1.80k
        const wolfssl_word* wp;
526
1.80k
    } tpm;
527
528
1.80k
    if ((((wc_ptr_t)buf & (WOLFSSL_WORD_SIZE - 1)) == 0) &&
529
1.80k
        (((wc_ptr_t)mask & (WOLFSSL_WORD_SIZE - 1)) == 0))
530
1.80k
    {
531
        /* Both buffers are already aligned.  Possible to XOR by words without
532
         * fixup.
533
         */
534
535
1.80k
        tpb.bp = b;
536
1.80k
        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
1.80k
        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
1.80k
        b = tpb.bp;
547
1.80k
        m = tpm.bp;
548
1.80k
        count &= (WOLFSSL_WORD_SIZE - 1);
549
1.80k
    }
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
1.80k
    while (count > 0) {
581
0
        *b++ ^= *m++;
582
0
        count--;
583
0
    }
584
1.80k
}
Unexecuted instantiation: coding.c:xorbuf
Unexecuted instantiation: curve25519.c:xorbuf
Unexecuted instantiation: curve448.c:xorbuf
des3.c:xorbuf
Line
Count
Source
514
2.18k
{
515
2.18k
    byte*       b = (byte*)buf;
516
2.18k
    const byte* m = (const byte*)mask;
517
518
    /* type-punning helpers */
519
2.18k
    union {
520
2.18k
        byte* bp;
521
2.18k
        wolfssl_word* wp;
522
2.18k
    } tpb;
523
2.18k
    union {
524
2.18k
        const byte* bp;
525
2.18k
        const wolfssl_word* wp;
526
2.18k
    } tpm;
527
528
2.18k
    if ((((wc_ptr_t)buf & (WOLFSSL_WORD_SIZE - 1)) == 0) &&
529
2.18k
        (((wc_ptr_t)mask & (WOLFSSL_WORD_SIZE - 1)) == 0))
530
2.18k
    {
531
        /* Both buffers are already aligned.  Possible to XOR by words without
532
         * fixup.
533
         */
534
535
2.18k
        tpb.bp = b;
536
2.18k
        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
2.18k
        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
2.18k
        b = tpb.bp;
547
2.18k
        m = tpm.bp;
548
2.18k
        count &= (WOLFSSL_WORD_SIZE - 1);
549
2.18k
    }
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
2.18k
    while (count > 0) {
581
0
        *b++ ^= *m++;
582
0
        count--;
583
0
    }
584
2.18k
}
Unexecuted instantiation: dh.c:xorbuf
Unexecuted instantiation: ecc.c:xorbuf
Unexecuted instantiation: eccsi.c:xorbuf
Unexecuted instantiation: ed25519.c:xorbuf
Unexecuted instantiation: ed448.c:xorbuf
Unexecuted instantiation: fe_448.c:xorbuf
Unexecuted instantiation: fe_operations.c:xorbuf
Unexecuted instantiation: ge_448.c:xorbuf
Unexecuted instantiation: ge_operations.c:xorbuf
Unexecuted instantiation: hash.c:xorbuf
Unexecuted instantiation: hmac.c:xorbuf
kdf.c:xorbuf
Line
Count
Source
514
241
{
515
241
    byte*       b = (byte*)buf;
516
241
    const byte* m = (const byte*)mask;
517
518
    /* type-punning helpers */
519
241
    union {
520
241
        byte* bp;
521
241
        wolfssl_word* wp;
522
241
    } tpb;
523
241
    union {
524
241
        const byte* bp;
525
241
        const wolfssl_word* wp;
526
241
    } tpm;
527
528
241
    if ((((wc_ptr_t)buf & (WOLFSSL_WORD_SIZE - 1)) == 0) &&
529
241
        (((wc_ptr_t)mask & (WOLFSSL_WORD_SIZE - 1)) == 0))
530
115
    {
531
        /* Both buffers are already aligned.  Possible to XOR by words without
532
         * fixup.
533
         */
534
535
115
        tpb.bp = b;
536
115
        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
115
        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
115
        b = tpb.bp;
547
115
        m = tpm.bp;
548
115
        count &= (WOLFSSL_WORD_SIZE - 1);
549
115
    }
550
126
    else if (((wc_ptr_t)buf & (WOLFSSL_WORD_SIZE - 1)) ==
551
126
             ((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
5.73k
    while (count > 0) {
581
5.49k
        *b++ ^= *m++;
582
5.49k
        count--;
583
5.49k
    }
584
241
}
Unexecuted instantiation: md2.c:xorbuf
Unexecuted instantiation: md4.c:xorbuf
Unexecuted instantiation: md5.c:xorbuf
Unexecuted instantiation: poly1305.c:xorbuf
pwdbased.c:xorbuf
Line
Count
Source
514
11.2k
{
515
11.2k
    byte*       b = (byte*)buf;
516
11.2k
    const byte* m = (const byte*)mask;
517
518
    /* type-punning helpers */
519
11.2k
    union {
520
11.2k
        byte* bp;
521
11.2k
        wolfssl_word* wp;
522
11.2k
    } tpb;
523
11.2k
    union {
524
11.2k
        const byte* bp;
525
11.2k
        const wolfssl_word* wp;
526
11.2k
    } tpm;
527
528
11.2k
    if ((((wc_ptr_t)buf & (WOLFSSL_WORD_SIZE - 1)) == 0) &&
529
11.2k
        (((wc_ptr_t)mask & (WOLFSSL_WORD_SIZE - 1)) == 0))
530
10.1k
    {
531
        /* Both buffers are already aligned.  Possible to XOR by words without
532
         * fixup.
533
         */
534
535
10.1k
        tpb.bp = b;
536
10.1k
        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
10.1k
        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
10.1k
        b = tpb.bp;
547
10.1k
        m = tpm.bp;
548
10.1k
        count &= (WOLFSSL_WORD_SIZE - 1);
549
10.1k
    }
550
1.07k
    else if (((wc_ptr_t)buf & (WOLFSSL_WORD_SIZE - 1)) ==
551
1.07k
             ((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
40.7k
    while (count > 0) {
581
29.5k
        *b++ ^= *m++;
582
29.5k
        count--;
583
29.5k
    }
584
11.2k
}
Unexecuted instantiation: random.c:xorbuf
Unexecuted instantiation: ripemd.c:xorbuf
rsa.c:xorbuf
Line
Count
Source
514
2.58k
{
515
2.58k
    byte*       b = (byte*)buf;
516
2.58k
    const byte* m = (const byte*)mask;
517
518
    /* type-punning helpers */
519
2.58k
    union {
520
2.58k
        byte* bp;
521
2.58k
        wolfssl_word* wp;
522
2.58k
    } tpb;
523
2.58k
    union {
524
2.58k
        const byte* bp;
525
2.58k
        const wolfssl_word* wp;
526
2.58k
    } tpm;
527
528
2.58k
    if ((((wc_ptr_t)buf & (WOLFSSL_WORD_SIZE - 1)) == 0) &&
529
2.58k
        (((wc_ptr_t)mask & (WOLFSSL_WORD_SIZE - 1)) == 0))
530
506
    {
531
        /* Both buffers are already aligned.  Possible to XOR by words without
532
         * fixup.
533
         */
534
535
506
        tpb.bp = b;
536
506
        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
506
        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
506
        b = tpb.bp;
547
506
        m = tpm.bp;
548
506
        count &= (WOLFSSL_WORD_SIZE - 1);
549
506
    }
550
2.07k
    else if (((wc_ptr_t)buf & (WOLFSSL_WORD_SIZE - 1)) ==
551
2.07k
             ((wc_ptr_t)mask & (WOLFSSL_WORD_SIZE - 1)))
552
763
    {
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
2.29k
        while ((((wc_ptr_t)b & (WOLFSSL_WORD_SIZE - 1)) != 0) && (count > 0))
559
1.53k
        {
560
1.53k
            *(b++) ^= *(m++);
561
1.53k
            count--;
562
1.53k
        }
563
564
763
        tpb.bp = b;
565
763
        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
763
        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
763
        b = tpb.bp;
576
763
        m = tpm.bp;
577
763
        count &= (WOLFSSL_WORD_SIZE - 1);
578
763
    }
579
580
111k
    while (count > 0) {
581
108k
        *b++ ^= *m++;
582
108k
        count--;
583
108k
    }
584
2.58k
}
Unexecuted instantiation: sha.c:xorbuf
Unexecuted instantiation: sha256.c:xorbuf
Unexecuted instantiation: sha3.c:xorbuf
Unexecuted instantiation: sha512.c:xorbuf
Unexecuted instantiation: siphash.c:xorbuf
Unexecuted instantiation: sm2.c:xorbuf
Unexecuted instantiation: sm3.c:xorbuf
Unexecuted instantiation: sm4.c:xorbuf
Unexecuted instantiation: sp_int.c:xorbuf
Unexecuted instantiation: wc_encrypt.c:xorbuf
Unexecuted instantiation: wolfmath.c:xorbuf
Unexecuted instantiation: ssl.c:xorbuf
Unexecuted instantiation: tls.c:xorbuf
tls13.c:xorbuf
Line
Count
Source
514
7.39k
{
515
7.39k
    byte*       b = (byte*)buf;
516
7.39k
    const byte* m = (const byte*)mask;
517
518
    /* type-punning helpers */
519
7.39k
    union {
520
7.39k
        byte* bp;
521
7.39k
        wolfssl_word* wp;
522
7.39k
    } tpb;
523
7.39k
    union {
524
7.39k
        const byte* bp;
525
7.39k
        const wolfssl_word* wp;
526
7.39k
    } tpm;
527
528
7.39k
    if ((((wc_ptr_t)buf & (WOLFSSL_WORD_SIZE - 1)) == 0) &&
529
7.39k
        (((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
7.39k
    else if (((wc_ptr_t)buf & (WOLFSSL_WORD_SIZE - 1)) ==
551
7.39k
             ((wc_ptr_t)mask & (WOLFSSL_WORD_SIZE - 1)))
552
2.07k
    {
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
10.3k
        while ((((wc_ptr_t)b & (WOLFSSL_WORD_SIZE - 1)) != 0) && (count > 0))
559
8.29k
        {
560
8.29k
            *(b++) ^= *(m++);
561
8.29k
            count--;
562
8.29k
        }
563
564
2.07k
        tpb.bp = b;
565
2.07k
        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
2.07k
        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
2.07k
        b = tpb.bp;
576
2.07k
        m = tpm.bp;
577
2.07k
        count &= (WOLFSSL_WORD_SIZE - 1);
578
2.07k
    }
579
580
58.2k
    while (count > 0) {
581
50.8k
        *b++ ^= *m++;
582
50.8k
        count--;
583
50.8k
    }
584
7.39k
}
internal.c:xorbuf
Line
Count
Source
514
312
{
515
312
    byte*       b = (byte*)buf;
516
312
    const byte* m = (const byte*)mask;
517
518
    /* type-punning helpers */
519
312
    union {
520
312
        byte* bp;
521
312
        wolfssl_word* wp;
522
312
    } tpb;
523
312
    union {
524
312
        const byte* bp;
525
312
        const wolfssl_word* wp;
526
312
    } tpm;
527
528
312
    if ((((wc_ptr_t)buf & (WOLFSSL_WORD_SIZE - 1)) == 0) &&
529
312
        (((wc_ptr_t)mask & (WOLFSSL_WORD_SIZE - 1)) == 0))
530
252
    {
531
        /* Both buffers are already aligned.  Possible to XOR by words without
532
         * fixup.
533
         */
534
535
252
        tpb.bp = b;
536
252
        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
252
        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
252
        b = tpb.bp;
547
252
        m = tpm.bp;
548
252
        count &= (WOLFSSL_WORD_SIZE - 1);
549
252
    }
550
60
    else if (((wc_ptr_t)buf & (WOLFSSL_WORD_SIZE - 1)) ==
551
60
             ((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
2.04k
    while (count > 0) {
581
1.72k
        *b++ ^= *m++;
582
1.72k
        count--;
583
1.72k
    }
584
312
}
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
16.8M
{
593
16.8M
    volatile byte* z = (volatile byte*)mem;
594
595
16.8M
#if (defined(WOLFSSL_X86_64_BUILD) || defined(WOLFSSL_AARCH64_BUILD)) \
596
16.8M
            && defined(WORD64_AVAILABLE)
597
16.8M
    volatile word64* w;
598
16.8M
    #ifndef WOLFSSL_UNALIGNED_64BIT_ACCESS
599
16.8M
        word32 l = (sizeof(word64) - ((size_t)z & (sizeof(word64)-1))) &
600
16.8M
                                                             (sizeof(word64)-1);
601
602
16.8M
        if (len < l) l = len;
603
16.8M
        len -= l;
604
18.0M
        while (l--) *z++ = 0;
605
16.8M
    #endif
606
16.8M
        for (w = (volatile word64*)z;
607
468M
             len >= sizeof(*w);
608
451M
             len -= (word32)sizeof(*w))
609
451M
        {
610
451M
            *w++ = 0;
611
451M
        }
612
16.8M
    z = (volatile byte*)w;
613
16.8M
#endif
614
615
25.3M
    while (len--) *z++ = 0;
616
16.8M
}
aes.c:ForceZero
Line
Count
Source
592
43.4k
{
593
43.4k
    volatile byte* z = (volatile byte*)mem;
594
595
43.4k
#if (defined(WOLFSSL_X86_64_BUILD) || defined(WOLFSSL_AARCH64_BUILD)) \
596
43.4k
            && defined(WORD64_AVAILABLE)
597
43.4k
    volatile word64* w;
598
43.4k
    #ifndef WOLFSSL_UNALIGNED_64BIT_ACCESS
599
43.4k
        word32 l = (sizeof(word64) - ((size_t)z & (sizeof(word64)-1))) &
600
43.4k
                                                             (sizeof(word64)-1);
601
602
43.4k
        if (len < l) l = len;
603
43.4k
        len -= l;
604
91.9k
        while (l--) *z++ = 0;
605
43.4k
    #endif
606
43.4k
        for (w = (volatile word64*)z;
607
2.73M
             len >= sizeof(*w);
608
2.68M
             len -= (word32)sizeof(*w))
609
2.68M
        {
610
2.68M
            *w++ = 0;
611
2.68M
        }
612
43.4k
    z = (volatile byte*)w;
613
43.4k
#endif
614
615
67.6k
    while (len--) *z++ = 0;
616
43.4k
}
asn.c:ForceZero
Line
Count
Source
592
68.7k
{
593
68.7k
    volatile byte* z = (volatile byte*)mem;
594
595
68.7k
#if (defined(WOLFSSL_X86_64_BUILD) || defined(WOLFSSL_AARCH64_BUILD)) \
596
68.7k
            && defined(WORD64_AVAILABLE)
597
68.7k
    volatile word64* w;
598
68.7k
    #ifndef WOLFSSL_UNALIGNED_64BIT_ACCESS
599
68.7k
        word32 l = (sizeof(word64) - ((size_t)z & (sizeof(word64)-1))) &
600
68.7k
                                                             (sizeof(word64)-1);
601
602
68.7k
        if (len < l) l = len;
603
68.7k
        len -= l;
604
68.7k
        while (l--) *z++ = 0;
605
68.7k
    #endif
606
68.7k
        for (w = (volatile word64*)z;
607
10.3M
             len >= sizeof(*w);
608
10.2M
             len -= (word32)sizeof(*w))
609
10.2M
        {
610
10.2M
            *w++ = 0;
611
10.2M
        }
612
68.7k
    z = (volatile byte*)w;
613
68.7k
#endif
614
615
137k
    while (len--) *z++ = 0;
616
68.7k
}
Unexecuted instantiation: camellia.c:ForceZero
Unexecuted instantiation: chacha.c:ForceZero
Unexecuted instantiation: chacha20_poly1305.c:ForceZero
cmac.c:ForceZero
Line
Count
Source
592
466
{
593
466
    volatile byte* z = (volatile byte*)mem;
594
595
466
#if (defined(WOLFSSL_X86_64_BUILD) || defined(WOLFSSL_AARCH64_BUILD)) \
596
466
            && defined(WORD64_AVAILABLE)
597
466
    volatile word64* w;
598
466
    #ifndef WOLFSSL_UNALIGNED_64BIT_ACCESS
599
466
        word32 l = (sizeof(word64) - ((size_t)z & (sizeof(word64)-1))) &
600
466
                                                             (sizeof(word64)-1);
601
602
466
        if (len < l) l = len;
603
466
        len -= l;
604
466
        while (l--) *z++ = 0;
605
466
    #endif
606
466
        for (w = (volatile word64*)z;
607
33.5k
             len >= sizeof(*w);
608
33.0k
             len -= (word32)sizeof(*w))
609
33.0k
        {
610
33.0k
            *w++ = 0;
611
33.0k
        }
612
466
    z = (volatile byte*)w;
613
466
#endif
614
615
466
    while (len--) *z++ = 0;
616
466
}
Unexecuted instantiation: coding.c:ForceZero
curve25519.c:ForceZero
Line
Count
Source
592
3.97k
{
593
3.97k
    volatile byte* z = (volatile byte*)mem;
594
595
3.97k
#if (defined(WOLFSSL_X86_64_BUILD) || defined(WOLFSSL_AARCH64_BUILD)) \
596
3.97k
            && defined(WORD64_AVAILABLE)
597
3.97k
    volatile word64* w;
598
3.97k
    #ifndef WOLFSSL_UNALIGNED_64BIT_ACCESS
599
3.97k
        word32 l = (sizeof(word64) - ((size_t)z & (sizeof(word64)-1))) &
600
3.97k
                                                             (sizeof(word64)-1);
601
602
3.97k
        if (len < l) l = len;
603
3.97k
        len -= l;
604
3.97k
        while (l--) *z++ = 0;
605
3.97k
    #endif
606
3.97k
        for (w = (volatile word64*)z;
607
67.3k
             len >= sizeof(*w);
608
63.3k
             len -= (word32)sizeof(*w))
609
63.3k
        {
610
63.3k
            *w++ = 0;
611
63.3k
        }
612
3.97k
    z = (volatile byte*)w;
613
3.97k
#endif
614
615
3.97k
    while (len--) *z++ = 0;
616
3.97k
}
curve448.c:ForceZero
Line
Count
Source
592
1.11k
{
593
1.11k
    volatile byte* z = (volatile byte*)mem;
594
595
1.11k
#if (defined(WOLFSSL_X86_64_BUILD) || defined(WOLFSSL_AARCH64_BUILD)) \
596
1.11k
            && defined(WORD64_AVAILABLE)
597
1.11k
    volatile word64* w;
598
1.11k
    #ifndef WOLFSSL_UNALIGNED_64BIT_ACCESS
599
1.11k
        word32 l = (sizeof(word64) - ((size_t)z & (sizeof(word64)-1))) &
600
1.11k
                                                             (sizeof(word64)-1);
601
602
1.11k
        if (len < l) l = len;
603
1.11k
        len -= l;
604
1.38k
        while (l--) *z++ = 0;
605
1.11k
    #endif
606
1.11k
        for (w = (volatile word64*)z;
607
8.61k
             len >= sizeof(*w);
608
7.50k
             len -= (word32)sizeof(*w))
609
7.50k
        {
610
7.50k
            *w++ = 0;
611
7.50k
        }
612
1.11k
    z = (volatile byte*)w;
613
1.11k
#endif
614
615
3.05k
    while (len--) *z++ = 0;
616
1.11k
}
Unexecuted instantiation: des3.c:ForceZero
Unexecuted instantiation: dh.c:ForceZero
ecc.c:ForceZero
Line
Count
Source
592
70.1k
{
593
70.1k
    volatile byte* z = (volatile byte*)mem;
594
595
70.1k
#if (defined(WOLFSSL_X86_64_BUILD) || defined(WOLFSSL_AARCH64_BUILD)) \
596
70.1k
            && defined(WORD64_AVAILABLE)
597
70.1k
    volatile word64* w;
598
70.1k
    #ifndef WOLFSSL_UNALIGNED_64BIT_ACCESS
599
70.1k
        word32 l = (sizeof(word64) - ((size_t)z & (sizeof(word64)-1))) &
600
70.1k
                                                             (sizeof(word64)-1);
601
602
70.1k
        if (len < l) l = len;
603
70.1k
        len -= l;
604
70.1k
        while (l--) *z++ = 0;
605
70.1k
    #endif
606
70.1k
        for (w = (volatile word64*)z;
607
6.11M
             len >= sizeof(*w);
608
6.04M
             len -= (word32)sizeof(*w))
609
6.04M
        {
610
6.04M
            *w++ = 0;
611
6.04M
        }
612
70.1k
    z = (volatile byte*)w;
613
70.1k
#endif
614
615
174k
    while (len--) *z++ = 0;
616
70.1k
}
Unexecuted instantiation: eccsi.c:ForceZero
ed25519.c:ForceZero
Line
Count
Source
592
3.08k
{
593
3.08k
    volatile byte* z = (volatile byte*)mem;
594
595
3.08k
#if (defined(WOLFSSL_X86_64_BUILD) || defined(WOLFSSL_AARCH64_BUILD)) \
596
3.08k
            && defined(WORD64_AVAILABLE)
597
3.08k
    volatile word64* w;
598
3.08k
    #ifndef WOLFSSL_UNALIGNED_64BIT_ACCESS
599
3.08k
        word32 l = (sizeof(word64) - ((size_t)z & (sizeof(word64)-1))) &
600
3.08k
                                                             (sizeof(word64)-1);
601
602
3.08k
        if (len < l) l = len;
603
3.08k
        len -= l;
604
3.08k
        while (l--) *z++ = 0;
605
3.08k
    #endif
606
3.08k
        for (w = (volatile word64*)z;
607
150k
             len >= sizeof(*w);
608
147k
             len -= (word32)sizeof(*w))
609
147k
        {
610
147k
            *w++ = 0;
611
147k
        }
612
3.08k
    z = (volatile byte*)w;
613
3.08k
#endif
614
615
3.08k
    while (len--) *z++ = 0;
616
3.08k
}
ed448.c:ForceZero
Line
Count
Source
592
2.50k
{
593
2.50k
    volatile byte* z = (volatile byte*)mem;
594
595
2.50k
#if (defined(WOLFSSL_X86_64_BUILD) || defined(WOLFSSL_AARCH64_BUILD)) \
596
2.50k
            && defined(WORD64_AVAILABLE)
597
2.50k
    volatile word64* w;
598
2.50k
    #ifndef WOLFSSL_UNALIGNED_64BIT_ACCESS
599
2.50k
        word32 l = (sizeof(word64) - ((size_t)z & (sizeof(word64)-1))) &
600
2.50k
                                                             (sizeof(word64)-1);
601
602
2.50k
        if (len < l) l = len;
603
2.50k
        len -= l;
604
2.98k
        while (l--) *z++ = 0;
605
2.50k
    #endif
606
2.50k
        for (w = (volatile word64*)z;
607
195k
             len >= sizeof(*w);
608
192k
             len -= (word32)sizeof(*w))
609
192k
        {
610
192k
            *w++ = 0;
611
192k
        }
612
2.50k
    z = (volatile byte*)w;
613
2.50k
#endif
614
615
2.64k
    while (len--) *z++ = 0;
616
2.50k
}
Unexecuted instantiation: fe_448.c:ForceZero
Unexecuted instantiation: fe_operations.c:ForceZero
Unexecuted instantiation: ge_448.c:ForceZero
Unexecuted instantiation: ge_operations.c:ForceZero
Unexecuted instantiation: hash.c:ForceZero
hmac.c:ForceZero
Line
Count
Source
592
189k
{
593
189k
    volatile byte* z = (volatile byte*)mem;
594
595
189k
#if (defined(WOLFSSL_X86_64_BUILD) || defined(WOLFSSL_AARCH64_BUILD)) \
596
189k
            && defined(WORD64_AVAILABLE)
597
189k
    volatile word64* w;
598
189k
    #ifndef WOLFSSL_UNALIGNED_64BIT_ACCESS
599
189k
        word32 l = (sizeof(word64) - ((size_t)z & (sizeof(word64)-1))) &
600
189k
                                                             (sizeof(word64)-1);
601
602
189k
        if (len < l) l = len;
603
189k
        len -= l;
604
189k
        while (l--) *z++ = 0;
605
189k
    #endif
606
189k
        for (w = (volatile word64*)z;
607
19.8M
             len >= sizeof(*w);
608
19.6M
             len -= (word32)sizeof(*w))
609
19.6M
        {
610
19.6M
            *w++ = 0;
611
19.6M
        }
612
189k
    z = (volatile byte*)w;
613
189k
#endif
614
615
189k
    while (len--) *z++ = 0;
616
189k
}
kdf.c:ForceZero
Line
Count
Source
592
21.1k
{
593
21.1k
    volatile byte* z = (volatile byte*)mem;
594
595
21.1k
#if (defined(WOLFSSL_X86_64_BUILD) || defined(WOLFSSL_AARCH64_BUILD)) \
596
21.1k
            && defined(WORD64_AVAILABLE)
597
21.1k
    volatile word64* w;
598
21.1k
    #ifndef WOLFSSL_UNALIGNED_64BIT_ACCESS
599
21.1k
        word32 l = (sizeof(word64) - ((size_t)z & (sizeof(word64)-1))) &
600
21.1k
                                                             (sizeof(word64)-1);
601
602
21.1k
        if (len < l) l = len;
603
21.1k
        len -= l;
604
21.1k
        while (l--) *z++ = 0;
605
21.1k
    #endif
606
21.1k
        for (w = (volatile word64*)z;
607
560k
             len >= sizeof(*w);
608
539k
             len -= (word32)sizeof(*w))
609
539k
        {
610
539k
            *w++ = 0;
611
539k
        }
612
21.1k
    z = (volatile byte*)w;
613
21.1k
#endif
614
615
67.9k
    while (len--) *z++ = 0;
616
21.1k
}
Unexecuted instantiation: md2.c:ForceZero
Unexecuted instantiation: md4.c:ForceZero
Unexecuted instantiation: md5.c:ForceZero
Unexecuted instantiation: poly1305.c:ForceZero
Unexecuted instantiation: pwdbased.c:ForceZero
random.c:ForceZero
Line
Count
Source
592
2.69M
{
593
2.69M
    volatile byte* z = (volatile byte*)mem;
594
595
2.69M
#if (defined(WOLFSSL_X86_64_BUILD) || defined(WOLFSSL_AARCH64_BUILD)) \
596
2.69M
            && defined(WORD64_AVAILABLE)
597
2.69M
    volatile word64* w;
598
2.69M
    #ifndef WOLFSSL_UNALIGNED_64BIT_ACCESS
599
2.69M
        word32 l = (sizeof(word64) - ((size_t)z & (sizeof(word64)-1))) &
600
2.69M
                                                             (sizeof(word64)-1);
601
602
2.69M
        if (len < l) l = len;
603
2.69M
        len -= l;
604
2.69M
        while (l--) *z++ = 0;
605
2.69M
    #endif
606
2.69M
        for (w = (volatile word64*)z;
607
19.5M
             len >= sizeof(*w);
608
16.8M
             len -= (word32)sizeof(*w))
609
16.8M
        {
610
16.8M
            *w++ = 0;
611
16.8M
        }
612
2.69M
    z = (volatile byte*)w;
613
2.69M
#endif
614
615
8.63M
    while (len--) *z++ = 0;
616
2.69M
}
Unexecuted instantiation: ripemd.c:ForceZero
rsa.c:ForceZero
Line
Count
Source
592
327
{
593
327
    volatile byte* z = (volatile byte*)mem;
594
595
327
#if (defined(WOLFSSL_X86_64_BUILD) || defined(WOLFSSL_AARCH64_BUILD)) \
596
327
            && defined(WORD64_AVAILABLE)
597
327
    volatile word64* w;
598
327
    #ifndef WOLFSSL_UNALIGNED_64BIT_ACCESS
599
327
        word32 l = (sizeof(word64) - ((size_t)z & (sizeof(word64)-1))) &
600
327
                                                             (sizeof(word64)-1);
601
602
327
        if (len < l) l = len;
603
327
        len -= l;
604
327
        while (l--) *z++ = 0;
605
327
    #endif
606
327
        for (w = (volatile word64*)z;
607
1.93k
             len >= sizeof(*w);
608
1.61k
             len -= (word32)sizeof(*w))
609
1.61k
        {
610
1.61k
            *w++ = 0;
611
1.61k
        }
612
327
    z = (volatile byte*)w;
613
327
#endif
614
615
751
    while (len--) *z++ = 0;
616
327
}
Unexecuted instantiation: sha.c:ForceZero
sha256.c:ForceZero
Line
Count
Source
592
10.6M
{
593
10.6M
    volatile byte* z = (volatile byte*)mem;
594
595
10.6M
#if (defined(WOLFSSL_X86_64_BUILD) || defined(WOLFSSL_AARCH64_BUILD)) \
596
10.6M
            && defined(WORD64_AVAILABLE)
597
10.6M
    volatile word64* w;
598
10.6M
    #ifndef WOLFSSL_UNALIGNED_64BIT_ACCESS
599
10.6M
        word32 l = (sizeof(word64) - ((size_t)z & (sizeof(word64)-1))) &
600
10.6M
                                                             (sizeof(word64)-1);
601
602
10.6M
        if (len < l) l = len;
603
10.6M
        len -= l;
604
10.6M
        while (l--) *z++ = 0;
605
10.6M
    #endif
606
10.6M
        for (w = (volatile word64*)z;
607
287M
             len >= sizeof(*w);
608
276M
             len -= (word32)sizeof(*w))
609
276M
        {
610
276M
            *w++ = 0;
611
276M
        }
612
10.6M
    z = (volatile byte*)w;
613
10.6M
#endif
614
615
10.6M
    while (len--) *z++ = 0;
616
10.6M
}
Unexecuted instantiation: sha3.c:ForceZero
sha512.c:ForceZero
Line
Count
Source
592
1.65M
{
593
1.65M
    volatile byte* z = (volatile byte*)mem;
594
595
1.65M
#if (defined(WOLFSSL_X86_64_BUILD) || defined(WOLFSSL_AARCH64_BUILD)) \
596
1.65M
            && defined(WORD64_AVAILABLE)
597
1.65M
    volatile word64* w;
598
1.65M
    #ifndef WOLFSSL_UNALIGNED_64BIT_ACCESS
599
1.65M
        word32 l = (sizeof(word64) - ((size_t)z & (sizeof(word64)-1))) &
600
1.65M
                                                             (sizeof(word64)-1);
601
602
1.65M
        if (len < l) l = len;
603
1.65M
        len -= l;
604
1.65M
        while (l--) *z++ = 0;
605
1.65M
    #endif
606
1.65M
        for (w = (volatile word64*)z;
607
25.8M
             len >= sizeof(*w);
608
24.1M
             len -= (word32)sizeof(*w))
609
24.1M
        {
610
24.1M
            *w++ = 0;
611
24.1M
        }
612
1.65M
    z = (volatile byte*)w;
613
1.65M
#endif
614
615
1.65M
    while (len--) *z++ = 0;
616
1.65M
}
Unexecuted instantiation: siphash.c:ForceZero
Unexecuted instantiation: sm2.c:ForceZero
Unexecuted instantiation: sm3.c:ForceZero
Unexecuted instantiation: sm4.c:ForceZero
sp_int.c:ForceZero
Line
Count
Source
592
225k
{
593
225k
    volatile byte* z = (volatile byte*)mem;
594
595
225k
#if (defined(WOLFSSL_X86_64_BUILD) || defined(WOLFSSL_AARCH64_BUILD)) \
596
225k
            && defined(WORD64_AVAILABLE)
597
225k
    volatile word64* w;
598
225k
    #ifndef WOLFSSL_UNALIGNED_64BIT_ACCESS
599
225k
        word32 l = (sizeof(word64) - ((size_t)z & (sizeof(word64)-1))) &
600
225k
                                                             (sizeof(word64)-1);
601
602
225k
        if (len < l) l = len;
603
225k
        len -= l;
604
292k
        while (l--) *z++ = 0;
605
225k
    #endif
606
225k
        for (w = (volatile word64*)z;
607
24.2M
             len >= sizeof(*w);
608
24.0M
             len -= (word32)sizeof(*w))
609
24.0M
        {
610
24.0M
            *w++ = 0;
611
24.0M
        }
612
225k
    z = (volatile byte*)w;
613
225k
#endif
614
615
271k
    while (len--) *z++ = 0;
616
225k
}
Unexecuted instantiation: wc_encrypt.c:ForceZero
Unexecuted instantiation: wolfmath.c:ForceZero
ssl.c:ForceZero
Line
Count
Source
592
398k
{
593
398k
    volatile byte* z = (volatile byte*)mem;
594
595
398k
#if (defined(WOLFSSL_X86_64_BUILD) || defined(WOLFSSL_AARCH64_BUILD)) \
596
398k
            && defined(WORD64_AVAILABLE)
597
398k
    volatile word64* w;
598
398k
    #ifndef WOLFSSL_UNALIGNED_64BIT_ACCESS
599
398k
        word32 l = (sizeof(word64) - ((size_t)z & (sizeof(word64)-1))) &
600
398k
                                                             (sizeof(word64)-1);
601
602
398k
        if (len < l) l = len;
603
398k
        len -= l;
604
1.44M
        while (l--) *z++ = 0;
605
398k
    #endif
606
398k
        for (w = (volatile word64*)z;
607
12.8M
             len >= sizeof(*w);
608
12.4M
             len -= (word32)sizeof(*w))
609
12.4M
        {
610
12.4M
            *w++ = 0;
611
12.4M
        }
612
398k
    z = (volatile byte*)w;
613
398k
#endif
614
615
2.00M
    while (len--) *z++ = 0;
616
398k
}
tls.c:ForceZero
Line
Count
Source
592
18.8k
{
593
18.8k
    volatile byte* z = (volatile byte*)mem;
594
595
18.8k
#if (defined(WOLFSSL_X86_64_BUILD) || defined(WOLFSSL_AARCH64_BUILD)) \
596
18.8k
            && defined(WORD64_AVAILABLE)
597
18.8k
    volatile word64* w;
598
18.8k
    #ifndef WOLFSSL_UNALIGNED_64BIT_ACCESS
599
18.8k
        word32 l = (sizeof(word64) - ((size_t)z & (sizeof(word64)-1))) &
600
18.8k
                                                             (sizeof(word64)-1);
601
602
18.8k
        if (len < l) l = len;
603
18.8k
        len -= l;
604
18.8k
        while (l--) *z++ = 0;
605
18.8k
    #endif
606
18.8k
        for (w = (volatile word64*)z;
607
3.07M
             len >= sizeof(*w);
608
3.05M
             len -= (word32)sizeof(*w))
609
3.05M
        {
610
3.05M
            *w++ = 0;
611
3.05M
        }
612
18.8k
    z = (volatile byte*)w;
613
18.8k
#endif
614
615
20.1k
    while (len--) *z++ = 0;
616
18.8k
}
tls13.c:ForceZero
Line
Count
Source
592
16.7k
{
593
16.7k
    volatile byte* z = (volatile byte*)mem;
594
595
16.7k
#if (defined(WOLFSSL_X86_64_BUILD) || defined(WOLFSSL_AARCH64_BUILD)) \
596
16.7k
            && defined(WORD64_AVAILABLE)
597
16.7k
    volatile word64* w;
598
16.7k
    #ifndef WOLFSSL_UNALIGNED_64BIT_ACCESS
599
16.7k
        word32 l = (sizeof(word64) - ((size_t)z & (sizeof(word64)-1))) &
600
16.7k
                                                             (sizeof(word64)-1);
601
602
16.7k
        if (len < l) l = len;
603
16.7k
        len -= l;
604
16.7k
        while (l--) *z++ = 0;
605
16.7k
    #endif
606
16.7k
        for (w = (volatile word64*)z;
607
152k
             len >= sizeof(*w);
608
136k
             len -= (word32)sizeof(*w))
609
136k
        {
610
136k
            *w++ = 0;
611
136k
        }
612
16.7k
    z = (volatile byte*)w;
613
16.7k
#endif
614
615
53.7k
    while (len--) *z++ = 0;
616
16.7k
}
internal.c:ForceZero
Line
Count
Source
592
749k
{
593
749k
    volatile byte* z = (volatile byte*)mem;
594
595
749k
#if (defined(WOLFSSL_X86_64_BUILD) || defined(WOLFSSL_AARCH64_BUILD)) \
596
749k
            && defined(WORD64_AVAILABLE)
597
749k
    volatile word64* w;
598
749k
    #ifndef WOLFSSL_UNALIGNED_64BIT_ACCESS
599
749k
        word32 l = (sizeof(word64) - ((size_t)z & (sizeof(word64)-1))) &
600
749k
                                                             (sizeof(word64)-1);
601
602
749k
        if (len < l) l = len;
603
749k
        len -= l;
604
753k
        while (l--) *z++ = 0;
605
749k
    #endif
606
749k
        for (w = (volatile word64*)z;
607
55.0M
             len >= sizeof(*w);
608
54.3M
             len -= (word32)sizeof(*w))
609
54.3M
        {
610
54.3M
            *w++ = 0;
611
54.3M
        }
612
749k
    z = (volatile byte*)w;
613
749k
#endif
614
615
1.41M
    while (len--) *z++ = 0;
616
749k
}
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
1.57M
{
625
1.57M
    int i;
626
1.57M
    int compareSum = 0;
627
628
35.8M
    for (i = 0; i < length; i++) {
629
34.2M
        compareSum |= a[i] ^ b[i];
630
34.2M
    }
631
632
1.57M
    return compareSum;
633
1.57M
}
aes.c:ConstantCompare
Line
Count
Source
624
3.28k
{
625
3.28k
    int i;
626
3.28k
    int compareSum = 0;
627
628
50.4k
    for (i = 0; i < length; i++) {
629
47.1k
        compareSum |= a[i] ^ b[i];
630
47.1k
    }
631
632
3.28k
    return compareSum;
633
3.28k
}
Unexecuted instantiation: asn.c:ConstantCompare
Unexecuted instantiation: camellia.c:ConstantCompare
Unexecuted instantiation: chacha.c:ConstantCompare
Unexecuted instantiation: chacha20_poly1305.c:ConstantCompare
Unexecuted instantiation: cmac.c:ConstantCompare
Unexecuted instantiation: coding.c:ConstantCompare
Unexecuted instantiation: curve25519.c:ConstantCompare
Unexecuted instantiation: curve448.c:ConstantCompare
Unexecuted instantiation: des3.c:ConstantCompare
Unexecuted instantiation: dh.c:ConstantCompare
Unexecuted instantiation: ecc.c:ConstantCompare
Unexecuted instantiation: eccsi.c:ConstantCompare
ed25519.c:ConstantCompare
Line
Count
Source
624
899
{
625
899
    int i;
626
899
    int compareSum = 0;
627
628
29.6k
    for (i = 0; i < length; i++) {
629
28.7k
        compareSum |= a[i] ^ b[i];
630
28.7k
    }
631
632
899
    return compareSum;
633
899
}
ed448.c:ConstantCompare
Line
Count
Source
624
810
{
625
810
    int i;
626
810
    int compareSum = 0;
627
628
46.9k
    for (i = 0; i < length; i++) {
629
46.1k
        compareSum |= a[i] ^ b[i];
630
46.1k
    }
631
632
810
    return compareSum;
633
810
}
Unexecuted instantiation: fe_448.c:ConstantCompare
fe_operations.c:ConstantCompare
Line
Count
Source
624
3.92k
{
625
3.92k
    int i;
626
3.92k
    int compareSum = 0;
627
628
129k
    for (i = 0; i < length; i++) {
629
125k
        compareSum |= a[i] ^ b[i];
630
125k
    }
631
632
3.92k
    return compareSum;
633
3.92k
}
Unexecuted instantiation: ge_448.c:ConstantCompare
Unexecuted instantiation: ge_operations.c:ConstantCompare
Unexecuted instantiation: hash.c:ConstantCompare
Unexecuted instantiation: hmac.c:ConstantCompare
Unexecuted instantiation: kdf.c:ConstantCompare
Unexecuted instantiation: md2.c:ConstantCompare
Unexecuted instantiation: md4.c:ConstantCompare
Unexecuted instantiation: md5.c:ConstantCompare
Unexecuted instantiation: poly1305.c:ConstantCompare
Unexecuted instantiation: pwdbased.c:ConstantCompare
random.c:ConstantCompare
Line
Count
Source
624
1.56M
{
625
1.56M
    int i;
626
1.56M
    int compareSum = 0;
627
628
35.5M
    for (i = 0; i < length; i++) {
629
33.9M
        compareSum |= a[i] ^ b[i];
630
33.9M
    }
631
632
1.56M
    return compareSum;
633
1.56M
}
Unexecuted instantiation: ripemd.c:ConstantCompare
Unexecuted instantiation: rsa.c:ConstantCompare
Unexecuted instantiation: sha.c:ConstantCompare
Unexecuted instantiation: sha256.c:ConstantCompare
Unexecuted instantiation: sha3.c:ConstantCompare
Unexecuted instantiation: sha512.c:ConstantCompare
Unexecuted instantiation: siphash.c:ConstantCompare
Unexecuted instantiation: sm2.c:ConstantCompare
Unexecuted instantiation: sm3.c:ConstantCompare
Unexecuted instantiation: sm4.c:ConstantCompare
Unexecuted instantiation: sp_int.c:ConstantCompare
Unexecuted instantiation: wc_encrypt.c:ConstantCompare
Unexecuted instantiation: wolfmath.c:ConstantCompare
Unexecuted instantiation: ssl.c:ConstantCompare
Unexecuted instantiation: tls.c:ConstantCompare
tls13.c:ConstantCompare
Line
Count
Source
624
2.68k
{
625
2.68k
    int i;
626
2.68k
    int compareSum = 0;
627
628
45.6k
    for (i = 0; i < length; i++) {
629
43.0k
        compareSum |= a[i] ^ b[i];
630
43.0k
    }
631
632
2.68k
    return compareSum;
633
2.68k
}
internal.c:ConstantCompare
Line
Count
Source
624
109
{
625
109
    int i;
626
109
    int compareSum = 0;
627
628
2.37k
    for (i = 0; i < length; i++) {
629
2.26k
        compareSum |= a[i] ^ b[i];
630
2.26k
    }
631
632
109
    return compareSum;
633
109
}
634
#endif
635
636
637
#if defined(WOLFSSL_NO_CT_OPS) && (!defined(NO_RSA) || !defined(WOLFCRYPT_ONLY))
638
/* constant time operations with mask are required for RSA and TLS operations */
639
#warning constant time operations required unless using NO_RSA & WOLFCRYPT_ONLY
640
#endif
641
642
#if !defined(WOLFSSL_NO_CT_OPS) || !defined(NO_RSA) || !defined(WOLFCRYPT_ONLY)
643
/* Constant time - mask set when a > b. */
644
WC_MISC_STATIC WC_INLINE byte ctMaskGT(int a, int b)
645
94.6k
{
646
94.6k
    return (byte)((((word32)a - (word32)b - 1) >> 31) - 1);
647
94.6k
}
Unexecuted instantiation: aes.c:ctMaskGT
Unexecuted instantiation: asn.c:ctMaskGT
Unexecuted instantiation: camellia.c:ctMaskGT
Unexecuted instantiation: chacha.c:ctMaskGT
Unexecuted instantiation: chacha20_poly1305.c:ctMaskGT
Unexecuted instantiation: cmac.c:ctMaskGT
Unexecuted instantiation: coding.c:ctMaskGT
Unexecuted instantiation: curve25519.c:ctMaskGT
Unexecuted instantiation: curve448.c:ctMaskGT
Unexecuted instantiation: des3.c:ctMaskGT
Unexecuted instantiation: dh.c:ctMaskGT
Unexecuted instantiation: ecc.c:ctMaskGT
Unexecuted instantiation: eccsi.c:ctMaskGT
Unexecuted instantiation: ed25519.c:ctMaskGT
Unexecuted instantiation: ed448.c:ctMaskGT
Unexecuted instantiation: fe_448.c:ctMaskGT
Unexecuted instantiation: fe_operations.c:ctMaskGT
Unexecuted instantiation: ge_448.c:ctMaskGT
Unexecuted instantiation: ge_operations.c:ctMaskGT
Unexecuted instantiation: hash.c:ctMaskGT
Unexecuted instantiation: hmac.c:ctMaskGT
Unexecuted instantiation: kdf.c:ctMaskGT
Unexecuted instantiation: md2.c:ctMaskGT
Unexecuted instantiation: md4.c:ctMaskGT
Unexecuted instantiation: md5.c:ctMaskGT
Unexecuted instantiation: poly1305.c:ctMaskGT
Unexecuted instantiation: pwdbased.c:ctMaskGT
Unexecuted instantiation: random.c:ctMaskGT
Unexecuted instantiation: ripemd.c:ctMaskGT
rsa.c:ctMaskGT
Line
Count
Source
645
6.94k
{
646
6.94k
    return (byte)((((word32)a - (word32)b - 1) >> 31) - 1);
647
6.94k
}
Unexecuted instantiation: sha.c:ctMaskGT
Unexecuted instantiation: sha256.c:ctMaskGT
Unexecuted instantiation: sha3.c:ctMaskGT
Unexecuted instantiation: sha512.c:ctMaskGT
Unexecuted instantiation: siphash.c:ctMaskGT
Unexecuted instantiation: sm2.c:ctMaskGT
Unexecuted instantiation: sm3.c:ctMaskGT
Unexecuted instantiation: sm4.c:ctMaskGT
sp_int.c:ctMaskGT
Line
Count
Source
645
771
{
646
771
    return (byte)((((word32)a - (word32)b - 1) >> 31) - 1);
647
771
}
Unexecuted instantiation: wc_encrypt.c:ctMaskGT
Unexecuted instantiation: wolfmath.c:ctMaskGT
Unexecuted instantiation: ssl.c:ctMaskGT
tls.c:ctMaskGT
Line
Count
Source
645
86.7k
{
646
86.7k
    return (byte)((((word32)a - (word32)b - 1) >> 31) - 1);
647
86.7k
}
Unexecuted instantiation: tls13.c:ctMaskGT
internal.c:ctMaskGT
Line
Count
Source
645
148
{
646
148
    return (byte)((((word32)a - (word32)b - 1) >> 31) - 1);
647
148
}
648
649
/* Constant time - mask set when a >= b. */
650
WC_MISC_STATIC WC_INLINE byte ctMaskGTE(int a, int b)
651
28.5k
{
652
28.5k
    return (byte)((((word32)a - (word32)b) >> 31) - 1);
653
28.5k
}
Unexecuted instantiation: aes.c:ctMaskGTE
Unexecuted instantiation: asn.c:ctMaskGTE
Unexecuted instantiation: camellia.c:ctMaskGTE
Unexecuted instantiation: chacha.c:ctMaskGTE
Unexecuted instantiation: chacha20_poly1305.c:ctMaskGTE
Unexecuted instantiation: cmac.c:ctMaskGTE
Unexecuted instantiation: coding.c:ctMaskGTE
Unexecuted instantiation: curve25519.c:ctMaskGTE
Unexecuted instantiation: curve448.c:ctMaskGTE
Unexecuted instantiation: des3.c:ctMaskGTE
Unexecuted instantiation: dh.c:ctMaskGTE
Unexecuted instantiation: ecc.c:ctMaskGTE
Unexecuted instantiation: eccsi.c:ctMaskGTE
Unexecuted instantiation: ed25519.c:ctMaskGTE
Unexecuted instantiation: ed448.c:ctMaskGTE
Unexecuted instantiation: fe_448.c:ctMaskGTE
Unexecuted instantiation: fe_operations.c:ctMaskGTE
Unexecuted instantiation: ge_448.c:ctMaskGTE
Unexecuted instantiation: ge_operations.c:ctMaskGTE
Unexecuted instantiation: hash.c:ctMaskGTE
Unexecuted instantiation: hmac.c:ctMaskGTE
Unexecuted instantiation: kdf.c:ctMaskGTE
Unexecuted instantiation: md2.c:ctMaskGTE
Unexecuted instantiation: md4.c:ctMaskGTE
Unexecuted instantiation: md5.c:ctMaskGTE
Unexecuted instantiation: poly1305.c:ctMaskGTE
Unexecuted instantiation: pwdbased.c:ctMaskGTE
Unexecuted instantiation: random.c:ctMaskGTE
Unexecuted instantiation: ripemd.c:ctMaskGTE
Unexecuted instantiation: rsa.c:ctMaskGTE
Unexecuted instantiation: sha.c:ctMaskGTE
Unexecuted instantiation: sha256.c:ctMaskGTE
Unexecuted instantiation: sha3.c:ctMaskGTE
Unexecuted instantiation: sha512.c:ctMaskGTE
Unexecuted instantiation: siphash.c:ctMaskGTE
Unexecuted instantiation: sm2.c:ctMaskGTE
Unexecuted instantiation: sm3.c:ctMaskGTE
Unexecuted instantiation: sm4.c:ctMaskGTE
Unexecuted instantiation: sp_int.c:ctMaskGTE
Unexecuted instantiation: wc_encrypt.c:ctMaskGTE
Unexecuted instantiation: wolfmath.c:ctMaskGTE
Unexecuted instantiation: ssl.c:ctMaskGTE
Unexecuted instantiation: tls.c:ctMaskGTE
Unexecuted instantiation: tls13.c:ctMaskGTE
internal.c:ctMaskGTE
Line
Count
Source
651
28.5k
{
652
28.5k
    return (byte)((((word32)a - (word32)b) >> 31) - 1);
653
28.5k
}
654
655
/* Constant time - mask set when a >= b. */
656
WC_MISC_STATIC WC_INLINE int ctMaskIntGTE(int a, int b)
657
495k
{
658
495k
    return (int)((((word32)a - (word32)b) >> 31) - 1);
659
495k
}
Unexecuted instantiation: aes.c:ctMaskIntGTE
Unexecuted instantiation: asn.c:ctMaskIntGTE
Unexecuted instantiation: camellia.c:ctMaskIntGTE
Unexecuted instantiation: chacha.c:ctMaskIntGTE
Unexecuted instantiation: chacha20_poly1305.c:ctMaskIntGTE
Unexecuted instantiation: cmac.c:ctMaskIntGTE
Unexecuted instantiation: coding.c:ctMaskIntGTE
Unexecuted instantiation: curve25519.c:ctMaskIntGTE
Unexecuted instantiation: curve448.c:ctMaskIntGTE
Unexecuted instantiation: des3.c:ctMaskIntGTE
Unexecuted instantiation: dh.c:ctMaskIntGTE
Unexecuted instantiation: ecc.c:ctMaskIntGTE
Unexecuted instantiation: eccsi.c:ctMaskIntGTE
Unexecuted instantiation: ed25519.c:ctMaskIntGTE
Unexecuted instantiation: ed448.c:ctMaskIntGTE
Unexecuted instantiation: fe_448.c:ctMaskIntGTE
Unexecuted instantiation: fe_operations.c:ctMaskIntGTE
Unexecuted instantiation: ge_448.c:ctMaskIntGTE
Unexecuted instantiation: ge_operations.c:ctMaskIntGTE
Unexecuted instantiation: hash.c:ctMaskIntGTE
Unexecuted instantiation: hmac.c:ctMaskIntGTE
Unexecuted instantiation: kdf.c:ctMaskIntGTE
Unexecuted instantiation: md2.c:ctMaskIntGTE
Unexecuted instantiation: md4.c:ctMaskIntGTE
Unexecuted instantiation: md5.c:ctMaskIntGTE
Unexecuted instantiation: poly1305.c:ctMaskIntGTE
Unexecuted instantiation: pwdbased.c:ctMaskIntGTE
Unexecuted instantiation: random.c:ctMaskIntGTE
Unexecuted instantiation: ripemd.c:ctMaskIntGTE
Unexecuted instantiation: rsa.c:ctMaskIntGTE
Unexecuted instantiation: sha.c:ctMaskIntGTE
Unexecuted instantiation: sha256.c:ctMaskIntGTE
Unexecuted instantiation: sha3.c:ctMaskIntGTE
Unexecuted instantiation: sha512.c:ctMaskIntGTE
Unexecuted instantiation: siphash.c:ctMaskIntGTE
Unexecuted instantiation: sm2.c:ctMaskIntGTE
Unexecuted instantiation: sm3.c:ctMaskIntGTE
Unexecuted instantiation: sm4.c:ctMaskIntGTE
sp_int.c:ctMaskIntGTE
Line
Count
Source
657
495k
{
658
495k
    return (int)((((word32)a - (word32)b) >> 31) - 1);
659
495k
}
Unexecuted instantiation: wc_encrypt.c:ctMaskIntGTE
Unexecuted instantiation: wolfmath.c:ctMaskIntGTE
Unexecuted instantiation: ssl.c:ctMaskIntGTE
Unexecuted instantiation: tls.c:ctMaskIntGTE
Unexecuted instantiation: tls13.c:ctMaskIntGTE
internal.c:ctMaskIntGTE
Line
Count
Source
657
296
{
658
296
    return (int)((((word32)a - (word32)b) >> 31) - 1);
659
296
}
660
661
#ifdef WORD64_AVAILABLE
662
/* Constant time - mask set when a >= b. */
663
WC_MISC_STATIC WC_INLINE word32 ctMaskWord32GTE(word32 a, word32 b)
664
7.08M
{
665
7.08M
  return (word32)((((word64)a - (word64)b) >> 63) - 1);
666
7.08M
}
aes.c:ctMaskWord32GTE
Line
Count
Source
664
1.68k
{
665
1.68k
  return (word32)((((word64)a - (word64)b) >> 63) - 1);
666
1.68k
}
asn.c:ctMaskWord32GTE
Line
Count
Source
664
50.2k
{
665
50.2k
  return (word32)((((word64)a - (word64)b) >> 63) - 1);
666
50.2k
}
Unexecuted instantiation: camellia.c:ctMaskWord32GTE
Unexecuted instantiation: chacha.c:ctMaskWord32GTE
Unexecuted instantiation: chacha20_poly1305.c:ctMaskWord32GTE
cmac.c:ctMaskWord32GTE
Line
Count
Source
664
1.69k
{
665
1.69k
  return (word32)((((word64)a - (word64)b) >> 63) - 1);
666
1.69k
}
Unexecuted instantiation: coding.c:ctMaskWord32GTE
Unexecuted instantiation: curve25519.c:ctMaskWord32GTE
Unexecuted instantiation: curve448.c:ctMaskWord32GTE
Unexecuted instantiation: des3.c:ctMaskWord32GTE
dh.c:ctMaskWord32GTE
Line
Count
Source
664
75.0k
{
665
75.0k
  return (word32)((((word64)a - (word64)b) >> 63) - 1);
666
75.0k
}
Unexecuted instantiation: ecc.c:ctMaskWord32GTE
Unexecuted instantiation: eccsi.c:ctMaskWord32GTE
Unexecuted instantiation: ed25519.c:ctMaskWord32GTE
Unexecuted instantiation: ed448.c:ctMaskWord32GTE
Unexecuted instantiation: fe_448.c:ctMaskWord32GTE
Unexecuted instantiation: fe_operations.c:ctMaskWord32GTE
Unexecuted instantiation: ge_448.c:ctMaskWord32GTE
Unexecuted instantiation: ge_operations.c:ctMaskWord32GTE
Unexecuted instantiation: hash.c:ctMaskWord32GTE
hmac.c:ctMaskWord32GTE
Line
Count
Source
664
53.2k
{
665
53.2k
  return (word32)((((word64)a - (word64)b) >> 63) - 1);
666
53.2k
}
kdf.c:ctMaskWord32GTE
Line
Count
Source
664
2.92k
{
665
2.92k
  return (word32)((((word64)a - (word64)b) >> 63) - 1);
666
2.92k
}
Unexecuted instantiation: md2.c:ctMaskWord32GTE
md4.c:ctMaskWord32GTE
Line
Count
Source
664
1.86k
{
665
1.86k
  return (word32)((((word64)a - (word64)b) >> 63) - 1);
666
1.86k
}
md5.c:ctMaskWord32GTE
Line
Count
Source
664
126k
{
665
126k
  return (word32)((((word64)a - (word64)b) >> 63) - 1);
666
126k
}
Unexecuted instantiation: poly1305.c:ctMaskWord32GTE
pwdbased.c:ctMaskWord32GTE
Line
Count
Source
664
8.54k
{
665
8.54k
  return (word32)((((word64)a - (word64)b) >> 63) - 1);
666
8.54k
}
random.c:ctMaskWord32GTE
Line
Count
Source
664
1.45M
{
665
1.45M
  return (word32)((((word64)a - (word64)b) >> 63) - 1);
666
1.45M
}
Unexecuted instantiation: ripemd.c:ctMaskWord32GTE
Unexecuted instantiation: rsa.c:ctMaskWord32GTE
sha.c:ctMaskWord32GTE
Line
Count
Source
664
242k
{
665
242k
  return (word32)((((word64)a - (word64)b) >> 63) - 1);
666
242k
}
sha256.c:ctMaskWord32GTE
Line
Count
Source
664
4.65M
{
665
4.65M
  return (word32)((((word64)a - (word64)b) >> 63) - 1);
666
4.65M
}
Unexecuted instantiation: sha3.c:ctMaskWord32GTE
sha512.c:ctMaskWord32GTE
Line
Count
Source
664
329k
{
665
329k
  return (word32)((((word64)a - (word64)b) >> 63) - 1);
666
329k
}
Unexecuted instantiation: siphash.c:ctMaskWord32GTE
Unexecuted instantiation: sm2.c:ctMaskWord32GTE
Unexecuted instantiation: sm3.c:ctMaskWord32GTE
Unexecuted instantiation: sm4.c:ctMaskWord32GTE
Unexecuted instantiation: sp_int.c:ctMaskWord32GTE
Unexecuted instantiation: wc_encrypt.c:ctMaskWord32GTE
Unexecuted instantiation: wolfmath.c:ctMaskWord32GTE
ssl.c:ctMaskWord32GTE
Line
Count
Source
664
142
{
665
142
  return (word32)((((word64)a - (word64)b) >> 63) - 1);
666
142
}
Unexecuted instantiation: tls.c:ctMaskWord32GTE
tls13.c:ctMaskWord32GTE
Line
Count
Source
664
12.4k
{
665
12.4k
  return (word32)((((word64)a - (word64)b) >> 63) - 1);
666
12.4k
}
internal.c:ctMaskWord32GTE
Line
Count
Source
664
79.4k
{
665
79.4k
  return (word32)((((word64)a - (word64)b) >> 63) - 1);
666
79.4k
}
667
#endif
668
669
/* Constant time - mask set when a < b. */
670
WC_MISC_STATIC WC_INLINE byte ctMaskLT(int a, int b)
671
80.1k
{
672
80.1k
    return (byte)((((word32)b - (word32)a - 1) >> 31) - 1);
673
80.1k
}
Unexecuted instantiation: aes.c:ctMaskLT
Unexecuted instantiation: asn.c:ctMaskLT
Unexecuted instantiation: camellia.c:ctMaskLT
Unexecuted instantiation: chacha.c:ctMaskLT
Unexecuted instantiation: chacha20_poly1305.c:ctMaskLT
Unexecuted instantiation: cmac.c:ctMaskLT
Unexecuted instantiation: coding.c:ctMaskLT
Unexecuted instantiation: curve25519.c:ctMaskLT
Unexecuted instantiation: curve448.c:ctMaskLT
Unexecuted instantiation: des3.c:ctMaskLT
Unexecuted instantiation: dh.c:ctMaskLT
Unexecuted instantiation: ecc.c:ctMaskLT
Unexecuted instantiation: eccsi.c:ctMaskLT
Unexecuted instantiation: ed25519.c:ctMaskLT
Unexecuted instantiation: ed448.c:ctMaskLT
Unexecuted instantiation: fe_448.c:ctMaskLT
Unexecuted instantiation: fe_operations.c:ctMaskLT
Unexecuted instantiation: ge_448.c:ctMaskLT
Unexecuted instantiation: ge_operations.c:ctMaskLT
Unexecuted instantiation: hash.c:ctMaskLT
Unexecuted instantiation: hmac.c:ctMaskLT
Unexecuted instantiation: kdf.c:ctMaskLT
Unexecuted instantiation: md2.c:ctMaskLT
Unexecuted instantiation: md4.c:ctMaskLT
Unexecuted instantiation: md5.c:ctMaskLT
Unexecuted instantiation: poly1305.c:ctMaskLT
Unexecuted instantiation: pwdbased.c:ctMaskLT
Unexecuted instantiation: random.c:ctMaskLT
Unexecuted instantiation: ripemd.c:ctMaskLT
rsa.c:ctMaskLT
Line
Count
Source
671
6.94k
{
672
6.94k
    return (byte)((((word32)b - (word32)a - 1) >> 31) - 1);
673
6.94k
}
Unexecuted instantiation: sha.c:ctMaskLT
Unexecuted instantiation: sha256.c:ctMaskLT
Unexecuted instantiation: sha3.c:ctMaskLT
Unexecuted instantiation: sha512.c:ctMaskLT
Unexecuted instantiation: siphash.c:ctMaskLT
Unexecuted instantiation: sm2.c:ctMaskLT
Unexecuted instantiation: sm3.c:ctMaskLT
Unexecuted instantiation: sm4.c:ctMaskLT
sp_int.c:ctMaskLT
Line
Count
Source
671
771
{
672
771
    return (byte)((((word32)b - (word32)a - 1) >> 31) - 1);
673
771
}
Unexecuted instantiation: wc_encrypt.c:ctMaskLT
Unexecuted instantiation: wolfmath.c:ctMaskLT
Unexecuted instantiation: ssl.c:ctMaskLT
tls.c:ctMaskLT
Line
Count
Source
671
43.9k
{
672
43.9k
    return (byte)((((word32)b - (word32)a - 1) >> 31) - 1);
673
43.9k
}
Unexecuted instantiation: tls13.c:ctMaskLT
internal.c:ctMaskLT
Line
Count
Source
671
28.5k
{
672
28.5k
    return (byte)((((word32)b - (word32)a - 1) >> 31) - 1);
673
28.5k
}
674
675
/* Constant time - mask set when a <= b. */
676
WC_MISC_STATIC WC_INLINE byte ctMaskLTE(int a, int b)
677
33.0k
{
678
33.0k
    return (byte)((((word32)b - (word32)a) >> 31) - 1);
679
33.0k
}
Unexecuted instantiation: aes.c:ctMaskLTE
Unexecuted instantiation: asn.c:ctMaskLTE
Unexecuted instantiation: camellia.c:ctMaskLTE
Unexecuted instantiation: chacha.c:ctMaskLTE
Unexecuted instantiation: chacha20_poly1305.c:ctMaskLTE
Unexecuted instantiation: cmac.c:ctMaskLTE
Unexecuted instantiation: coding.c:ctMaskLTE
Unexecuted instantiation: curve25519.c:ctMaskLTE
Unexecuted instantiation: curve448.c:ctMaskLTE
Unexecuted instantiation: des3.c:ctMaskLTE
Unexecuted instantiation: dh.c:ctMaskLTE
Unexecuted instantiation: ecc.c:ctMaskLTE
Unexecuted instantiation: eccsi.c:ctMaskLTE
Unexecuted instantiation: ed25519.c:ctMaskLTE
Unexecuted instantiation: ed448.c:ctMaskLTE
Unexecuted instantiation: fe_448.c:ctMaskLTE
Unexecuted instantiation: fe_operations.c:ctMaskLTE
Unexecuted instantiation: ge_448.c:ctMaskLTE
Unexecuted instantiation: ge_operations.c:ctMaskLTE
Unexecuted instantiation: hash.c:ctMaskLTE
Unexecuted instantiation: hmac.c:ctMaskLTE
Unexecuted instantiation: kdf.c:ctMaskLTE
Unexecuted instantiation: md2.c:ctMaskLTE
Unexecuted instantiation: md4.c:ctMaskLTE
Unexecuted instantiation: md5.c:ctMaskLTE
Unexecuted instantiation: poly1305.c:ctMaskLTE
Unexecuted instantiation: pwdbased.c:ctMaskLTE
Unexecuted instantiation: random.c:ctMaskLTE
Unexecuted instantiation: ripemd.c:ctMaskLTE
rsa.c:ctMaskLTE
Line
Count
Source
677
6.94k
{
678
6.94k
    return (byte)((((word32)b - (word32)a) >> 31) - 1);
679
6.94k
}
Unexecuted instantiation: sha.c:ctMaskLTE
Unexecuted instantiation: sha256.c:ctMaskLTE
Unexecuted instantiation: sha3.c:ctMaskLTE
Unexecuted instantiation: sha512.c:ctMaskLTE
Unexecuted instantiation: siphash.c:ctMaskLTE
Unexecuted instantiation: sm2.c:ctMaskLTE
Unexecuted instantiation: sm3.c:ctMaskLTE
Unexecuted instantiation: sm4.c:ctMaskLTE
Unexecuted instantiation: sp_int.c:ctMaskLTE
Unexecuted instantiation: wc_encrypt.c:ctMaskLTE
Unexecuted instantiation: wolfmath.c:ctMaskLTE
Unexecuted instantiation: ssl.c:ctMaskLTE
Unexecuted instantiation: tls.c:ctMaskLTE
Unexecuted instantiation: tls13.c:ctMaskLTE
internal.c:ctMaskLTE
Line
Count
Source
677
26.1k
{
678
26.1k
    return (byte)((((word32)b - (word32)a) >> 31) - 1);
679
26.1k
}
680
681
/* Constant time - mask set when a == b. */
682
WC_MISC_STATIC WC_INLINE byte ctMaskEq(int a, int b)
683
44.6k
{
684
44.6k
    return (byte)((byte)(~ctMaskGT(a, b)) & (byte)(~ctMaskLT(a, b)));
685
44.6k
}
Unexecuted instantiation: aes.c:ctMaskEq
Unexecuted instantiation: asn.c:ctMaskEq
Unexecuted instantiation: camellia.c:ctMaskEq
Unexecuted instantiation: chacha.c:ctMaskEq
Unexecuted instantiation: chacha20_poly1305.c:ctMaskEq
Unexecuted instantiation: cmac.c:ctMaskEq
Unexecuted instantiation: coding.c:ctMaskEq
Unexecuted instantiation: curve25519.c:ctMaskEq
Unexecuted instantiation: curve448.c:ctMaskEq
Unexecuted instantiation: des3.c:ctMaskEq
Unexecuted instantiation: dh.c:ctMaskEq
Unexecuted instantiation: ecc.c:ctMaskEq
Unexecuted instantiation: eccsi.c:ctMaskEq
Unexecuted instantiation: ed25519.c:ctMaskEq
Unexecuted instantiation: ed448.c:ctMaskEq
Unexecuted instantiation: fe_448.c:ctMaskEq
Unexecuted instantiation: fe_operations.c:ctMaskEq
Unexecuted instantiation: ge_448.c:ctMaskEq
Unexecuted instantiation: ge_operations.c:ctMaskEq
Unexecuted instantiation: hash.c:ctMaskEq
Unexecuted instantiation: hmac.c:ctMaskEq
Unexecuted instantiation: kdf.c:ctMaskEq
Unexecuted instantiation: md2.c:ctMaskEq
Unexecuted instantiation: md4.c:ctMaskEq
Unexecuted instantiation: md5.c:ctMaskEq
Unexecuted instantiation: poly1305.c:ctMaskEq
Unexecuted instantiation: pwdbased.c:ctMaskEq
Unexecuted instantiation: random.c:ctMaskEq
Unexecuted instantiation: ripemd.c:ctMaskEq
Unexecuted instantiation: rsa.c:ctMaskEq
Unexecuted instantiation: sha.c:ctMaskEq
Unexecuted instantiation: sha256.c:ctMaskEq
Unexecuted instantiation: sha3.c:ctMaskEq
Unexecuted instantiation: sha512.c:ctMaskEq
Unexecuted instantiation: siphash.c:ctMaskEq
Unexecuted instantiation: sm2.c:ctMaskEq
Unexecuted instantiation: sm3.c:ctMaskEq
Unexecuted instantiation: sm4.c:ctMaskEq
sp_int.c:ctMaskEq
Line
Count
Source
683
771
{
684
771
    return (byte)((byte)(~ctMaskGT(a, b)) & (byte)(~ctMaskLT(a, b)));
685
771
}
Unexecuted instantiation: wc_encrypt.c:ctMaskEq
Unexecuted instantiation: wolfmath.c:ctMaskEq
Unexecuted instantiation: ssl.c:ctMaskEq
tls.c:ctMaskEq
Line
Count
Source
683
43.9k
{
684
43.9k
    return (byte)((byte)(~ctMaskGT(a, b)) & (byte)(~ctMaskLT(a, b)));
685
43.9k
}
Unexecuted instantiation: tls13.c:ctMaskEq
Unexecuted instantiation: internal.c:ctMaskEq
686
687
/* Constant time - sets 16 bit integer mask when a > b */
688
WC_MISC_STATIC WC_INLINE word16 ctMask16GT(int a, int b)
689
0
{
690
0
    return (word16)((((word32)a - (word32)b - 1) >> 31) - 1);
691
0
}
Unexecuted instantiation: aes.c:ctMask16GT
Unexecuted instantiation: asn.c:ctMask16GT
Unexecuted instantiation: camellia.c:ctMask16GT
Unexecuted instantiation: chacha.c:ctMask16GT
Unexecuted instantiation: chacha20_poly1305.c:ctMask16GT
Unexecuted instantiation: cmac.c:ctMask16GT
Unexecuted instantiation: coding.c:ctMask16GT
Unexecuted instantiation: curve25519.c:ctMask16GT
Unexecuted instantiation: curve448.c:ctMask16GT
Unexecuted instantiation: des3.c:ctMask16GT
Unexecuted instantiation: dh.c:ctMask16GT
Unexecuted instantiation: ecc.c:ctMask16GT
Unexecuted instantiation: eccsi.c:ctMask16GT
Unexecuted instantiation: ed25519.c:ctMask16GT
Unexecuted instantiation: ed448.c:ctMask16GT
Unexecuted instantiation: fe_448.c:ctMask16GT
Unexecuted instantiation: fe_operations.c:ctMask16GT
Unexecuted instantiation: ge_448.c:ctMask16GT
Unexecuted instantiation: ge_operations.c:ctMask16GT
Unexecuted instantiation: hash.c:ctMask16GT
Unexecuted instantiation: hmac.c:ctMask16GT
Unexecuted instantiation: kdf.c:ctMask16GT
Unexecuted instantiation: md2.c:ctMask16GT
Unexecuted instantiation: md4.c:ctMask16GT
Unexecuted instantiation: md5.c:ctMask16GT
Unexecuted instantiation: poly1305.c:ctMask16GT
Unexecuted instantiation: pwdbased.c:ctMask16GT
Unexecuted instantiation: random.c:ctMask16GT
Unexecuted instantiation: ripemd.c:ctMask16GT
Unexecuted instantiation: rsa.c:ctMask16GT
Unexecuted instantiation: sha.c:ctMask16GT
Unexecuted instantiation: sha256.c:ctMask16GT
Unexecuted instantiation: sha3.c:ctMask16GT
Unexecuted instantiation: sha512.c:ctMask16GT
Unexecuted instantiation: siphash.c:ctMask16GT
Unexecuted instantiation: sm2.c:ctMask16GT
Unexecuted instantiation: sm3.c:ctMask16GT
Unexecuted instantiation: sm4.c:ctMask16GT
Unexecuted instantiation: sp_int.c:ctMask16GT
Unexecuted instantiation: wc_encrypt.c:ctMask16GT
Unexecuted instantiation: wolfmath.c:ctMask16GT
Unexecuted instantiation: ssl.c:ctMask16GT
Unexecuted instantiation: tls.c:ctMask16GT
Unexecuted instantiation: tls13.c:ctMask16GT
Unexecuted instantiation: internal.c:ctMask16GT
692
693
/* Constant time - sets 16 bit integer mask when a >= b */
694
WC_MISC_STATIC WC_INLINE word16 ctMask16GTE(int a, int b)
695
0
{
696
0
    return (word16)((((word32)a - (word32)b) >> 31) - 1);
697
0
}
Unexecuted instantiation: aes.c:ctMask16GTE
Unexecuted instantiation: asn.c:ctMask16GTE
Unexecuted instantiation: camellia.c:ctMask16GTE
Unexecuted instantiation: chacha.c:ctMask16GTE
Unexecuted instantiation: chacha20_poly1305.c:ctMask16GTE
Unexecuted instantiation: cmac.c:ctMask16GTE
Unexecuted instantiation: coding.c:ctMask16GTE
Unexecuted instantiation: curve25519.c:ctMask16GTE
Unexecuted instantiation: curve448.c:ctMask16GTE
Unexecuted instantiation: des3.c:ctMask16GTE
Unexecuted instantiation: dh.c:ctMask16GTE
Unexecuted instantiation: ecc.c:ctMask16GTE
Unexecuted instantiation: eccsi.c:ctMask16GTE
Unexecuted instantiation: ed25519.c:ctMask16GTE
Unexecuted instantiation: ed448.c:ctMask16GTE
Unexecuted instantiation: fe_448.c:ctMask16GTE
Unexecuted instantiation: fe_operations.c:ctMask16GTE
Unexecuted instantiation: ge_448.c:ctMask16GTE
Unexecuted instantiation: ge_operations.c:ctMask16GTE
Unexecuted instantiation: hash.c:ctMask16GTE
Unexecuted instantiation: hmac.c:ctMask16GTE
Unexecuted instantiation: kdf.c:ctMask16GTE
Unexecuted instantiation: md2.c:ctMask16GTE
Unexecuted instantiation: md4.c:ctMask16GTE
Unexecuted instantiation: md5.c:ctMask16GTE
Unexecuted instantiation: poly1305.c:ctMask16GTE
Unexecuted instantiation: pwdbased.c:ctMask16GTE
Unexecuted instantiation: random.c:ctMask16GTE
Unexecuted instantiation: ripemd.c:ctMask16GTE
Unexecuted instantiation: rsa.c:ctMask16GTE
Unexecuted instantiation: sha.c:ctMask16GTE
Unexecuted instantiation: sha256.c:ctMask16GTE
Unexecuted instantiation: sha3.c:ctMask16GTE
Unexecuted instantiation: sha512.c:ctMask16GTE
Unexecuted instantiation: siphash.c:ctMask16GTE
Unexecuted instantiation: sm2.c:ctMask16GTE
Unexecuted instantiation: sm3.c:ctMask16GTE
Unexecuted instantiation: sm4.c:ctMask16GTE
Unexecuted instantiation: sp_int.c:ctMask16GTE
Unexecuted instantiation: wc_encrypt.c:ctMask16GTE
Unexecuted instantiation: wolfmath.c:ctMask16GTE
Unexecuted instantiation: ssl.c:ctMask16GTE
Unexecuted instantiation: tls.c:ctMask16GTE
Unexecuted instantiation: tls13.c:ctMask16GTE
Unexecuted instantiation: internal.c:ctMask16GTE
698
699
/* Constant time - sets 16 bit integer mask when a < b. */
700
WC_MISC_STATIC WC_INLINE word16 ctMask16LT(int a, int b)
701
0
{
702
0
    return (word16)((((word32)b - (word32)a - 1) >> 31) - 1);
703
0
}
Unexecuted instantiation: aes.c:ctMask16LT
Unexecuted instantiation: asn.c:ctMask16LT
Unexecuted instantiation: camellia.c:ctMask16LT
Unexecuted instantiation: chacha.c:ctMask16LT
Unexecuted instantiation: chacha20_poly1305.c:ctMask16LT
Unexecuted instantiation: cmac.c:ctMask16LT
Unexecuted instantiation: coding.c:ctMask16LT
Unexecuted instantiation: curve25519.c:ctMask16LT
Unexecuted instantiation: curve448.c:ctMask16LT
Unexecuted instantiation: des3.c:ctMask16LT
Unexecuted instantiation: dh.c:ctMask16LT
Unexecuted instantiation: ecc.c:ctMask16LT
Unexecuted instantiation: eccsi.c:ctMask16LT
Unexecuted instantiation: ed25519.c:ctMask16LT
Unexecuted instantiation: ed448.c:ctMask16LT
Unexecuted instantiation: fe_448.c:ctMask16LT
Unexecuted instantiation: fe_operations.c:ctMask16LT
Unexecuted instantiation: ge_448.c:ctMask16LT
Unexecuted instantiation: ge_operations.c:ctMask16LT
Unexecuted instantiation: hash.c:ctMask16LT
Unexecuted instantiation: hmac.c:ctMask16LT
Unexecuted instantiation: kdf.c:ctMask16LT
Unexecuted instantiation: md2.c:ctMask16LT
Unexecuted instantiation: md4.c:ctMask16LT
Unexecuted instantiation: md5.c:ctMask16LT
Unexecuted instantiation: poly1305.c:ctMask16LT
Unexecuted instantiation: pwdbased.c:ctMask16LT
Unexecuted instantiation: random.c:ctMask16LT
Unexecuted instantiation: ripemd.c:ctMask16LT
Unexecuted instantiation: rsa.c:ctMask16LT
Unexecuted instantiation: sha.c:ctMask16LT
Unexecuted instantiation: sha256.c:ctMask16LT
Unexecuted instantiation: sha3.c:ctMask16LT
Unexecuted instantiation: sha512.c:ctMask16LT
Unexecuted instantiation: siphash.c:ctMask16LT
Unexecuted instantiation: sm2.c:ctMask16LT
Unexecuted instantiation: sm3.c:ctMask16LT
Unexecuted instantiation: sm4.c:ctMask16LT
Unexecuted instantiation: sp_int.c:ctMask16LT
Unexecuted instantiation: wc_encrypt.c:ctMask16LT
Unexecuted instantiation: wolfmath.c:ctMask16LT
Unexecuted instantiation: ssl.c:ctMask16LT
Unexecuted instantiation: tls.c:ctMask16LT
Unexecuted instantiation: tls13.c:ctMask16LT
Unexecuted instantiation: internal.c:ctMask16LT
704
705
/* Constant time - sets 16 bit integer mask when a <= b. */
706
WC_MISC_STATIC WC_INLINE word16 ctMask16LTE(int a, int b)
707
0
{
708
0
    return (word16)((((word32)b - (word32)a) >> 31) - 1);
709
0
}
Unexecuted instantiation: aes.c:ctMask16LTE
Unexecuted instantiation: asn.c:ctMask16LTE
Unexecuted instantiation: camellia.c:ctMask16LTE
Unexecuted instantiation: chacha.c:ctMask16LTE
Unexecuted instantiation: chacha20_poly1305.c:ctMask16LTE
Unexecuted instantiation: cmac.c:ctMask16LTE
Unexecuted instantiation: coding.c:ctMask16LTE
Unexecuted instantiation: curve25519.c:ctMask16LTE
Unexecuted instantiation: curve448.c:ctMask16LTE
Unexecuted instantiation: des3.c:ctMask16LTE
Unexecuted instantiation: dh.c:ctMask16LTE
Unexecuted instantiation: ecc.c:ctMask16LTE
Unexecuted instantiation: eccsi.c:ctMask16LTE
Unexecuted instantiation: ed25519.c:ctMask16LTE
Unexecuted instantiation: ed448.c:ctMask16LTE
Unexecuted instantiation: fe_448.c:ctMask16LTE
Unexecuted instantiation: fe_operations.c:ctMask16LTE
Unexecuted instantiation: ge_448.c:ctMask16LTE
Unexecuted instantiation: ge_operations.c:ctMask16LTE
Unexecuted instantiation: hash.c:ctMask16LTE
Unexecuted instantiation: hmac.c:ctMask16LTE
Unexecuted instantiation: kdf.c:ctMask16LTE
Unexecuted instantiation: md2.c:ctMask16LTE
Unexecuted instantiation: md4.c:ctMask16LTE
Unexecuted instantiation: md5.c:ctMask16LTE
Unexecuted instantiation: poly1305.c:ctMask16LTE
Unexecuted instantiation: pwdbased.c:ctMask16LTE
Unexecuted instantiation: random.c:ctMask16LTE
Unexecuted instantiation: ripemd.c:ctMask16LTE
Unexecuted instantiation: rsa.c:ctMask16LTE
Unexecuted instantiation: sha.c:ctMask16LTE
Unexecuted instantiation: sha256.c:ctMask16LTE
Unexecuted instantiation: sha3.c:ctMask16LTE
Unexecuted instantiation: sha512.c:ctMask16LTE
Unexecuted instantiation: siphash.c:ctMask16LTE
Unexecuted instantiation: sm2.c:ctMask16LTE
Unexecuted instantiation: sm3.c:ctMask16LTE
Unexecuted instantiation: sm4.c:ctMask16LTE
Unexecuted instantiation: sp_int.c:ctMask16LTE
Unexecuted instantiation: wc_encrypt.c:ctMask16LTE
Unexecuted instantiation: wolfmath.c:ctMask16LTE
Unexecuted instantiation: ssl.c:ctMask16LTE
Unexecuted instantiation: tls.c:ctMask16LTE
Unexecuted instantiation: tls13.c:ctMask16LTE
Unexecuted instantiation: internal.c:ctMask16LTE
710
711
/* Constant time - sets 16 bit integer mask when a == b. */
712
WC_MISC_STATIC WC_INLINE word16 ctMask16Eq(int a, int b)
713
0
{
714
0
    return (word16)((word16)(~ctMask16GT(a, b)) & (word16)(~ctMask16LT(a, b)));
715
0
}
Unexecuted instantiation: aes.c:ctMask16Eq
Unexecuted instantiation: asn.c:ctMask16Eq
Unexecuted instantiation: camellia.c:ctMask16Eq
Unexecuted instantiation: chacha.c:ctMask16Eq
Unexecuted instantiation: chacha20_poly1305.c:ctMask16Eq
Unexecuted instantiation: cmac.c:ctMask16Eq
Unexecuted instantiation: coding.c:ctMask16Eq
Unexecuted instantiation: curve25519.c:ctMask16Eq
Unexecuted instantiation: curve448.c:ctMask16Eq
Unexecuted instantiation: des3.c:ctMask16Eq
Unexecuted instantiation: dh.c:ctMask16Eq
Unexecuted instantiation: ecc.c:ctMask16Eq
Unexecuted instantiation: eccsi.c:ctMask16Eq
Unexecuted instantiation: ed25519.c:ctMask16Eq
Unexecuted instantiation: ed448.c:ctMask16Eq
Unexecuted instantiation: fe_448.c:ctMask16Eq
Unexecuted instantiation: fe_operations.c:ctMask16Eq
Unexecuted instantiation: ge_448.c:ctMask16Eq
Unexecuted instantiation: ge_operations.c:ctMask16Eq
Unexecuted instantiation: hash.c:ctMask16Eq
Unexecuted instantiation: hmac.c:ctMask16Eq
Unexecuted instantiation: kdf.c:ctMask16Eq
Unexecuted instantiation: md2.c:ctMask16Eq
Unexecuted instantiation: md4.c:ctMask16Eq
Unexecuted instantiation: md5.c:ctMask16Eq
Unexecuted instantiation: poly1305.c:ctMask16Eq
Unexecuted instantiation: pwdbased.c:ctMask16Eq
Unexecuted instantiation: random.c:ctMask16Eq
Unexecuted instantiation: ripemd.c:ctMask16Eq
Unexecuted instantiation: rsa.c:ctMask16Eq
Unexecuted instantiation: sha.c:ctMask16Eq
Unexecuted instantiation: sha256.c:ctMask16Eq
Unexecuted instantiation: sha3.c:ctMask16Eq
Unexecuted instantiation: sha512.c:ctMask16Eq
Unexecuted instantiation: siphash.c:ctMask16Eq
Unexecuted instantiation: sm2.c:ctMask16Eq
Unexecuted instantiation: sm3.c:ctMask16Eq
Unexecuted instantiation: sm4.c:ctMask16Eq
Unexecuted instantiation: sp_int.c:ctMask16Eq
Unexecuted instantiation: wc_encrypt.c:ctMask16Eq
Unexecuted instantiation: wolfmath.c:ctMask16Eq
Unexecuted instantiation: ssl.c:ctMask16Eq
Unexecuted instantiation: tls.c:ctMask16Eq
Unexecuted instantiation: tls13.c:ctMask16Eq
Unexecuted instantiation: internal.c:ctMask16Eq
716
717
/* Constant time - mask set when a != b. */
718
WC_MISC_STATIC WC_INLINE byte ctMaskNotEq(int a, int b)
719
6.94k
{
720
6.94k
    return (byte)((byte)ctMaskGT(a, b) | (byte)ctMaskLT(a, b));
721
6.94k
}
Unexecuted instantiation: aes.c:ctMaskNotEq
Unexecuted instantiation: asn.c:ctMaskNotEq
Unexecuted instantiation: camellia.c:ctMaskNotEq
Unexecuted instantiation: chacha.c:ctMaskNotEq
Unexecuted instantiation: chacha20_poly1305.c:ctMaskNotEq
Unexecuted instantiation: cmac.c:ctMaskNotEq
Unexecuted instantiation: coding.c:ctMaskNotEq
Unexecuted instantiation: curve25519.c:ctMaskNotEq
Unexecuted instantiation: curve448.c:ctMaskNotEq
Unexecuted instantiation: des3.c:ctMaskNotEq
Unexecuted instantiation: dh.c:ctMaskNotEq
Unexecuted instantiation: ecc.c:ctMaskNotEq
Unexecuted instantiation: eccsi.c:ctMaskNotEq
Unexecuted instantiation: ed25519.c:ctMaskNotEq
Unexecuted instantiation: ed448.c:ctMaskNotEq
Unexecuted instantiation: fe_448.c:ctMaskNotEq
Unexecuted instantiation: fe_operations.c:ctMaskNotEq
Unexecuted instantiation: ge_448.c:ctMaskNotEq
Unexecuted instantiation: ge_operations.c:ctMaskNotEq
Unexecuted instantiation: hash.c:ctMaskNotEq
Unexecuted instantiation: hmac.c:ctMaskNotEq
Unexecuted instantiation: kdf.c:ctMaskNotEq
Unexecuted instantiation: md2.c:ctMaskNotEq
Unexecuted instantiation: md4.c:ctMaskNotEq
Unexecuted instantiation: md5.c:ctMaskNotEq
Unexecuted instantiation: poly1305.c:ctMaskNotEq
Unexecuted instantiation: pwdbased.c:ctMaskNotEq
Unexecuted instantiation: random.c:ctMaskNotEq
Unexecuted instantiation: ripemd.c:ctMaskNotEq
rsa.c:ctMaskNotEq
Line
Count
Source
719
6.94k
{
720
6.94k
    return (byte)((byte)ctMaskGT(a, b) | (byte)ctMaskLT(a, b));
721
6.94k
}
Unexecuted instantiation: sha.c:ctMaskNotEq
Unexecuted instantiation: sha256.c:ctMaskNotEq
Unexecuted instantiation: sha3.c:ctMaskNotEq
Unexecuted instantiation: sha512.c:ctMaskNotEq
Unexecuted instantiation: siphash.c:ctMaskNotEq
Unexecuted instantiation: sm2.c:ctMaskNotEq
Unexecuted instantiation: sm3.c:ctMaskNotEq
Unexecuted instantiation: sm4.c:ctMaskNotEq
Unexecuted instantiation: sp_int.c:ctMaskNotEq
Unexecuted instantiation: wc_encrypt.c:ctMaskNotEq
Unexecuted instantiation: wolfmath.c:ctMaskNotEq
Unexecuted instantiation: ssl.c:ctMaskNotEq
Unexecuted instantiation: tls.c:ctMaskNotEq
Unexecuted instantiation: tls13.c:ctMaskNotEq
Unexecuted instantiation: internal.c:ctMaskNotEq
722
723
/* Constant time - select a when mask is set and b otherwise. */
724
WC_MISC_STATIC WC_INLINE byte ctMaskSel(byte m, byte a, byte b)
725
47.0k
{
726
47.0k
    return (byte)((b & ((byte)~(word32)m)) | (a & m));
727
47.0k
}
Unexecuted instantiation: aes.c:ctMaskSel
Unexecuted instantiation: asn.c:ctMaskSel
Unexecuted instantiation: camellia.c:ctMaskSel
Unexecuted instantiation: chacha.c:ctMaskSel
Unexecuted instantiation: chacha20_poly1305.c:ctMaskSel
Unexecuted instantiation: cmac.c:ctMaskSel
Unexecuted instantiation: coding.c:ctMaskSel
Unexecuted instantiation: curve25519.c:ctMaskSel
Unexecuted instantiation: curve448.c:ctMaskSel
Unexecuted instantiation: des3.c:ctMaskSel
Unexecuted instantiation: dh.c:ctMaskSel
Unexecuted instantiation: ecc.c:ctMaskSel
Unexecuted instantiation: eccsi.c:ctMaskSel
Unexecuted instantiation: ed25519.c:ctMaskSel
Unexecuted instantiation: ed448.c:ctMaskSel
Unexecuted instantiation: fe_448.c:ctMaskSel
Unexecuted instantiation: fe_operations.c:ctMaskSel
Unexecuted instantiation: ge_448.c:ctMaskSel
Unexecuted instantiation: ge_operations.c:ctMaskSel
Unexecuted instantiation: hash.c:ctMaskSel
Unexecuted instantiation: hmac.c:ctMaskSel
Unexecuted instantiation: kdf.c:ctMaskSel
Unexecuted instantiation: md2.c:ctMaskSel
Unexecuted instantiation: md4.c:ctMaskSel
Unexecuted instantiation: md5.c:ctMaskSel
Unexecuted instantiation: poly1305.c:ctMaskSel
Unexecuted instantiation: pwdbased.c:ctMaskSel
Unexecuted instantiation: random.c:ctMaskSel
Unexecuted instantiation: ripemd.c:ctMaskSel
Unexecuted instantiation: rsa.c:ctMaskSel
Unexecuted instantiation: sha.c:ctMaskSel
Unexecuted instantiation: sha256.c:ctMaskSel
Unexecuted instantiation: sha3.c:ctMaskSel
Unexecuted instantiation: sha512.c:ctMaskSel
Unexecuted instantiation: siphash.c:ctMaskSel
Unexecuted instantiation: sm2.c:ctMaskSel
Unexecuted instantiation: sm3.c:ctMaskSel
Unexecuted instantiation: sm4.c:ctMaskSel
Unexecuted instantiation: sp_int.c:ctMaskSel
Unexecuted instantiation: wc_encrypt.c:ctMaskSel
Unexecuted instantiation: wolfmath.c:ctMaskSel
Unexecuted instantiation: ssl.c:ctMaskSel
tls.c:ctMaskSel
Line
Count
Source
725
47.0k
{
726
47.0k
    return (byte)((b & ((byte)~(word32)m)) | (a & m));
727
47.0k
}
Unexecuted instantiation: tls13.c:ctMaskSel
Unexecuted instantiation: internal.c:ctMaskSel
728
729
/* Constant time - select integer a when mask is set and integer b otherwise. */
730
WC_MISC_STATIC WC_INLINE int ctMaskSelInt(byte m, int a, int b)
731
13.8k
{
732
13.8k
    return (b & (~(signed int)(signed char)m)) |
733
13.8k
           (a & ( (signed int)(signed char)m));
734
13.8k
}
Unexecuted instantiation: aes.c:ctMaskSelInt
Unexecuted instantiation: asn.c:ctMaskSelInt
Unexecuted instantiation: camellia.c:ctMaskSelInt
Unexecuted instantiation: chacha.c:ctMaskSelInt
Unexecuted instantiation: chacha20_poly1305.c:ctMaskSelInt
Unexecuted instantiation: cmac.c:ctMaskSelInt
Unexecuted instantiation: coding.c:ctMaskSelInt
Unexecuted instantiation: curve25519.c:ctMaskSelInt
Unexecuted instantiation: curve448.c:ctMaskSelInt
Unexecuted instantiation: des3.c:ctMaskSelInt
Unexecuted instantiation: dh.c:ctMaskSelInt
Unexecuted instantiation: ecc.c:ctMaskSelInt
Unexecuted instantiation: eccsi.c:ctMaskSelInt
Unexecuted instantiation: ed25519.c:ctMaskSelInt
Unexecuted instantiation: ed448.c:ctMaskSelInt
Unexecuted instantiation: fe_448.c:ctMaskSelInt
Unexecuted instantiation: fe_operations.c:ctMaskSelInt
Unexecuted instantiation: ge_448.c:ctMaskSelInt
Unexecuted instantiation: ge_operations.c:ctMaskSelInt
Unexecuted instantiation: hash.c:ctMaskSelInt
Unexecuted instantiation: hmac.c:ctMaskSelInt
Unexecuted instantiation: kdf.c:ctMaskSelInt
Unexecuted instantiation: md2.c:ctMaskSelInt
Unexecuted instantiation: md4.c:ctMaskSelInt
Unexecuted instantiation: md5.c:ctMaskSelInt
Unexecuted instantiation: poly1305.c:ctMaskSelInt
Unexecuted instantiation: pwdbased.c:ctMaskSelInt
Unexecuted instantiation: random.c:ctMaskSelInt
Unexecuted instantiation: ripemd.c:ctMaskSelInt
rsa.c:ctMaskSelInt
Line
Count
Source
731
13.8k
{
732
13.8k
    return (b & (~(signed int)(signed char)m)) |
733
13.8k
           (a & ( (signed int)(signed char)m));
734
13.8k
}
Unexecuted instantiation: sha.c:ctMaskSelInt
Unexecuted instantiation: sha256.c:ctMaskSelInt
Unexecuted instantiation: sha3.c:ctMaskSelInt
Unexecuted instantiation: sha512.c:ctMaskSelInt
Unexecuted instantiation: siphash.c:ctMaskSelInt
Unexecuted instantiation: sm2.c:ctMaskSelInt
Unexecuted instantiation: sm3.c:ctMaskSelInt
Unexecuted instantiation: sm4.c:ctMaskSelInt
Unexecuted instantiation: sp_int.c:ctMaskSelInt
Unexecuted instantiation: wc_encrypt.c:ctMaskSelInt
Unexecuted instantiation: wolfmath.c:ctMaskSelInt
Unexecuted instantiation: ssl.c:ctMaskSelInt
Unexecuted instantiation: tls.c:ctMaskSelInt
Unexecuted instantiation: tls13.c:ctMaskSelInt
Unexecuted instantiation: internal.c:ctMaskSelInt
735
736
/* Constant time - select word32 a when mask is set and word32 b otherwise. */
737
WC_MISC_STATIC WC_INLINE word32 ctMaskSelWord32(byte m, word32 a, word32 b)
738
0
{
739
0
    return (((word32)b & (word32)(~(signed int)(signed char)m)) |
740
0
            ((word32)a & (word32)( (signed int)(signed char)m)));
741
0
}
Unexecuted instantiation: aes.c:ctMaskSelWord32
Unexecuted instantiation: asn.c:ctMaskSelWord32
Unexecuted instantiation: camellia.c:ctMaskSelWord32
Unexecuted instantiation: chacha.c:ctMaskSelWord32
Unexecuted instantiation: chacha20_poly1305.c:ctMaskSelWord32
Unexecuted instantiation: cmac.c:ctMaskSelWord32
Unexecuted instantiation: coding.c:ctMaskSelWord32
Unexecuted instantiation: curve25519.c:ctMaskSelWord32
Unexecuted instantiation: curve448.c:ctMaskSelWord32
Unexecuted instantiation: des3.c:ctMaskSelWord32
Unexecuted instantiation: dh.c:ctMaskSelWord32
Unexecuted instantiation: ecc.c:ctMaskSelWord32
Unexecuted instantiation: eccsi.c:ctMaskSelWord32
Unexecuted instantiation: ed25519.c:ctMaskSelWord32
Unexecuted instantiation: ed448.c:ctMaskSelWord32
Unexecuted instantiation: fe_448.c:ctMaskSelWord32
Unexecuted instantiation: fe_operations.c:ctMaskSelWord32
Unexecuted instantiation: ge_448.c:ctMaskSelWord32
Unexecuted instantiation: ge_operations.c:ctMaskSelWord32
Unexecuted instantiation: hash.c:ctMaskSelWord32
Unexecuted instantiation: hmac.c:ctMaskSelWord32
Unexecuted instantiation: kdf.c:ctMaskSelWord32
Unexecuted instantiation: md2.c:ctMaskSelWord32
Unexecuted instantiation: md4.c:ctMaskSelWord32
Unexecuted instantiation: md5.c:ctMaskSelWord32
Unexecuted instantiation: poly1305.c:ctMaskSelWord32
Unexecuted instantiation: pwdbased.c:ctMaskSelWord32
Unexecuted instantiation: random.c:ctMaskSelWord32
Unexecuted instantiation: ripemd.c:ctMaskSelWord32
Unexecuted instantiation: rsa.c:ctMaskSelWord32
Unexecuted instantiation: sha.c:ctMaskSelWord32
Unexecuted instantiation: sha256.c:ctMaskSelWord32
Unexecuted instantiation: sha3.c:ctMaskSelWord32
Unexecuted instantiation: sha512.c:ctMaskSelWord32
Unexecuted instantiation: siphash.c:ctMaskSelWord32
Unexecuted instantiation: sm2.c:ctMaskSelWord32
Unexecuted instantiation: sm3.c:ctMaskSelWord32
Unexecuted instantiation: sm4.c:ctMaskSelWord32
Unexecuted instantiation: sp_int.c:ctMaskSelWord32
Unexecuted instantiation: wc_encrypt.c:ctMaskSelWord32
Unexecuted instantiation: wolfmath.c:ctMaskSelWord32
Unexecuted instantiation: ssl.c:ctMaskSelWord32
Unexecuted instantiation: tls.c:ctMaskSelWord32
Unexecuted instantiation: tls13.c:ctMaskSelWord32
Unexecuted instantiation: internal.c:ctMaskSelWord32
742
743
/* Constant time - bit set when a <= b. */
744
WC_MISC_STATIC WC_INLINE byte ctSetLTE(int a, int b)
745
145
{
746
145
    return (byte)(((word32)a - (word32)b - 1) >> 31);
747
145
}
Unexecuted instantiation: aes.c:ctSetLTE
Unexecuted instantiation: asn.c:ctSetLTE
Unexecuted instantiation: camellia.c:ctSetLTE
Unexecuted instantiation: chacha.c:ctSetLTE
Unexecuted instantiation: chacha20_poly1305.c:ctSetLTE
Unexecuted instantiation: cmac.c:ctSetLTE
Unexecuted instantiation: coding.c:ctSetLTE
Unexecuted instantiation: curve25519.c:ctSetLTE
Unexecuted instantiation: curve448.c:ctSetLTE
Unexecuted instantiation: des3.c:ctSetLTE
Unexecuted instantiation: dh.c:ctSetLTE
Unexecuted instantiation: ecc.c:ctSetLTE
Unexecuted instantiation: eccsi.c:ctSetLTE
Unexecuted instantiation: ed25519.c:ctSetLTE
Unexecuted instantiation: ed448.c:ctSetLTE
Unexecuted instantiation: fe_448.c:ctSetLTE
Unexecuted instantiation: fe_operations.c:ctSetLTE
Unexecuted instantiation: ge_448.c:ctSetLTE
Unexecuted instantiation: ge_operations.c:ctSetLTE
Unexecuted instantiation: hash.c:ctSetLTE
Unexecuted instantiation: hmac.c:ctSetLTE
Unexecuted instantiation: kdf.c:ctSetLTE
Unexecuted instantiation: md2.c:ctSetLTE
Unexecuted instantiation: md4.c:ctSetLTE
Unexecuted instantiation: md5.c:ctSetLTE
Unexecuted instantiation: poly1305.c:ctSetLTE
Unexecuted instantiation: pwdbased.c:ctSetLTE
Unexecuted instantiation: random.c:ctSetLTE
Unexecuted instantiation: ripemd.c:ctSetLTE
Unexecuted instantiation: rsa.c:ctSetLTE
Unexecuted instantiation: sha.c:ctSetLTE
Unexecuted instantiation: sha256.c:ctSetLTE
Unexecuted instantiation: sha3.c:ctSetLTE
Unexecuted instantiation: sha512.c:ctSetLTE
Unexecuted instantiation: siphash.c:ctSetLTE
Unexecuted instantiation: sm2.c:ctSetLTE
Unexecuted instantiation: sm3.c:ctSetLTE
Unexecuted instantiation: sm4.c:ctSetLTE
Unexecuted instantiation: sp_int.c:ctSetLTE
Unexecuted instantiation: wc_encrypt.c:ctSetLTE
Unexecuted instantiation: wolfmath.c:ctSetLTE
Unexecuted instantiation: ssl.c:ctSetLTE
tls.c:ctSetLTE
Line
Count
Source
745
145
{
746
145
    return (byte)(((word32)a - (word32)b - 1) >> 31);
747
145
}
Unexecuted instantiation: tls13.c:ctSetLTE
Unexecuted instantiation: internal.c:ctSetLTE
748
749
/* Constant time - conditionally copy size bytes from src to dst if mask is set
750
 */
751
WC_MISC_STATIC WC_INLINE void ctMaskCopy(byte mask, byte* dst, byte* src,
752
    word16 size)
753
0
{
754
0
    int i;
755
0
    for (i = 0; i < size; ++i) {
756
0
        dst[i] ^= (dst[i] ^ src[i]) & mask;
757
0
    }
758
0
}
Unexecuted instantiation: aes.c:ctMaskCopy
Unexecuted instantiation: asn.c:ctMaskCopy
Unexecuted instantiation: camellia.c:ctMaskCopy
Unexecuted instantiation: chacha.c:ctMaskCopy
Unexecuted instantiation: chacha20_poly1305.c:ctMaskCopy
Unexecuted instantiation: cmac.c:ctMaskCopy
Unexecuted instantiation: coding.c:ctMaskCopy
Unexecuted instantiation: curve25519.c:ctMaskCopy
Unexecuted instantiation: curve448.c:ctMaskCopy
Unexecuted instantiation: des3.c:ctMaskCopy
Unexecuted instantiation: dh.c:ctMaskCopy
Unexecuted instantiation: ecc.c:ctMaskCopy
Unexecuted instantiation: eccsi.c:ctMaskCopy
Unexecuted instantiation: ed25519.c:ctMaskCopy
Unexecuted instantiation: ed448.c:ctMaskCopy
Unexecuted instantiation: fe_448.c:ctMaskCopy
Unexecuted instantiation: fe_operations.c:ctMaskCopy
Unexecuted instantiation: ge_448.c:ctMaskCopy
Unexecuted instantiation: ge_operations.c:ctMaskCopy
Unexecuted instantiation: hash.c:ctMaskCopy
Unexecuted instantiation: hmac.c:ctMaskCopy
Unexecuted instantiation: kdf.c:ctMaskCopy
Unexecuted instantiation: md2.c:ctMaskCopy
Unexecuted instantiation: md4.c:ctMaskCopy
Unexecuted instantiation: md5.c:ctMaskCopy
Unexecuted instantiation: poly1305.c:ctMaskCopy
Unexecuted instantiation: pwdbased.c:ctMaskCopy
Unexecuted instantiation: random.c:ctMaskCopy
Unexecuted instantiation: ripemd.c:ctMaskCopy
Unexecuted instantiation: rsa.c:ctMaskCopy
Unexecuted instantiation: sha.c:ctMaskCopy
Unexecuted instantiation: sha256.c:ctMaskCopy
Unexecuted instantiation: sha3.c:ctMaskCopy
Unexecuted instantiation: sha512.c:ctMaskCopy
Unexecuted instantiation: siphash.c:ctMaskCopy
Unexecuted instantiation: sm2.c:ctMaskCopy
Unexecuted instantiation: sm3.c:ctMaskCopy
Unexecuted instantiation: sm4.c:ctMaskCopy
Unexecuted instantiation: sp_int.c:ctMaskCopy
Unexecuted instantiation: wc_encrypt.c:ctMaskCopy
Unexecuted instantiation: wolfmath.c:ctMaskCopy
Unexecuted instantiation: ssl.c:ctMaskCopy
Unexecuted instantiation: tls.c:ctMaskCopy
Unexecuted instantiation: tls13.c:ctMaskCopy
Unexecuted instantiation: internal.c:ctMaskCopy
759
760
#endif /* !WOLFSSL_NO_CT_OPS */
761
762
#ifndef WOLFSSL_HAVE_MIN
763
    #define WOLFSSL_HAVE_MIN
764
    #if defined(HAVE_FIPS) && !defined(min) /* so ifdef check passes */
765
        #define min min
766
    #endif
767
    /* returns the smaller of a and b */
768
    WC_MISC_STATIC WC_INLINE word32 min(word32 a, word32 b)
769
7.08M
    {
770
7.08M
#if !defined(WOLFSSL_NO_CT_OPS) && !defined(WOLFSSL_NO_CT_MAX_MIN) && \
771
7.08M
    defined(WORD64_AVAILABLE)
772
7.08M
        word32 gte_mask = (word32)ctMaskWord32GTE(a, b);
773
7.08M
        return (a & ~gte_mask) | (b & gte_mask);
774
#else /* WOLFSSL_NO_CT_OPS */
775
        return a > b ? b : a;
776
#endif /* WOLFSSL_NO_CT_OPS */
777
7.08M
    }
aes.c:min
Line
Count
Source
769
1.68k
    {
770
1.68k
#if !defined(WOLFSSL_NO_CT_OPS) && !defined(WOLFSSL_NO_CT_MAX_MIN) && \
771
1.68k
    defined(WORD64_AVAILABLE)
772
1.68k
        word32 gte_mask = (word32)ctMaskWord32GTE(a, b);
773
1.68k
        return (a & ~gte_mask) | (b & gte_mask);
774
#else /* WOLFSSL_NO_CT_OPS */
775
        return a > b ? b : a;
776
#endif /* WOLFSSL_NO_CT_OPS */
777
1.68k
    }
asn.c:min
Line
Count
Source
769
50.2k
    {
770
50.2k
#if !defined(WOLFSSL_NO_CT_OPS) && !defined(WOLFSSL_NO_CT_MAX_MIN) && \
771
50.2k
    defined(WORD64_AVAILABLE)
772
50.2k
        word32 gte_mask = (word32)ctMaskWord32GTE(a, b);
773
50.2k
        return (a & ~gte_mask) | (b & gte_mask);
774
#else /* WOLFSSL_NO_CT_OPS */
775
        return a > b ? b : a;
776
#endif /* WOLFSSL_NO_CT_OPS */
777
50.2k
    }
Unexecuted instantiation: camellia.c:min
Unexecuted instantiation: chacha.c:min
Unexecuted instantiation: chacha20_poly1305.c:min
cmac.c:min
Line
Count
Source
769
1.69k
    {
770
1.69k
#if !defined(WOLFSSL_NO_CT_OPS) && !defined(WOLFSSL_NO_CT_MAX_MIN) && \
771
1.69k
    defined(WORD64_AVAILABLE)
772
1.69k
        word32 gte_mask = (word32)ctMaskWord32GTE(a, b);
773
1.69k
        return (a & ~gte_mask) | (b & gte_mask);
774
#else /* WOLFSSL_NO_CT_OPS */
775
        return a > b ? b : a;
776
#endif /* WOLFSSL_NO_CT_OPS */
777
1.69k
    }
Unexecuted instantiation: coding.c:min
Unexecuted instantiation: curve25519.c:min
Unexecuted instantiation: curve448.c:min
Unexecuted instantiation: des3.c:min
dh.c:min
Line
Count
Source
769
75.0k
    {
770
75.0k
#if !defined(WOLFSSL_NO_CT_OPS) && !defined(WOLFSSL_NO_CT_MAX_MIN) && \
771
75.0k
    defined(WORD64_AVAILABLE)
772
75.0k
        word32 gte_mask = (word32)ctMaskWord32GTE(a, b);
773
75.0k
        return (a & ~gte_mask) | (b & gte_mask);
774
#else /* WOLFSSL_NO_CT_OPS */
775
        return a > b ? b : a;
776
#endif /* WOLFSSL_NO_CT_OPS */
777
75.0k
    }
Unexecuted instantiation: ecc.c:min
Unexecuted instantiation: eccsi.c:min
Unexecuted instantiation: ed25519.c:min
Unexecuted instantiation: ed448.c:min
Unexecuted instantiation: fe_448.c:min
Unexecuted instantiation: fe_operations.c:min
Unexecuted instantiation: ge_448.c:min
Unexecuted instantiation: ge_operations.c:min
Unexecuted instantiation: hash.c:min
hmac.c:min
Line
Count
Source
769
53.2k
    {
770
53.2k
#if !defined(WOLFSSL_NO_CT_OPS) && !defined(WOLFSSL_NO_CT_MAX_MIN) && \
771
53.2k
    defined(WORD64_AVAILABLE)
772
53.2k
        word32 gte_mask = (word32)ctMaskWord32GTE(a, b);
773
53.2k
        return (a & ~gte_mask) | (b & gte_mask);
774
#else /* WOLFSSL_NO_CT_OPS */
775
        return a > b ? b : a;
776
#endif /* WOLFSSL_NO_CT_OPS */
777
53.2k
    }
kdf.c:min
Line
Count
Source
769
2.92k
    {
770
2.92k
#if !defined(WOLFSSL_NO_CT_OPS) && !defined(WOLFSSL_NO_CT_MAX_MIN) && \
771
2.92k
    defined(WORD64_AVAILABLE)
772
2.92k
        word32 gte_mask = (word32)ctMaskWord32GTE(a, b);
773
2.92k
        return (a & ~gte_mask) | (b & gte_mask);
774
#else /* WOLFSSL_NO_CT_OPS */
775
        return a > b ? b : a;
776
#endif /* WOLFSSL_NO_CT_OPS */
777
2.92k
    }
Unexecuted instantiation: md2.c:min
md4.c:min
Line
Count
Source
769
1.86k
    {
770
1.86k
#if !defined(WOLFSSL_NO_CT_OPS) && !defined(WOLFSSL_NO_CT_MAX_MIN) && \
771
1.86k
    defined(WORD64_AVAILABLE)
772
1.86k
        word32 gte_mask = (word32)ctMaskWord32GTE(a, b);
773
1.86k
        return (a & ~gte_mask) | (b & gte_mask);
774
#else /* WOLFSSL_NO_CT_OPS */
775
        return a > b ? b : a;
776
#endif /* WOLFSSL_NO_CT_OPS */
777
1.86k
    }
md5.c:min
Line
Count
Source
769
126k
    {
770
126k
#if !defined(WOLFSSL_NO_CT_OPS) && !defined(WOLFSSL_NO_CT_MAX_MIN) && \
771
126k
    defined(WORD64_AVAILABLE)
772
126k
        word32 gte_mask = (word32)ctMaskWord32GTE(a, b);
773
126k
        return (a & ~gte_mask) | (b & gte_mask);
774
#else /* WOLFSSL_NO_CT_OPS */
775
        return a > b ? b : a;
776
#endif /* WOLFSSL_NO_CT_OPS */
777
126k
    }
Unexecuted instantiation: poly1305.c:min
pwdbased.c:min
Line
Count
Source
769
8.54k
    {
770
8.54k
#if !defined(WOLFSSL_NO_CT_OPS) && !defined(WOLFSSL_NO_CT_MAX_MIN) && \
771
8.54k
    defined(WORD64_AVAILABLE)
772
8.54k
        word32 gte_mask = (word32)ctMaskWord32GTE(a, b);
773
8.54k
        return (a & ~gte_mask) | (b & gte_mask);
774
#else /* WOLFSSL_NO_CT_OPS */
775
        return a > b ? b : a;
776
#endif /* WOLFSSL_NO_CT_OPS */
777
8.54k
    }
random.c:min
Line
Count
Source
769
1.45M
    {
770
1.45M
#if !defined(WOLFSSL_NO_CT_OPS) && !defined(WOLFSSL_NO_CT_MAX_MIN) && \
771
1.45M
    defined(WORD64_AVAILABLE)
772
1.45M
        word32 gte_mask = (word32)ctMaskWord32GTE(a, b);
773
1.45M
        return (a & ~gte_mask) | (b & gte_mask);
774
#else /* WOLFSSL_NO_CT_OPS */
775
        return a > b ? b : a;
776
#endif /* WOLFSSL_NO_CT_OPS */
777
1.45M
    }
Unexecuted instantiation: ripemd.c:min
Unexecuted instantiation: rsa.c:min
sha.c:min
Line
Count
Source
769
242k
    {
770
242k
#if !defined(WOLFSSL_NO_CT_OPS) && !defined(WOLFSSL_NO_CT_MAX_MIN) && \
771
242k
    defined(WORD64_AVAILABLE)
772
242k
        word32 gte_mask = (word32)ctMaskWord32GTE(a, b);
773
242k
        return (a & ~gte_mask) | (b & gte_mask);
774
#else /* WOLFSSL_NO_CT_OPS */
775
        return a > b ? b : a;
776
#endif /* WOLFSSL_NO_CT_OPS */
777
242k
    }
sha256.c:min
Line
Count
Source
769
4.65M
    {
770
4.65M
#if !defined(WOLFSSL_NO_CT_OPS) && !defined(WOLFSSL_NO_CT_MAX_MIN) && \
771
4.65M
    defined(WORD64_AVAILABLE)
772
4.65M
        word32 gte_mask = (word32)ctMaskWord32GTE(a, b);
773
4.65M
        return (a & ~gte_mask) | (b & gte_mask);
774
#else /* WOLFSSL_NO_CT_OPS */
775
        return a > b ? b : a;
776
#endif /* WOLFSSL_NO_CT_OPS */
777
4.65M
    }
Unexecuted instantiation: sha3.c:min
sha512.c:min
Line
Count
Source
769
329k
    {
770
329k
#if !defined(WOLFSSL_NO_CT_OPS) && !defined(WOLFSSL_NO_CT_MAX_MIN) && \
771
329k
    defined(WORD64_AVAILABLE)
772
329k
        word32 gte_mask = (word32)ctMaskWord32GTE(a, b);
773
329k
        return (a & ~gte_mask) | (b & gte_mask);
774
#else /* WOLFSSL_NO_CT_OPS */
775
        return a > b ? b : a;
776
#endif /* WOLFSSL_NO_CT_OPS */
777
329k
    }
Unexecuted instantiation: siphash.c:min
Unexecuted instantiation: sm2.c:min
Unexecuted instantiation: sm3.c:min
Unexecuted instantiation: sm4.c:min
Unexecuted instantiation: sp_int.c:min
Unexecuted instantiation: wc_encrypt.c:min
Unexecuted instantiation: wolfmath.c:min
ssl.c:min
Line
Count
Source
769
142
    {
770
142
#if !defined(WOLFSSL_NO_CT_OPS) && !defined(WOLFSSL_NO_CT_MAX_MIN) && \
771
142
    defined(WORD64_AVAILABLE)
772
142
        word32 gte_mask = (word32)ctMaskWord32GTE(a, b);
773
142
        return (a & ~gte_mask) | (b & gte_mask);
774
#else /* WOLFSSL_NO_CT_OPS */
775
        return a > b ? b : a;
776
#endif /* WOLFSSL_NO_CT_OPS */
777
142
    }
Unexecuted instantiation: tls.c:min
tls13.c:min
Line
Count
Source
769
12.4k
    {
770
12.4k
#if !defined(WOLFSSL_NO_CT_OPS) && !defined(WOLFSSL_NO_CT_MAX_MIN) && \
771
12.4k
    defined(WORD64_AVAILABLE)
772
12.4k
        word32 gte_mask = (word32)ctMaskWord32GTE(a, b);
773
12.4k
        return (a & ~gte_mask) | (b & gte_mask);
774
#else /* WOLFSSL_NO_CT_OPS */
775
        return a > b ? b : a;
776
#endif /* WOLFSSL_NO_CT_OPS */
777
12.4k
    }
internal.c:min
Line
Count
Source
769
78.4k
    {
770
78.4k
#if !defined(WOLFSSL_NO_CT_OPS) && !defined(WOLFSSL_NO_CT_MAX_MIN) && \
771
78.4k
    defined(WORD64_AVAILABLE)
772
78.4k
        word32 gte_mask = (word32)ctMaskWord32GTE(a, b);
773
78.4k
        return (a & ~gte_mask) | (b & gte_mask);
774
#else /* WOLFSSL_NO_CT_OPS */
775
        return a > b ? b : a;
776
#endif /* WOLFSSL_NO_CT_OPS */
777
78.4k
    }
778
#endif /* !WOLFSSL_HAVE_MIN */
779
780
#ifndef WOLFSSL_HAVE_MAX
781
    #define WOLFSSL_HAVE_MAX
782
    #if defined(HAVE_FIPS) && !defined(max) /* so ifdef check passes */
783
        #define max max
784
    #endif
785
    WC_MISC_STATIC WC_INLINE word32 max(word32 a, word32 b)
786
0
    {
787
0
#if !defined(WOLFSSL_NO_CT_OPS) && !defined(WOLFSSL_NO_CT_MAX_MIN) && \
788
0
    defined(WORD64_AVAILABLE)
789
0
        word32 gte_mask = (word32)ctMaskWord32GTE(a, b);
790
0
        return (a & gte_mask) | (b & ~gte_mask);
791
0
#else /* WOLFSSL_NO_CT_OPS */
792
0
        return a > b ? a : b;
793
0
#endif /* WOLFSSL_NO_CT_OPS */
794
0
    }
Unexecuted instantiation: aes.c:max
Unexecuted instantiation: asn.c:max
Unexecuted instantiation: camellia.c:max
Unexecuted instantiation: chacha.c:max
Unexecuted instantiation: chacha20_poly1305.c:max
Unexecuted instantiation: cmac.c:max
Unexecuted instantiation: coding.c:max
Unexecuted instantiation: curve25519.c:max
Unexecuted instantiation: curve448.c:max
Unexecuted instantiation: des3.c:max
Unexecuted instantiation: dh.c:max
Unexecuted instantiation: ecc.c:max
Unexecuted instantiation: eccsi.c:max
Unexecuted instantiation: ed25519.c:max
Unexecuted instantiation: ed448.c:max
Unexecuted instantiation: fe_448.c:max
Unexecuted instantiation: fe_operations.c:max
Unexecuted instantiation: ge_448.c:max
Unexecuted instantiation: ge_operations.c:max
Unexecuted instantiation: hash.c:max
Unexecuted instantiation: hmac.c:max
Unexecuted instantiation: kdf.c:max
Unexecuted instantiation: md2.c:max
Unexecuted instantiation: md4.c:max
Unexecuted instantiation: md5.c:max
Unexecuted instantiation: poly1305.c:max
Unexecuted instantiation: pwdbased.c:max
Unexecuted instantiation: random.c:max
Unexecuted instantiation: ripemd.c:max
Unexecuted instantiation: rsa.c:max
Unexecuted instantiation: sha.c:max
Unexecuted instantiation: sha256.c:max
Unexecuted instantiation: sha3.c:max
Unexecuted instantiation: sha512.c:max
Unexecuted instantiation: siphash.c:max
Unexecuted instantiation: sm2.c:max
Unexecuted instantiation: sm3.c:max
Unexecuted instantiation: sm4.c:max
Unexecuted instantiation: sp_int.c:max
Unexecuted instantiation: wc_encrypt.c:max
Unexecuted instantiation: wolfmath.c:max
Unexecuted instantiation: ssl.c:max
Unexecuted instantiation: tls.c:max
Unexecuted instantiation: tls13.c:max
795
#endif /* !WOLFSSL_HAVE_MAX */
796
797
#ifndef WOLFSSL_NO_INT_ENCODE
798
/* converts a 32 bit integer to 24 bit */
799
WC_MISC_STATIC WC_INLINE void c32to24(word32 in, word24 out)
800
105k
{
801
105k
    out[0] = (byte)((in >> 16) & 0xff);
802
105k
    out[1] = (byte)((in >>  8) & 0xff);
803
105k
    out[2] =  (byte)(in        & 0xff);
804
105k
}
Unexecuted instantiation: aes.c:c32to24
Unexecuted instantiation: asn.c:c32to24
Unexecuted instantiation: camellia.c:c32to24
Unexecuted instantiation: chacha.c:c32to24
Unexecuted instantiation: chacha20_poly1305.c:c32to24
Unexecuted instantiation: cmac.c:c32to24
Unexecuted instantiation: coding.c:c32to24
Unexecuted instantiation: curve25519.c:c32to24
Unexecuted instantiation: curve448.c:c32to24
Unexecuted instantiation: des3.c:c32to24
Unexecuted instantiation: dh.c:c32to24
Unexecuted instantiation: ecc.c:c32to24
Unexecuted instantiation: eccsi.c:c32to24
Unexecuted instantiation: ed25519.c:c32to24
Unexecuted instantiation: ed448.c:c32to24
Unexecuted instantiation: fe_448.c:c32to24
Unexecuted instantiation: fe_operations.c:c32to24
Unexecuted instantiation: ge_448.c:c32to24
Unexecuted instantiation: ge_operations.c:c32to24
Unexecuted instantiation: hash.c:c32to24
Unexecuted instantiation: hmac.c:c32to24
Unexecuted instantiation: kdf.c:c32to24
Unexecuted instantiation: md2.c:c32to24
Unexecuted instantiation: md4.c:c32to24
Unexecuted instantiation: md5.c:c32to24
Unexecuted instantiation: poly1305.c:c32to24
Unexecuted instantiation: pwdbased.c:c32to24
Unexecuted instantiation: random.c:c32to24
Unexecuted instantiation: ripemd.c:c32to24
Unexecuted instantiation: rsa.c:c32to24
Unexecuted instantiation: sha.c:c32to24
Unexecuted instantiation: sha256.c:c32to24
Unexecuted instantiation: sha3.c:c32to24
Unexecuted instantiation: sha512.c:c32to24
Unexecuted instantiation: siphash.c:c32to24
Unexecuted instantiation: sm2.c:c32to24
Unexecuted instantiation: sm3.c:c32to24
Unexecuted instantiation: sm4.c:c32to24
Unexecuted instantiation: sp_int.c:c32to24
Unexecuted instantiation: wc_encrypt.c:c32to24
Unexecuted instantiation: wolfmath.c:c32to24
Unexecuted instantiation: ssl.c:c32to24
Unexecuted instantiation: tls.c:c32to24
tls13.c:c32to24
Line
Count
Source
800
4.76k
{
801
4.76k
    out[0] = (byte)((in >> 16) & 0xff);
802
4.76k
    out[1] = (byte)((in >>  8) & 0xff);
803
4.76k
    out[2] =  (byte)(in        & 0xff);
804
4.76k
}
internal.c:c32to24
Line
Count
Source
800
100k
{
801
100k
    out[0] = (byte)((in >> 16) & 0xff);
802
100k
    out[1] = (byte)((in >>  8) & 0xff);
803
100k
    out[2] =  (byte)(in        & 0xff);
804
100k
}
805
806
/* convert 16 bit integer to opaque */
807
WC_MISC_STATIC WC_INLINE void c16toa(word16 wc_u16, byte* c)
808
896k
{
809
896k
    c[0] = (byte)((wc_u16 >> 8) & 0xff);
810
896k
    c[1] =  (byte)(wc_u16       & 0xff);
811
896k
}
Unexecuted instantiation: aes.c:c16toa
Unexecuted instantiation: asn.c:c16toa
Unexecuted instantiation: camellia.c:c16toa
Unexecuted instantiation: chacha.c:c16toa
Unexecuted instantiation: chacha20_poly1305.c:c16toa
Unexecuted instantiation: cmac.c:c16toa
Unexecuted instantiation: coding.c:c16toa
Unexecuted instantiation: curve25519.c:c16toa
Unexecuted instantiation: curve448.c:c16toa
Unexecuted instantiation: des3.c:c16toa
Unexecuted instantiation: dh.c:c16toa
Unexecuted instantiation: ecc.c:c16toa
Unexecuted instantiation: eccsi.c:c16toa
Unexecuted instantiation: ed25519.c:c16toa
Unexecuted instantiation: ed448.c:c16toa
Unexecuted instantiation: fe_448.c:c16toa
Unexecuted instantiation: fe_operations.c:c16toa
Unexecuted instantiation: ge_448.c:c16toa
Unexecuted instantiation: ge_operations.c:c16toa
Unexecuted instantiation: hash.c:c16toa
Unexecuted instantiation: hmac.c:c16toa
Unexecuted instantiation: kdf.c:c16toa
Unexecuted instantiation: md2.c:c16toa
Unexecuted instantiation: md4.c:c16toa
Unexecuted instantiation: md5.c:c16toa
Unexecuted instantiation: poly1305.c:c16toa
Unexecuted instantiation: pwdbased.c:c16toa
Unexecuted instantiation: random.c:c16toa
Unexecuted instantiation: ripemd.c:c16toa
Unexecuted instantiation: rsa.c:c16toa
Unexecuted instantiation: sha.c:c16toa
Unexecuted instantiation: sha256.c:c16toa
Unexecuted instantiation: sha3.c:c16toa
Unexecuted instantiation: sha512.c:c16toa
Unexecuted instantiation: siphash.c:c16toa
Unexecuted instantiation: sm2.c:c16toa
Unexecuted instantiation: sm3.c:c16toa
Unexecuted instantiation: sm4.c:c16toa
Unexecuted instantiation: sp_int.c:c16toa
Unexecuted instantiation: wc_encrypt.c:c16toa
Unexecuted instantiation: wolfmath.c:c16toa
Unexecuted instantiation: ssl.c:c16toa
tls.c:c16toa
Line
Count
Source
808
737k
{
809
737k
    c[0] = (byte)((wc_u16 >> 8) & 0xff);
810
737k
    c[1] =  (byte)(wc_u16       & 0xff);
811
737k
}
tls13.c:c16toa
Line
Count
Source
808
8.57k
{
809
8.57k
    c[0] = (byte)((wc_u16 >> 8) & 0xff);
810
8.57k
    c[1] =  (byte)(wc_u16       & 0xff);
811
8.57k
}
internal.c:c16toa
Line
Count
Source
808
150k
{
809
150k
    c[0] = (byte)((wc_u16 >> 8) & 0xff);
810
150k
    c[1] =  (byte)(wc_u16       & 0xff);
811
150k
}
812
813
/* convert 32 bit integer to opaque */
814
WC_MISC_STATIC WC_INLINE void c32toa(word32 wc_u32, byte* c)
815
608k
{
816
608k
#ifdef WOLFSSL_USE_ALIGN
817
608k
    c[0] = (byte)((wc_u32 >> 24) & 0xff);
818
608k
    c[1] = (byte)((wc_u32 >> 16) & 0xff);
819
608k
    c[2] = (byte)((wc_u32 >>  8) & 0xff);
820
608k
    c[3] =  (byte)(wc_u32        & 0xff);
821
#elif defined(LITTLE_ENDIAN_ORDER)
822
    *(word32*)c = ByteReverseWord32(wc_u32);
823
#else
824
    *(word32*)c = wc_u32;
825
#endif
826
608k
}
Unexecuted instantiation: aes.c:c32toa
Unexecuted instantiation: asn.c:c32toa
Unexecuted instantiation: camellia.c:c32toa
Unexecuted instantiation: chacha.c:c32toa
Unexecuted instantiation: chacha20_poly1305.c:c32toa
Unexecuted instantiation: cmac.c:c32toa
Unexecuted instantiation: coding.c:c32toa
Unexecuted instantiation: curve25519.c:c32toa
Unexecuted instantiation: curve448.c:c32toa
Unexecuted instantiation: des3.c:c32toa
Unexecuted instantiation: dh.c:c32toa
Unexecuted instantiation: ecc.c:c32toa
Unexecuted instantiation: eccsi.c:c32toa
Unexecuted instantiation: ed25519.c:c32toa
Unexecuted instantiation: ed448.c:c32toa
Unexecuted instantiation: fe_448.c:c32toa
Unexecuted instantiation: fe_operations.c:c32toa
Unexecuted instantiation: ge_448.c:c32toa
Unexecuted instantiation: ge_operations.c:c32toa
Unexecuted instantiation: hash.c:c32toa
Unexecuted instantiation: hmac.c:c32toa
Unexecuted instantiation: kdf.c:c32toa
Unexecuted instantiation: md2.c:c32toa
Unexecuted instantiation: md4.c:c32toa
Unexecuted instantiation: md5.c:c32toa
Unexecuted instantiation: poly1305.c:c32toa
Unexecuted instantiation: pwdbased.c:c32toa
Unexecuted instantiation: random.c:c32toa
Unexecuted instantiation: ripemd.c:c32toa
Unexecuted instantiation: rsa.c:c32toa
Unexecuted instantiation: sha.c:c32toa
Unexecuted instantiation: sha256.c:c32toa
Unexecuted instantiation: sha3.c:c32toa
Unexecuted instantiation: sha512.c:c32toa
Unexecuted instantiation: siphash.c:c32toa
Unexecuted instantiation: sm2.c:c32toa
Unexecuted instantiation: sm3.c:c32toa
Unexecuted instantiation: sm4.c:c32toa
Unexecuted instantiation: sp_int.c:c32toa
Unexecuted instantiation: wc_encrypt.c:c32toa
Unexecuted instantiation: wolfmath.c:c32toa
Unexecuted instantiation: ssl.c:c32toa
tls.c:c32toa
Line
Count
Source
815
3.13k
{
816
3.13k
#ifdef WOLFSSL_USE_ALIGN
817
3.13k
    c[0] = (byte)((wc_u32 >> 24) & 0xff);
818
3.13k
    c[1] = (byte)((wc_u32 >> 16) & 0xff);
819
3.13k
    c[2] = (byte)((wc_u32 >>  8) & 0xff);
820
3.13k
    c[3] =  (byte)(wc_u32        & 0xff);
821
#elif defined(LITTLE_ENDIAN_ORDER)
822
    *(word32*)c = ByteReverseWord32(wc_u32);
823
#else
824
    *(word32*)c = wc_u32;
825
#endif
826
3.13k
}
tls13.c:c32toa
Line
Count
Source
815
14.7k
{
816
14.7k
#ifdef WOLFSSL_USE_ALIGN
817
14.7k
    c[0] = (byte)((wc_u32 >> 24) & 0xff);
818
14.7k
    c[1] = (byte)((wc_u32 >> 16) & 0xff);
819
14.7k
    c[2] = (byte)((wc_u32 >>  8) & 0xff);
820
14.7k
    c[3] =  (byte)(wc_u32        & 0xff);
821
#elif defined(LITTLE_ENDIAN_ORDER)
822
    *(word32*)c = ByteReverseWord32(wc_u32);
823
#else
824
    *(word32*)c = wc_u32;
825
#endif
826
14.7k
}
internal.c:c32toa
Line
Count
Source
815
590k
{
816
590k
#ifdef WOLFSSL_USE_ALIGN
817
590k
    c[0] = (byte)((wc_u32 >> 24) & 0xff);
818
590k
    c[1] = (byte)((wc_u32 >> 16) & 0xff);
819
590k
    c[2] = (byte)((wc_u32 >>  8) & 0xff);
820
590k
    c[3] =  (byte)(wc_u32        & 0xff);
821
#elif defined(LITTLE_ENDIAN_ORDER)
822
    *(word32*)c = ByteReverseWord32(wc_u32);
823
#else
824
    *(word32*)c = wc_u32;
825
#endif
826
590k
}
827
#endif
828
829
#ifndef WOLFSSL_NO_INT_DECODE
830
/* convert a 24 bit integer into a 32 bit one */
831
WC_MISC_STATIC WC_INLINE void c24to32(const word24 wc_u24, word32* wc_u32)
832
214k
{
833
214k
    *wc_u32 = ((word32)wc_u24[0] << 16) |
834
214k
              ((word32)wc_u24[1] << 8) |
835
214k
               (word32)wc_u24[2];
836
214k
}
Unexecuted instantiation: aes.c:c24to32
Unexecuted instantiation: asn.c:c24to32
Unexecuted instantiation: camellia.c:c24to32
Unexecuted instantiation: chacha.c:c24to32
Unexecuted instantiation: chacha20_poly1305.c:c24to32
Unexecuted instantiation: cmac.c:c24to32
Unexecuted instantiation: coding.c:c24to32
Unexecuted instantiation: curve25519.c:c24to32
Unexecuted instantiation: curve448.c:c24to32
Unexecuted instantiation: des3.c:c24to32
Unexecuted instantiation: dh.c:c24to32
Unexecuted instantiation: ecc.c:c24to32
Unexecuted instantiation: eccsi.c:c24to32
Unexecuted instantiation: ed25519.c:c24to32
Unexecuted instantiation: ed448.c:c24to32
Unexecuted instantiation: fe_448.c:c24to32
Unexecuted instantiation: fe_operations.c:c24to32
Unexecuted instantiation: ge_448.c:c24to32
Unexecuted instantiation: ge_operations.c:c24to32
Unexecuted instantiation: hash.c:c24to32
Unexecuted instantiation: hmac.c:c24to32
Unexecuted instantiation: kdf.c:c24to32
Unexecuted instantiation: md2.c:c24to32
Unexecuted instantiation: md4.c:c24to32
Unexecuted instantiation: md5.c:c24to32
Unexecuted instantiation: poly1305.c:c24to32
Unexecuted instantiation: pwdbased.c:c24to32
Unexecuted instantiation: random.c:c24to32
Unexecuted instantiation: ripemd.c:c24to32
Unexecuted instantiation: rsa.c:c24to32
Unexecuted instantiation: sha.c:c24to32
Unexecuted instantiation: sha256.c:c24to32
Unexecuted instantiation: sha3.c:c24to32
Unexecuted instantiation: sha512.c:c24to32
Unexecuted instantiation: siphash.c:c24to32
Unexecuted instantiation: sm2.c:c24to32
Unexecuted instantiation: sm3.c:c24to32
Unexecuted instantiation: sm4.c:c24to32
Unexecuted instantiation: sp_int.c:c24to32
Unexecuted instantiation: wc_encrypt.c:c24to32
Unexecuted instantiation: wolfmath.c:c24to32
Unexecuted instantiation: ssl.c:c24to32
Unexecuted instantiation: tls.c:c24to32
Unexecuted instantiation: tls13.c:c24to32
internal.c:c24to32
Line
Count
Source
832
214k
{
833
214k
    *wc_u32 = ((word32)wc_u24[0] << 16) |
834
214k
              ((word32)wc_u24[1] << 8) |
835
214k
               (word32)wc_u24[2];
836
214k
}
837
838
839
/* convert opaque to 24 bit integer */
840
WC_MISC_STATIC WC_INLINE void ato24(const byte* c, word32* wc_u24)
841
0
{
842
0
    *wc_u24 = ((word32)c[0] << 16) | ((word32)c[1] << 8) | c[2];
843
0
}
Unexecuted instantiation: aes.c:ato24
Unexecuted instantiation: asn.c:ato24
Unexecuted instantiation: camellia.c:ato24
Unexecuted instantiation: chacha.c:ato24
Unexecuted instantiation: chacha20_poly1305.c:ato24
Unexecuted instantiation: cmac.c:ato24
Unexecuted instantiation: coding.c:ato24
Unexecuted instantiation: curve25519.c:ato24
Unexecuted instantiation: curve448.c:ato24
Unexecuted instantiation: des3.c:ato24
Unexecuted instantiation: dh.c:ato24
Unexecuted instantiation: ecc.c:ato24
Unexecuted instantiation: eccsi.c:ato24
Unexecuted instantiation: ed25519.c:ato24
Unexecuted instantiation: ed448.c:ato24
Unexecuted instantiation: fe_448.c:ato24
Unexecuted instantiation: fe_operations.c:ato24
Unexecuted instantiation: ge_448.c:ato24
Unexecuted instantiation: ge_operations.c:ato24
Unexecuted instantiation: hash.c:ato24
Unexecuted instantiation: hmac.c:ato24
Unexecuted instantiation: kdf.c:ato24
Unexecuted instantiation: md2.c:ato24
Unexecuted instantiation: md4.c:ato24
Unexecuted instantiation: md5.c:ato24
Unexecuted instantiation: poly1305.c:ato24
Unexecuted instantiation: pwdbased.c:ato24
Unexecuted instantiation: random.c:ato24
Unexecuted instantiation: ripemd.c:ato24
Unexecuted instantiation: rsa.c:ato24
Unexecuted instantiation: sha.c:ato24
Unexecuted instantiation: sha256.c:ato24
Unexecuted instantiation: sha3.c:ato24
Unexecuted instantiation: sha512.c:ato24
Unexecuted instantiation: siphash.c:ato24
Unexecuted instantiation: sm2.c:ato24
Unexecuted instantiation: sm3.c:ato24
Unexecuted instantiation: sm4.c:ato24
Unexecuted instantiation: sp_int.c:ato24
Unexecuted instantiation: wc_encrypt.c:ato24
Unexecuted instantiation: wolfmath.c:ato24
Unexecuted instantiation: ssl.c:ato24
Unexecuted instantiation: tls.c:ato24
Unexecuted instantiation: tls13.c:ato24
Unexecuted instantiation: internal.c:ato24
844
845
/* convert opaque to 16 bit integer */
846
WC_MISC_STATIC WC_INLINE void ato16(const byte* c, word16* wc_u16)
847
840k
{
848
840k
    *wc_u16 = (word16) ((c[0] << 8) | (c[1]));
849
840k
}
Unexecuted instantiation: aes.c:ato16
Unexecuted instantiation: asn.c:ato16
Unexecuted instantiation: camellia.c:ato16
Unexecuted instantiation: chacha.c:ato16
Unexecuted instantiation: chacha20_poly1305.c:ato16
Unexecuted instantiation: cmac.c:ato16
Unexecuted instantiation: coding.c:ato16
Unexecuted instantiation: curve25519.c:ato16
Unexecuted instantiation: curve448.c:ato16
Unexecuted instantiation: des3.c:ato16
Unexecuted instantiation: dh.c:ato16
Unexecuted instantiation: ecc.c:ato16
Unexecuted instantiation: eccsi.c:ato16
Unexecuted instantiation: ed25519.c:ato16
Unexecuted instantiation: ed448.c:ato16
Unexecuted instantiation: fe_448.c:ato16
Unexecuted instantiation: fe_operations.c:ato16
Unexecuted instantiation: ge_448.c:ato16
Unexecuted instantiation: ge_operations.c:ato16
Unexecuted instantiation: hash.c:ato16
Unexecuted instantiation: hmac.c:ato16
Unexecuted instantiation: kdf.c:ato16
Unexecuted instantiation: md2.c:ato16
Unexecuted instantiation: md4.c:ato16
Unexecuted instantiation: md5.c:ato16
Unexecuted instantiation: poly1305.c:ato16
Unexecuted instantiation: pwdbased.c:ato16
Unexecuted instantiation: random.c:ato16
Unexecuted instantiation: ripemd.c:ato16
Unexecuted instantiation: rsa.c:ato16
Unexecuted instantiation: sha.c:ato16
Unexecuted instantiation: sha256.c:ato16
Unexecuted instantiation: sha3.c:ato16
Unexecuted instantiation: sha512.c:ato16
Unexecuted instantiation: siphash.c:ato16
Unexecuted instantiation: sm2.c:ato16
Unexecuted instantiation: sm3.c:ato16
Unexecuted instantiation: sm4.c:ato16
Unexecuted instantiation: sp_int.c:ato16
Unexecuted instantiation: wc_encrypt.c:ato16
Unexecuted instantiation: wolfmath.c:ato16
Unexecuted instantiation: ssl.c:ato16
tls.c:ato16
Line
Count
Source
847
278k
{
848
278k
    *wc_u16 = (word16) ((c[0] << 8) | (c[1]));
849
278k
}
tls13.c:ato16
Line
Count
Source
847
11.6k
{
848
11.6k
    *wc_u16 = (word16) ((c[0] << 8) | (c[1]));
849
11.6k
}
internal.c:ato16
Line
Count
Source
847
550k
{
848
550k
    *wc_u16 = (word16) ((c[0] << 8) | (c[1]));
849
550k
}
850
851
/* convert opaque to 32 bit integer */
852
WC_MISC_STATIC WC_INLINE void ato32(const byte* c, word32* wc_u32)
853
0
{
854
0
#ifdef WOLFSSL_USE_ALIGN
855
0
    *wc_u32 = ((word32)c[0] << 24) |
856
0
              ((word32)c[1] << 16) |
857
0
              ((word32)c[2] << 8) |
858
0
               (word32)c[3];
859
0
#elif defined(LITTLE_ENDIAN_ORDER)
860
0
    *wc_u32 = ByteReverseWord32(*(word32*)c);
861
0
#else
862
0
    *wc_u32 = *(word32*)c;
863
0
#endif
864
0
}
Unexecuted instantiation: aes.c:ato32
Unexecuted instantiation: asn.c:ato32
Unexecuted instantiation: camellia.c:ato32
Unexecuted instantiation: chacha.c:ato32
Unexecuted instantiation: chacha20_poly1305.c:ato32
Unexecuted instantiation: cmac.c:ato32
Unexecuted instantiation: coding.c:ato32
Unexecuted instantiation: curve25519.c:ato32
Unexecuted instantiation: curve448.c:ato32
Unexecuted instantiation: des3.c:ato32
Unexecuted instantiation: dh.c:ato32
Unexecuted instantiation: ecc.c:ato32
Unexecuted instantiation: eccsi.c:ato32
Unexecuted instantiation: ed25519.c:ato32
Unexecuted instantiation: ed448.c:ato32
Unexecuted instantiation: fe_448.c:ato32
Unexecuted instantiation: fe_operations.c:ato32
Unexecuted instantiation: ge_448.c:ato32
Unexecuted instantiation: ge_operations.c:ato32
Unexecuted instantiation: hash.c:ato32
Unexecuted instantiation: hmac.c:ato32
Unexecuted instantiation: kdf.c:ato32
Unexecuted instantiation: md2.c:ato32
Unexecuted instantiation: md4.c:ato32
Unexecuted instantiation: md5.c:ato32
Unexecuted instantiation: poly1305.c:ato32
Unexecuted instantiation: pwdbased.c:ato32
Unexecuted instantiation: random.c:ato32
Unexecuted instantiation: ripemd.c:ato32
Unexecuted instantiation: rsa.c:ato32
Unexecuted instantiation: sha.c:ato32
Unexecuted instantiation: sha256.c:ato32
Unexecuted instantiation: sha3.c:ato32
Unexecuted instantiation: sha512.c:ato32
Unexecuted instantiation: siphash.c:ato32
Unexecuted instantiation: sm2.c:ato32
Unexecuted instantiation: sm3.c:ato32
Unexecuted instantiation: sm4.c:ato32
Unexecuted instantiation: sp_int.c:ato32
Unexecuted instantiation: wc_encrypt.c:ato32
Unexecuted instantiation: wolfmath.c:ato32
Unexecuted instantiation: ssl.c:ato32
Unexecuted instantiation: tls13.c:ato32
865
866
/* convert opaque to 32 bit integer. Interpret as little endian. */
867
WC_MISC_STATIC WC_INLINE void ato32le(const byte* c, word32* wc_u32)
868
0
{
869
0
    *wc_u32 =  (word32)c[0] |
870
0
              ((word32)c[1] << 8) |
871
0
              ((word32)c[2] << 16) |
872
0
              ((word32)c[3] << 24);
873
0
}
Unexecuted instantiation: aes.c:ato32le
Unexecuted instantiation: asn.c:ato32le
Unexecuted instantiation: camellia.c:ato32le
Unexecuted instantiation: chacha.c:ato32le
Unexecuted instantiation: chacha20_poly1305.c:ato32le
Unexecuted instantiation: cmac.c:ato32le
Unexecuted instantiation: coding.c:ato32le
Unexecuted instantiation: curve25519.c:ato32le
Unexecuted instantiation: curve448.c:ato32le
Unexecuted instantiation: des3.c:ato32le
Unexecuted instantiation: dh.c:ato32le
Unexecuted instantiation: ecc.c:ato32le
Unexecuted instantiation: eccsi.c:ato32le
Unexecuted instantiation: ed25519.c:ato32le
Unexecuted instantiation: ed448.c:ato32le
Unexecuted instantiation: fe_448.c:ato32le
Unexecuted instantiation: fe_operations.c:ato32le
Unexecuted instantiation: ge_448.c:ato32le
Unexecuted instantiation: ge_operations.c:ato32le
Unexecuted instantiation: hash.c:ato32le
Unexecuted instantiation: hmac.c:ato32le
Unexecuted instantiation: kdf.c:ato32le
Unexecuted instantiation: md2.c:ato32le
Unexecuted instantiation: md4.c:ato32le
Unexecuted instantiation: md5.c:ato32le
Unexecuted instantiation: poly1305.c:ato32le
Unexecuted instantiation: pwdbased.c:ato32le
Unexecuted instantiation: random.c:ato32le
Unexecuted instantiation: ripemd.c:ato32le
Unexecuted instantiation: rsa.c:ato32le
Unexecuted instantiation: sha.c:ato32le
Unexecuted instantiation: sha256.c:ato32le
Unexecuted instantiation: sha3.c:ato32le
Unexecuted instantiation: sha512.c:ato32le
Unexecuted instantiation: siphash.c:ato32le
Unexecuted instantiation: sm2.c:ato32le
Unexecuted instantiation: sm3.c:ato32le
Unexecuted instantiation: sm4.c:ato32le
Unexecuted instantiation: sp_int.c:ato32le
Unexecuted instantiation: wc_encrypt.c:ato32le
Unexecuted instantiation: wolfmath.c:ato32le
Unexecuted instantiation: ssl.c:ato32le
Unexecuted instantiation: tls.c:ato32le
Unexecuted instantiation: tls13.c:ato32le
Unexecuted instantiation: internal.c:ato32le
874
875
876
WC_MISC_STATIC WC_INLINE word32 btoi(byte b)
877
215k
{
878
215k
    return (word32)(b - 0x30);
879
215k
}
Unexecuted instantiation: aes.c:btoi
asn.c:btoi
Line
Count
Source
877
215k
{
878
215k
    return (word32)(b - 0x30);
879
215k
}
Unexecuted instantiation: camellia.c:btoi
Unexecuted instantiation: chacha.c:btoi
Unexecuted instantiation: chacha20_poly1305.c:btoi
Unexecuted instantiation: cmac.c:btoi
Unexecuted instantiation: coding.c:btoi
Unexecuted instantiation: curve25519.c:btoi
Unexecuted instantiation: curve448.c:btoi
Unexecuted instantiation: des3.c:btoi
Unexecuted instantiation: dh.c:btoi
Unexecuted instantiation: ecc.c:btoi
Unexecuted instantiation: eccsi.c:btoi
Unexecuted instantiation: ed25519.c:btoi
Unexecuted instantiation: ed448.c:btoi
Unexecuted instantiation: fe_448.c:btoi
Unexecuted instantiation: fe_operations.c:btoi
Unexecuted instantiation: ge_448.c:btoi
Unexecuted instantiation: ge_operations.c:btoi
Unexecuted instantiation: hash.c:btoi
Unexecuted instantiation: hmac.c:btoi
Unexecuted instantiation: kdf.c:btoi
Unexecuted instantiation: md2.c:btoi
Unexecuted instantiation: md4.c:btoi
Unexecuted instantiation: md5.c:btoi
Unexecuted instantiation: poly1305.c:btoi
Unexecuted instantiation: pwdbased.c:btoi
Unexecuted instantiation: random.c:btoi
Unexecuted instantiation: ripemd.c:btoi
Unexecuted instantiation: rsa.c:btoi
Unexecuted instantiation: sha.c:btoi
Unexecuted instantiation: sha256.c:btoi
Unexecuted instantiation: sha3.c:btoi
Unexecuted instantiation: sha512.c:btoi
Unexecuted instantiation: siphash.c:btoi
Unexecuted instantiation: sm2.c:btoi
Unexecuted instantiation: sm3.c:btoi
Unexecuted instantiation: sm4.c:btoi
Unexecuted instantiation: sp_int.c:btoi
Unexecuted instantiation: wc_encrypt.c:btoi
Unexecuted instantiation: wolfmath.c:btoi
Unexecuted instantiation: ssl.c:btoi
Unexecuted instantiation: tls.c:btoi
Unexecuted instantiation: tls13.c:btoi
Unexecuted instantiation: internal.c:btoi
880
#endif
881
882
WC_MISC_STATIC WC_INLINE signed char HexCharToByte(char ch)
883
13.6M
{
884
13.6M
    signed char ret = (signed char)ch;
885
13.6M
    if (ret >= '0' && ret <= '9')
886
6.50M
        ret = (signed char)(ret - '0');
887
7.15M
    else if (ret >= 'A' && ret <= 'F')
888
6.26M
        ret = (signed char)(ret - ('A' - 10));
889
889k
    else if (ret >= 'a' && ret <= 'f')
890
888k
        ret = (signed char)(ret - ('a' - 10));
891
638
    else
892
638
        ret = -1; /* error case - return code must be signed */
893
13.6M
    return ret;
894
13.6M
}
Unexecuted instantiation: aes.c:HexCharToByte
Unexecuted instantiation: asn.c:HexCharToByte
Unexecuted instantiation: camellia.c:HexCharToByte
Unexecuted instantiation: chacha.c:HexCharToByte
Unexecuted instantiation: chacha20_poly1305.c:HexCharToByte
Unexecuted instantiation: cmac.c:HexCharToByte
Unexecuted instantiation: coding.c:HexCharToByte
Unexecuted instantiation: curve25519.c:HexCharToByte
Unexecuted instantiation: curve448.c:HexCharToByte
Unexecuted instantiation: des3.c:HexCharToByte
Unexecuted instantiation: dh.c:HexCharToByte
Unexecuted instantiation: ecc.c:HexCharToByte
Unexecuted instantiation: eccsi.c:HexCharToByte
Unexecuted instantiation: ed25519.c:HexCharToByte
Unexecuted instantiation: ed448.c:HexCharToByte
Unexecuted instantiation: fe_448.c:HexCharToByte
Unexecuted instantiation: fe_operations.c:HexCharToByte
Unexecuted instantiation: ge_448.c:HexCharToByte
Unexecuted instantiation: ge_operations.c:HexCharToByte
Unexecuted instantiation: hash.c:HexCharToByte
Unexecuted instantiation: hmac.c:HexCharToByte
Unexecuted instantiation: kdf.c:HexCharToByte
Unexecuted instantiation: md2.c:HexCharToByte
Unexecuted instantiation: md4.c:HexCharToByte
Unexecuted instantiation: md5.c:HexCharToByte
Unexecuted instantiation: poly1305.c:HexCharToByte
Unexecuted instantiation: pwdbased.c:HexCharToByte
Unexecuted instantiation: random.c:HexCharToByte
Unexecuted instantiation: ripemd.c:HexCharToByte
Unexecuted instantiation: rsa.c:HexCharToByte
Unexecuted instantiation: sha.c:HexCharToByte
Unexecuted instantiation: sha256.c:HexCharToByte
Unexecuted instantiation: sha3.c:HexCharToByte
Unexecuted instantiation: sha512.c:HexCharToByte
Unexecuted instantiation: siphash.c:HexCharToByte
Unexecuted instantiation: sm2.c:HexCharToByte
Unexecuted instantiation: sm3.c:HexCharToByte
Unexecuted instantiation: sm4.c:HexCharToByte
sp_int.c:HexCharToByte
Line
Count
Source
883
13.6M
{
884
13.6M
    signed char ret = (signed char)ch;
885
13.6M
    if (ret >= '0' && ret <= '9')
886
6.50M
        ret = (signed char)(ret - '0');
887
7.15M
    else if (ret >= 'A' && ret <= 'F')
888
6.26M
        ret = (signed char)(ret - ('A' - 10));
889
889k
    else if (ret >= 'a' && ret <= 'f')
890
888k
        ret = (signed char)(ret - ('a' - 10));
891
638
    else
892
638
        ret = -1; /* error case - return code must be signed */
893
13.6M
    return ret;
894
13.6M
}
Unexecuted instantiation: wc_encrypt.c:HexCharToByte
Unexecuted instantiation: wolfmath.c:HexCharToByte
Unexecuted instantiation: ssl.c:HexCharToByte
Unexecuted instantiation: tls.c:HexCharToByte
Unexecuted instantiation: tls13.c:HexCharToByte
Unexecuted instantiation: internal.c:HexCharToByte
895
896
WC_MISC_STATIC WC_INLINE char ByteToHex(byte in)
897
278k
{
898
278k
    static ALIGN64 const char kHexChar[] = {
899
278k
        '0', '1', '2', '3', '4', '5', '6', '7',
900
278k
        '8', '9', 'A', 'B', 'C', 'D', 'E', 'F'
901
278k
    };
902
278k
    return (char)(kHexChar[in & 0xF]);
903
278k
}
Unexecuted instantiation: aes.c:ByteToHex
Unexecuted instantiation: camellia.c:ByteToHex
Unexecuted instantiation: chacha.c:ByteToHex
Unexecuted instantiation: chacha20_poly1305.c:ByteToHex
Unexecuted instantiation: cmac.c:ByteToHex
Unexecuted instantiation: coding.c:ByteToHex
Unexecuted instantiation: curve25519.c:ByteToHex
Unexecuted instantiation: curve448.c:ByteToHex
Unexecuted instantiation: des3.c:ByteToHex
Unexecuted instantiation: dh.c:ByteToHex
Unexecuted instantiation: ecc.c:ByteToHex
Unexecuted instantiation: eccsi.c:ByteToHex
Unexecuted instantiation: ed25519.c:ByteToHex
Unexecuted instantiation: ed448.c:ByteToHex
Unexecuted instantiation: fe_448.c:ByteToHex
Unexecuted instantiation: fe_operations.c:ByteToHex
Unexecuted instantiation: ge_448.c:ByteToHex
Unexecuted instantiation: ge_operations.c:ByteToHex
Unexecuted instantiation: hash.c:ByteToHex
Unexecuted instantiation: hmac.c:ByteToHex
Unexecuted instantiation: kdf.c:ByteToHex
Unexecuted instantiation: md2.c:ByteToHex
Unexecuted instantiation: md4.c:ByteToHex
Unexecuted instantiation: md5.c:ByteToHex
Unexecuted instantiation: poly1305.c:ByteToHex
Unexecuted instantiation: pwdbased.c:ByteToHex
Unexecuted instantiation: random.c:ByteToHex
Unexecuted instantiation: ripemd.c:ByteToHex
Unexecuted instantiation: rsa.c:ByteToHex
Unexecuted instantiation: sha.c:ByteToHex
Unexecuted instantiation: sha256.c:ByteToHex
Unexecuted instantiation: sha3.c:ByteToHex
Unexecuted instantiation: sha512.c:ByteToHex
Unexecuted instantiation: siphash.c:ByteToHex
Unexecuted instantiation: sm2.c:ByteToHex
Unexecuted instantiation: sm3.c:ByteToHex
Unexecuted instantiation: sm4.c:ByteToHex
sp_int.c:ByteToHex
Line
Count
Source
897
278k
{
898
278k
    static ALIGN64 const char kHexChar[] = {
899
278k
        '0', '1', '2', '3', '4', '5', '6', '7',
900
278k
        '8', '9', 'A', 'B', 'C', 'D', 'E', 'F'
901
278k
    };
902
278k
    return (char)(kHexChar[in & 0xF]);
903
278k
}
Unexecuted instantiation: wc_encrypt.c:ByteToHex
Unexecuted instantiation: wolfmath.c:ByteToHex
Unexecuted instantiation: ssl.c:ByteToHex
Unexecuted instantiation: tls.c:ByteToHex
Unexecuted instantiation: tls13.c:ByteToHex
Unexecuted instantiation: internal.c:ByteToHex
904
905
WC_MISC_STATIC WC_INLINE int ByteToHexStr(byte in, char* out)
906
0
{
907
0
    if (out == NULL)
908
0
        return -1;
909
0
910
0
    out[0] = ByteToHex((byte)(in >> 4));
911
0
    out[1] = ByteToHex((byte)(in & 0xf));
912
0
    return 0;
913
0
}
Unexecuted instantiation: aes.c:ByteToHexStr
Unexecuted instantiation: camellia.c:ByteToHexStr
Unexecuted instantiation: chacha.c:ByteToHexStr
Unexecuted instantiation: chacha20_poly1305.c:ByteToHexStr
Unexecuted instantiation: cmac.c:ByteToHexStr
Unexecuted instantiation: coding.c:ByteToHexStr
Unexecuted instantiation: curve25519.c:ByteToHexStr
Unexecuted instantiation: curve448.c:ByteToHexStr
Unexecuted instantiation: des3.c:ByteToHexStr
Unexecuted instantiation: dh.c:ByteToHexStr
Unexecuted instantiation: ecc.c:ByteToHexStr
Unexecuted instantiation: eccsi.c:ByteToHexStr
Unexecuted instantiation: ed25519.c:ByteToHexStr
Unexecuted instantiation: ed448.c:ByteToHexStr
Unexecuted instantiation: fe_448.c:ByteToHexStr
Unexecuted instantiation: fe_operations.c:ByteToHexStr
Unexecuted instantiation: ge_448.c:ByteToHexStr
Unexecuted instantiation: ge_operations.c:ByteToHexStr
Unexecuted instantiation: hash.c:ByteToHexStr
Unexecuted instantiation: hmac.c:ByteToHexStr
Unexecuted instantiation: kdf.c:ByteToHexStr
Unexecuted instantiation: md2.c:ByteToHexStr
Unexecuted instantiation: md4.c:ByteToHexStr
Unexecuted instantiation: md5.c:ByteToHexStr
Unexecuted instantiation: poly1305.c:ByteToHexStr
Unexecuted instantiation: pwdbased.c:ByteToHexStr
Unexecuted instantiation: random.c:ByteToHexStr
Unexecuted instantiation: ripemd.c:ByteToHexStr
Unexecuted instantiation: rsa.c:ByteToHexStr
Unexecuted instantiation: sha.c:ByteToHexStr
Unexecuted instantiation: sha256.c:ByteToHexStr
Unexecuted instantiation: sha3.c:ByteToHexStr
Unexecuted instantiation: sha512.c:ByteToHexStr
Unexecuted instantiation: siphash.c:ByteToHexStr
Unexecuted instantiation: sm2.c:ByteToHexStr
Unexecuted instantiation: sm3.c:ByteToHexStr
Unexecuted instantiation: sm4.c:ByteToHexStr
Unexecuted instantiation: sp_int.c:ByteToHexStr
Unexecuted instantiation: wc_encrypt.c:ByteToHexStr
Unexecuted instantiation: wolfmath.c:ByteToHexStr
Unexecuted instantiation: ssl.c:ByteToHexStr
Unexecuted instantiation: tls.c:ByteToHexStr
Unexecuted instantiation: tls13.c:ByteToHexStr
Unexecuted instantiation: internal.c:ByteToHexStr
914
915
WC_MISC_STATIC WC_INLINE int CharIsWhiteSpace(char ch)
916
257
{
917
257
#ifndef WOLFSSL_NO_CT_OPS
918
257
    return (ctMaskEq(ch, ' ') |
919
257
            ctMaskEq(ch, '\t') |
920
257
            ctMaskEq(ch, '\n')) & 1;
921
#else /* WOLFSSL_NO_CT_OPS */
922
    switch (ch) {
923
        case ' ':
924
        case '\t':
925
        case '\n':
926
            return 1;
927
        default:
928
            return 0;
929
    }
930
#endif /* WOLFSSL_NO_CT_OPS */
931
257
}
Unexecuted instantiation: aes.c:CharIsWhiteSpace
Unexecuted instantiation: asn.c:CharIsWhiteSpace
Unexecuted instantiation: camellia.c:CharIsWhiteSpace
Unexecuted instantiation: chacha.c:CharIsWhiteSpace
Unexecuted instantiation: chacha20_poly1305.c:CharIsWhiteSpace
Unexecuted instantiation: cmac.c:CharIsWhiteSpace
Unexecuted instantiation: coding.c:CharIsWhiteSpace
Unexecuted instantiation: curve25519.c:CharIsWhiteSpace
Unexecuted instantiation: curve448.c:CharIsWhiteSpace
Unexecuted instantiation: des3.c:CharIsWhiteSpace
Unexecuted instantiation: dh.c:CharIsWhiteSpace
Unexecuted instantiation: ecc.c:CharIsWhiteSpace
Unexecuted instantiation: eccsi.c:CharIsWhiteSpace
Unexecuted instantiation: ed25519.c:CharIsWhiteSpace
Unexecuted instantiation: ed448.c:CharIsWhiteSpace
Unexecuted instantiation: fe_448.c:CharIsWhiteSpace
Unexecuted instantiation: fe_operations.c:CharIsWhiteSpace
Unexecuted instantiation: ge_448.c:CharIsWhiteSpace
Unexecuted instantiation: ge_operations.c:CharIsWhiteSpace
Unexecuted instantiation: hash.c:CharIsWhiteSpace
Unexecuted instantiation: hmac.c:CharIsWhiteSpace
Unexecuted instantiation: kdf.c:CharIsWhiteSpace
Unexecuted instantiation: md2.c:CharIsWhiteSpace
Unexecuted instantiation: md4.c:CharIsWhiteSpace
Unexecuted instantiation: md5.c:CharIsWhiteSpace
Unexecuted instantiation: poly1305.c:CharIsWhiteSpace
Unexecuted instantiation: pwdbased.c:CharIsWhiteSpace
Unexecuted instantiation: random.c:CharIsWhiteSpace
Unexecuted instantiation: ripemd.c:CharIsWhiteSpace
Unexecuted instantiation: rsa.c:CharIsWhiteSpace
Unexecuted instantiation: sha.c:CharIsWhiteSpace
Unexecuted instantiation: sha256.c:CharIsWhiteSpace
Unexecuted instantiation: sha3.c:CharIsWhiteSpace
Unexecuted instantiation: sha512.c:CharIsWhiteSpace
Unexecuted instantiation: siphash.c:CharIsWhiteSpace
Unexecuted instantiation: sm2.c:CharIsWhiteSpace
Unexecuted instantiation: sm3.c:CharIsWhiteSpace
Unexecuted instantiation: sm4.c:CharIsWhiteSpace
sp_int.c:CharIsWhiteSpace
Line
Count
Source
916
257
{
917
257
#ifndef WOLFSSL_NO_CT_OPS
918
257
    return (ctMaskEq(ch, ' ') |
919
257
            ctMaskEq(ch, '\t') |
920
257
            ctMaskEq(ch, '\n')) & 1;
921
#else /* WOLFSSL_NO_CT_OPS */
922
    switch (ch) {
923
        case ' ':
924
        case '\t':
925
        case '\n':
926
            return 1;
927
        default:
928
            return 0;
929
    }
930
#endif /* WOLFSSL_NO_CT_OPS */
931
257
}
Unexecuted instantiation: wc_encrypt.c:CharIsWhiteSpace
Unexecuted instantiation: wolfmath.c:CharIsWhiteSpace
Unexecuted instantiation: ssl.c:CharIsWhiteSpace
Unexecuted instantiation: tls.c:CharIsWhiteSpace
Unexecuted instantiation: tls13.c:CharIsWhiteSpace
Unexecuted instantiation: internal.c:CharIsWhiteSpace
932
933
#if defined(WOLFSSL_W64_WRAPPER)
934
#if defined(WORD64_AVAILABLE) && !defined(WOLFSSL_W64_WRAPPER_TEST)
935
0
WC_MISC_STATIC WC_INLINE void w64Increment(w64wrapper *n) {
936
0
    n->n++;
937
0
}
Unexecuted instantiation: aes.c:w64Increment
Unexecuted instantiation: asn.c:w64Increment
Unexecuted instantiation: camellia.c:w64Increment
Unexecuted instantiation: chacha.c:w64Increment
Unexecuted instantiation: chacha20_poly1305.c:w64Increment
Unexecuted instantiation: cmac.c:w64Increment
Unexecuted instantiation: coding.c:w64Increment
Unexecuted instantiation: curve25519.c:w64Increment
Unexecuted instantiation: curve448.c:w64Increment
Unexecuted instantiation: des3.c:w64Increment
Unexecuted instantiation: dh.c:w64Increment
Unexecuted instantiation: ecc.c:w64Increment
Unexecuted instantiation: eccsi.c:w64Increment
Unexecuted instantiation: ed25519.c:w64Increment
Unexecuted instantiation: ed448.c:w64Increment
Unexecuted instantiation: fe_448.c:w64Increment
Unexecuted instantiation: fe_operations.c:w64Increment
Unexecuted instantiation: ge_448.c:w64Increment
Unexecuted instantiation: ge_operations.c:w64Increment
Unexecuted instantiation: hash.c:w64Increment
Unexecuted instantiation: hmac.c:w64Increment
Unexecuted instantiation: kdf.c:w64Increment
Unexecuted instantiation: md2.c:w64Increment
Unexecuted instantiation: md4.c:w64Increment
Unexecuted instantiation: md5.c:w64Increment
Unexecuted instantiation: poly1305.c:w64Increment
Unexecuted instantiation: pwdbased.c:w64Increment
Unexecuted instantiation: random.c:w64Increment
Unexecuted instantiation: ripemd.c:w64Increment
Unexecuted instantiation: rsa.c:w64Increment
Unexecuted instantiation: sha.c:w64Increment
Unexecuted instantiation: sha256.c:w64Increment
Unexecuted instantiation: sha3.c:w64Increment
Unexecuted instantiation: sha512.c:w64Increment
Unexecuted instantiation: siphash.c:w64Increment
Unexecuted instantiation: sm2.c:w64Increment
Unexecuted instantiation: sm3.c:w64Increment
Unexecuted instantiation: sm4.c:w64Increment
Unexecuted instantiation: sp_int.c:w64Increment
Unexecuted instantiation: wc_encrypt.c:w64Increment
Unexecuted instantiation: wolfmath.c:w64Increment
Unexecuted instantiation: ssl.c:w64Increment
Unexecuted instantiation: tls.c:w64Increment
Unexecuted instantiation: tls13.c:w64Increment
938
939
0
WC_MISC_STATIC WC_INLINE void w64Decrement(w64wrapper *n) {
940
0
    n->n--;
941
0
}
Unexecuted instantiation: aes.c:w64Decrement
Unexecuted instantiation: asn.c:w64Decrement
Unexecuted instantiation: camellia.c:w64Decrement
Unexecuted instantiation: chacha.c:w64Decrement
Unexecuted instantiation: chacha20_poly1305.c:w64Decrement
Unexecuted instantiation: cmac.c:w64Decrement
Unexecuted instantiation: coding.c:w64Decrement
Unexecuted instantiation: curve25519.c:w64Decrement
Unexecuted instantiation: curve448.c:w64Decrement
Unexecuted instantiation: des3.c:w64Decrement
Unexecuted instantiation: dh.c:w64Decrement
Unexecuted instantiation: ecc.c:w64Decrement
Unexecuted instantiation: eccsi.c:w64Decrement
Unexecuted instantiation: ed25519.c:w64Decrement
Unexecuted instantiation: ed448.c:w64Decrement
Unexecuted instantiation: fe_448.c:w64Decrement
Unexecuted instantiation: fe_operations.c:w64Decrement
Unexecuted instantiation: ge_448.c:w64Decrement
Unexecuted instantiation: ge_operations.c:w64Decrement
Unexecuted instantiation: hash.c:w64Decrement
Unexecuted instantiation: hmac.c:w64Decrement
Unexecuted instantiation: kdf.c:w64Decrement
Unexecuted instantiation: md2.c:w64Decrement
Unexecuted instantiation: md4.c:w64Decrement
Unexecuted instantiation: md5.c:w64Decrement
Unexecuted instantiation: poly1305.c:w64Decrement
Unexecuted instantiation: pwdbased.c:w64Decrement
Unexecuted instantiation: random.c:w64Decrement
Unexecuted instantiation: ripemd.c:w64Decrement
Unexecuted instantiation: rsa.c:w64Decrement
Unexecuted instantiation: sha.c:w64Decrement
Unexecuted instantiation: sha256.c:w64Decrement
Unexecuted instantiation: sha3.c:w64Decrement
Unexecuted instantiation: sha512.c:w64Decrement
Unexecuted instantiation: siphash.c:w64Decrement
Unexecuted instantiation: sm2.c:w64Decrement
Unexecuted instantiation: sm3.c:w64Decrement
Unexecuted instantiation: sm4.c:w64Decrement
Unexecuted instantiation: sp_int.c:w64Decrement
Unexecuted instantiation: wc_encrypt.c:w64Decrement
Unexecuted instantiation: wolfmath.c:w64Decrement
Unexecuted instantiation: ssl.c:w64Decrement
Unexecuted instantiation: tls.c:w64Decrement
Unexecuted instantiation: tls13.c:w64Decrement
942
943
0
WC_MISC_STATIC WC_INLINE byte w64Equal(w64wrapper a, w64wrapper b) {
944
0
    return (a.n == b.n);
945
0
}
Unexecuted instantiation: aes.c:w64Equal
Unexecuted instantiation: asn.c:w64Equal
Unexecuted instantiation: camellia.c:w64Equal
Unexecuted instantiation: chacha.c:w64Equal
Unexecuted instantiation: chacha20_poly1305.c:w64Equal
Unexecuted instantiation: cmac.c:w64Equal
Unexecuted instantiation: coding.c:w64Equal
Unexecuted instantiation: curve25519.c:w64Equal
Unexecuted instantiation: curve448.c:w64Equal
Unexecuted instantiation: des3.c:w64Equal
Unexecuted instantiation: dh.c:w64Equal
Unexecuted instantiation: ecc.c:w64Equal
Unexecuted instantiation: eccsi.c:w64Equal
Unexecuted instantiation: ed25519.c:w64Equal
Unexecuted instantiation: ed448.c:w64Equal
Unexecuted instantiation: fe_448.c:w64Equal
Unexecuted instantiation: fe_operations.c:w64Equal
Unexecuted instantiation: ge_448.c:w64Equal
Unexecuted instantiation: ge_operations.c:w64Equal
Unexecuted instantiation: hash.c:w64Equal
Unexecuted instantiation: hmac.c:w64Equal
Unexecuted instantiation: kdf.c:w64Equal
Unexecuted instantiation: md2.c:w64Equal
Unexecuted instantiation: md4.c:w64Equal
Unexecuted instantiation: md5.c:w64Equal
Unexecuted instantiation: poly1305.c:w64Equal
Unexecuted instantiation: pwdbased.c:w64Equal
Unexecuted instantiation: random.c:w64Equal
Unexecuted instantiation: ripemd.c:w64Equal
Unexecuted instantiation: rsa.c:w64Equal
Unexecuted instantiation: sha.c:w64Equal
Unexecuted instantiation: sha256.c:w64Equal
Unexecuted instantiation: sha3.c:w64Equal
Unexecuted instantiation: sha512.c:w64Equal
Unexecuted instantiation: siphash.c:w64Equal
Unexecuted instantiation: sm2.c:w64Equal
Unexecuted instantiation: sm3.c:w64Equal
Unexecuted instantiation: sm4.c:w64Equal
Unexecuted instantiation: sp_int.c:w64Equal
Unexecuted instantiation: wc_encrypt.c:w64Equal
Unexecuted instantiation: wolfmath.c:w64Equal
Unexecuted instantiation: ssl.c:w64Equal
Unexecuted instantiation: tls.c:w64Equal
Unexecuted instantiation: tls13.c:w64Equal
946
947
0
WC_MISC_STATIC WC_INLINE word32 w64GetLow32(w64wrapper n) {
948
0
    return (word32)n.n;
949
0
}
Unexecuted instantiation: aes.c:w64GetLow32
Unexecuted instantiation: asn.c:w64GetLow32
Unexecuted instantiation: camellia.c:w64GetLow32
Unexecuted instantiation: chacha.c:w64GetLow32
Unexecuted instantiation: chacha20_poly1305.c:w64GetLow32
Unexecuted instantiation: cmac.c:w64GetLow32
Unexecuted instantiation: coding.c:w64GetLow32
Unexecuted instantiation: curve25519.c:w64GetLow32
Unexecuted instantiation: curve448.c:w64GetLow32
Unexecuted instantiation: des3.c:w64GetLow32
Unexecuted instantiation: dh.c:w64GetLow32
Unexecuted instantiation: ecc.c:w64GetLow32
Unexecuted instantiation: eccsi.c:w64GetLow32
Unexecuted instantiation: ed25519.c:w64GetLow32
Unexecuted instantiation: ed448.c:w64GetLow32
Unexecuted instantiation: fe_448.c:w64GetLow32
Unexecuted instantiation: fe_operations.c:w64GetLow32
Unexecuted instantiation: ge_448.c:w64GetLow32
Unexecuted instantiation: ge_operations.c:w64GetLow32
Unexecuted instantiation: hash.c:w64GetLow32
Unexecuted instantiation: hmac.c:w64GetLow32
Unexecuted instantiation: kdf.c:w64GetLow32
Unexecuted instantiation: md2.c:w64GetLow32
Unexecuted instantiation: md4.c:w64GetLow32
Unexecuted instantiation: md5.c:w64GetLow32
Unexecuted instantiation: poly1305.c:w64GetLow32
Unexecuted instantiation: pwdbased.c:w64GetLow32
Unexecuted instantiation: random.c:w64GetLow32
Unexecuted instantiation: ripemd.c:w64GetLow32
Unexecuted instantiation: rsa.c:w64GetLow32
Unexecuted instantiation: sha.c:w64GetLow32
Unexecuted instantiation: sha256.c:w64GetLow32
Unexecuted instantiation: sha3.c:w64GetLow32
Unexecuted instantiation: sha512.c:w64GetLow32
Unexecuted instantiation: siphash.c:w64GetLow32
Unexecuted instantiation: sm2.c:w64GetLow32
Unexecuted instantiation: sm3.c:w64GetLow32
Unexecuted instantiation: sm4.c:w64GetLow32
Unexecuted instantiation: sp_int.c:w64GetLow32
Unexecuted instantiation: wc_encrypt.c:w64GetLow32
Unexecuted instantiation: wolfmath.c:w64GetLow32
Unexecuted instantiation: ssl.c:w64GetLow32
Unexecuted instantiation: tls.c:w64GetLow32
Unexecuted instantiation: tls13.c:w64GetLow32
950
951
0
WC_MISC_STATIC WC_INLINE word32 w64GetHigh32(w64wrapper n) {
952
0
    return (word32)(n.n >> 32);
953
0
}
Unexecuted instantiation: aes.c:w64GetHigh32
Unexecuted instantiation: asn.c:w64GetHigh32
Unexecuted instantiation: camellia.c:w64GetHigh32
Unexecuted instantiation: chacha.c:w64GetHigh32
Unexecuted instantiation: chacha20_poly1305.c:w64GetHigh32
Unexecuted instantiation: cmac.c:w64GetHigh32
Unexecuted instantiation: coding.c:w64GetHigh32
Unexecuted instantiation: curve25519.c:w64GetHigh32
Unexecuted instantiation: curve448.c:w64GetHigh32
Unexecuted instantiation: des3.c:w64GetHigh32
Unexecuted instantiation: dh.c:w64GetHigh32
Unexecuted instantiation: ecc.c:w64GetHigh32
Unexecuted instantiation: eccsi.c:w64GetHigh32
Unexecuted instantiation: ed25519.c:w64GetHigh32
Unexecuted instantiation: ed448.c:w64GetHigh32
Unexecuted instantiation: fe_448.c:w64GetHigh32
Unexecuted instantiation: fe_operations.c:w64GetHigh32
Unexecuted instantiation: ge_448.c:w64GetHigh32
Unexecuted instantiation: ge_operations.c:w64GetHigh32
Unexecuted instantiation: hash.c:w64GetHigh32
Unexecuted instantiation: hmac.c:w64GetHigh32
Unexecuted instantiation: kdf.c:w64GetHigh32
Unexecuted instantiation: md2.c:w64GetHigh32
Unexecuted instantiation: md4.c:w64GetHigh32
Unexecuted instantiation: md5.c:w64GetHigh32
Unexecuted instantiation: poly1305.c:w64GetHigh32
Unexecuted instantiation: pwdbased.c:w64GetHigh32
Unexecuted instantiation: random.c:w64GetHigh32
Unexecuted instantiation: ripemd.c:w64GetHigh32
Unexecuted instantiation: rsa.c:w64GetHigh32
Unexecuted instantiation: sha.c:w64GetHigh32
Unexecuted instantiation: sha256.c:w64GetHigh32
Unexecuted instantiation: sha3.c:w64GetHigh32
Unexecuted instantiation: sha512.c:w64GetHigh32
Unexecuted instantiation: siphash.c:w64GetHigh32
Unexecuted instantiation: sm2.c:w64GetHigh32
Unexecuted instantiation: sm3.c:w64GetHigh32
Unexecuted instantiation: sm4.c:w64GetHigh32
Unexecuted instantiation: sp_int.c:w64GetHigh32
Unexecuted instantiation: wc_encrypt.c:w64GetHigh32
Unexecuted instantiation: wolfmath.c:w64GetHigh32
Unexecuted instantiation: ssl.c:w64GetHigh32
Unexecuted instantiation: tls.c:w64GetHigh32
Unexecuted instantiation: tls13.c:w64GetHigh32
Unexecuted instantiation: internal.c:w64GetHigh32
954
955
0
WC_MISC_STATIC WC_INLINE void w64SetLow32(w64wrapper *n, word32 low) {
956
0
    n->n = (n->n & (~(word64)(0xffffffff))) | low;
957
0
}
Unexecuted instantiation: aes.c:w64SetLow32
Unexecuted instantiation: asn.c:w64SetLow32
Unexecuted instantiation: camellia.c:w64SetLow32
Unexecuted instantiation: chacha.c:w64SetLow32
Unexecuted instantiation: chacha20_poly1305.c:w64SetLow32
Unexecuted instantiation: cmac.c:w64SetLow32
Unexecuted instantiation: coding.c:w64SetLow32
Unexecuted instantiation: curve25519.c:w64SetLow32
Unexecuted instantiation: curve448.c:w64SetLow32
Unexecuted instantiation: des3.c:w64SetLow32
Unexecuted instantiation: dh.c:w64SetLow32
Unexecuted instantiation: ecc.c:w64SetLow32
Unexecuted instantiation: eccsi.c:w64SetLow32
Unexecuted instantiation: ed25519.c:w64SetLow32
Unexecuted instantiation: ed448.c:w64SetLow32
Unexecuted instantiation: fe_448.c:w64SetLow32
Unexecuted instantiation: fe_operations.c:w64SetLow32
Unexecuted instantiation: ge_448.c:w64SetLow32
Unexecuted instantiation: ge_operations.c:w64SetLow32
Unexecuted instantiation: hash.c:w64SetLow32
Unexecuted instantiation: hmac.c:w64SetLow32
Unexecuted instantiation: kdf.c:w64SetLow32
Unexecuted instantiation: md2.c:w64SetLow32
Unexecuted instantiation: md4.c:w64SetLow32
Unexecuted instantiation: md5.c:w64SetLow32
Unexecuted instantiation: poly1305.c:w64SetLow32
Unexecuted instantiation: pwdbased.c:w64SetLow32
Unexecuted instantiation: random.c:w64SetLow32
Unexecuted instantiation: ripemd.c:w64SetLow32
Unexecuted instantiation: rsa.c:w64SetLow32
Unexecuted instantiation: sha.c:w64SetLow32
Unexecuted instantiation: sha256.c:w64SetLow32
Unexecuted instantiation: sha3.c:w64SetLow32
Unexecuted instantiation: sha512.c:w64SetLow32
Unexecuted instantiation: siphash.c:w64SetLow32
Unexecuted instantiation: sm2.c:w64SetLow32
Unexecuted instantiation: sm3.c:w64SetLow32
Unexecuted instantiation: sm4.c:w64SetLow32
Unexecuted instantiation: sp_int.c:w64SetLow32
Unexecuted instantiation: wc_encrypt.c:w64SetLow32
Unexecuted instantiation: wolfmath.c:w64SetLow32
Unexecuted instantiation: ssl.c:w64SetLow32
Unexecuted instantiation: tls.c:w64SetLow32
Unexecuted instantiation: tls13.c:w64SetLow32
Unexecuted instantiation: internal.c:w64SetLow32
958
959
WC_MISC_STATIC WC_INLINE w64wrapper w64Add32(w64wrapper a, word32 b, byte *wrap)
960
0
{
961
0
    a.n += b;
962
0
    if (a.n < b && wrap != NULL)
963
0
        *wrap = 1;
964
0
965
0
    return a;
966
0
}
Unexecuted instantiation: aes.c:w64Add32
Unexecuted instantiation: asn.c:w64Add32
Unexecuted instantiation: camellia.c:w64Add32
Unexecuted instantiation: chacha.c:w64Add32
Unexecuted instantiation: chacha20_poly1305.c:w64Add32
Unexecuted instantiation: cmac.c:w64Add32
Unexecuted instantiation: coding.c:w64Add32
Unexecuted instantiation: curve25519.c:w64Add32
Unexecuted instantiation: curve448.c:w64Add32
Unexecuted instantiation: des3.c:w64Add32
Unexecuted instantiation: dh.c:w64Add32
Unexecuted instantiation: ecc.c:w64Add32
Unexecuted instantiation: eccsi.c:w64Add32
Unexecuted instantiation: ed25519.c:w64Add32
Unexecuted instantiation: ed448.c:w64Add32
Unexecuted instantiation: fe_448.c:w64Add32
Unexecuted instantiation: fe_operations.c:w64Add32
Unexecuted instantiation: ge_448.c:w64Add32
Unexecuted instantiation: ge_operations.c:w64Add32
Unexecuted instantiation: hash.c:w64Add32
Unexecuted instantiation: hmac.c:w64Add32
Unexecuted instantiation: kdf.c:w64Add32
Unexecuted instantiation: md2.c:w64Add32
Unexecuted instantiation: md4.c:w64Add32
Unexecuted instantiation: md5.c:w64Add32
Unexecuted instantiation: poly1305.c:w64Add32
Unexecuted instantiation: pwdbased.c:w64Add32
Unexecuted instantiation: random.c:w64Add32
Unexecuted instantiation: ripemd.c:w64Add32
Unexecuted instantiation: rsa.c:w64Add32
Unexecuted instantiation: sha.c:w64Add32
Unexecuted instantiation: sha256.c:w64Add32
Unexecuted instantiation: sha3.c:w64Add32
Unexecuted instantiation: sha512.c:w64Add32
Unexecuted instantiation: siphash.c:w64Add32
Unexecuted instantiation: sm2.c:w64Add32
Unexecuted instantiation: sm3.c:w64Add32
Unexecuted instantiation: sm4.c:w64Add32
Unexecuted instantiation: sp_int.c:w64Add32
Unexecuted instantiation: wc_encrypt.c:w64Add32
Unexecuted instantiation: wolfmath.c:w64Add32
Unexecuted instantiation: ssl.c:w64Add32
Unexecuted instantiation: tls.c:w64Add32
Unexecuted instantiation: tls13.c:w64Add32
Unexecuted instantiation: internal.c:w64Add32
967
968
WC_MISC_STATIC WC_INLINE w64wrapper w64Add(w64wrapper a, w64wrapper b,
969
    byte *wrap)
970
0
{
971
0
    a.n += b.n;
972
0
    if (a.n < b.n && wrap != NULL)
973
0
        *wrap = 1;
974
0
975
0
    return a;
976
0
}
Unexecuted instantiation: aes.c:w64Add
Unexecuted instantiation: asn.c:w64Add
Unexecuted instantiation: camellia.c:w64Add
Unexecuted instantiation: chacha.c:w64Add
Unexecuted instantiation: chacha20_poly1305.c:w64Add
Unexecuted instantiation: cmac.c:w64Add
Unexecuted instantiation: coding.c:w64Add
Unexecuted instantiation: curve25519.c:w64Add
Unexecuted instantiation: curve448.c:w64Add
Unexecuted instantiation: des3.c:w64Add
Unexecuted instantiation: dh.c:w64Add
Unexecuted instantiation: ecc.c:w64Add
Unexecuted instantiation: eccsi.c:w64Add
Unexecuted instantiation: ed25519.c:w64Add
Unexecuted instantiation: ed448.c:w64Add
Unexecuted instantiation: fe_448.c:w64Add
Unexecuted instantiation: fe_operations.c:w64Add
Unexecuted instantiation: ge_448.c:w64Add
Unexecuted instantiation: ge_operations.c:w64Add
Unexecuted instantiation: hash.c:w64Add
Unexecuted instantiation: hmac.c:w64Add
Unexecuted instantiation: kdf.c:w64Add
Unexecuted instantiation: md2.c:w64Add
Unexecuted instantiation: md4.c:w64Add
Unexecuted instantiation: md5.c:w64Add
Unexecuted instantiation: poly1305.c:w64Add
Unexecuted instantiation: pwdbased.c:w64Add
Unexecuted instantiation: random.c:w64Add
Unexecuted instantiation: ripemd.c:w64Add
Unexecuted instantiation: rsa.c:w64Add
Unexecuted instantiation: sha.c:w64Add
Unexecuted instantiation: sha256.c:w64Add
Unexecuted instantiation: sha3.c:w64Add
Unexecuted instantiation: sha512.c:w64Add
Unexecuted instantiation: siphash.c:w64Add
Unexecuted instantiation: sm2.c:w64Add
Unexecuted instantiation: sm3.c:w64Add
Unexecuted instantiation: sm4.c:w64Add
Unexecuted instantiation: sp_int.c:w64Add
Unexecuted instantiation: wc_encrypt.c:w64Add
Unexecuted instantiation: wolfmath.c:w64Add
Unexecuted instantiation: ssl.c:w64Add
Unexecuted instantiation: tls.c:w64Add
Unexecuted instantiation: tls13.c:w64Add
Unexecuted instantiation: internal.c:w64Add
977
978
WC_MISC_STATIC WC_INLINE w64wrapper w64Sub32(w64wrapper a, word32 b, byte *wrap)
979
0
{
980
0
    if (a.n < b && wrap != NULL)
981
0
        *wrap = 1;
982
0
    a.n = a.n - b;
983
0
    return a;
984
0
}
Unexecuted instantiation: aes.c:w64Sub32
Unexecuted instantiation: asn.c:w64Sub32
Unexecuted instantiation: camellia.c:w64Sub32
Unexecuted instantiation: chacha.c:w64Sub32
Unexecuted instantiation: chacha20_poly1305.c:w64Sub32
Unexecuted instantiation: cmac.c:w64Sub32
Unexecuted instantiation: coding.c:w64Sub32
Unexecuted instantiation: curve25519.c:w64Sub32
Unexecuted instantiation: curve448.c:w64Sub32
Unexecuted instantiation: des3.c:w64Sub32
Unexecuted instantiation: dh.c:w64Sub32
Unexecuted instantiation: ecc.c:w64Sub32
Unexecuted instantiation: eccsi.c:w64Sub32
Unexecuted instantiation: ed25519.c:w64Sub32
Unexecuted instantiation: ed448.c:w64Sub32
Unexecuted instantiation: fe_448.c:w64Sub32
Unexecuted instantiation: fe_operations.c:w64Sub32
Unexecuted instantiation: ge_448.c:w64Sub32
Unexecuted instantiation: ge_operations.c:w64Sub32
Unexecuted instantiation: hash.c:w64Sub32
Unexecuted instantiation: hmac.c:w64Sub32
Unexecuted instantiation: kdf.c:w64Sub32
Unexecuted instantiation: md2.c:w64Sub32
Unexecuted instantiation: md4.c:w64Sub32
Unexecuted instantiation: md5.c:w64Sub32
Unexecuted instantiation: poly1305.c:w64Sub32
Unexecuted instantiation: pwdbased.c:w64Sub32
Unexecuted instantiation: random.c:w64Sub32
Unexecuted instantiation: ripemd.c:w64Sub32
Unexecuted instantiation: rsa.c:w64Sub32
Unexecuted instantiation: sha.c:w64Sub32
Unexecuted instantiation: sha256.c:w64Sub32
Unexecuted instantiation: sha3.c:w64Sub32
Unexecuted instantiation: sha512.c:w64Sub32
Unexecuted instantiation: siphash.c:w64Sub32
Unexecuted instantiation: sm2.c:w64Sub32
Unexecuted instantiation: sm3.c:w64Sub32
Unexecuted instantiation: sm4.c:w64Sub32
Unexecuted instantiation: sp_int.c:w64Sub32
Unexecuted instantiation: wc_encrypt.c:w64Sub32
Unexecuted instantiation: wolfmath.c:w64Sub32
Unexecuted instantiation: ssl.c:w64Sub32
Unexecuted instantiation: tls.c:w64Sub32
Unexecuted instantiation: tls13.c:w64Sub32
Unexecuted instantiation: internal.c:w64Sub32
985
986
WC_MISC_STATIC WC_INLINE byte w64GT(w64wrapper a, w64wrapper b)
987
0
{
988
0
    return a.n > b.n;
989
0
}
Unexecuted instantiation: aes.c:w64GT
Unexecuted instantiation: asn.c:w64GT
Unexecuted instantiation: camellia.c:w64GT
Unexecuted instantiation: chacha.c:w64GT
Unexecuted instantiation: chacha20_poly1305.c:w64GT
Unexecuted instantiation: cmac.c:w64GT
Unexecuted instantiation: coding.c:w64GT
Unexecuted instantiation: curve25519.c:w64GT
Unexecuted instantiation: curve448.c:w64GT
Unexecuted instantiation: des3.c:w64GT
Unexecuted instantiation: dh.c:w64GT
Unexecuted instantiation: ecc.c:w64GT
Unexecuted instantiation: eccsi.c:w64GT
Unexecuted instantiation: ed25519.c:w64GT
Unexecuted instantiation: ed448.c:w64GT
Unexecuted instantiation: fe_448.c:w64GT
Unexecuted instantiation: fe_operations.c:w64GT
Unexecuted instantiation: ge_448.c:w64GT
Unexecuted instantiation: ge_operations.c:w64GT
Unexecuted instantiation: hash.c:w64GT
Unexecuted instantiation: hmac.c:w64GT
Unexecuted instantiation: kdf.c:w64GT
Unexecuted instantiation: md2.c:w64GT
Unexecuted instantiation: md4.c:w64GT
Unexecuted instantiation: md5.c:w64GT
Unexecuted instantiation: poly1305.c:w64GT
Unexecuted instantiation: pwdbased.c:w64GT
Unexecuted instantiation: random.c:w64GT
Unexecuted instantiation: ripemd.c:w64GT
Unexecuted instantiation: rsa.c:w64GT
Unexecuted instantiation: sha.c:w64GT
Unexecuted instantiation: sha256.c:w64GT
Unexecuted instantiation: sha3.c:w64GT
Unexecuted instantiation: sha512.c:w64GT
Unexecuted instantiation: siphash.c:w64GT
Unexecuted instantiation: sm2.c:w64GT
Unexecuted instantiation: sm3.c:w64GT
Unexecuted instantiation: sm4.c:w64GT
Unexecuted instantiation: sp_int.c:w64GT
Unexecuted instantiation: wc_encrypt.c:w64GT
Unexecuted instantiation: wolfmath.c:w64GT
Unexecuted instantiation: ssl.c:w64GT
Unexecuted instantiation: tls.c:w64GT
Unexecuted instantiation: tls13.c:w64GT
990
991
WC_MISC_STATIC WC_INLINE byte w64IsZero(w64wrapper a)
992
0
{
993
0
    return a.n == 0;
994
0
}
Unexecuted instantiation: aes.c:w64IsZero
Unexecuted instantiation: asn.c:w64IsZero
Unexecuted instantiation: camellia.c:w64IsZero
Unexecuted instantiation: chacha.c:w64IsZero
Unexecuted instantiation: chacha20_poly1305.c:w64IsZero
Unexecuted instantiation: cmac.c:w64IsZero
Unexecuted instantiation: coding.c:w64IsZero
Unexecuted instantiation: curve25519.c:w64IsZero
Unexecuted instantiation: curve448.c:w64IsZero
Unexecuted instantiation: des3.c:w64IsZero
Unexecuted instantiation: dh.c:w64IsZero
Unexecuted instantiation: ecc.c:w64IsZero
Unexecuted instantiation: eccsi.c:w64IsZero
Unexecuted instantiation: ed25519.c:w64IsZero
Unexecuted instantiation: ed448.c:w64IsZero
Unexecuted instantiation: fe_448.c:w64IsZero
Unexecuted instantiation: fe_operations.c:w64IsZero
Unexecuted instantiation: ge_448.c:w64IsZero
Unexecuted instantiation: ge_operations.c:w64IsZero
Unexecuted instantiation: hash.c:w64IsZero
Unexecuted instantiation: hmac.c:w64IsZero
Unexecuted instantiation: kdf.c:w64IsZero
Unexecuted instantiation: md2.c:w64IsZero
Unexecuted instantiation: md4.c:w64IsZero
Unexecuted instantiation: md5.c:w64IsZero
Unexecuted instantiation: poly1305.c:w64IsZero
Unexecuted instantiation: pwdbased.c:w64IsZero
Unexecuted instantiation: random.c:w64IsZero
Unexecuted instantiation: ripemd.c:w64IsZero
Unexecuted instantiation: rsa.c:w64IsZero
Unexecuted instantiation: sha.c:w64IsZero
Unexecuted instantiation: sha256.c:w64IsZero
Unexecuted instantiation: sha3.c:w64IsZero
Unexecuted instantiation: sha512.c:w64IsZero
Unexecuted instantiation: siphash.c:w64IsZero
Unexecuted instantiation: sm2.c:w64IsZero
Unexecuted instantiation: sm3.c:w64IsZero
Unexecuted instantiation: sm4.c:w64IsZero
Unexecuted instantiation: sp_int.c:w64IsZero
Unexecuted instantiation: wc_encrypt.c:w64IsZero
Unexecuted instantiation: wolfmath.c:w64IsZero
Unexecuted instantiation: ssl.c:w64IsZero
Unexecuted instantiation: tls.c:w64IsZero
Unexecuted instantiation: tls13.c:w64IsZero
995
996
WC_MISC_STATIC WC_INLINE void c64toa(const w64wrapper *a, byte *out)
997
0
{
998
0
#ifdef BIG_ENDIAN_ORDER
999
0
    XMEMCPY(out, &a->n, sizeof(a->n));
1000
0
#else
1001
0
    word64 _out;
1002
0
    _out = ByteReverseWord64(a->n);
1003
0
    XMEMCPY(out, &_out, sizeof(_out));
1004
0
#endif /* BIG_ENDIAN_ORDER */
1005
0
}
Unexecuted instantiation: aes.c:c64toa
Unexecuted instantiation: asn.c:c64toa
Unexecuted instantiation: camellia.c:c64toa
Unexecuted instantiation: chacha.c:c64toa
Unexecuted instantiation: chacha20_poly1305.c:c64toa
Unexecuted instantiation: cmac.c:c64toa
Unexecuted instantiation: coding.c:c64toa
Unexecuted instantiation: curve25519.c:c64toa
Unexecuted instantiation: curve448.c:c64toa
Unexecuted instantiation: des3.c:c64toa
Unexecuted instantiation: dh.c:c64toa
Unexecuted instantiation: ecc.c:c64toa
Unexecuted instantiation: eccsi.c:c64toa
Unexecuted instantiation: ed25519.c:c64toa
Unexecuted instantiation: ed448.c:c64toa
Unexecuted instantiation: fe_448.c:c64toa
Unexecuted instantiation: fe_operations.c:c64toa
Unexecuted instantiation: ge_448.c:c64toa
Unexecuted instantiation: ge_operations.c:c64toa
Unexecuted instantiation: hash.c:c64toa
Unexecuted instantiation: hmac.c:c64toa
Unexecuted instantiation: kdf.c:c64toa
Unexecuted instantiation: md2.c:c64toa
Unexecuted instantiation: md4.c:c64toa
Unexecuted instantiation: md5.c:c64toa
Unexecuted instantiation: poly1305.c:c64toa
Unexecuted instantiation: pwdbased.c:c64toa
Unexecuted instantiation: random.c:c64toa
Unexecuted instantiation: ripemd.c:c64toa
Unexecuted instantiation: rsa.c:c64toa
Unexecuted instantiation: sha.c:c64toa
Unexecuted instantiation: sha256.c:c64toa
Unexecuted instantiation: sha3.c:c64toa
Unexecuted instantiation: sha512.c:c64toa
Unexecuted instantiation: siphash.c:c64toa
Unexecuted instantiation: sm2.c:c64toa
Unexecuted instantiation: sm3.c:c64toa
Unexecuted instantiation: sm4.c:c64toa
Unexecuted instantiation: sp_int.c:c64toa
Unexecuted instantiation: wc_encrypt.c:c64toa
Unexecuted instantiation: wolfmath.c:c64toa
Unexecuted instantiation: ssl.c:c64toa
Unexecuted instantiation: tls.c:c64toa
Unexecuted instantiation: tls13.c:c64toa
Unexecuted instantiation: internal.c:c64toa
1006
1007
WC_MISC_STATIC WC_INLINE void ato64(const byte *in, w64wrapper *w64)
1008
0
{
1009
0
#ifdef BIG_ENDIAN_ORDER
1010
0
    XMEMCPY(&w64->n, in, sizeof(w64->n));
1011
0
#else
1012
0
    union {
1013
0
        word64 w;
1014
0
        byte b[sizeof(word64)];
1015
0
    } _in;
1016
0
    XMEMCPY(_in.b, in, sizeof(_in));
1017
0
    w64->n = ByteReverseWord64(_in.w);
1018
0
#endif /* BIG_ENDIAN_ORDER */
1019
0
}
Unexecuted instantiation: aes.c:ato64
Unexecuted instantiation: asn.c:ato64
Unexecuted instantiation: camellia.c:ato64
Unexecuted instantiation: chacha.c:ato64
Unexecuted instantiation: chacha20_poly1305.c:ato64
Unexecuted instantiation: cmac.c:ato64
Unexecuted instantiation: coding.c:ato64
Unexecuted instantiation: curve25519.c:ato64
Unexecuted instantiation: curve448.c:ato64
Unexecuted instantiation: des3.c:ato64
Unexecuted instantiation: dh.c:ato64
Unexecuted instantiation: ecc.c:ato64
Unexecuted instantiation: eccsi.c:ato64
Unexecuted instantiation: ed25519.c:ato64
Unexecuted instantiation: ed448.c:ato64
Unexecuted instantiation: fe_448.c:ato64
Unexecuted instantiation: fe_operations.c:ato64
Unexecuted instantiation: ge_448.c:ato64
Unexecuted instantiation: ge_operations.c:ato64
Unexecuted instantiation: hash.c:ato64
Unexecuted instantiation: hmac.c:ato64
Unexecuted instantiation: kdf.c:ato64
Unexecuted instantiation: md2.c:ato64
Unexecuted instantiation: md4.c:ato64
Unexecuted instantiation: md5.c:ato64
Unexecuted instantiation: poly1305.c:ato64
Unexecuted instantiation: pwdbased.c:ato64
Unexecuted instantiation: random.c:ato64
Unexecuted instantiation: ripemd.c:ato64
Unexecuted instantiation: rsa.c:ato64
Unexecuted instantiation: sha.c:ato64
Unexecuted instantiation: sha256.c:ato64
Unexecuted instantiation: sha3.c:ato64
Unexecuted instantiation: sha512.c:ato64
Unexecuted instantiation: siphash.c:ato64
Unexecuted instantiation: sm2.c:ato64
Unexecuted instantiation: sm3.c:ato64
Unexecuted instantiation: sm4.c:ato64
Unexecuted instantiation: sp_int.c:ato64
Unexecuted instantiation: wc_encrypt.c:ato64
Unexecuted instantiation: wolfmath.c:ato64
Unexecuted instantiation: ssl.c:ato64
Unexecuted instantiation: tls.c:ato64
Unexecuted instantiation: tls13.c:ato64
Unexecuted instantiation: internal.c:ato64
1020
1021
WC_MISC_STATIC WC_INLINE w64wrapper w64From32(word32 hi, word32 lo)
1022
116k
{
1023
116k
    w64wrapper ret;
1024
116k
    ret.n = ((word64)hi << 32) | lo;
1025
116k
    return ret;
1026
116k
}
Unexecuted instantiation: aes.c:w64From32
Unexecuted instantiation: asn.c:w64From32
Unexecuted instantiation: camellia.c:w64From32
Unexecuted instantiation: chacha.c:w64From32
Unexecuted instantiation: chacha20_poly1305.c:w64From32
Unexecuted instantiation: cmac.c:w64From32
Unexecuted instantiation: coding.c:w64From32
Unexecuted instantiation: curve25519.c:w64From32
Unexecuted instantiation: curve448.c:w64From32
Unexecuted instantiation: des3.c:w64From32
Unexecuted instantiation: dh.c:w64From32
Unexecuted instantiation: ecc.c:w64From32
Unexecuted instantiation: eccsi.c:w64From32
Unexecuted instantiation: ed25519.c:w64From32
Unexecuted instantiation: ed448.c:w64From32
Unexecuted instantiation: fe_448.c:w64From32
Unexecuted instantiation: fe_operations.c:w64From32
Unexecuted instantiation: ge_448.c:w64From32
Unexecuted instantiation: ge_operations.c:w64From32
Unexecuted instantiation: hash.c:w64From32
Unexecuted instantiation: hmac.c:w64From32
Unexecuted instantiation: kdf.c:w64From32
Unexecuted instantiation: md2.c:w64From32
Unexecuted instantiation: md4.c:w64From32
Unexecuted instantiation: md5.c:w64From32
Unexecuted instantiation: poly1305.c:w64From32
Unexecuted instantiation: pwdbased.c:w64From32
Unexecuted instantiation: random.c:w64From32
Unexecuted instantiation: ripemd.c:w64From32
Unexecuted instantiation: rsa.c:w64From32
Unexecuted instantiation: sha.c:w64From32
Unexecuted instantiation: sha256.c:w64From32
Unexecuted instantiation: sha3.c:w64From32
Unexecuted instantiation: sha512.c:w64From32
Unexecuted instantiation: siphash.c:w64From32
Unexecuted instantiation: sm2.c:w64From32
Unexecuted instantiation: sm3.c:w64From32
Unexecuted instantiation: sm4.c:w64From32
Unexecuted instantiation: sp_int.c:w64From32
Unexecuted instantiation: wc_encrypt.c:w64From32
Unexecuted instantiation: wolfmath.c:w64From32
Unexecuted instantiation: ssl.c:w64From32
Unexecuted instantiation: tls.c:w64From32
Unexecuted instantiation: tls13.c:w64From32
internal.c:w64From32
Line
Count
Source
1022
116k
{
1023
116k
    w64wrapper ret;
1024
116k
    ret.n = ((word64)hi << 32) | lo;
1025
116k
    return ret;
1026
116k
}
1027
1028
WC_MISC_STATIC WC_INLINE byte w64GTE(w64wrapper a, w64wrapper b)
1029
16.4k
{
1030
16.4k
    return a.n >= b.n;
1031
16.4k
}
Unexecuted instantiation: aes.c:w64GTE
Unexecuted instantiation: asn.c:w64GTE
Unexecuted instantiation: camellia.c:w64GTE
Unexecuted instantiation: chacha.c:w64GTE
Unexecuted instantiation: chacha20_poly1305.c:w64GTE
Unexecuted instantiation: cmac.c:w64GTE
Unexecuted instantiation: coding.c:w64GTE
Unexecuted instantiation: curve25519.c:w64GTE
Unexecuted instantiation: curve448.c:w64GTE
Unexecuted instantiation: des3.c:w64GTE
Unexecuted instantiation: dh.c:w64GTE
Unexecuted instantiation: ecc.c:w64GTE
Unexecuted instantiation: eccsi.c:w64GTE
Unexecuted instantiation: ed25519.c:w64GTE
Unexecuted instantiation: ed448.c:w64GTE
Unexecuted instantiation: fe_448.c:w64GTE
Unexecuted instantiation: fe_operations.c:w64GTE
Unexecuted instantiation: ge_448.c:w64GTE
Unexecuted instantiation: ge_operations.c:w64GTE
Unexecuted instantiation: hash.c:w64GTE
Unexecuted instantiation: hmac.c:w64GTE
Unexecuted instantiation: kdf.c:w64GTE
Unexecuted instantiation: md2.c:w64GTE
Unexecuted instantiation: md4.c:w64GTE
Unexecuted instantiation: md5.c:w64GTE
Unexecuted instantiation: poly1305.c:w64GTE
Unexecuted instantiation: pwdbased.c:w64GTE
Unexecuted instantiation: random.c:w64GTE
Unexecuted instantiation: ripemd.c:w64GTE
Unexecuted instantiation: rsa.c:w64GTE
Unexecuted instantiation: sha.c:w64GTE
Unexecuted instantiation: sha256.c:w64GTE
Unexecuted instantiation: sha3.c:w64GTE
Unexecuted instantiation: sha512.c:w64GTE
Unexecuted instantiation: siphash.c:w64GTE
Unexecuted instantiation: sm2.c:w64GTE
Unexecuted instantiation: sm3.c:w64GTE
Unexecuted instantiation: sm4.c:w64GTE
Unexecuted instantiation: sp_int.c:w64GTE
Unexecuted instantiation: wc_encrypt.c:w64GTE
Unexecuted instantiation: wolfmath.c:w64GTE
Unexecuted instantiation: ssl.c:w64GTE
Unexecuted instantiation: tls.c:w64GTE
Unexecuted instantiation: tls13.c:w64GTE
internal.c:w64GTE
Line
Count
Source
1029
16.4k
{
1030
16.4k
    return a.n >= b.n;
1031
16.4k
}
1032
1033
WC_MISC_STATIC WC_INLINE byte w64LT(w64wrapper a, w64wrapper b)
1034
0
{
1035
0
    return a.n < b.n;
1036
0
}
Unexecuted instantiation: aes.c:w64LT
Unexecuted instantiation: asn.c:w64LT
Unexecuted instantiation: camellia.c:w64LT
Unexecuted instantiation: chacha.c:w64LT
Unexecuted instantiation: chacha20_poly1305.c:w64LT
Unexecuted instantiation: cmac.c:w64LT
Unexecuted instantiation: coding.c:w64LT
Unexecuted instantiation: curve25519.c:w64LT
Unexecuted instantiation: curve448.c:w64LT
Unexecuted instantiation: des3.c:w64LT
Unexecuted instantiation: dh.c:w64LT
Unexecuted instantiation: ecc.c:w64LT
Unexecuted instantiation: eccsi.c:w64LT
Unexecuted instantiation: ed25519.c:w64LT
Unexecuted instantiation: ed448.c:w64LT
Unexecuted instantiation: fe_448.c:w64LT
Unexecuted instantiation: fe_operations.c:w64LT
Unexecuted instantiation: ge_448.c:w64LT
Unexecuted instantiation: ge_operations.c:w64LT
Unexecuted instantiation: hash.c:w64LT
Unexecuted instantiation: hmac.c:w64LT
Unexecuted instantiation: kdf.c:w64LT
Unexecuted instantiation: md2.c:w64LT
Unexecuted instantiation: md4.c:w64LT
Unexecuted instantiation: md5.c:w64LT
Unexecuted instantiation: poly1305.c:w64LT
Unexecuted instantiation: pwdbased.c:w64LT
Unexecuted instantiation: random.c:w64LT
Unexecuted instantiation: ripemd.c:w64LT
Unexecuted instantiation: rsa.c:w64LT
Unexecuted instantiation: sha.c:w64LT
Unexecuted instantiation: sha256.c:w64LT
Unexecuted instantiation: sha3.c:w64LT
Unexecuted instantiation: sha512.c:w64LT
Unexecuted instantiation: siphash.c:w64LT
Unexecuted instantiation: sm2.c:w64LT
Unexecuted instantiation: sm3.c:w64LT
Unexecuted instantiation: sm4.c:w64LT
Unexecuted instantiation: sp_int.c:w64LT
Unexecuted instantiation: wc_encrypt.c:w64LT
Unexecuted instantiation: wolfmath.c:w64LT
Unexecuted instantiation: ssl.c:w64LT
Unexecuted instantiation: tls.c:w64LT
Unexecuted instantiation: tls13.c:w64LT
1037
1038
WC_MISC_STATIC WC_INLINE w64wrapper w64Sub(w64wrapper a, w64wrapper b)
1039
0
{
1040
0
    a.n -= b.n;
1041
0
    return a;
1042
0
}
Unexecuted instantiation: aes.c:w64Sub
Unexecuted instantiation: asn.c:w64Sub
Unexecuted instantiation: camellia.c:w64Sub
Unexecuted instantiation: chacha.c:w64Sub
Unexecuted instantiation: chacha20_poly1305.c:w64Sub
Unexecuted instantiation: cmac.c:w64Sub
Unexecuted instantiation: coding.c:w64Sub
Unexecuted instantiation: curve25519.c:w64Sub
Unexecuted instantiation: curve448.c:w64Sub
Unexecuted instantiation: des3.c:w64Sub
Unexecuted instantiation: dh.c:w64Sub
Unexecuted instantiation: ecc.c:w64Sub
Unexecuted instantiation: eccsi.c:w64Sub
Unexecuted instantiation: ed25519.c:w64Sub
Unexecuted instantiation: ed448.c:w64Sub
Unexecuted instantiation: fe_448.c:w64Sub
Unexecuted instantiation: fe_operations.c:w64Sub
Unexecuted instantiation: ge_448.c:w64Sub
Unexecuted instantiation: ge_operations.c:w64Sub
Unexecuted instantiation: hash.c:w64Sub
Unexecuted instantiation: hmac.c:w64Sub
Unexecuted instantiation: kdf.c:w64Sub
Unexecuted instantiation: md2.c:w64Sub
Unexecuted instantiation: md4.c:w64Sub
Unexecuted instantiation: md5.c:w64Sub
Unexecuted instantiation: poly1305.c:w64Sub
Unexecuted instantiation: pwdbased.c:w64Sub
Unexecuted instantiation: random.c:w64Sub
Unexecuted instantiation: ripemd.c:w64Sub
Unexecuted instantiation: rsa.c:w64Sub
Unexecuted instantiation: sha.c:w64Sub
Unexecuted instantiation: sha256.c:w64Sub
Unexecuted instantiation: sha3.c:w64Sub
Unexecuted instantiation: sha512.c:w64Sub
Unexecuted instantiation: siphash.c:w64Sub
Unexecuted instantiation: sm2.c:w64Sub
Unexecuted instantiation: sm3.c:w64Sub
Unexecuted instantiation: sm4.c:w64Sub
Unexecuted instantiation: sp_int.c:w64Sub
Unexecuted instantiation: wc_encrypt.c:w64Sub
Unexecuted instantiation: wolfmath.c:w64Sub
Unexecuted instantiation: ssl.c:w64Sub
Unexecuted instantiation: tls.c:w64Sub
Unexecuted instantiation: tls13.c:w64Sub
1043
1044
WC_MISC_STATIC WC_INLINE void w64Zero(w64wrapper *a)
1045
0
{
1046
0
    a->n = 0;
1047
0
}
Unexecuted instantiation: aes.c:w64Zero
Unexecuted instantiation: asn.c:w64Zero
Unexecuted instantiation: camellia.c:w64Zero
Unexecuted instantiation: chacha.c:w64Zero
Unexecuted instantiation: chacha20_poly1305.c:w64Zero
Unexecuted instantiation: cmac.c:w64Zero
Unexecuted instantiation: coding.c:w64Zero
Unexecuted instantiation: curve25519.c:w64Zero
Unexecuted instantiation: curve448.c:w64Zero
Unexecuted instantiation: des3.c:w64Zero
Unexecuted instantiation: dh.c:w64Zero
Unexecuted instantiation: ecc.c:w64Zero
Unexecuted instantiation: eccsi.c:w64Zero
Unexecuted instantiation: ed25519.c:w64Zero
Unexecuted instantiation: ed448.c:w64Zero
Unexecuted instantiation: fe_448.c:w64Zero
Unexecuted instantiation: fe_operations.c:w64Zero
Unexecuted instantiation: ge_448.c:w64Zero
Unexecuted instantiation: ge_operations.c:w64Zero
Unexecuted instantiation: hash.c:w64Zero
Unexecuted instantiation: hmac.c:w64Zero
Unexecuted instantiation: kdf.c:w64Zero
Unexecuted instantiation: md2.c:w64Zero
Unexecuted instantiation: md4.c:w64Zero
Unexecuted instantiation: md5.c:w64Zero
Unexecuted instantiation: poly1305.c:w64Zero
Unexecuted instantiation: pwdbased.c:w64Zero
Unexecuted instantiation: random.c:w64Zero
Unexecuted instantiation: ripemd.c:w64Zero
Unexecuted instantiation: rsa.c:w64Zero
Unexecuted instantiation: sha.c:w64Zero
Unexecuted instantiation: sha256.c:w64Zero
Unexecuted instantiation: sha3.c:w64Zero
Unexecuted instantiation: sha512.c:w64Zero
Unexecuted instantiation: siphash.c:w64Zero
Unexecuted instantiation: sm2.c:w64Zero
Unexecuted instantiation: sm3.c:w64Zero
Unexecuted instantiation: sm4.c:w64Zero
Unexecuted instantiation: sp_int.c:w64Zero
Unexecuted instantiation: wc_encrypt.c:w64Zero
Unexecuted instantiation: wolfmath.c:w64Zero
Unexecuted instantiation: ssl.c:w64Zero
Unexecuted instantiation: tls.c:w64Zero
Unexecuted instantiation: tls13.c:w64Zero
1048
1049
WC_MISC_STATIC WC_INLINE w64wrapper w64ShiftRight(w64wrapper a, int shift)
1050
0
{
1051
0
    a.n >>= shift;
1052
0
    return a;
1053
0
}
Unexecuted instantiation: aes.c:w64ShiftRight
Unexecuted instantiation: asn.c:w64ShiftRight
Unexecuted instantiation: camellia.c:w64ShiftRight
Unexecuted instantiation: chacha.c:w64ShiftRight
Unexecuted instantiation: chacha20_poly1305.c:w64ShiftRight
Unexecuted instantiation: cmac.c:w64ShiftRight
Unexecuted instantiation: coding.c:w64ShiftRight
Unexecuted instantiation: curve25519.c:w64ShiftRight
Unexecuted instantiation: curve448.c:w64ShiftRight
Unexecuted instantiation: des3.c:w64ShiftRight
Unexecuted instantiation: dh.c:w64ShiftRight
Unexecuted instantiation: ecc.c:w64ShiftRight
Unexecuted instantiation: eccsi.c:w64ShiftRight
Unexecuted instantiation: ed25519.c:w64ShiftRight
Unexecuted instantiation: ed448.c:w64ShiftRight
Unexecuted instantiation: fe_448.c:w64ShiftRight
Unexecuted instantiation: fe_operations.c:w64ShiftRight
Unexecuted instantiation: ge_448.c:w64ShiftRight
Unexecuted instantiation: ge_operations.c:w64ShiftRight
Unexecuted instantiation: hash.c:w64ShiftRight
Unexecuted instantiation: hmac.c:w64ShiftRight
Unexecuted instantiation: kdf.c:w64ShiftRight
Unexecuted instantiation: md2.c:w64ShiftRight
Unexecuted instantiation: md4.c:w64ShiftRight
Unexecuted instantiation: md5.c:w64ShiftRight
Unexecuted instantiation: poly1305.c:w64ShiftRight
Unexecuted instantiation: pwdbased.c:w64ShiftRight
Unexecuted instantiation: random.c:w64ShiftRight
Unexecuted instantiation: ripemd.c:w64ShiftRight
Unexecuted instantiation: rsa.c:w64ShiftRight
Unexecuted instantiation: sha.c:w64ShiftRight
Unexecuted instantiation: sha256.c:w64ShiftRight
Unexecuted instantiation: sha3.c:w64ShiftRight
Unexecuted instantiation: sha512.c:w64ShiftRight
Unexecuted instantiation: siphash.c:w64ShiftRight
Unexecuted instantiation: sm2.c:w64ShiftRight
Unexecuted instantiation: sm3.c:w64ShiftRight
Unexecuted instantiation: sm4.c:w64ShiftRight
Unexecuted instantiation: sp_int.c:w64ShiftRight
Unexecuted instantiation: wc_encrypt.c:w64ShiftRight
Unexecuted instantiation: wolfmath.c:w64ShiftRight
Unexecuted instantiation: ssl.c:w64ShiftRight
Unexecuted instantiation: tls.c:w64ShiftRight
Unexecuted instantiation: tls13.c:w64ShiftRight
Unexecuted instantiation: internal.c:w64ShiftRight
1054
1055
WC_MISC_STATIC WC_INLINE w64wrapper w64ShiftLeft(w64wrapper a, int shift)
1056
0
{
1057
0
    a.n <<= shift;
1058
0
    return a;
1059
0
}
Unexecuted instantiation: aes.c:w64ShiftLeft
Unexecuted instantiation: asn.c:w64ShiftLeft
Unexecuted instantiation: camellia.c:w64ShiftLeft
Unexecuted instantiation: chacha.c:w64ShiftLeft
Unexecuted instantiation: chacha20_poly1305.c:w64ShiftLeft
Unexecuted instantiation: cmac.c:w64ShiftLeft
Unexecuted instantiation: coding.c:w64ShiftLeft
Unexecuted instantiation: curve25519.c:w64ShiftLeft
Unexecuted instantiation: curve448.c:w64ShiftLeft
Unexecuted instantiation: des3.c:w64ShiftLeft
Unexecuted instantiation: dh.c:w64ShiftLeft
Unexecuted instantiation: ecc.c:w64ShiftLeft
Unexecuted instantiation: eccsi.c:w64ShiftLeft
Unexecuted instantiation: ed25519.c:w64ShiftLeft
Unexecuted instantiation: ed448.c:w64ShiftLeft
Unexecuted instantiation: fe_448.c:w64ShiftLeft
Unexecuted instantiation: fe_operations.c:w64ShiftLeft
Unexecuted instantiation: ge_448.c:w64ShiftLeft
Unexecuted instantiation: ge_operations.c:w64ShiftLeft
Unexecuted instantiation: hash.c:w64ShiftLeft
Unexecuted instantiation: hmac.c:w64ShiftLeft
Unexecuted instantiation: kdf.c:w64ShiftLeft
Unexecuted instantiation: md2.c:w64ShiftLeft
Unexecuted instantiation: md4.c:w64ShiftLeft
Unexecuted instantiation: md5.c:w64ShiftLeft
Unexecuted instantiation: poly1305.c:w64ShiftLeft
Unexecuted instantiation: pwdbased.c:w64ShiftLeft
Unexecuted instantiation: random.c:w64ShiftLeft
Unexecuted instantiation: ripemd.c:w64ShiftLeft
Unexecuted instantiation: rsa.c:w64ShiftLeft
Unexecuted instantiation: sha.c:w64ShiftLeft
Unexecuted instantiation: sha256.c:w64ShiftLeft
Unexecuted instantiation: sha3.c:w64ShiftLeft
Unexecuted instantiation: sha512.c:w64ShiftLeft
Unexecuted instantiation: siphash.c:w64ShiftLeft
Unexecuted instantiation: sm2.c:w64ShiftLeft
Unexecuted instantiation: sm3.c:w64ShiftLeft
Unexecuted instantiation: sm4.c:w64ShiftLeft
Unexecuted instantiation: sp_int.c:w64ShiftLeft
Unexecuted instantiation: wc_encrypt.c:w64ShiftLeft
Unexecuted instantiation: wolfmath.c:w64ShiftLeft
Unexecuted instantiation: ssl.c:w64ShiftLeft
Unexecuted instantiation: tls.c:w64ShiftLeft
Unexecuted instantiation: tls13.c:w64ShiftLeft
Unexecuted instantiation: internal.c:w64ShiftLeft
1060
1061
WC_MISC_STATIC WC_INLINE w64wrapper w64Mul(word32 a, word32 b)
1062
0
{
1063
0
    w64wrapper ret;
1064
0
    ret.n = (word64)a * (word64)b;
1065
0
    return ret;
1066
0
}
Unexecuted instantiation: aes.c:w64Mul
Unexecuted instantiation: asn.c:w64Mul
Unexecuted instantiation: camellia.c:w64Mul
Unexecuted instantiation: chacha.c:w64Mul
Unexecuted instantiation: chacha20_poly1305.c:w64Mul
Unexecuted instantiation: cmac.c:w64Mul
Unexecuted instantiation: coding.c:w64Mul
Unexecuted instantiation: curve25519.c:w64Mul
Unexecuted instantiation: curve448.c:w64Mul
Unexecuted instantiation: des3.c:w64Mul
Unexecuted instantiation: dh.c:w64Mul
Unexecuted instantiation: ecc.c:w64Mul
Unexecuted instantiation: eccsi.c:w64Mul
Unexecuted instantiation: ed25519.c:w64Mul
Unexecuted instantiation: ed448.c:w64Mul
Unexecuted instantiation: fe_448.c:w64Mul
Unexecuted instantiation: fe_operations.c:w64Mul
Unexecuted instantiation: ge_448.c:w64Mul
Unexecuted instantiation: ge_operations.c:w64Mul
Unexecuted instantiation: hash.c:w64Mul
Unexecuted instantiation: hmac.c:w64Mul
Unexecuted instantiation: kdf.c:w64Mul
Unexecuted instantiation: md2.c:w64Mul
Unexecuted instantiation: md4.c:w64Mul
Unexecuted instantiation: md5.c:w64Mul
Unexecuted instantiation: poly1305.c:w64Mul
Unexecuted instantiation: pwdbased.c:w64Mul
Unexecuted instantiation: random.c:w64Mul
Unexecuted instantiation: ripemd.c:w64Mul
Unexecuted instantiation: rsa.c:w64Mul
Unexecuted instantiation: sha.c:w64Mul
Unexecuted instantiation: sha256.c:w64Mul
Unexecuted instantiation: sha3.c:w64Mul
Unexecuted instantiation: sha512.c:w64Mul
Unexecuted instantiation: siphash.c:w64Mul
Unexecuted instantiation: sm2.c:w64Mul
Unexecuted instantiation: sm3.c:w64Mul
Unexecuted instantiation: sm4.c:w64Mul
Unexecuted instantiation: sp_int.c:w64Mul
Unexecuted instantiation: wc_encrypt.c:w64Mul
Unexecuted instantiation: wolfmath.c:w64Mul
Unexecuted instantiation: ssl.c:w64Mul
Unexecuted instantiation: tls.c:w64Mul
Unexecuted instantiation: tls13.c:w64Mul
Unexecuted instantiation: internal.c:w64Mul
1067
1068
#else
1069
1070
WC_MISC_STATIC WC_INLINE void w64Increment(w64wrapper *n)
1071
{
1072
    n->n[1]++;
1073
    if (n->n[1] == 0)
1074
        n->n[0]++;
1075
}
1076
1077
WC_MISC_STATIC WC_INLINE void w64Decrement(w64wrapper *n) {
1078
    if (n->n[1] == 0)
1079
        n->n[0]--;
1080
    n->n[1]--;
1081
}
1082
1083
WC_MISC_STATIC WC_INLINE byte w64Equal(w64wrapper a, w64wrapper b)
1084
{
1085
    return (a.n[0] == b.n[0] && a.n[1] == b.n[1]);
1086
}
1087
1088
WC_MISC_STATIC WC_INLINE word32 w64GetLow32(w64wrapper n) {
1089
    return n.n[1];
1090
}
1091
1092
WC_MISC_STATIC WC_INLINE word32 w64GetHigh32(w64wrapper n) {
1093
    return n.n[0];
1094
}
1095
1096
WC_MISC_STATIC WC_INLINE void w64SetLow32(w64wrapper *n, word32 low)
1097
{
1098
    n->n[1] = low;
1099
}
1100
1101
WC_MISC_STATIC WC_INLINE w64wrapper w64Add32(w64wrapper a, word32 b, byte *wrap)
1102
{
1103
    a.n[1] += b;
1104
    if (a.n[1] < b) {
1105
        a.n[0]++;
1106
        if (wrap != NULL && a.n[0] == 0)
1107
                *wrap = 1;
1108
    }
1109
1110
    return a;
1111
}
1112
1113
WC_MISC_STATIC WC_INLINE w64wrapper w64Add(w64wrapper a, w64wrapper b,
1114
    byte *wrap)
1115
{
1116
    a.n[1] += b.n[1];
1117
    if (a.n[1] < b.n[1]) {
1118
        a.n[0]++;
1119
        if (wrap != NULL && a.n[0] == 0)
1120
                *wrap = 1;
1121
    }
1122
1123
    a.n[0] += b.n[0];
1124
    if (wrap != NULL && a.n[0] < b.n[0]) {
1125
        *wrap = 1;
1126
    }
1127
1128
    return a;
1129
}
1130
1131
WC_MISC_STATIC WC_INLINE w64wrapper w64Sub32(w64wrapper a, word32 b, byte *wrap)
1132
{
1133
    byte _underflow = 0;
1134
    if (a.n[1] < b)
1135
        _underflow = 1;
1136
1137
    a.n[1] -= b;
1138
    if (_underflow) {
1139
        if (a.n[0] == 0 && wrap != NULL)
1140
            *wrap = 1;
1141
        a.n[0]--;
1142
    }
1143
1144
    return a;
1145
}
1146
1147
WC_MISC_STATIC WC_INLINE w64wrapper w64Sub(w64wrapper a, w64wrapper b)
1148
{
1149
    if (a.n[1] < b.n[1])
1150
        a.n[0]--;
1151
    a.n[1] -= b.n[1];
1152
    a.n[0] -= b.n[0];
1153
    return a;
1154
}
1155
1156
WC_MISC_STATIC WC_INLINE void w64Zero(w64wrapper *a)
1157
{
1158
    a->n[0] = a->n[1] = 0;
1159
}
1160
1161
WC_MISC_STATIC WC_INLINE byte w64GT(w64wrapper a, w64wrapper b)
1162
{
1163
    if (a.n[0] > b.n[0])
1164
        return 1;
1165
    if (a.n[0] == b.n[0])
1166
        return a.n[1] > b.n[1];
1167
    return 0;
1168
}
1169
1170
WC_MISC_STATIC WC_INLINE byte w64GTE(w64wrapper a, w64wrapper b)
1171
{
1172
    if (a.n[0] > b.n[0])
1173
        return 1;
1174
    if (a.n[0] == b.n[0])
1175
        return a.n[1] >= b.n[1];
1176
    return 0;
1177
}
1178
1179
WC_MISC_STATIC WC_INLINE byte w64IsZero(w64wrapper a)
1180
{
1181
    return a.n[0] == 0 && a.n[1] == 0;
1182
}
1183
1184
WC_MISC_STATIC WC_INLINE void c64toa(const w64wrapper *a, byte *out)
1185
{
1186
#ifdef BIG_ENDIAN_ORDER
1187
    word32 *_out = (word32*)(out);
1188
    _out[0] = a->n[0];
1189
    _out[1] = a->n[1];
1190
#else
1191
    c32toa(a->n[0], out);
1192
    c32toa(a->n[1], out + 4);
1193
#endif /* BIG_ENDIAN_ORDER */
1194
}
1195
1196
WC_MISC_STATIC WC_INLINE void ato64(const byte *in, w64wrapper *w64)
1197
{
1198
#ifdef BIG_ENDIAN_ORDER
1199
    const word32 *_in = (const word32*)(in);
1200
    w64->n[0] = *_in;
1201
    w64->n[1] = *(_in + 1);
1202
#else
1203
    ato32(in, &w64->n[0]);
1204
    ato32(in + 4, &w64->n[1]);
1205
#endif /* BIG_ENDIAN_ORDER */
1206
}
1207
1208
WC_MISC_STATIC WC_INLINE w64wrapper w64From32(word32 hi, word32 lo)
1209
{
1210
    w64wrapper w64;
1211
    w64.n[0] = hi;
1212
    w64.n[1] = lo;
1213
    return w64;
1214
}
1215
1216
WC_MISC_STATIC WC_INLINE byte w64LT(w64wrapper a, w64wrapper b)
1217
{
1218
    if (a.n[0] < b.n[0])
1219
        return 1;
1220
    if (a.n[0] == b.n[0])
1221
        return a.n[1] < b.n[1];
1222
1223
    return 0;
1224
}
1225
1226
WC_MISC_STATIC WC_INLINE w64wrapper w64ShiftRight(w64wrapper a, int shift)
1227
{
1228
     if (shift < 32) {
1229
         a.n[1] = (a.n[1] >> shift) | (a.n[0] << (32 - shift));
1230
         a.n[0] >>= shift;
1231
     }
1232
     else {
1233
         a.n[1] = a.n[0] >> (shift - 32);
1234
         a.n[0] = 0;
1235
     }
1236
     return a;
1237
}
1238
WC_MISC_STATIC WC_INLINE w64wrapper w64ShiftLeft(w64wrapper a, int shift)
1239
{
1240
     if (shift < 32) {
1241
         a.n[0] = (a.n[0] << shift) | (a.n[1] >> (32 - shift));
1242
         a.n[1] <<= shift;
1243
     }
1244
     else {
1245
         a.n[0] = a.n[1] << (shift - 32);
1246
         a.n[1] = 0;
1247
     }
1248
     return a;
1249
}
1250
1251
WC_MISC_STATIC WC_INLINE w64wrapper w64Mul(word32 a, word32 b)
1252
{
1253
    w64wrapper ret;
1254
    word16 ltlA, ltlB, ltlC, ltlD;
1255
    word32 bigA, bigB, bigC, bigD;
1256
1257
    ltlA = a & 0xFFFF;
1258
    ltlB = (a >> 16) & 0xFFFF;
1259
    ltlC = b & 0xFFFF;
1260
    ltlD = (b >> 16) & 0xFFFF;
1261
1262
    bigA = (word32)ltlA * (word32)ltlC;
1263
    bigC = (word32)ltlB * (word32)ltlC;
1264
    bigD = (word32)ltlA * (word32)ltlD;
1265
    bigB = (word32)ltlB * (word32)ltlD;
1266
1267
    ret = w64From32(0, bigB);
1268
    ret = w64ShiftLeft(ret, 16);
1269
    ret = w64Add32(ret, bigD, NULL);
1270
    ret = w64Add32(ret, bigC, NULL);
1271
    ret = w64ShiftLeft(ret, 16);
1272
    return w64Add32(ret, bigA, NULL);
1273
}
1274
1275
#endif /* WORD64_AVAILABLE && !WOLFSSL_W64_WRAPPER_TEST */
1276
#endif /* WOLFSSL_W64_WRAPPER */
1277
1278
#if defined(HAVE_SESSION_TICKET) || !defined(NO_CERTS) || \
1279
    !defined(NO_SESSION_CACHE)
1280
/* Make a word from the front of random hash */
1281
WC_MISC_STATIC WC_INLINE word32 MakeWordFromHash(const byte* hashID)
1282
6.36k
{
1283
6.36k
    return ((word32)hashID[0] << 24) | ((word32)hashID[1] << 16) |
1284
6.36k
           ((word32)hashID[2] <<  8) |  (word32)hashID[3];
1285
6.36k
}
Unexecuted instantiation: aes.c:MakeWordFromHash
Unexecuted instantiation: asn.c:MakeWordFromHash
Unexecuted instantiation: camellia.c:MakeWordFromHash
Unexecuted instantiation: chacha.c:MakeWordFromHash
Unexecuted instantiation: chacha20_poly1305.c:MakeWordFromHash
Unexecuted instantiation: cmac.c:MakeWordFromHash
Unexecuted instantiation: coding.c:MakeWordFromHash
Unexecuted instantiation: curve25519.c:MakeWordFromHash
Unexecuted instantiation: curve448.c:MakeWordFromHash
Unexecuted instantiation: des3.c:MakeWordFromHash
Unexecuted instantiation: dh.c:MakeWordFromHash
Unexecuted instantiation: ecc.c:MakeWordFromHash
Unexecuted instantiation: eccsi.c:MakeWordFromHash
Unexecuted instantiation: ed25519.c:MakeWordFromHash
Unexecuted instantiation: ed448.c:MakeWordFromHash
Unexecuted instantiation: fe_448.c:MakeWordFromHash
Unexecuted instantiation: fe_operations.c:MakeWordFromHash
Unexecuted instantiation: ge_448.c:MakeWordFromHash
Unexecuted instantiation: ge_operations.c:MakeWordFromHash
Unexecuted instantiation: hash.c:MakeWordFromHash
Unexecuted instantiation: hmac.c:MakeWordFromHash
Unexecuted instantiation: kdf.c:MakeWordFromHash
Unexecuted instantiation: md2.c:MakeWordFromHash
Unexecuted instantiation: md4.c:MakeWordFromHash
Unexecuted instantiation: md5.c:MakeWordFromHash
Unexecuted instantiation: poly1305.c:MakeWordFromHash
Unexecuted instantiation: pwdbased.c:MakeWordFromHash
Unexecuted instantiation: random.c:MakeWordFromHash
Unexecuted instantiation: ripemd.c:MakeWordFromHash
Unexecuted instantiation: rsa.c:MakeWordFromHash
Unexecuted instantiation: sha.c:MakeWordFromHash
Unexecuted instantiation: sha256.c:MakeWordFromHash
Unexecuted instantiation: sha3.c:MakeWordFromHash
Unexecuted instantiation: sha512.c:MakeWordFromHash
Unexecuted instantiation: siphash.c:MakeWordFromHash
Unexecuted instantiation: sm2.c:MakeWordFromHash
Unexecuted instantiation: sm3.c:MakeWordFromHash
Unexecuted instantiation: sm4.c:MakeWordFromHash
Unexecuted instantiation: sp_int.c:MakeWordFromHash
Unexecuted instantiation: wc_encrypt.c:MakeWordFromHash
Unexecuted instantiation: wolfmath.c:MakeWordFromHash
ssl.c:MakeWordFromHash
Line
Count
Source
1282
6.36k
{
1283
6.36k
    return ((word32)hashID[0] << 24) | ((word32)hashID[1] << 16) |
1284
6.36k
           ((word32)hashID[2] <<  8) |  (word32)hashID[3];
1285
6.36k
}
Unexecuted instantiation: tls.c:MakeWordFromHash
Unexecuted instantiation: tls13.c:MakeWordFromHash
Unexecuted instantiation: internal.c:MakeWordFromHash
1286
#endif /* HAVE_SESSION_TICKET || !NO_CERTS || !NO_SESSION_CACHE */
1287
1288
1289
#if !defined(WOLFCRYPT_ONLY) && !defined(NO_HASH_WRAPPER) && \
1290
    (!defined(NO_SESSION_CACHE) || defined(HAVE_SESSION_TICKET))
1291
1292
#include <wolfssl/wolfcrypt/hash.h>
1293
1294
/* some session IDs aren't random after all, let's make them random */
1295
WC_MISC_STATIC WC_INLINE word32 HashObject(const byte* o, word32 len,
1296
                                           int* error)
1297
538
{
1298
538
    byte digest[WC_MAX_DIGEST_SIZE];
1299
1300
538
#ifndef NO_MD5
1301
538
    *error =  wc_Md5Hash(o, len, digest);
1302
#elif !defined(NO_SHA)
1303
    *error =  wc_ShaHash(o, len, digest);
1304
#elif !defined(NO_SHA256)
1305
    *error =  wc_Sha256Hash(o, len, digest);
1306
#else
1307
    #error "We need a digest to hash the session IDs"
1308
#endif
1309
1310
538
    return *error == 0 ? MakeWordFromHash(digest) : 0; /* 0 on failure */
1311
538
}
Unexecuted instantiation: aes.c:HashObject
Unexecuted instantiation: asn.c:HashObject
Unexecuted instantiation: camellia.c:HashObject
Unexecuted instantiation: chacha.c:HashObject
Unexecuted instantiation: chacha20_poly1305.c:HashObject
Unexecuted instantiation: cmac.c:HashObject
Unexecuted instantiation: coding.c:HashObject
Unexecuted instantiation: curve25519.c:HashObject
Unexecuted instantiation: curve448.c:HashObject
Unexecuted instantiation: des3.c:HashObject
Unexecuted instantiation: dh.c:HashObject
Unexecuted instantiation: ecc.c:HashObject
Unexecuted instantiation: eccsi.c:HashObject
Unexecuted instantiation: ed25519.c:HashObject
Unexecuted instantiation: ed448.c:HashObject
Unexecuted instantiation: fe_448.c:HashObject
Unexecuted instantiation: fe_operations.c:HashObject
Unexecuted instantiation: ge_448.c:HashObject
Unexecuted instantiation: ge_operations.c:HashObject
Unexecuted instantiation: hash.c:HashObject
Unexecuted instantiation: hmac.c:HashObject
Unexecuted instantiation: kdf.c:HashObject
Unexecuted instantiation: md2.c:HashObject
Unexecuted instantiation: md4.c:HashObject
Unexecuted instantiation: md5.c:HashObject
Unexecuted instantiation: poly1305.c:HashObject
Unexecuted instantiation: pwdbased.c:HashObject
Unexecuted instantiation: random.c:HashObject
Unexecuted instantiation: ripemd.c:HashObject
Unexecuted instantiation: rsa.c:HashObject
Unexecuted instantiation: sha.c:HashObject
Unexecuted instantiation: sha256.c:HashObject
Unexecuted instantiation: sha3.c:HashObject
Unexecuted instantiation: sha512.c:HashObject
Unexecuted instantiation: siphash.c:HashObject
Unexecuted instantiation: sm2.c:HashObject
Unexecuted instantiation: sm3.c:HashObject
Unexecuted instantiation: sm4.c:HashObject
Unexecuted instantiation: sp_int.c:HashObject
Unexecuted instantiation: wc_encrypt.c:HashObject
Unexecuted instantiation: wolfmath.c:HashObject
ssl.c:HashObject
Line
Count
Source
1297
538
{
1298
538
    byte digest[WC_MAX_DIGEST_SIZE];
1299
1300
538
#ifndef NO_MD5
1301
538
    *error =  wc_Md5Hash(o, len, digest);
1302
#elif !defined(NO_SHA)
1303
    *error =  wc_ShaHash(o, len, digest);
1304
#elif !defined(NO_SHA256)
1305
    *error =  wc_Sha256Hash(o, len, digest);
1306
#else
1307
    #error "We need a digest to hash the session IDs"
1308
#endif
1309
1310
538
    return *error == 0 ? MakeWordFromHash(digest) : 0; /* 0 on failure */
1311
538
}
Unexecuted instantiation: tls.c:HashObject
Unexecuted instantiation: tls13.c:HashObject
Unexecuted instantiation: internal.c:HashObject
1312
#endif /* WOLFCRYPT_ONLY && !NO_HASH_WRAPPER &&
1313
        * (!NO_SESSION_CACHE || HAVE_SESSION_TICKET) */
1314
1315
WC_MISC_STATIC WC_INLINE char* CopyString(const char* src, int srcLen,
1316
12.2k
        void* heap, int type) {
1317
12.2k
    char* dst = NULL;
1318
1319
12.2k
    if (src == NULL)
1320
7.71k
        return NULL;
1321
1322
4.53k
    if (srcLen <= 0)
1323
1.36k
        srcLen = (int)XSTRLEN(src);
1324
1325
4.53k
    dst = (char*)XMALLOC((size_t)srcLen + 1, heap, type);
1326
4.53k
    if (dst != NULL) {
1327
4.53k
        XMEMCPY(dst, src, (size_t)srcLen);
1328
4.53k
        dst[srcLen] = '\0';
1329
4.53k
    }
1330
1331
4.53k
    return dst;
1332
12.2k
}
Unexecuted instantiation: aes.c:CopyString
asn.c:CopyString
Line
Count
Source
1316
12.2k
        void* heap, int type) {
1317
12.2k
    char* dst = NULL;
1318
1319
12.2k
    if (src == NULL)
1320
7.71k
        return NULL;
1321
1322
4.53k
    if (srcLen <= 0)
1323
1.36k
        srcLen = (int)XSTRLEN(src);
1324
1325
4.53k
    dst = (char*)XMALLOC((size_t)srcLen + 1, heap, type);
1326
4.53k
    if (dst != NULL) {
1327
4.53k
        XMEMCPY(dst, src, (size_t)srcLen);
1328
4.53k
        dst[srcLen] = '\0';
1329
4.53k
    }
1330
1331
4.53k
    return dst;
1332
12.2k
}
Unexecuted instantiation: camellia.c:CopyString
Unexecuted instantiation: chacha.c:CopyString
Unexecuted instantiation: chacha20_poly1305.c:CopyString
Unexecuted instantiation: cmac.c:CopyString
Unexecuted instantiation: coding.c:CopyString
Unexecuted instantiation: curve25519.c:CopyString
Unexecuted instantiation: curve448.c:CopyString
Unexecuted instantiation: des3.c:CopyString
Unexecuted instantiation: dh.c:CopyString
Unexecuted instantiation: ecc.c:CopyString
Unexecuted instantiation: eccsi.c:CopyString
Unexecuted instantiation: ed25519.c:CopyString
Unexecuted instantiation: ed448.c:CopyString
Unexecuted instantiation: fe_448.c:CopyString
Unexecuted instantiation: fe_operations.c:CopyString
Unexecuted instantiation: ge_448.c:CopyString
Unexecuted instantiation: ge_operations.c:CopyString
Unexecuted instantiation: hash.c:CopyString
Unexecuted instantiation: hmac.c:CopyString
Unexecuted instantiation: kdf.c:CopyString
Unexecuted instantiation: md2.c:CopyString
Unexecuted instantiation: md4.c:CopyString
Unexecuted instantiation: md5.c:CopyString
Unexecuted instantiation: poly1305.c:CopyString
Unexecuted instantiation: pwdbased.c:CopyString
Unexecuted instantiation: random.c:CopyString
Unexecuted instantiation: ripemd.c:CopyString
Unexecuted instantiation: rsa.c:CopyString
Unexecuted instantiation: sha.c:CopyString
Unexecuted instantiation: sha256.c:CopyString
Unexecuted instantiation: sha3.c:CopyString
Unexecuted instantiation: sha512.c:CopyString
Unexecuted instantiation: siphash.c:CopyString
Unexecuted instantiation: sm2.c:CopyString
Unexecuted instantiation: sm3.c:CopyString
Unexecuted instantiation: sm4.c:CopyString
Unexecuted instantiation: sp_int.c:CopyString
Unexecuted instantiation: wc_encrypt.c:CopyString
Unexecuted instantiation: wolfmath.c:CopyString
Unexecuted instantiation: ssl.c:CopyString
Unexecuted instantiation: tls.c:CopyString
Unexecuted instantiation: tls13.c:CopyString
Unexecuted instantiation: internal.c:CopyString
1333
1334
#endif /* !WOLFSSL_MISC_INCLUDED && !NO_INLINE */
1335
1336
#endif /* WOLF_CRYPT_MISC_C */