oss-fuzz/projects/mpg123
Markus Kusano 2ae303bc3b Add mpg123_decode fuzzer (#2037)
* Add fuzzer for mpg123_decode.

This fuzzes a different and non-filebased API that read_fuzzer.c.
mpg123_decode is, however, streaming based so we need to chunk the
fuzzer's input into multiple pieces, and pass them to the library. This
is pretty annoying to do by hand so I've introduced byte_stream.h to do
this automatically. Sadly, byte_stream.h is very C++ so the
decode_fuzzer is also C++ now. This isn't ideal since mpg123 is a
C library but this is the easiest way to do it.

* Do not carry next input within std::string.

* Malloc a new buffer for each decode invocation.

I used malloc instead of new since ideally this fuzz target would be
written in C.
2018-12-21 11:20:00 -08:00
..
Dockerfile Add mpg123_decode fuzzer (#2037) 2018-12-21 11:20:00 -08:00
build.sh Add mpg123_decode fuzzer (#2037) 2018-12-21 11:20:00 -08:00
byte_stream.h Add mpg123_decode fuzzer (#2037) 2018-12-21 11:20:00 -08:00
decode_fuzzer.cc Add mpg123_decode fuzzer (#2037) 2018-12-21 11:20:00 -08:00
project.yaml Add mpg123_decode fuzzer (#2037) 2018-12-21 11:20:00 -08:00
read_fuzzer.c [mpg123] Integrate project along with a fuzz target. (#2032) 2018-12-18 11:04:32 -08:00