Coverage Report

Created: 2024-02-25 07:20

/src/libcaes/ossfuzz/crypt_xts_fuzzer.cc
Line
Count
Source (jump to first uncovered line)
1
/*
2
 * OSS-Fuzz target for libcaes AES-ECB 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 tweak_key[ 16 ]   = {
39
622
    0x80, 0x81, 0x82, 0x83, 0x84, 0x85, 0x86, 0x87, 0x88, 0x89, 0x8a, 0x8b, 0x8c, 0x8d, 0x8e, 0x8f };
40
622
  uint8_t tweak_value[ 16 ] = {
41
622
    0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f };
42
43
622
  libcaes_tweaked_context_t *tweaked_context = NULL;
44
45
622
  if( libcaes_tweaked_context_initialize(
46
622
       &tweaked_context,
47
622
       NULL ) != 1 )
48
0
  {
49
0
    return( 0 );
50
0
  }
51
622
  if( libcaes_tweaked_context_set_keys(
52
622
       tweaked_context,
53
622
       LIBCAES_CRYPT_MODE_ENCRYPT,
54
622
       key,
55
622
       128,
56
622
       tweak_key,
57
622
       128,
58
622
       NULL ) != 1 )
59
0
  {
60
0
    goto on_error_libcaes;
61
0
  }
62
622
  libcaes_crypt_xts(
63
622
   tweaked_context,
64
622
   LIBCAES_CRYPT_MODE_ENCRYPT,
65
622
   tweak_value,
66
622
   16,
67
622
   data,
68
622
   size,
69
622
   encrypted_data,
70
622
   64,
71
622
   NULL );
72
73
622
on_error_libcaes:
74
622
  libcaes_tweaked_context_free(
75
622
   &tweaked_context,
76
622
   NULL );
77
78
622
  return( 0 );
79
622
}
80
81
} /* extern "C" */
82