]> git.ipfire.org Git - thirdparty/samba.git/commitdiff
fuzz: add lzxpress compress/decompress round-trip
authorDouglas Bagnall <douglas.bagnall@catalyst.net.nz>
Wed, 11 May 2022 00:08:54 +0000 (12:08 +1200)
committerAndrew Bartlett <abartlet@samba.org>
Thu, 12 May 2022 02:22:35 +0000 (02:22 +0000)
We say it is an error to end up at a different result.

Signed-off-by: Douglas Bagnall <douglas.bagnall@catalyst.net.nz>
Reviewed-by: Andrew Bartlett <abartlet@samba.org>
lib/fuzzing/fuzz_lzxpress_round_trip.c [new file with mode: 0644]
lib/fuzzing/wscript_build

diff --git a/lib/fuzzing/fuzz_lzxpress_round_trip.c b/lib/fuzzing/fuzz_lzxpress_round_trip.c
new file mode 100644 (file)
index 0000000..a6173bb
--- /dev/null
@@ -0,0 +1,53 @@
+/*
+   Fuzzing for lzxpress_decompress
+   Copyright (C) Michael Hanselmann 2019
+
+   This program is free software; you can redistribute it and/or modify
+   it under the terms of the GNU General Public License as published by
+   the Free Software Foundation; either version 3 of the License, or
+   (at your option) any later version.
+
+   This program is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+   GNU General Public License for more details.
+
+   You should have received a copy of the GNU General Public License
+   along with this program.  If not, see <http://www.gnu.org/licenses/>.
+*/
+
+#include "includes.h"
+#include "fuzzing/fuzzing.h"
+#include "lzxpress.h"
+
+int LLVMFuzzerInitialize(int *argc, char ***argv)
+{
+       return 0;
+}
+
+int LLVMFuzzerTestOneInput(uint8_t *buf, size_t len)
+{
+       static uint8_t compressed[1024 * 1024] = {0};
+       static uint8_t decompressed[1024 * 1024] = {0};
+       ssize_t compressed_size;
+       ssize_t decompressed_size;
+
+       if (len > sizeof(decompressed)) {
+               return 0;
+       }
+
+       compressed_size = lzxpress_compress(buf, len,
+                                           compressed, sizeof(compressed));
+
+       decompressed_size = lzxpress_decompress(compressed, compressed_size,
+                                               decompressed, sizeof(decompressed));
+
+       if (decompressed_size != len) {
+               abort();
+       }
+       if (memcmp(buf, decompressed, len) != 0) {
+               abort();
+       }
+
+       return 0;
+}
index f9e2a9ab8b3f6c4bcd5725e1a5d9de9da627e6f2..9c559b3bcc89a3f55d96c4ebd15ce7f7316f8e77 100644 (file)
@@ -52,6 +52,11 @@ bld.SAMBA_BINARY('fuzz_lzxpress_compress',
                  deps='fuzzing LZXPRESS afl-fuzz-main',
                  fuzzer=True)
 
+bld.SAMBA_BINARY('fuzz_lzxpress_round_trip',
+                 source='fuzz_lzxpress_round_trip.c',
+                 deps='fuzzing LZXPRESS afl-fuzz-main',
+                 fuzzer=True)
+
 bld.SAMBA_BINARY('fuzz_ldap_decode',
                  source='fuzz_ldap_decode.c',
                  deps='fuzzing cli-ldap afl-fuzz-main',