diff --git a/fuzzers/libafl_280224/builder.Dockerfile b/fuzzers/libafl_280224/builder.Dockerfile deleted file mode 100644 index 068566e8c..000000000 --- a/fuzzers/libafl_280224/builder.Dockerfile +++ /dev/null @@ -1,61 +0,0 @@ -# Copyright 2020 Google LLC -# -# 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. - -ARG parent_image -FROM $parent_image - -# Uninstall old Rust & Install the latest one. -RUN if which rustup; then rustup self uninstall -y; fi && \ - curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs > /rustup.sh && \ - sh /rustup.sh --default-toolchain nightly-2024-02-14 -y && \ - rm /rustup.sh - -# Install dependencies. -RUN apt-get update && \ - apt-get remove -y llvm-10 && \ - apt-get install -y \ - build-essential \ - lsb-release wget software-properties-common gnupg && \ - apt-get install -y wget libstdc++5 libtool-bin automake flex bison \ - libglib2.0-dev libpixman-1-dev python3-setuptools unzip \ - apt-utils apt-transport-https ca-certificates joe curl && \ - wget https://apt.llvm.org/llvm.sh && chmod +x llvm.sh && ./llvm.sh 16 - -RUN wget https://gist.githubusercontent.com/tokatoka/26f4ba95991c6e33139999976332aa8e/raw/698ac2087d58ce5c7a6ad59adce58dbfdc32bd46/createAliases.sh && chmod u+x ./createAliases.sh && ./createAliases.sh - -# Uninstall old Rust & Install the latest one. -RUN if which rustup; then rustup self uninstall -y; fi && \ - curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs > /rustup.sh && \ - sh /rustup.sh --default-toolchain nightly-2024-02-14 -y && \ - rm /rustup.sh && \ - PATH="/root/.cargo/bin/:$PATH" cargo install cargo-make - -# Download libafl. -RUN git clone https://github.com/AFLplusplus/LibAFL /libafl - -# Checkout a current commit -RUN cd /libafl && git pull && git checkout 2bfe91e4bd5a5678a3935c50b429cf33616cbca4 || true -# Note that due a nightly bug it is currently fixed to a known version on top! - -# Compile libafl. -RUN cd /libafl && \ - unset CFLAGS CXXFLAGS && \ - export LIBAFL_EDGES_MAP_SIZE=2621440 && \ - cd ./fuzzers/fuzzbench && \ - PATH="/root/.cargo/bin/:$PATH" cargo build --profile release-fuzzbench --features no_link_main - -# Auxiliary weak references. -RUN cd /libafl/fuzzers/fuzzbench && \ - clang -c stub_rt.c && \ - ar r /stub_rt.a stub_rt.o diff --git a/fuzzers/libafl_280224/description.md b/fuzzers/libafl_280224/description.md deleted file mode 100644 index ea9b947d6..000000000 --- a/fuzzers/libafl_280224/description.md +++ /dev/null @@ -1,11 +0,0 @@ -# libafl - -libafl fuzzer instance - - cmplog feature - - persistent mode - -Repository: [https://github.com/AFLplusplus/libafl/](https://github.com/AFLplusplus/libafl/) - -[builder.Dockerfile](builder.Dockerfile) -[fuzzer.py](fuzzer.py) -[runner.Dockerfile](runner.Dockerfile) diff --git a/fuzzers/libafl_280224/fuzzer.py b/fuzzers/libafl_280224/fuzzer.py deleted file mode 100755 index d00bb1dd5..000000000 --- a/fuzzers/libafl_280224/fuzzer.py +++ /dev/null @@ -1,67 +0,0 @@ -# Copyright 2020 Google LLC -# -# 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. -# -"""Integration code for a LibAFL-based fuzzer.""" - -import os -import subprocess - -from fuzzers import utils - - -def prepare_fuzz_environment(input_corpus): - """Prepare to fuzz with a LibAFL-based fuzzer.""" - os.environ['ASAN_OPTIONS'] = 'abort_on_error=1:detect_leaks=0:'\ - 'malloc_context_size=0:symbolize=0:'\ - 'allocator_may_return_null=1:'\ - 'detect_odr_violation=0:handle_segv=0:'\ - 'handle_sigbus=0:handle_abort=0:'\ - 'handle_sigfpe=0:handle_sigill=0' - os.environ['UBSAN_OPTIONS'] = 'abort_on_error=1:'\ - 'allocator_release_to_os_interval_ms=500:'\ - 'handle_abort=0:handle_segv=0:'\ - 'handle_sigbus=0:handle_sigfpe=0:'\ - 'handle_sigill=0:print_stacktrace=0:'\ - 'symbolize=0:symbolize_inline_frames=0' - # Create at least one non-empty seed to start. - utils.create_seed_file_for_empty_corpus(input_corpus) - - -def build(): # pylint: disable=too-many-branches,too-many-statements - """Build benchmark.""" - os.environ['CC'] = '/libafl/fuzzers/fuzzbench/target/release/libafl_cc' - os.environ['CXX'] = '/libafl/fuzzers/fuzzbench/target/release/libafl_cxx' - - os.environ['ASAN_OPTIONS'] = 'abort_on_error=0:allocator_may_return_null=1' - os.environ['UBSAN_OPTIONS'] = 'abort_on_error=0' - - cflags = ['--libafl'] - utils.append_flags('CFLAGS', cflags) - utils.append_flags('CXXFLAGS', cflags) - utils.append_flags('LDFLAGS', cflags) - - os.environ['FUZZER_LIB'] = '/stub_rt.a' - utils.build_benchmark() - - -def fuzz(input_corpus, output_corpus, target_binary): - """Run fuzzer.""" - prepare_fuzz_environment(input_corpus) - dictionary_path = utils.get_dictionary_path(target_binary) - command = [target_binary] - if dictionary_path: - command += (['-x', dictionary_path]) - command += (['-o', output_corpus, '-i', input_corpus]) - print(command) - subprocess.check_call(command, cwd=os.environ['OUT']) diff --git a/fuzzers/libafl_280224/runner.Dockerfile b/fuzzers/libafl_280224/runner.Dockerfile deleted file mode 100644 index 7aa1da8e4..000000000 --- a/fuzzers/libafl_280224/runner.Dockerfile +++ /dev/null @@ -1,23 +0,0 @@ -# Copyright 2020 Google LLC -# -# 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. - -FROM gcr.io/fuzzbench/base-image - -# This makes interactive docker runs painless: -ENV LD_LIBRARY_PATH="$LD_LIBRARY_PATH:/out" -#ENV AFL_MAP_SIZE=2621440 -ENV PATH="$PATH:/out" -ENV AFL_SKIP_CPUFREQ=1 -ENV AFL_I_DONT_CARE_ABOUT_MISSING_CRASHES=1 -ENV AFL_TESTCACHE_SIZE=2 diff --git a/fuzzers/libafl_ctx_large_map/builder.Dockerfile b/fuzzers/libafl_ctx_large_map/builder.Dockerfile deleted file mode 100644 index d0d6ebc3d..000000000 --- a/fuzzers/libafl_ctx_large_map/builder.Dockerfile +++ /dev/null @@ -1,61 +0,0 @@ -# Copyright 2020 Google LLC -# -# 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. - -ARG parent_image -FROM $parent_image - -# Uninstall old Rust & Install the latest one. -RUN if which rustup; then rustup self uninstall -y; fi && \ - curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs > /rustup.sh && \ - sh /rustup.sh --default-toolchain nightly-2024-02-14 -y && \ - rm /rustup.sh - -# Install dependencies. -RUN apt-get update && \ - apt-get remove -y llvm-10 && \ - apt-get install -y \ - build-essential \ - lsb-release wget software-properties-common gnupg && \ - apt-get install -y wget libstdc++5 libtool-bin automake flex bison \ - libglib2.0-dev libpixman-1-dev python3-setuptools unzip \ - apt-utils apt-transport-https ca-certificates joe curl && \ - wget https://apt.llvm.org/llvm.sh && chmod +x llvm.sh && ./llvm.sh 16 - -RUN wget https://gist.githubusercontent.com/tokatoka/26f4ba95991c6e33139999976332aa8e/raw/698ac2087d58ce5c7a6ad59adce58dbfdc32bd46/createAliases.sh && chmod u+x ./createAliases.sh && ./createAliases.sh - -# Uninstall old Rust & Install the latest one. -RUN if which rustup; then rustup self uninstall -y; fi && \ - curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs > /rustup.sh && \ - sh /rustup.sh --default-toolchain nightly-2024-02-14 -y && \ - rm /rustup.sh && \ - PATH="/root/.cargo/bin/:$PATH" cargo install cargo-make - -# Download libafl. -RUN git clone https://github.com/AFLplusplus/LibAFL /libafl - -# Checkout a current commit -RUN cd /libafl && git pull && git checkout a5f2daf6e70c0b57b6781c1e8cd9a5b309a6c1de || true -# Note that due a nightly bug it is currently fixed to a known version on top! - -# Compile libafl. -RUN cd /libafl && \ - unset CFLAGS CXXFLAGS && \ - export LIBAFL_EDGES_MAP_SIZE=2621440 && \ - cd ./fuzzers/fuzzbench_ctx && \ - PATH="/root/.cargo/bin/:$PATH" cargo build --profile release-fuzzbench --features no_link_main - -# Auxiliary weak references. -RUN cd /libafl/fuzzers/fuzzbench_ctx && \ - clang -c stub_rt.c && \ - ar r /stub_rt.a stub_rt.o diff --git a/fuzzers/libafl_ctx_large_map/description.md b/fuzzers/libafl_ctx_large_map/description.md deleted file mode 100644 index ea9b947d6..000000000 --- a/fuzzers/libafl_ctx_large_map/description.md +++ /dev/null @@ -1,11 +0,0 @@ -# libafl - -libafl fuzzer instance - - cmplog feature - - persistent mode - -Repository: [https://github.com/AFLplusplus/libafl/](https://github.com/AFLplusplus/libafl/) - -[builder.Dockerfile](builder.Dockerfile) -[fuzzer.py](fuzzer.py) -[runner.Dockerfile](runner.Dockerfile) diff --git a/fuzzers/libafl_ctx_large_map/fuzzer.py b/fuzzers/libafl_ctx_large_map/fuzzer.py deleted file mode 100755 index 19b64b9d7..000000000 --- a/fuzzers/libafl_ctx_large_map/fuzzer.py +++ /dev/null @@ -1,72 +0,0 @@ -# Copyright 2020 Google LLC -# -# 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. -# -"""Integration code for a LibAFL-based fuzzer.""" - -import os -import subprocess - -from fuzzers import utils - - -def prepare_fuzz_environment(input_corpus): - """Prepare to fuzz with a LibAFL-based fuzzer.""" - os.environ["ASAN_OPTIONS"] = ("abort_on_error=1:detect_leaks=0:" - "malloc_context_size=0:symbolize=0:" - "allocator_may_return_null=1:" - "detect_odr_violation=0:handle_segv=0:" - "handle_sigbus=0:handle_abort=0:" - "handle_sigfpe=0:handle_sigill=0") - os.environ["UBSAN_OPTIONS"] = ("abort_on_error=1:" - "allocator_release_to_os_interval_ms=500:" - "handle_abort=0:handle_segv=0:" - "handle_sigbus=0:handle_sigfpe=0:" - "handle_sigill=0:print_stacktrace=0:" - "symbolize=0:symbolize_inline_frames=0") - # Create at least one non-empty seed to start. - utils.create_seed_file_for_empty_corpus(input_corpus) - - -def build(): # pylint: disable=too-many-branches,too-many-statements - """Build benchmark.""" - os.environ["CC"] = ( - "/libafl/fuzzers/fuzzbench_ctx/target/release-fuzzbench/libafl_cc") - os.environ["CXX"] = ( - "/libafl/fuzzers/fuzzbench_ctx/target/release-fuzzbench/libafl_cxx") - - os.environ["ASAN_OPTIONS"] = "abort_on_error=0:allocator_may_return_null=1" - os.environ["UBSAN_OPTIONS"] = "abort_on_error=0" - - cflags = ["--libafl"] - cxxflags = ["--libafl", "--std=c++14"] - utils.append_flags("CFLAGS", cflags) - utils.append_flags("CXXFLAGS", cxxflags) - utils.append_flags("LDFLAGS", cflags) - - os.environ["FUZZER_LIB"] = "/stub_rt.a" - utils.build_benchmark() - - -def fuzz(input_corpus, output_corpus, target_binary): - """Run fuzzer.""" - prepare_fuzz_environment(input_corpus) - dictionary_path = utils.get_dictionary_path(target_binary) - command = [target_binary] - if dictionary_path: - command += ["-x", dictionary_path] - command += ["-o", output_corpus, "-i", input_corpus] - fuzzer_env = os.environ.copy() - fuzzer_env["LD_PRELOAD"] = "/usr/lib/x86_64-linux-gnu/libjemalloc.so.2" - print(command) - subprocess.check_call(command, cwd=os.environ["OUT"], env=fuzzer_env) diff --git a/fuzzers/libafl_ctx_large_map/runner.Dockerfile b/fuzzers/libafl_ctx_large_map/runner.Dockerfile deleted file mode 100644 index f0c5eb6cc..000000000 --- a/fuzzers/libafl_ctx_large_map/runner.Dockerfile +++ /dev/null @@ -1,25 +0,0 @@ -# Copyright 2020 Google LLC -# -# 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. - -FROM gcr.io/fuzzbench/base-image - -RUN apt install libjemalloc2 - -# This makes interactive docker runs painless: -ENV LD_LIBRARY_PATH="$LD_LIBRARY_PATH:/out" -#ENV AFL_MAP_SIZE=2621440 -ENV PATH="$PATH:/out" -ENV AFL_SKIP_CPUFREQ=1 -ENV AFL_I_DONT_CARE_ABOUT_MISSING_CRASHES=1 -ENV AFL_TESTCACHE_SIZE=2 diff --git a/fuzzers/libafl_ctx_mid_map/builder.Dockerfile b/fuzzers/libafl_ctx_mid_map/builder.Dockerfile deleted file mode 100644 index 13df1591a..000000000 --- a/fuzzers/libafl_ctx_mid_map/builder.Dockerfile +++ /dev/null @@ -1,61 +0,0 @@ -# Copyright 2020 Google LLC -# -# 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. - -ARG parent_image -FROM $parent_image - -# Uninstall old Rust & Install the latest one. -RUN if which rustup; then rustup self uninstall -y; fi && \ - curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs > /rustup.sh && \ - sh /rustup.sh --default-toolchain nightly-2024-02-14 -y && \ - rm /rustup.sh - -# Install dependencies. -RUN apt-get update && \ - apt-get remove -y llvm-10 && \ - apt-get install -y \ - build-essential \ - lsb-release wget software-properties-common gnupg && \ - apt-get install -y wget libstdc++5 libtool-bin automake flex bison \ - libglib2.0-dev libpixman-1-dev python3-setuptools unzip \ - apt-utils apt-transport-https ca-certificates joe curl && \ - wget https://apt.llvm.org/llvm.sh && chmod +x llvm.sh && ./llvm.sh 16 - -RUN wget https://gist.githubusercontent.com/tokatoka/26f4ba95991c6e33139999976332aa8e/raw/698ac2087d58ce5c7a6ad59adce58dbfdc32bd46/createAliases.sh && chmod u+x ./createAliases.sh && ./createAliases.sh - -# Uninstall old Rust & Install the latest one. -RUN if which rustup; then rustup self uninstall -y; fi && \ - curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs > /rustup.sh && \ - sh /rustup.sh --default-toolchain nightly-2024-02-14 -y && \ - rm /rustup.sh && \ - PATH="/root/.cargo/bin/:$PATH" cargo install cargo-make - -# Download libafl. -RUN git clone https://github.com/AFLplusplus/LibAFL /libafl - -# Checkout a current commit -RUN cd /libafl && git pull && git checkout a5f2daf6e70c0b57b6781c1e8cd9a5b309a6c1de || true -# Note that due a nightly bug it is currently fixed to a known version on top! - -# Compile libafl. -RUN cd /libafl && \ - unset CFLAGS CXXFLAGS && \ - export LIBAFL_EDGES_MAP_SIZE=262144 && \ - cd ./fuzzers/fuzzbench_ctx && \ - PATH="/root/.cargo/bin/:$PATH" cargo build --profile release-fuzzbench --features no_link_main - -# Auxiliary weak references. -RUN cd /libafl/fuzzers/fuzzbench_ctx && \ - clang -c stub_rt.c && \ - ar r /stub_rt.a stub_rt.o diff --git a/fuzzers/libafl_ctx_mid_map/description.md b/fuzzers/libafl_ctx_mid_map/description.md deleted file mode 100644 index ea9b947d6..000000000 --- a/fuzzers/libafl_ctx_mid_map/description.md +++ /dev/null @@ -1,11 +0,0 @@ -# libafl - -libafl fuzzer instance - - cmplog feature - - persistent mode - -Repository: [https://github.com/AFLplusplus/libafl/](https://github.com/AFLplusplus/libafl/) - -[builder.Dockerfile](builder.Dockerfile) -[fuzzer.py](fuzzer.py) -[runner.Dockerfile](runner.Dockerfile) diff --git a/fuzzers/libafl_ctx_mid_map/fuzzer.py b/fuzzers/libafl_ctx_mid_map/fuzzer.py deleted file mode 100755 index 19b64b9d7..000000000 --- a/fuzzers/libafl_ctx_mid_map/fuzzer.py +++ /dev/null @@ -1,72 +0,0 @@ -# Copyright 2020 Google LLC -# -# 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. -# -"""Integration code for a LibAFL-based fuzzer.""" - -import os -import subprocess - -from fuzzers import utils - - -def prepare_fuzz_environment(input_corpus): - """Prepare to fuzz with a LibAFL-based fuzzer.""" - os.environ["ASAN_OPTIONS"] = ("abort_on_error=1:detect_leaks=0:" - "malloc_context_size=0:symbolize=0:" - "allocator_may_return_null=1:" - "detect_odr_violation=0:handle_segv=0:" - "handle_sigbus=0:handle_abort=0:" - "handle_sigfpe=0:handle_sigill=0") - os.environ["UBSAN_OPTIONS"] = ("abort_on_error=1:" - "allocator_release_to_os_interval_ms=500:" - "handle_abort=0:handle_segv=0:" - "handle_sigbus=0:handle_sigfpe=0:" - "handle_sigill=0:print_stacktrace=0:" - "symbolize=0:symbolize_inline_frames=0") - # Create at least one non-empty seed to start. - utils.create_seed_file_for_empty_corpus(input_corpus) - - -def build(): # pylint: disable=too-many-branches,too-many-statements - """Build benchmark.""" - os.environ["CC"] = ( - "/libafl/fuzzers/fuzzbench_ctx/target/release-fuzzbench/libafl_cc") - os.environ["CXX"] = ( - "/libafl/fuzzers/fuzzbench_ctx/target/release-fuzzbench/libafl_cxx") - - os.environ["ASAN_OPTIONS"] = "abort_on_error=0:allocator_may_return_null=1" - os.environ["UBSAN_OPTIONS"] = "abort_on_error=0" - - cflags = ["--libafl"] - cxxflags = ["--libafl", "--std=c++14"] - utils.append_flags("CFLAGS", cflags) - utils.append_flags("CXXFLAGS", cxxflags) - utils.append_flags("LDFLAGS", cflags) - - os.environ["FUZZER_LIB"] = "/stub_rt.a" - utils.build_benchmark() - - -def fuzz(input_corpus, output_corpus, target_binary): - """Run fuzzer.""" - prepare_fuzz_environment(input_corpus) - dictionary_path = utils.get_dictionary_path(target_binary) - command = [target_binary] - if dictionary_path: - command += ["-x", dictionary_path] - command += ["-o", output_corpus, "-i", input_corpus] - fuzzer_env = os.environ.copy() - fuzzer_env["LD_PRELOAD"] = "/usr/lib/x86_64-linux-gnu/libjemalloc.so.2" - print(command) - subprocess.check_call(command, cwd=os.environ["OUT"], env=fuzzer_env) diff --git a/fuzzers/libafl_ctx_mid_map/runner.Dockerfile b/fuzzers/libafl_ctx_mid_map/runner.Dockerfile deleted file mode 100644 index f0c5eb6cc..000000000 --- a/fuzzers/libafl_ctx_mid_map/runner.Dockerfile +++ /dev/null @@ -1,25 +0,0 @@ -# Copyright 2020 Google LLC -# -# 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. - -FROM gcr.io/fuzzbench/base-image - -RUN apt install libjemalloc2 - -# This makes interactive docker runs painless: -ENV LD_LIBRARY_PATH="$LD_LIBRARY_PATH:/out" -#ENV AFL_MAP_SIZE=2621440 -ENV PATH="$PATH:/out" -ENV AFL_SKIP_CPUFREQ=1 -ENV AFL_I_DONT_CARE_ABOUT_MISSING_CRASHES=1 -ENV AFL_TESTCACHE_SIZE=2 diff --git a/fuzzers/libafl_ctx_small_map/builder.Dockerfile b/fuzzers/libafl_ctx_small_map/builder.Dockerfile deleted file mode 100644 index c8a326445..000000000 --- a/fuzzers/libafl_ctx_small_map/builder.Dockerfile +++ /dev/null @@ -1,61 +0,0 @@ -# Copyright 2020 Google LLC -# -# 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. - -ARG parent_image -FROM $parent_image - -# Uninstall old Rust & Install the latest one. -RUN if which rustup; then rustup self uninstall -y; fi && \ - curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs > /rustup.sh && \ - sh /rustup.sh --default-toolchain nightly-2024-02-14 -y && \ - rm /rustup.sh - -# Install dependencies. -RUN apt-get update && \ - apt-get remove -y llvm-10 && \ - apt-get install -y \ - build-essential \ - lsb-release wget software-properties-common gnupg && \ - apt-get install -y wget libstdc++5 libtool-bin automake flex bison \ - libglib2.0-dev libpixman-1-dev python3-setuptools unzip \ - apt-utils apt-transport-https ca-certificates joe curl && \ - wget https://apt.llvm.org/llvm.sh && chmod +x llvm.sh && ./llvm.sh 16 - -RUN wget https://gist.githubusercontent.com/tokatoka/26f4ba95991c6e33139999976332aa8e/raw/698ac2087d58ce5c7a6ad59adce58dbfdc32bd46/createAliases.sh && chmod u+x ./createAliases.sh && ./createAliases.sh - -# Uninstall old Rust & Install the latest one. -RUN if which rustup; then rustup self uninstall -y; fi && \ - curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs > /rustup.sh && \ - sh /rustup.sh --default-toolchain nightly-2024-02-14 -y && \ - rm /rustup.sh && \ - PATH="/root/.cargo/bin/:$PATH" cargo install cargo-make - -# Download libafl. -RUN git clone https://github.com/AFLplusplus/LibAFL /libafl - -# Checkout a current commit -RUN cd /libafl && git pull && git checkout a5f2daf6e70c0b57b6781c1e8cd9a5b309a6c1de || true -# Note that due a nightly bug it is currently fixed to a known version on top! - -# Compile libafl. -RUN cd /libafl && \ - unset CFLAGS CXXFLAGS && \ - export LIBAFL_EDGES_MAP_SIZE=131072 && \ - cd ./fuzzers/fuzzbench_ctx && \ - PATH="/root/.cargo/bin/:$PATH" cargo build --profile release-fuzzbench --features no_link_main - -# Auxiliary weak references. -RUN cd /libafl/fuzzers/fuzzbench_ctx && \ - clang -c stub_rt.c && \ - ar r /stub_rt.a stub_rt.o diff --git a/fuzzers/libafl_ctx_small_map/description.md b/fuzzers/libafl_ctx_small_map/description.md deleted file mode 100644 index ea9b947d6..000000000 --- a/fuzzers/libafl_ctx_small_map/description.md +++ /dev/null @@ -1,11 +0,0 @@ -# libafl - -libafl fuzzer instance - - cmplog feature - - persistent mode - -Repository: [https://github.com/AFLplusplus/libafl/](https://github.com/AFLplusplus/libafl/) - -[builder.Dockerfile](builder.Dockerfile) -[fuzzer.py](fuzzer.py) -[runner.Dockerfile](runner.Dockerfile) diff --git a/fuzzers/libafl_ctx_small_map/fuzzer.py b/fuzzers/libafl_ctx_small_map/fuzzer.py deleted file mode 100755 index 19b64b9d7..000000000 --- a/fuzzers/libafl_ctx_small_map/fuzzer.py +++ /dev/null @@ -1,72 +0,0 @@ -# Copyright 2020 Google LLC -# -# 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. -# -"""Integration code for a LibAFL-based fuzzer.""" - -import os -import subprocess - -from fuzzers import utils - - -def prepare_fuzz_environment(input_corpus): - """Prepare to fuzz with a LibAFL-based fuzzer.""" - os.environ["ASAN_OPTIONS"] = ("abort_on_error=1:detect_leaks=0:" - "malloc_context_size=0:symbolize=0:" - "allocator_may_return_null=1:" - "detect_odr_violation=0:handle_segv=0:" - "handle_sigbus=0:handle_abort=0:" - "handle_sigfpe=0:handle_sigill=0") - os.environ["UBSAN_OPTIONS"] = ("abort_on_error=1:" - "allocator_release_to_os_interval_ms=500:" - "handle_abort=0:handle_segv=0:" - "handle_sigbus=0:handle_sigfpe=0:" - "handle_sigill=0:print_stacktrace=0:" - "symbolize=0:symbolize_inline_frames=0") - # Create at least one non-empty seed to start. - utils.create_seed_file_for_empty_corpus(input_corpus) - - -def build(): # pylint: disable=too-many-branches,too-many-statements - """Build benchmark.""" - os.environ["CC"] = ( - "/libafl/fuzzers/fuzzbench_ctx/target/release-fuzzbench/libafl_cc") - os.environ["CXX"] = ( - "/libafl/fuzzers/fuzzbench_ctx/target/release-fuzzbench/libafl_cxx") - - os.environ["ASAN_OPTIONS"] = "abort_on_error=0:allocator_may_return_null=1" - os.environ["UBSAN_OPTIONS"] = "abort_on_error=0" - - cflags = ["--libafl"] - cxxflags = ["--libafl", "--std=c++14"] - utils.append_flags("CFLAGS", cflags) - utils.append_flags("CXXFLAGS", cxxflags) - utils.append_flags("LDFLAGS", cflags) - - os.environ["FUZZER_LIB"] = "/stub_rt.a" - utils.build_benchmark() - - -def fuzz(input_corpus, output_corpus, target_binary): - """Run fuzzer.""" - prepare_fuzz_environment(input_corpus) - dictionary_path = utils.get_dictionary_path(target_binary) - command = [target_binary] - if dictionary_path: - command += ["-x", dictionary_path] - command += ["-o", output_corpus, "-i", input_corpus] - fuzzer_env = os.environ.copy() - fuzzer_env["LD_PRELOAD"] = "/usr/lib/x86_64-linux-gnu/libjemalloc.so.2" - print(command) - subprocess.check_call(command, cwd=os.environ["OUT"], env=fuzzer_env) diff --git a/fuzzers/libafl_ctx_small_map/runner.Dockerfile b/fuzzers/libafl_ctx_small_map/runner.Dockerfile deleted file mode 100644 index f0c5eb6cc..000000000 --- a/fuzzers/libafl_ctx_small_map/runner.Dockerfile +++ /dev/null @@ -1,25 +0,0 @@ -# Copyright 2020 Google LLC -# -# 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. - -FROM gcr.io/fuzzbench/base-image - -RUN apt install libjemalloc2 - -# This makes interactive docker runs painless: -ENV LD_LIBRARY_PATH="$LD_LIBRARY_PATH:/out" -#ENV AFL_MAP_SIZE=2621440 -ENV PATH="$PATH:/out" -ENV AFL_SKIP_CPUFREQ=1 -ENV AFL_I_DONT_CARE_ABOUT_MISSING_CRASHES=1 -ENV AFL_TESTCACHE_SIZE=2 diff --git a/fuzzers/libafl_ngram_large_map/builder.Dockerfile b/fuzzers/libafl_ngram_large_map/builder.Dockerfile deleted file mode 100644 index afefeb112..000000000 --- a/fuzzers/libafl_ngram_large_map/builder.Dockerfile +++ /dev/null @@ -1,61 +0,0 @@ -# Copyright 2020 Google LLC -# -# 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. - -ARG parent_image -FROM $parent_image - -# Uninstall old Rust & Install the latest one. -RUN if which rustup; then rustup self uninstall -y; fi && \ - curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs > /rustup.sh && \ - sh /rustup.sh --default-toolchain nightly-2024-02-14 -y && \ - rm /rustup.sh - -# Install dependencies. -RUN apt-get update && \ - apt-get remove -y llvm-10 && \ - apt-get install -y \ - build-essential \ - lsb-release wget software-properties-common gnupg && \ - apt-get install -y wget libstdc++5 libtool-bin automake flex bison \ - libglib2.0-dev libpixman-1-dev python3-setuptools unzip \ - apt-utils apt-transport-https ca-certificates joe curl && \ - wget https://apt.llvm.org/llvm.sh && chmod +x llvm.sh && ./llvm.sh 16 - -RUN wget https://gist.githubusercontent.com/tokatoka/26f4ba95991c6e33139999976332aa8e/raw/698ac2087d58ce5c7a6ad59adce58dbfdc32bd46/createAliases.sh && chmod u+x ./createAliases.sh && ./createAliases.sh - -# Uninstall old Rust & Install the latest one. -RUN if which rustup; then rustup self uninstall -y; fi && \ - curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs > /rustup.sh && \ - sh /rustup.sh --default-toolchain nightly-2024-02-14 -y && \ - rm /rustup.sh && \ - PATH="/root/.cargo/bin/:$PATH" cargo install cargo-make - -# Download libafl. -RUN git clone https://github.com/AFLplusplus/LibAFL /libafl - -# Checkout a current commit -RUN cd /libafl && git pull && git checkout a5f2daf6e70c0b57b6781c1e8cd9a5b309a6c1de || true -# Note that due a nightly bug it is currently fixed to a known version on top! - -# Compile libafl. -RUN cd /libafl && \ - unset CFLAGS CXXFLAGS && \ - export LIBAFL_EDGES_MAP_SIZE=2621440 && \ - cd ./fuzzers/fuzzbench_ngram && \ - PATH="/root/.cargo/bin/:$PATH" cargo build --profile release-fuzzbench --features no_link_main - -# Auxiliary weak references. -RUN cd /libafl/fuzzers/fuzzbench_ngram && \ - clang -c stub_rt.c && \ - ar r /stub_rt.a stub_rt.o diff --git a/fuzzers/libafl_ngram_large_map/description.md b/fuzzers/libafl_ngram_large_map/description.md deleted file mode 100644 index ea9b947d6..000000000 --- a/fuzzers/libafl_ngram_large_map/description.md +++ /dev/null @@ -1,11 +0,0 @@ -# libafl - -libafl fuzzer instance - - cmplog feature - - persistent mode - -Repository: [https://github.com/AFLplusplus/libafl/](https://github.com/AFLplusplus/libafl/) - -[builder.Dockerfile](builder.Dockerfile) -[fuzzer.py](fuzzer.py) -[runner.Dockerfile](runner.Dockerfile) diff --git a/fuzzers/libafl_ngram_large_map/fuzzer.py b/fuzzers/libafl_ngram_large_map/fuzzer.py deleted file mode 100755 index 7498be883..000000000 --- a/fuzzers/libafl_ngram_large_map/fuzzer.py +++ /dev/null @@ -1,72 +0,0 @@ -# Copyright 2020 Google LLC -# -# 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. -# -"""Integration code for a LibAFL-based fuzzer.""" - -import os -import subprocess - -from fuzzers import utils - - -def prepare_fuzz_environment(input_corpus): - """Prepare to fuzz with a LibAFL-based fuzzer.""" - os.environ["ASAN_OPTIONS"] = ("abort_on_error=1:detect_leaks=0:" - "malloc_context_size=0:symbolize=0:" - "allocator_may_return_null=1:" - "detect_odr_violation=0:handle_segv=0:" - "handle_sigbus=0:handle_abort=0:" - "handle_sigfpe=0:handle_sigill=0") - os.environ["UBSAN_OPTIONS"] = ("abort_on_error=1:" - "allocator_release_to_os_interval_ms=500:" - "handle_abort=0:handle_segv=0:" - "handle_sigbus=0:handle_sigfpe=0:" - "handle_sigill=0:print_stacktrace=0:" - "symbolize=0:symbolize_inline_frames=0") - # Create at least one non-empty seed to start. - utils.create_seed_file_for_empty_corpus(input_corpus) - - -def build(): # pylint: disable=too-many-branches,too-many-statements - """Build benchmark.""" - os.environ["CC"] = ( - "/libafl/fuzzers/fuzzbench_ngram/target/release-fuzzbench/libafl_cc") - os.environ["CXX"] = ( - "/libafl/fuzzers/fuzzbench_ngram/target/release-fuzzbench/libafl_cxx") - - os.environ["ASAN_OPTIONS"] = "abort_on_error=0:allocator_may_return_null=1" - os.environ["UBSAN_OPTIONS"] = "abort_on_error=0" - - cflags = ["--libafl"] - cxxflags = ["--libafl", "--std=c++14"] - utils.append_flags("CFLAGS", cflags) - utils.append_flags("CXXFLAGS", cxxflags) - utils.append_flags("LDFLAGS", cflags) - - os.environ["FUZZER_LIB"] = "/stub_rt.a" - utils.build_benchmark() - - -def fuzz(input_corpus, output_corpus, target_binary): - """Run fuzzer.""" - prepare_fuzz_environment(input_corpus) - dictionary_path = utils.get_dictionary_path(target_binary) - command = [target_binary] - if dictionary_path: - command += ["-x", dictionary_path] - command += ["-o", output_corpus, "-i", input_corpus] - fuzzer_env = os.environ.copy() - fuzzer_env["LD_PRELOAD"] = "/usr/lib/x86_64-linux-gnu/libjemalloc.so.2" - print(command) - subprocess.check_call(command, cwd=os.environ["OUT"], env=fuzzer_env) diff --git a/fuzzers/libafl_ngram_large_map/runner.Dockerfile b/fuzzers/libafl_ngram_large_map/runner.Dockerfile deleted file mode 100644 index f0c5eb6cc..000000000 --- a/fuzzers/libafl_ngram_large_map/runner.Dockerfile +++ /dev/null @@ -1,25 +0,0 @@ -# Copyright 2020 Google LLC -# -# 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. - -FROM gcr.io/fuzzbench/base-image - -RUN apt install libjemalloc2 - -# This makes interactive docker runs painless: -ENV LD_LIBRARY_PATH="$LD_LIBRARY_PATH:/out" -#ENV AFL_MAP_SIZE=2621440 -ENV PATH="$PATH:/out" -ENV AFL_SKIP_CPUFREQ=1 -ENV AFL_I_DONT_CARE_ABOUT_MISSING_CRASHES=1 -ENV AFL_TESTCACHE_SIZE=2 diff --git a/fuzzers/libafl_ngram_mid_map/builder.Dockerfile b/fuzzers/libafl_ngram_mid_map/builder.Dockerfile deleted file mode 100644 index fda9d1f1a..000000000 --- a/fuzzers/libafl_ngram_mid_map/builder.Dockerfile +++ /dev/null @@ -1,61 +0,0 @@ -# Copyright 2020 Google LLC -# -# 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. - -ARG parent_image -FROM $parent_image - -# Uninstall old Rust & Install the latest one. -RUN if which rustup; then rustup self uninstall -y; fi && \ - curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs > /rustup.sh && \ - sh /rustup.sh --default-toolchain nightly-2024-02-14 -y && \ - rm /rustup.sh - -# Install dependencies. -RUN apt-get update && \ - apt-get remove -y llvm-10 && \ - apt-get install -y \ - build-essential \ - lsb-release wget software-properties-common gnupg && \ - apt-get install -y wget libstdc++5 libtool-bin automake flex bison \ - libglib2.0-dev libpixman-1-dev python3-setuptools unzip \ - apt-utils apt-transport-https ca-certificates joe curl && \ - wget https://apt.llvm.org/llvm.sh && chmod +x llvm.sh && ./llvm.sh 16 - -RUN wget https://gist.githubusercontent.com/tokatoka/26f4ba95991c6e33139999976332aa8e/raw/698ac2087d58ce5c7a6ad59adce58dbfdc32bd46/createAliases.sh && chmod u+x ./createAliases.sh && ./createAliases.sh - -# Uninstall old Rust & Install the latest one. -RUN if which rustup; then rustup self uninstall -y; fi && \ - curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs > /rustup.sh && \ - sh /rustup.sh --default-toolchain nightly-2024-02-14 -y && \ - rm /rustup.sh && \ - PATH="/root/.cargo/bin/:$PATH" cargo install cargo-make - -# Download libafl. -RUN git clone https://github.com/AFLplusplus/LibAFL /libafl - -# Checkout a current commit -RUN cd /libafl && git pull && git checkout a5f2daf6e70c0b57b6781c1e8cd9a5b309a6c1de || true -# Note that due a nightly bug it is currently fixed to a known version on top! - -# Compile libafl. -RUN cd /libafl && \ - unset CFLAGS CXXFLAGS && \ - export LIBAFL_EDGES_MAP_SIZE=262144 && \ - cd ./fuzzers/fuzzbench_ngram && \ - PATH="/root/.cargo/bin/:$PATH" cargo build --profile release-fuzzbench --features no_link_main - -# Auxiliary weak references. -RUN cd /libafl/fuzzers/fuzzbench_ngram && \ - clang -c stub_rt.c && \ - ar r /stub_rt.a stub_rt.o diff --git a/fuzzers/libafl_ngram_mid_map/description.md b/fuzzers/libafl_ngram_mid_map/description.md deleted file mode 100644 index ea9b947d6..000000000 --- a/fuzzers/libafl_ngram_mid_map/description.md +++ /dev/null @@ -1,11 +0,0 @@ -# libafl - -libafl fuzzer instance - - cmplog feature - - persistent mode - -Repository: [https://github.com/AFLplusplus/libafl/](https://github.com/AFLplusplus/libafl/) - -[builder.Dockerfile](builder.Dockerfile) -[fuzzer.py](fuzzer.py) -[runner.Dockerfile](runner.Dockerfile) diff --git a/fuzzers/libafl_ngram_mid_map/fuzzer.py b/fuzzers/libafl_ngram_mid_map/fuzzer.py deleted file mode 100755 index 7498be883..000000000 --- a/fuzzers/libafl_ngram_mid_map/fuzzer.py +++ /dev/null @@ -1,72 +0,0 @@ -# Copyright 2020 Google LLC -# -# 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. -# -"""Integration code for a LibAFL-based fuzzer.""" - -import os -import subprocess - -from fuzzers import utils - - -def prepare_fuzz_environment(input_corpus): - """Prepare to fuzz with a LibAFL-based fuzzer.""" - os.environ["ASAN_OPTIONS"] = ("abort_on_error=1:detect_leaks=0:" - "malloc_context_size=0:symbolize=0:" - "allocator_may_return_null=1:" - "detect_odr_violation=0:handle_segv=0:" - "handle_sigbus=0:handle_abort=0:" - "handle_sigfpe=0:handle_sigill=0") - os.environ["UBSAN_OPTIONS"] = ("abort_on_error=1:" - "allocator_release_to_os_interval_ms=500:" - "handle_abort=0:handle_segv=0:" - "handle_sigbus=0:handle_sigfpe=0:" - "handle_sigill=0:print_stacktrace=0:" - "symbolize=0:symbolize_inline_frames=0") - # Create at least one non-empty seed to start. - utils.create_seed_file_for_empty_corpus(input_corpus) - - -def build(): # pylint: disable=too-many-branches,too-many-statements - """Build benchmark.""" - os.environ["CC"] = ( - "/libafl/fuzzers/fuzzbench_ngram/target/release-fuzzbench/libafl_cc") - os.environ["CXX"] = ( - "/libafl/fuzzers/fuzzbench_ngram/target/release-fuzzbench/libafl_cxx") - - os.environ["ASAN_OPTIONS"] = "abort_on_error=0:allocator_may_return_null=1" - os.environ["UBSAN_OPTIONS"] = "abort_on_error=0" - - cflags = ["--libafl"] - cxxflags = ["--libafl", "--std=c++14"] - utils.append_flags("CFLAGS", cflags) - utils.append_flags("CXXFLAGS", cxxflags) - utils.append_flags("LDFLAGS", cflags) - - os.environ["FUZZER_LIB"] = "/stub_rt.a" - utils.build_benchmark() - - -def fuzz(input_corpus, output_corpus, target_binary): - """Run fuzzer.""" - prepare_fuzz_environment(input_corpus) - dictionary_path = utils.get_dictionary_path(target_binary) - command = [target_binary] - if dictionary_path: - command += ["-x", dictionary_path] - command += ["-o", output_corpus, "-i", input_corpus] - fuzzer_env = os.environ.copy() - fuzzer_env["LD_PRELOAD"] = "/usr/lib/x86_64-linux-gnu/libjemalloc.so.2" - print(command) - subprocess.check_call(command, cwd=os.environ["OUT"], env=fuzzer_env) diff --git a/fuzzers/libafl_ngram_mid_map/runner.Dockerfile b/fuzzers/libafl_ngram_mid_map/runner.Dockerfile deleted file mode 100644 index f0c5eb6cc..000000000 --- a/fuzzers/libafl_ngram_mid_map/runner.Dockerfile +++ /dev/null @@ -1,25 +0,0 @@ -# Copyright 2020 Google LLC -# -# 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. - -FROM gcr.io/fuzzbench/base-image - -RUN apt install libjemalloc2 - -# This makes interactive docker runs painless: -ENV LD_LIBRARY_PATH="$LD_LIBRARY_PATH:/out" -#ENV AFL_MAP_SIZE=2621440 -ENV PATH="$PATH:/out" -ENV AFL_SKIP_CPUFREQ=1 -ENV AFL_I_DONT_CARE_ABOUT_MISSING_CRASHES=1 -ENV AFL_TESTCACHE_SIZE=2 diff --git a/fuzzers/libafl_ngram_small_map/builder.Dockerfile b/fuzzers/libafl_ngram_small_map/builder.Dockerfile deleted file mode 100644 index 0921146e8..000000000 --- a/fuzzers/libafl_ngram_small_map/builder.Dockerfile +++ /dev/null @@ -1,61 +0,0 @@ -# Copyright 2020 Google LLC -# -# 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. - -ARG parent_image -FROM $parent_image - -# Uninstall old Rust & Install the latest one. -RUN if which rustup; then rustup self uninstall -y; fi && \ - curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs > /rustup.sh && \ - sh /rustup.sh --default-toolchain nightly-2024-02-14 -y && \ - rm /rustup.sh - -# Install dependencies. -RUN apt-get update && \ - apt-get remove -y llvm-10 && \ - apt-get install -y \ - build-essential \ - lsb-release wget software-properties-common gnupg && \ - apt-get install -y wget libstdc++5 libtool-bin automake flex bison \ - libglib2.0-dev libpixman-1-dev python3-setuptools unzip \ - apt-utils apt-transport-https ca-certificates joe curl && \ - wget https://apt.llvm.org/llvm.sh && chmod +x llvm.sh && ./llvm.sh 16 - -RUN wget https://gist.githubusercontent.com/tokatoka/26f4ba95991c6e33139999976332aa8e/raw/698ac2087d58ce5c7a6ad59adce58dbfdc32bd46/createAliases.sh && chmod u+x ./createAliases.sh && ./createAliases.sh - -# Uninstall old Rust & Install the latest one. -RUN if which rustup; then rustup self uninstall -y; fi && \ - curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs > /rustup.sh && \ - sh /rustup.sh --default-toolchain nightly-2024-02-14 -y && \ - rm /rustup.sh && \ - PATH="/root/.cargo/bin/:$PATH" cargo install cargo-make - -# Download libafl. -RUN git clone https://github.com/AFLplusplus/LibAFL /libafl - -# Checkout a current commit -RUN cd /libafl && git pull && git checkout a5f2daf6e70c0b57b6781c1e8cd9a5b309a6c1de || true -# Note that due a nightly bug it is currently fixed to a known version on top! - -# Compile libafl. -RUN cd /libafl && \ - unset CFLAGS CXXFLAGS && \ - export LIBAFL_EDGES_MAP_SIZE=131072 && \ - cd ./fuzzers/fuzzbench_ngram && \ - PATH="/root/.cargo/bin/:$PATH" cargo build --profile release-fuzzbench --features no_link_main - -# Auxiliary weak references. -RUN cd /libafl/fuzzers/fuzzbench_ngram && \ - clang -c stub_rt.c && \ - ar r /stub_rt.a stub_rt.o diff --git a/fuzzers/libafl_ngram_small_map/description.md b/fuzzers/libafl_ngram_small_map/description.md deleted file mode 100644 index ea9b947d6..000000000 --- a/fuzzers/libafl_ngram_small_map/description.md +++ /dev/null @@ -1,11 +0,0 @@ -# libafl - -libafl fuzzer instance - - cmplog feature - - persistent mode - -Repository: [https://github.com/AFLplusplus/libafl/](https://github.com/AFLplusplus/libafl/) - -[builder.Dockerfile](builder.Dockerfile) -[fuzzer.py](fuzzer.py) -[runner.Dockerfile](runner.Dockerfile) diff --git a/fuzzers/libafl_ngram_small_map/fuzzer.py b/fuzzers/libafl_ngram_small_map/fuzzer.py deleted file mode 100755 index 7498be883..000000000 --- a/fuzzers/libafl_ngram_small_map/fuzzer.py +++ /dev/null @@ -1,72 +0,0 @@ -# Copyright 2020 Google LLC -# -# 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. -# -"""Integration code for a LibAFL-based fuzzer.""" - -import os -import subprocess - -from fuzzers import utils - - -def prepare_fuzz_environment(input_corpus): - """Prepare to fuzz with a LibAFL-based fuzzer.""" - os.environ["ASAN_OPTIONS"] = ("abort_on_error=1:detect_leaks=0:" - "malloc_context_size=0:symbolize=0:" - "allocator_may_return_null=1:" - "detect_odr_violation=0:handle_segv=0:" - "handle_sigbus=0:handle_abort=0:" - "handle_sigfpe=0:handle_sigill=0") - os.environ["UBSAN_OPTIONS"] = ("abort_on_error=1:" - "allocator_release_to_os_interval_ms=500:" - "handle_abort=0:handle_segv=0:" - "handle_sigbus=0:handle_sigfpe=0:" - "handle_sigill=0:print_stacktrace=0:" - "symbolize=0:symbolize_inline_frames=0") - # Create at least one non-empty seed to start. - utils.create_seed_file_for_empty_corpus(input_corpus) - - -def build(): # pylint: disable=too-many-branches,too-many-statements - """Build benchmark.""" - os.environ["CC"] = ( - "/libafl/fuzzers/fuzzbench_ngram/target/release-fuzzbench/libafl_cc") - os.environ["CXX"] = ( - "/libafl/fuzzers/fuzzbench_ngram/target/release-fuzzbench/libafl_cxx") - - os.environ["ASAN_OPTIONS"] = "abort_on_error=0:allocator_may_return_null=1" - os.environ["UBSAN_OPTIONS"] = "abort_on_error=0" - - cflags = ["--libafl"] - cxxflags = ["--libafl", "--std=c++14"] - utils.append_flags("CFLAGS", cflags) - utils.append_flags("CXXFLAGS", cxxflags) - utils.append_flags("LDFLAGS", cflags) - - os.environ["FUZZER_LIB"] = "/stub_rt.a" - utils.build_benchmark() - - -def fuzz(input_corpus, output_corpus, target_binary): - """Run fuzzer.""" - prepare_fuzz_environment(input_corpus) - dictionary_path = utils.get_dictionary_path(target_binary) - command = [target_binary] - if dictionary_path: - command += ["-x", dictionary_path] - command += ["-o", output_corpus, "-i", input_corpus] - fuzzer_env = os.environ.copy() - fuzzer_env["LD_PRELOAD"] = "/usr/lib/x86_64-linux-gnu/libjemalloc.so.2" - print(command) - subprocess.check_call(command, cwd=os.environ["OUT"], env=fuzzer_env) diff --git a/fuzzers/libafl_ngram_small_map/runner.Dockerfile b/fuzzers/libafl_ngram_small_map/runner.Dockerfile deleted file mode 100644 index f0c5eb6cc..000000000 --- a/fuzzers/libafl_ngram_small_map/runner.Dockerfile +++ /dev/null @@ -1,25 +0,0 @@ -# Copyright 2020 Google LLC -# -# 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. - -FROM gcr.io/fuzzbench/base-image - -RUN apt install libjemalloc2 - -# This makes interactive docker runs painless: -ENV LD_LIBRARY_PATH="$LD_LIBRARY_PATH:/out" -#ENV AFL_MAP_SIZE=2621440 -ENV PATH="$PATH:/out" -ENV AFL_SKIP_CPUFREQ=1 -ENV AFL_I_DONT_CARE_ABOUT_MISSING_CRASHES=1 -ENV AFL_TESTCACHE_SIZE=2