diff --git a/Meta/Lagom/Fuzzers/FuzzTinyVGLoader.cpp b/Meta/Lagom/Fuzzers/FuzzTinyVGLoader.cpp new file mode 100644 index 0000000000..30f334fe6b --- /dev/null +++ b/Meta/Lagom/Fuzzers/FuzzTinyVGLoader.cpp @@ -0,0 +1,17 @@ +/* + * Copyright (c) 2023, MacDue + * + * SPDX-License-Identifier: BSD-2-Clause + */ + +#include + +extern "C" int LLVMFuzzerTestOneInput(uint8_t const* data, size_t size) +{ + auto decoder_or_error = Gfx::TinyVGImageDecoderPlugin::create({ data, size }); + if (decoder_or_error.is_error()) + return 0; + auto decoder = decoder_or_error.release_value(); + (void)decoder->frame(0); + return 0; +} diff --git a/Meta/Lagom/Fuzzers/fuzzers.cmake b/Meta/Lagom/Fuzzers/fuzzers.cmake index 19d35f1bd1..7670148a4d 100644 --- a/Meta/Lagom/Fuzzers/fuzzers.cmake +++ b/Meta/Lagom/Fuzzers/fuzzers.cmake @@ -50,6 +50,7 @@ set(FUZZER_TARGETS Tar TGALoader TTF + TinyVGLoader URL UTF16BEDecoder VP9Decoder @@ -118,6 +119,7 @@ set(FUZZER_DEPENDENCIES_SQLParser LibSQL) set(FUZZER_DEPENDENCIES_Tar LibArchive) set(FUZZER_DEPENDENCIES_TGALoader LibGfx) set(FUZZER_DEPENDENCIES_TTF LibGfx) +set(FUZZER_DEPENDENCIES_TinyVGLoader LibGfx) set(FUZZER_DEPENDENCIES_UTF16BEDecoder LibTextCodec) set(FUZZER_DEPENDENCIES_VP9Decoder LibVideo) set(FUZZER_DEPENDENCIES_WasmParser LibWasm) diff --git a/Userland/Utilities/test-fuzz.cpp b/Userland/Utilities/test-fuzz.cpp index 775e4b5236..4e747890c5 100644 --- a/Userland/Utilities/test-fuzz.cpp +++ b/Userland/Utilities/test-fuzz.cpp @@ -64,6 +64,7 @@ T(Tar) \ T(TGALoader) \ T(TTF) \ + T(TinyVGLoader) \ T(URL) \ T(UTF16BEDecoder) \ T(VP9Decoder) \