3ea72c286e
It replaces current fuzz setup with 5 new fuzzers integrating them with top-level Makefile. It now supports multiple fuzzing engines and Google's oss-fuzz. By default, the fuzzers are linked against an standalone runner to easily reproduce bugs.
31 lines
505 B
C++
31 lines
505 B
C++
#include <vips/vips.h>
|
|
|
|
extern "C" int
|
|
LLVMFuzzerInitialize( int *argc, char ***argv )
|
|
{
|
|
vips_concurrency_set( 1 );
|
|
return( 0 );
|
|
}
|
|
|
|
extern "C" int
|
|
LLVMFuzzerTestOneInput( const guint8 *data, size_t size )
|
|
{
|
|
VipsImage *image;
|
|
void *buf;
|
|
size_t len;
|
|
|
|
if( !(image = vips_image_new_from_buffer( data, size, "", NULL )) ) {
|
|
return( 0 );
|
|
}
|
|
|
|
if( vips_pngsave_buffer( image, &buf, &len, NULL ) ) {
|
|
g_object_unref( image );
|
|
return( 0 );
|
|
}
|
|
|
|
g_free( buf );
|
|
g_object_unref( image );
|
|
|
|
return( 0 );
|
|
}
|