]> git.ipfire.org Git - thirdparty/systemd.git/commitdiff
fuzz-lldp-rx: fuzz lldp_rx_build_neighbors_json() 31583/head
authorYu Watanabe <watanabe.yu+github@gmail.com>
Sat, 2 Mar 2024 04:50:50 +0000 (13:50 +0900)
committerYu Watanabe <watanabe.yu+github@gmail.com>
Sat, 2 Mar 2024 04:52:28 +0000 (13:52 +0900)
Addresses https://github.com/systemd/systemd/pull/31583#discussion_r1509882453.

src/libsystemd-network/fuzz-lldp-rx.c

index 844957c069e0f7671d29f4d08c873babeb450168..24146b709da5f828a2e42f35f747f2b592fadbac 100644 (file)
@@ -9,6 +9,7 @@
 #include "fd-util.h"
 #include "fuzz.h"
 #include "lldp-network.h"
+#include "lldp-rx-internal.h"
 
 static int test_fd[2] = EBADF_PAIR;
 
@@ -22,6 +23,7 @@ int lldp_network_bind_raw_socket(int ifindex) {
 int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
         _cleanup_(sd_event_unrefp) sd_event *e = NULL;
         _cleanup_(sd_lldp_rx_unrefp) sd_lldp_rx *lldp_rx = NULL;
+        _cleanup_(json_variant_unrefp) JsonVariant *v = NULL;
 
         if (outside_size_range(size, 0, 2048))
                 return 0;
@@ -37,6 +39,8 @@ int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
         assert_se(write(test_fd[1], data, size) == (ssize_t) size);
         assert_se(sd_event_run(e, 0) >= 0);
 
+        assert_se(lldp_rx_build_neighbors_json(lldp_rx, &v) >= 0);
+
         assert_se(sd_lldp_rx_stop(lldp_rx) >= 0);
         assert_se(sd_lldp_rx_detach_event(lldp_rx) >= 0);
         test_fd[1] = safe_close(test_fd[1]);