Merge pull request #1397 from omira-sch/more-fuzzers
add fuzzers for vips_smartcrop and vip_mosaic
This commit is contained in:
commit
c8296ecd15
@ -6,7 +6,9 @@ FUZZPROGS = \
|
|||||||
pngsave_buffer_fuzzer \
|
pngsave_buffer_fuzzer \
|
||||||
webpsave_buffer_fuzzer \
|
webpsave_buffer_fuzzer \
|
||||||
sharpen_fuzzer \
|
sharpen_fuzzer \
|
||||||
thumbnail_fuzzer
|
thumbnail_fuzzer \
|
||||||
|
smartcrop_fuzzer \
|
||||||
|
mosaic_fuzzer
|
||||||
|
|
||||||
AM_DEFAULT_SOURCE_EXT = .cc
|
AM_DEFAULT_SOURCE_EXT = .cc
|
||||||
|
|
||||||
|
63
fuzz/mosaic_fuzzer.cc
Normal file
63
fuzz/mosaic_fuzzer.cc
Normal file
@ -0,0 +1,63 @@
|
|||||||
|
#include <vips/vips.h>
|
||||||
|
|
||||||
|
struct mosaic_opt {
|
||||||
|
guint8 dir : 1;
|
||||||
|
guint16 xref;
|
||||||
|
guint16 yref;
|
||||||
|
guint16 xsec;
|
||||||
|
guint16 ysec;
|
||||||
|
};
|
||||||
|
|
||||||
|
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 *ref, *sec, *out;
|
||||||
|
struct mosaic_opt *opt;
|
||||||
|
double d;
|
||||||
|
|
||||||
|
if( size < sizeof(struct mosaic_opt) )
|
||||||
|
return( 0 );
|
||||||
|
|
||||||
|
if( !(ref = vips_image_new_from_buffer( data, size, "", NULL )) )
|
||||||
|
return( 0 );
|
||||||
|
|
||||||
|
/* Skip big images. They are likely to timeout.
|
||||||
|
*/
|
||||||
|
if( ref->Xsize > 1024 ||
|
||||||
|
ref->Ysize > 1024 ||
|
||||||
|
ref->Bands > 10 ) {
|
||||||
|
g_object_unref( ref );
|
||||||
|
return( 0 );
|
||||||
|
}
|
||||||
|
|
||||||
|
if( vips_rot180( ref, &sec, NULL ) ) {
|
||||||
|
g_object_unref( ref );
|
||||||
|
return( 0 );
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Extract some bytes from the tail to fuzz the arguments of the API.
|
||||||
|
*/
|
||||||
|
opt = (struct mosaic_opt *) (data + size - sizeof(struct mosaic_opt));
|
||||||
|
|
||||||
|
if( vips_mosaic( ref, sec, &out, (VipsDirection) opt->dir,
|
||||||
|
opt->xref, opt->yref, opt->xsec, opt->ysec, NULL ) ) {
|
||||||
|
g_object_unref( sec );
|
||||||
|
g_object_unref( ref );
|
||||||
|
return( 0 );
|
||||||
|
}
|
||||||
|
|
||||||
|
vips_max( out, &d, NULL );
|
||||||
|
|
||||||
|
g_object_unref( out );
|
||||||
|
g_object_unref( sec );
|
||||||
|
g_object_unref( ref );
|
||||||
|
|
||||||
|
return( 0 );
|
||||||
|
}
|
0
fuzz/mosaic_fuzzer_corpus/.keep
Normal file
0
fuzz/mosaic_fuzzer_corpus/.keep
Normal file
39
fuzz/smartcrop_fuzzer.cc
Normal file
39
fuzz/smartcrop_fuzzer.cc
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
#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, *out;
|
||||||
|
double d;
|
||||||
|
|
||||||
|
if( !(image = vips_image_new_from_buffer( data, size, "", NULL )) )
|
||||||
|
return( 0 );
|
||||||
|
|
||||||
|
/* Skip big images. They are likely to timeout.
|
||||||
|
*/
|
||||||
|
if( image->Xsize > 1024 ||
|
||||||
|
image->Ysize > 1024 ||
|
||||||
|
image->Bands > 10 ) {
|
||||||
|
g_object_unref( image );
|
||||||
|
return( 0 );
|
||||||
|
}
|
||||||
|
|
||||||
|
if( vips_smartcrop( image, &out, 32, 32, NULL ) ) {
|
||||||
|
g_object_unref( image );
|
||||||
|
return( 0 );
|
||||||
|
}
|
||||||
|
|
||||||
|
vips_min( out, &d, NULL );
|
||||||
|
|
||||||
|
g_object_unref( out );
|
||||||
|
g_object_unref( image );
|
||||||
|
|
||||||
|
return( 0 );
|
||||||
|
}
|
0
fuzz/smartcrop_fuzzer_corpus/.keep
Normal file
0
fuzz/smartcrop_fuzzer_corpus/.keep
Normal file
Loading…
Reference in New Issue
Block a user