diff options
author | AdamKorcz <adam@adalogics.com> | 2020-12-08 20:15:21 (GMT) |
---|---|---|
committer | AdamKorcz <adam@adalogics.com> | 2020-12-08 20:18:29 (GMT) |
commit | 9c801316baade0b27b62dbdd4767c10e1d11f411 (patch) | |
tree | ed6a932a00d374eb5b67e68baa831f8eb92d7ade /misc | |
parent | 58f77f972bcece256c16ca1cc4a933270b1ea1c1 (diff) | |
download | Ninja-9c801316baade0b27b62dbdd4767c10e1d11f411.zip Ninja-9c801316baade0b27b62dbdd4767c10e1d11f411.tar.gz Ninja-9c801316baade0b27b62dbdd4767c10e1d11f411.tar.bz2 |
Added fuzzer with build script and seed
Diffstat (limited to 'misc')
-rw-r--r-- | misc/build.sh | 29 | ||||
-rw-r--r-- | misc/manifest_fuzzer.cc | 41 | ||||
-rw-r--r-- | misc/sample_ninja_build | 14 |
3 files changed, 84 insertions, 0 deletions
diff --git a/misc/build.sh b/misc/build.sh new file mode 100644 index 0000000..4328feb --- /dev/null +++ b/misc/build.sh @@ -0,0 +1,29 @@ +#!/bin/bash -eu +# Copyright 2020 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. +# +################################################################################ + +cmake -Bbuild-cmake -H. +cmake --build build-cmake + +cd $SRC/ninja/misc + +$CXX $CXXFLAGS -fdiagnostics-color -I/src/ninja/src -o fuzzer.o -c manifest_fuzzer.cc + +find .. -name "*.o" -exec ar rcs fuzz_lib.a {} \; + +$CXX $CXXFLAGS $LIB_FUZZING_ENGINE fuzzer.o -o $OUT/fuzzer fuzz_lib.a + +zip $OUT/fuzzer_seed_corpus.zip $SRC/sample_ninja_build diff --git a/misc/manifest_fuzzer.cc b/misc/manifest_fuzzer.cc new file mode 100644 index 0000000..0e1261a --- /dev/null +++ b/misc/manifest_fuzzer.cc @@ -0,0 +1,41 @@ +// Copyright 2020 Google Inc. All Rights Reserved. +// +// 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 "stdint.h" +#include <string> +#include "disk_interface.h" +#include "state.h" +#include "manifest_parser.h" +#include <filesystem> + +extern "C" int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) +{ + char build_file[256]; + sprintf(build_file, "/tmp/build.ninja"); + FILE *fp = fopen(build_file, "wb"); + if (!fp) + return 0; + fwrite(data, size, 1, fp); + fclose(fp); + + std::string err; + RealDiskInterface disk_interface; + State state; + ManifestParser parser(&state, &disk_interface); + + parser.Load("/tmp/build.ninja", &err); + + std::__fs::filesystem::remove_all("/tmp/build.ninja"); + return 0; +} diff --git a/misc/sample_ninja_build b/misc/sample_ninja_build new file mode 100644 index 0000000..7b513be --- /dev/null +++ b/misc/sample_ninja_build @@ -0,0 +1,14 @@ +# build.ninja +cc = clang +cflags = -Weverything + +rule compile + command = $cc $cflags -c $in -o $out + +rule link + command = $cc $in -o $out + +build hello.o: compile hello.c +build hello: link hello.o + +default hello |