summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLuke Wilde <lukew@serenityos.org>2022-02-26 17:10:12 +0000
committerIdan Horowitz <idan.horowitz@gmail.com>2022-02-26 19:31:16 +0200
commit0568229d810112e93573046590d8076dcf8c98e8 (patch)
tree3d6eec174d617bf9238a29984524a65361a79045
parent50dc9a7be771f0b2ac8190dd437162f380e4b8a7 (diff)
downloadserenity-0568229d810112e93573046590d8076dcf8c98e8.zip
Lagom/Fuzzers: Add MP3 fuzzer
-rw-r--r--Meta/Lagom/Fuzzers/CMakeLists.txt1
-rw-r--r--Meta/Lagom/Fuzzers/FuzzMP3Loader.cpp28
2 files changed, 29 insertions, 0 deletions
diff --git a/Meta/Lagom/Fuzzers/CMakeLists.txt b/Meta/Lagom/Fuzzers/CMakeLists.txt
index da2c8e37f7..6fa8da4750 100644
--- a/Meta/Lagom/Fuzzers/CMakeLists.txt
+++ b/Meta/Lagom/Fuzzers/CMakeLists.txt
@@ -28,6 +28,7 @@ add_simple_fuzzer(FuzzGzipDecompression LagomCompress)
add_simple_fuzzer(FuzzICOLoader LagomGfx)
add_simple_fuzzer(FuzzJPGLoader LagomGfx)
add_simple_fuzzer(FuzzMD5 LagomCrypto)
+add_simple_fuzzer(FuzzMP3Loader LagomAudio)
add_simple_fuzzer(FuzzPEM LagomCrypto)
add_simple_fuzzer(FuzzPNGLoader LagomGfx)
add_simple_fuzzer(FuzzPBMLoader LagomGfx)
diff --git a/Meta/Lagom/Fuzzers/FuzzMP3Loader.cpp b/Meta/Lagom/Fuzzers/FuzzMP3Loader.cpp
new file mode 100644
index 0000000000..fd8cecc810
--- /dev/null
+++ b/Meta/Lagom/Fuzzers/FuzzMP3Loader.cpp
@@ -0,0 +1,28 @@
+/*
+ * Copyright (c) 2022, Luke Wilde <lukew@serenityos.org>
+ *
+ * SPDX-License-Identifier: BSD-2-Clause
+ */
+
+#include <LibAudio/MP3Loader.h>
+#include <stddef.h>
+#include <stdint.h>
+
+extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size)
+{
+ auto flac_data = ByteBuffer::copy(data, size).release_value();
+ auto mp3 = make<Audio::MP3LoaderPlugin>(flac_data);
+
+ if (mp3->initialize().is_error())
+ return 1;
+
+ for (;;) {
+ auto samples = mp3->get_more_samples();
+ if (samples.is_error())
+ return 2;
+ if (samples.value()->sample_count() > 0)
+ break;
+ }
+
+ return 0;
+}