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