From 8b64577c3bb4d5dd60e4939223550f2f2002284b Mon Sep 17 00:00:00 2001 From: Daiki Ueno Date: Mon, 22 May 2017 15:31:23 +0200 Subject: build: Add fuzzer using AFL --- build/fuzz/rpc_fuzzer.c | 52 +++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 52 insertions(+) create mode 100644 build/fuzz/rpc_fuzzer.c (limited to 'build/fuzz/rpc_fuzzer.c') diff --git a/build/fuzz/rpc_fuzzer.c b/build/fuzz/rpc_fuzzer.c new file mode 100644 index 0000000..3bef578 --- /dev/null +++ b/build/fuzz/rpc_fuzzer.c @@ -0,0 +1,52 @@ +/* +# Copyright 2016 Google Inc. +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +# +################################################################################ +*/ + +#include "config.h" +#include "test.h" + +#include "library.h" +#include "mock.h" +#include "rpc.h" + +#include +#include + +static p11_virtual base; + +#ifdef __cplusplus +extern "C" +#endif +int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) +{ + p11_buffer buffer; + + mock_module_init (); + p11_library_init (); + + p11_buffer_init (&buffer, 0); + + p11_virtual_init (&base, &p11_virtual_base, &mock_module_no_slots, NULL); + base.funcs.C_Initialize (&base.funcs, NULL); + + p11_buffer_add (&buffer, data, size); + assert (!p11_buffer_failed (&buffer)); + + p11_rpc_server_handle (&base.funcs, &buffer, &buffer); + + return 0; +} -- cgit v1.1