2015-02-16 14:04:02 +01:00
|
|
|
#
|
|
|
|
# spec file for package afl
|
|
|
|
#
|
2022-01-31 14:22:18 +01:00
|
|
|
# Copyright (c) 2022 SUSE LLC
|
2015-02-16 14:04:02 +01:00
|
|
|
#
|
|
|
|
# All modifications and additions to the file contributed by third parties
|
|
|
|
# remain the property of their copyright owners, unless otherwise agreed
|
|
|
|
# upon. The license for this file, and modifications and additions to the
|
|
|
|
# file, is the same license as for the pristine package itself (unless the
|
|
|
|
# license for the pristine package is not an Open Source License, in which
|
|
|
|
# case the license is the MIT License). An "Open Source License" is a
|
|
|
|
# license that conforms to the Open Source Definition (Version 1.9)
|
|
|
|
# published by the Open Source Initiative.
|
|
|
|
|
2019-12-27 17:48:56 +01:00
|
|
|
# Please submit bugfixes or comments via https://bugs.opensuse.org/
|
2015-02-16 14:04:02 +01:00
|
|
|
#
|
|
|
|
|
|
|
|
|
2022-03-31 11:27:56 +02:00
|
|
|
%ifarch riscv64
|
|
|
|
%define afl_rt compiler-rt,llvm-rt
|
|
|
|
%else
|
|
|
|
%define afl_rt compiler-rt,llvm-rt,llvm-rt-lto
|
|
|
|
%endif
|
|
|
|
|
|
|
|
%ifarch %{arm} %ix86 s390x x86_64
|
|
|
|
%define afl_32 1
|
|
|
|
%endif
|
|
|
|
%ifarch ppc64le
|
|
|
|
%if %{pkg_vcmp clang < 12}
|
|
|
|
%define afl_32 1
|
|
|
|
%endif
|
|
|
|
%endif
|
|
|
|
|
|
|
|
%ifarch aarch64 ppc64 ppc64le riscv64 s390x x86_64
|
|
|
|
%define afl_64 1
|
|
|
|
%endif
|
|
|
|
|
2015-02-16 14:04:02 +01:00
|
|
|
Name: afl
|
2022-01-31 14:22:18 +01:00
|
|
|
Version: 4.00c
|
2015-02-16 14:04:02 +01:00
|
|
|
Release: 0
|
|
|
|
Summary: American fuzzy lop is a security-oriented fuzzer
|
2022-01-31 14:22:18 +01:00
|
|
|
#URL: https://lcamtuf.coredump.cx/afl/
|
2015-02-16 14:04:02 +01:00
|
|
|
License: Apache-2.0
|
2022-01-31 14:22:18 +01:00
|
|
|
URL: https://github.com/AFLplusplus/AFLplusplus
|
- update to 3.10c
- Mac OS ARM64 support
- Android support fixed and updated by Joey Jiaojg - thanks!
- New selective instrumentation option with __AFL_COVERAGE_* commands
to be placed in the source code.
Check out instrumentation/README.instrument_list.md
- afl-fuzz
- Making AFL_MAP_SIZE (mostly) obsolete - afl-fuzz now learns on
start the target map size
- upgraded cmplog/redqueen: solving for floating point, solving
transformations (e.g. toupper, tolower, to/from hex, xor,
arithmetics, etc.). This is costly hence new command line option
`-l` that sets the intensity (values 1 to 3). Recommended is 2.
- added `AFL_CMPLOG_ONLY_NEW` to not use cmplog on initial seeds
from `-i` or resumes (these have most likely already been done)
- fix crash for very, very fast targets+systems (thanks to mhlakhani
for reporting)
- on restarts (`-i`)/autoresume (AFL_AUTORESUME) the stats are now
reloaded and used, thanks to Vimal Joseph for this patch!
- changed the meaning of '+' of the '-t' option, it now means to
auto-calculate the timeout with the value given being the max
timeout. The original meaning of skipping timeouts instead of
abort is now inherent to the -t option.
- if deterministic mode is active (`-D`, or `-M` without `-d`) then
we sync after every queue entry as this can take very long time
otherwise
- added minimum SYNC_TIME to include/config.h (30 minutes default)
- better detection if a target needs a large shared map
- fix for `-Z`
- fixed a few crashes
OBS-URL: https://build.opensuse.org/package/show/devel:tools/afl?expand=0&rev=125
2021-03-01 10:51:20 +01:00
|
|
|
Source: https://github.com/AFLplusplus/AFLplusplus/archive/%{version}.tar.gz
|
2015-03-27 15:44:52 +01:00
|
|
|
Source1: afl-rpmlintrc
|
2020-12-15 14:57:19 +01:00
|
|
|
Patch1: afl-3.0c-fix-paths.patch
|
2021-03-16 12:48:35 +01:00
|
|
|
BuildRequires: clang
|
2015-02-16 14:04:02 +01:00
|
|
|
BuildRequires: gcc-c++
|
2021-09-26 13:20:54 +02:00
|
|
|
%ifarch x86_64
|
|
|
|
BuildRequires: gcc-32bit
|
|
|
|
%endif
|
|
|
|
%if %?suse_version >= 1550
|
|
|
|
BuildRequires: gcc-devel
|
|
|
|
%endif
|
2021-04-04 10:47:30 +02:00
|
|
|
BuildRequires: lld
|
|
|
|
BuildRequires: llvm-devel >= 11.0.0
|
2020-12-15 14:57:19 +01:00
|
|
|
BuildRequires: python3-devel
|
2021-04-04 10:47:30 +02:00
|
|
|
Requires: lld
|
2015-02-16 14:04:02 +01:00
|
|
|
|
|
|
|
%description
|
2016-10-20 20:27:52 +02:00
|
|
|
American fuzzy lop is a security-oriented fuzzer that employs a novel type
|
|
|
|
of compile-time instrumentation and genetic algorithms to automatically
|
|
|
|
discover clean, interesting test cases that trigger new internal states in
|
|
|
|
the targeted binary. This substantially improves the functional coverage
|
|
|
|
for the fuzzed code. The compact synthesized corpora produced by the tool
|
|
|
|
are also useful for seeding other, more labor- or resource-intensive
|
|
|
|
testing regimes down the road.
|
2015-02-16 14:04:02 +01:00
|
|
|
|
2016-10-20 20:27:52 +02:00
|
|
|
Compared to other instrumented fuzzers, afl-fuzz is designed to be
|
|
|
|
practical: it has modest performance overhead, uses a variety of highly
|
|
|
|
effective fuzzing strategies and effort minimization tricks, requires
|
|
|
|
essentially no configuration, and seamlessly handles complex, real-world
|
|
|
|
use cases - say, common image parsing or file compression libraries.
|
2015-02-16 14:04:02 +01:00
|
|
|
|
|
|
|
%prep
|
2019-06-24 09:24:50 +02:00
|
|
|
%setup -q -n AFLplusplus-%version
|
2015-03-27 21:33:36 +01:00
|
|
|
%patch1 -p1
|
2021-04-04 10:47:30 +02:00
|
|
|
sed -i 's|#!/usr/bin/env sh|#!/bin/sh|g' afl-cmin
|
|
|
|
sed -i 's|#!/usr/bin/env bash|#!/bin/bash|g' afl-cmin.bash
|
2015-02-16 14:04:02 +01:00
|
|
|
|
|
|
|
%build
|
2021-03-16 12:48:35 +01:00
|
|
|
export CFLAGS="$CFLAGS %{optflags} -fno-lto"
|
2018-08-30 17:07:23 +02:00
|
|
|
%ifnarch %{ix86} x86_64
|
|
|
|
export AFL_NO_X86=1
|
|
|
|
%endif
|
2021-04-04 10:47:30 +02:00
|
|
|
make %{?_smp_mflags} PREFIX=%{_prefix} LIBEXEC_DIR=%{_libexecdir} DOC_DIR=%{_docdir}
|
2020-07-02 15:33:33 +02:00
|
|
|
# make radamsa
|
2015-02-16 14:04:02 +01:00
|
|
|
|
|
|
|
%install
|
2018-08-30 17:07:23 +02:00
|
|
|
%ifnarch %{ix86} x86_64
|
|
|
|
export AFL_NO_X86=1
|
|
|
|
%endif
|
2019-11-10 11:24:08 +01:00
|
|
|
make %{?_smp_mflags} PREFIX=%{_prefix} LIBEXEC_DIR=%{_libexecdir} DOC_DIR=%{_docdir} MAN_PATH=%{_mandir}/man8 DESTDIR=%{buildroot} install
|
2021-04-04 10:47:30 +02:00
|
|
|
chmod -x %{buildroot}/%{_libexecdir}/%{name}/*.o
|
2015-02-16 14:04:02 +01:00
|
|
|
|
|
|
|
%files
|
2020-02-25 17:42:55 +01:00
|
|
|
%license docs/COPYING LICENSE
|
|
|
|
%doc /usr/share/doc/packages/%name/
|
2015-02-16 14:04:02 +01:00
|
|
|
%{_bindir}/%{name}-*
|
2015-03-27 15:44:52 +01:00
|
|
|
%dir %{_libexecdir}/%{name}
|
|
|
|
%{_libexecdir}/%{name}/%{name}-as
|
|
|
|
%{_libexecdir}/%{name}/as
|
2022-03-31 11:27:56 +02:00
|
|
|
%if 0%{?afl_64}
|
|
|
|
%{_libexecdir}/%{name}/afl-{%{afl_rt}}-64.o
|
2020-12-15 14:57:19 +01:00
|
|
|
%endif
|
2022-03-31 11:27:56 +02:00
|
|
|
%if 0%{?afl_32}
|
|
|
|
%{_libexecdir}/%{name}/afl-{%{afl_rt}}-32.o
|
2021-06-08 11:11:00 +02:00
|
|
|
%endif
|
2022-03-31 11:27:56 +02:00
|
|
|
%ifarch aarch64
|
2021-04-04 10:47:30 +02:00
|
|
|
%{_libexecdir}/%{name}/afl-llvm-rt-lto-32.o
|
2020-12-15 14:57:19 +01:00
|
|
|
%endif
|
2022-03-31 11:27:56 +02:00
|
|
|
%{_libexecdir}/%{name}/afl-{%{afl_rt}}.o
|
2020-12-15 14:57:19 +01:00
|
|
|
%{_libexecdir}/%{name}/dynamic_list.txt
|
2021-03-16 12:48:35 +01:00
|
|
|
%{_libexecdir}/%{name}/*.so
|
2021-07-20 10:02:42 +02:00
|
|
|
%{_libexecdir}/%{name}/*.a
|
2015-02-16 14:04:02 +01:00
|
|
|
%dir %{_datadir}/%{name}
|
|
|
|
%dir %{_datadir}/%{name}/testcases
|
|
|
|
%{_datadir}/%{name}/testcases/*
|
2016-10-20 20:27:52 +02:00
|
|
|
%dir %{_datadir}/afl/dictionaries/
|
|
|
|
%{_datadir}/afl/dictionaries/*
|
2019-11-10 11:24:08 +01:00
|
|
|
%{_mandir}/man8/afl*.8*
|
2015-02-16 14:04:02 +01:00
|
|
|
|
2015-03-27 15:44:52 +01:00
|
|
|
%changelog
|