Coverage Report

Created: 2024-02-25 07:20

/src/libcaes/ossfuzz/crypt_ccm_fuzzer.cc
Line
Count
Source (jump to first uncovered line)
1
/*
2
 * OSS-Fuzz target for libcaes AES-CCM crypt function
3
 *
4
 * Copyright (C) 2011-2024, Joachim Metz <joachim.metz@gmail.com>
5
 *
6
 * Refer to AUTHORS for acknowledgements.
7
 *
8
 * This program is free software: you can redistribute it and/or modify
9
 * it under the terms of the GNU Lesser General Public License as published by
10
 * the Free Software Foundation, either version 3 of the License, or
11
 * (at your option) any later version.
12
 *
13
 * This program is distributed in the hope that it will be useful,
14
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16
 * GNU General Public License for more details.
17
 *
18
 * You should have received a copy of the GNU Lesser General Public License
19
 * along with this program.  If not, see <https://www.gnu.org/licenses/>.
20
 */
21
22
#include <stddef.h>
23
#include <stdint.h>
24
25
/* Note that some of the OSS-Fuzz engines use C++
26
 */
27
extern "C" {
28
29
#include "ossfuzz_libcaes.h"
30
31
int LLVMFuzzerTestOneInput(
32
     const uint8_t *data,
33
     size_t size )
34
622
{
35
622
  uint8_t encrypted_data[ 64 ];
36
622
  uint8_t key[ 16 ]  = {
37
622
    0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f };
38
622
  uint8_t nonce[ 8 ] = {
39
622
    0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07 };
40
41
622
  libcaes_context_t *context = NULL;
42
43
622
  if( libcaes_context_initialize(
44
622
       &context,
45
622
       NULL ) != 1 )
46
0
  {
47
0
    return( 0 );
48
0
  }
49
622
  if( libcaes_context_set_key(
50
622
       context,
51
622
       LIBCAES_CRYPT_MODE_ENCRYPT,
52
622
       key,
53
622
       128,
54
622
       NULL ) != 1 )
55
0
  {
56
0
    goto on_error_libcaes;
57
0
  }
58
622
  libcaes_crypt_ccm(
59
622
   context,
60
622
   LIBCAES_CRYPT_MODE_ENCRYPT,
61
622
   nonce,
62
622
   8,
63
622
   data,
64
622
   size,
65
622
   encrypted_data,
66
622
   64,
67
622
   NULL );
68
69
622
on_error_libcaes:
70
622
  libcaes_context_free(
71
622
   &context,
72
622
   NULL );
73
74
622
  return( 0 );
75
622
}
76
77
} /* extern "C" */
78