Skip to content

Commit 8857fb9

Browse files
committed
tests: add a fuzzer for dev_kmsg_record
1 parent a6da77b commit 8857fb9

File tree

8 files changed

+44
-1
lines changed

8 files changed

+44
-1
lines changed

src/fuzz/fuzz-journald-kmsg.c

Lines changed: 29 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,29 @@
1+
/* SPDX-License-Identifier: LGPL-2.1+ */
2+
3+
#include "fuzz.h"
4+
#include "journald-kmsg.h"
5+
6+
int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
7+
Server s = {};
8+
_cleanup_free_ char *buffer = NULL;
9+
10+
if (size == 0)
11+
return 0;
12+
13+
s = (Server) {
14+
.native_fd = -1,
15+
.stdout_fd = -1,
16+
.dev_kmsg_fd = -1,
17+
.audit_fd = -1,
18+
.hostname_fd = -1,
19+
.notify_fd = -1,
20+
.storage = STORAGE_NONE,
21+
};
22+
assert_se(sd_event_default(&s.event) >= 0);
23+
buffer = memdup(data, size);
24+
assert_se(buffer);
25+
dev_kmsg_record(&s, buffer, size);
26+
server_done(&s);
27+
28+
return 0;
29+
}

src/fuzz/meson.build

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -51,6 +51,11 @@ fuzzers += [
5151
libshared],
5252
[libmount]],
5353

54+
[['src/fuzz/fuzz-journald-kmsg.c'],
55+
[libjournal_core,
56+
libshared],
57+
[libselinux]],
58+
5459
[['src/fuzz/fuzz-journald-native.c',
5560
'src/fuzz/fuzz-journald.c'],
5661
[libjournal_core,

src/journal/journald-kmsg.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -94,7 +94,7 @@ static bool is_us(const char *identifier, const char *pid) {
9494
streq(identifier, program_invocation_short_name);
9595
}
9696

97-
static void dev_kmsg_record(Server *s, char *p, size_t l) {
97+
void dev_kmsg_record(Server *s, char *p, size_t l) {
9898

9999
_cleanup_free_ char *message = NULL, *syslog_priority = NULL, *syslog_pid = NULL, *syslog_facility = NULL, *syslog_identifier = NULL, *source_time = NULL, *identifier = NULL, *pid = NULL;
100100
struct iovec iovec[N_IOVEC_META_FIELDS + 7 + N_IOVEC_KERNEL_FIELDS + 2 + N_IOVEC_UDEV_FIELDS];

src/journal/journald-kmsg.h

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -9,3 +9,5 @@ int server_flush_dev_kmsg(Server *s);
99
void server_forward_kmsg(Server *s, int priority, const char *identifier, const char *message, const struct ucred *ucred);
1010

1111
int server_open_kernel_seqnum(Server *s);
12+
13+
void dev_kmsg_record(Server *s, char *p, size_t l);

test/fuzz/fuzz-journald-kmsg/basic

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
29,456,292891883,-;systemd[1]: Reexecuting.
Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,2 @@
1+
12,460,1322026586,-;hey
2+
DEVICE=c1:3
Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,2 @@
1+
12,460,1322026586,-;hey
2+
DEVICE=n1
Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,2 @@
1+
12,460,1322026586,-;hey
2+
DEVICE=+net:lo

0 commit comments

Comments
 (0)