/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 | | |