Coverage Report

Created: 2026-04-04 07:15

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/ndpi/fuzz/fuzz_gcrypt_light.cpp
Line
Count
Source
1
#include "fuzz_common_code.h"
2
3
#include <stdint.h>
4
#include <stdio.h>
5
#include <assert.h>
6
#include "fuzzer/FuzzedDataProvider.h"
7
8
#ifdef HAVE_LIBGCRYPT
9
#include "gcrypt.h"
10
#define HMAC_SHA256_DIGEST_SIZE 32
11
#else
12
#include "../src/lib/third_party/include/gcrypt_light.h"
13
#endif
14
15
696
extern "C" int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
16
696
  FuzzedDataProvider fuzzed_data(data, size);
17
696
  gcry_md_hd_t hh;
18
696
  gcry_cipher_hd_t h;
19
696
  gcry_error_t rc;
20
696
  int algo = 0, flags = 0, mode = 0; /* Invalid values */
21
696
  int key_len, iv_len, auth_len;
22
696
  u_int8_t out[HMAC_SHA256_DIGEST_SIZE];
23
696
  char buf_err[16];
24
696
  void *enc_out;
25
26
  /* To allow memory allocation failures */
27
696
  fuzz_set_alloc_callbacks_and_seed(size);
28
29
696
  gcry_control(fuzzed_data.ConsumeIntegralInRange(0, 2),
30
696
               fuzzed_data.ConsumeIntegralInRange(0, 1));
31
32
  /* MD */
33
34
696
  if(fuzzed_data.ConsumeBool())
35
355
    algo = GCRY_MD_SHA256;
36
696
  if(fuzzed_data.ConsumeBool())
37
221
    flags = GCRY_MD_FLAG_HMAC;
38
696
  key_len = fuzzed_data.ConsumeIntegralInRange(0, 65); /* Max valid key length is 64 */
39
696
  std::vector<u_int8_t>key = fuzzed_data.ConsumeBytes<u_int8_t>(key_len);
40
696
  std::vector<u_int8_t>src = fuzzed_data.ConsumeBytes<uint8_t>(300);
41
42
696
  gcry_md_get_algo_dlen(algo);
43
696
  rc = gcry_md_open(&hh, algo, flags);
44
696
  if (rc == 0) {
45
175
    gcry_md_reset(hh);
46
175
    rc = gcry_md_setkey(hh, key.data(), key.size());
47
175
    if (rc == 0) {
48
175
      if(fuzzed_data.ConsumeBool()) { /* To trigger MBEDTLS_ERR_MD_REKEY */
49
44
        rc = gcry_md_setkey(hh, key.data(), key.size());
50
131
      } else {
51
131
        rc = gcry_md_write(hh, src.data(), src.size());
52
131
        if (rc == 0) {
53
99
          memcpy(out, gcry_md_read(hh, 0), gcry_md_get_algo_dlen(algo));
54
99
          gcry_md_get_algo(hh);
55
99
        }
56
131
      }
57
175
    }
58
175
    gcry_md_close(hh);
59
175
  }
60
696
  gpg_strerror_r(rc, buf_err, sizeof(buf_err));
61
62
63
  /* Encryption */
64
65
  /* ECB */
66
67
696
  if(fuzzed_data.ConsumeBool())
68
383
    algo = GCRY_CIPHER_AES128;
69
696
  if(fuzzed_data.ConsumeBool())
70
86
    flags = 1; /* Invalid value */
71
696
  if(fuzzed_data.ConsumeBool())
72
298
    mode = GCRY_CIPHER_MODE_ECB;
73
696
  key_len = fuzzed_data.ConsumeIntegralInRange(16, 17); /* Only 16 is a valid key length */
74
696
  std::vector<u_int8_t>key2 = fuzzed_data.ConsumeBytes<u_int8_t>(key_len);
75
696
  enc_out = ndpi_malloc(src.size());
76
696
  if (!enc_out)
77
21
    return 0;
78
79
675
  h = NULL;
80
675
  rc = gcry_cipher_open(&h, algo, mode, flags);
81
675
  gpg_strerror_r(rc, buf_err, sizeof(buf_err));
82
675
  if(fuzzed_data.ConsumeBool())
83
261
    gcry_cipher_setkey(h, key2.data(), key2.size());
84
675
  if(fuzzed_data.ConsumeBool()) /* To trigger MBEDTLS_ERR_CIPHER_BAD_KEY */
85
247
    gcry_cipher_setkey(h, key2.data(), key2.size());
86
675
  rc = gcry_cipher_decrypt(h, enc_out, src.size(), src.data(), src.size());
87
675
  gpg_strerror_r(rc, buf_err, sizeof(buf_err));
88
675
  rc = gcry_cipher_encrypt(h, enc_out, src.size(), src.data(), src.size());
89
675
  gcry_cipher_ctl(h, 0, NULL, 0);
90
675
  gcry_cipher_close(h);
91
92
675
  gpg_strerror_r(rc, buf_err, sizeof(buf_err));
93
94
  /* GCM */
95
96
675
  if(fuzzed_data.ConsumeBool())
97
282
    mode = GCRY_CIPHER_MODE_GCM;
98
675
  iv_len = fuzzed_data.ConsumeIntegralInRange(12, 12); /* Only 12 is a valid key length */
99
675
  std::vector<u_int8_t>iv = fuzzed_data.ConsumeBytes<u_int8_t>(iv_len);
100
675
  auth_len = fuzzed_data.ConsumeIntegralInRange(0, 257); /* 257 is an invalid value */
101
675
  std::vector<u_int8_t>auth = fuzzed_data.ConsumeBytes<u_int8_t>(auth_len);
102
103
675
  h = NULL;
104
675
  rc = gcry_cipher_open(&h, algo, mode, flags);
105
675
  gpg_strerror_r(rc, buf_err, sizeof(buf_err));
106
675
  if(fuzzed_data.ConsumeBool()) {
107
258
    rc = gcry_cipher_setkey(h, key2.data(), key2.size());
108
258
    gpg_strerror_r(rc, buf_err, sizeof(buf_err));
109
258
  }
110
675
  if(fuzzed_data.ConsumeBool())
111
193
    gcry_cipher_reset(h);
112
675
  rc = gcry_cipher_setiv(h, iv.data(), iv.size());
113
675
  gpg_strerror_r(rc, buf_err, sizeof(buf_err));
114
675
  if(fuzzed_data.ConsumeBool()) { /* To trigger MBEDTLS_ERR_CIPHER_BAD_KEY */
115
142
    rc = gcry_cipher_setiv(h, iv.data(), iv.size());
116
533
  } else {
117
533
    rc = gcry_cipher_authenticate(h, auth.data(), auth.size());
118
533
    if (rc == 0) {
119
155
      rc = gcry_cipher_encrypt(h, enc_out, src.size(), src.data(), src.size());
120
155
      gpg_strerror_r(rc, buf_err, sizeof(buf_err));
121
155
      rc = gcry_cipher_decrypt(h, enc_out, src.size(), src.data(), src.size());
122
155
    }
123
533
  }
124
675
  gcry_cipher_close(h);
125
126
675
  gpg_strerror_r(rc, buf_err, sizeof(buf_err));
127
128
675
  gpg_strerror_r(static_cast<gcry_error_t>(fuzzed_data.ConsumeIntegral<u_int16_t>()), buf_err, sizeof(buf_err));
129
130
675
  ndpi_free(enc_out);
131
132
675
  return 0;
133
696
}