blob: cb5be7a9b77f24bc4b8740830d35474b92b38f62 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
/* SPDX-License-Identifier: LGPL-2.1-or-later */
#include "alloc-util.h"
#include "bcd.h"
#include "fuzz.h"
#include "utf8.h"
int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
_cleanup_free_ void *p = NULL;
/* This limit was borrowed from src/boot/efi/boot.c */
if (outside_size_range(size, 0, 100*1024))
return 0;
fuzz_setup_logging();
p = memdup(data, size);
assert_se(p);
char16_t *title = get_bcd_title(p, size);
/* If we get something, it must be NUL-terminated, but an empty string is still valid! */
DO_NOT_OPTIMIZE(title && char16_strlen(title));
return 0;
}
|