summaryrefslogtreecommitdiff
path: root/src/udev/fuzz-udev-rules.c
blob: aff176eb1bddcb701cd5f7806edf0a552f3d6249 (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
25
26
27
28
29
30
31
32
33
34
35
36
/* SPDX-License-Identifier: LGPL-2.1-or-later */

#include <stdio.h>

#include "fd-util.h"
#include "fs-util.h"
#include "fuzz.h"
#include "tests.h"
#include "tmpfile-util.h"
#include "udev-rules.h"

int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
        _cleanup_(udev_rules_freep) UdevRules *rules = NULL;
        _cleanup_fclose_ FILE *f = NULL;
        _cleanup_(unlink_tempfilep) char filename[] = "/tmp/fuzz-udev-rules.XXXXXX";
        int r;

        if (outside_size_range(size, 0, 65536))
                return 0;

        if (!getenv("SYSTEMD_LOG_LEVEL"))
                log_set_max_level(LOG_CRIT);

        assert_se(fmkostemp_safe(filename, "r+", &f) == 0);
        if (size != 0)
                assert_se(fwrite(data, size, 1, f) == 1);
        fflush(f);

        assert_se(rules = udev_rules_new(RESOLVE_NAME_EARLY));
        r = udev_rules_parse_file(rules, filename, /* extra_checks = */ false, NULL);
        log_info_errno(r, "Parsing %s: %m", filename);
        assert_se(r >= 0 ||             /* OK */
                  r == -ENOBUFS);       /* line length exceeded */

        return 0;
}