1
0
mirror of https://github.com/systemd/systemd.git synced 2025-01-09 01:18:19 +03:00

tests: hook up fuzz targets to FuzzBuzz

This commit is contained in:
Evgeny Vereshchagin 2019-05-05 19:28:42 +00:00
parent 717e8eda77
commit 87ac55a129
6 changed files with 91 additions and 33 deletions

32
fuzz.yaml Normal file
View File

@ -0,0 +1,32 @@
base: ubuntu:16.04
language: c
setup:
- sudo bash -c "echo 'deb-src http://archive.ubuntu.com/ubuntu/ xenial main restricted universe multiverse' >>/etc/apt/sources.list"
- sudo apt-get update -y
- sudo apt-get build-dep -y systemd
- sudo apt-get install -y python3-pip
- pip3 install meson ninja
- export PATH="$HOME/.local/bin/:$PATH"
- CC=$FUZZ_CC CXX=$FUZZ_CXX meson -Dfuzzbuzz=true -Dfuzzbuzz-engine-dir=$(dirname "$FUZZ_ENGINE") -Dfuzzbuzz-engine=$(cut -d. -f1 <(basename "$FUZZ_ENGINE")) -Db_lundef=false ./build
- ninja -v -C ./build fuzzers
environment:
targets:
- name: fuzz-compress
harness:
binary: ./build/fuzz-compress
- name: fuzz-unit-file
harness:
binary: ./build/fuzz-unit-file
corpus: ./test/fuzz/fuzz-unit-file
- name: fuzz-journald-syslog
harness:
binary: ./build/fuzz-journald-syslog
corpus: ./test/fuzz/fuzz-journald-syslog
- name: fuzz-netdev-parser
harness:
binary: ./build/fuzz-netdev-parser
corpus: ./test/fuzz/fuzz-netdev-parser
- name: fuzz-network-parser
harness:
binary: ./build/fuzz-network-parser
corpus: ./test/fuzz/fuzz-network-parser

View File

@ -32,10 +32,13 @@ project_source_root = meson.current_source_dir()
want_ossfuzz = get_option('oss-fuzz') want_ossfuzz = get_option('oss-fuzz')
want_libfuzzer = get_option('llvm-fuzz') want_libfuzzer = get_option('llvm-fuzz')
if want_ossfuzz and want_libfuzzer want_fuzzbuzz = get_option('fuzzbuzz')
error('only one of oss-fuzz and llvm-fuzz can be specified') if want_ossfuzz + want_libfuzzer + want_fuzzbuzz > 1
error('only one of oss-fuzz, llvm-fuzz or fuzzbuzz can be specified')
endif endif
fuzzer_build = want_ossfuzz or want_libfuzzer
skip_deps = want_ossfuzz or want_libfuzzer
fuzzer_build = want_ossfuzz or want_libfuzzer or want_fuzzbuzz
##################################################################### #####################################################################
@ -303,6 +306,8 @@ if want_libfuzzer
fuzzing_engine = meson.get_compiler('cpp').find_library('Fuzzer') fuzzing_engine = meson.get_compiler('cpp').find_library('Fuzzer')
elif want_ossfuzz elif want_ossfuzz
fuzzing_engine = meson.get_compiler('cpp').find_library('FuzzingEngine') fuzzing_engine = meson.get_compiler('cpp').find_library('FuzzingEngine')
elif want_fuzzbuzz
fuzzing_engine = meson.get_compiler('cpp').find_library(get_option('fuzzbuzz-engine'), dirs: get_option('fuzzbuzz-engine-dir'))
endif endif
possible_cc_flags = [ possible_cc_flags = [
@ -815,7 +820,7 @@ libmount = dependency('mount',
version : fuzzer_build ? '>= 0' : '>= 2.30') version : fuzzer_build ? '>= 0' : '>= 2.30')
want_seccomp = get_option('seccomp') want_seccomp = get_option('seccomp')
if want_seccomp != 'false' and not fuzzer_build if want_seccomp != 'false' and not skip_deps
libseccomp = dependency('libseccomp', libseccomp = dependency('libseccomp',
version : '>= 2.3.1', version : '>= 2.3.1',
required : want_seccomp == 'true') required : want_seccomp == 'true')
@ -827,7 +832,7 @@ endif
conf.set10('HAVE_SECCOMP', have) conf.set10('HAVE_SECCOMP', have)
want_selinux = get_option('selinux') want_selinux = get_option('selinux')
if want_selinux != 'false' and not fuzzer_build if want_selinux != 'false' and not skip_deps
libselinux = dependency('libselinux', libselinux = dependency('libselinux',
version : '>= 2.1.9', version : '>= 2.1.9',
required : want_selinux == 'true') required : want_selinux == 'true')
@ -839,7 +844,7 @@ endif
conf.set10('HAVE_SELINUX', have) conf.set10('HAVE_SELINUX', have)
want_apparmor = get_option('apparmor') want_apparmor = get_option('apparmor')
if want_apparmor != 'false' and not fuzzer_build if want_apparmor != 'false' and not skip_deps
libapparmor = dependency('libapparmor', libapparmor = dependency('libapparmor',
required : want_apparmor == 'true') required : want_apparmor == 'true')
have = libapparmor.found() have = libapparmor.found()
@ -857,7 +862,7 @@ endif
want_polkit = get_option('polkit') want_polkit = get_option('polkit')
install_polkit = false install_polkit = false
install_polkit_pkla = false install_polkit_pkla = false
if want_polkit != 'false' and not fuzzer_build if want_polkit != 'false' and not skip_deps
install_polkit = true install_polkit = true
libpolkit = dependency('polkit-gobject-1', libpolkit = dependency('polkit-gobject-1',
@ -870,7 +875,7 @@ endif
conf.set10('ENABLE_POLKIT', install_polkit) conf.set10('ENABLE_POLKIT', install_polkit)
want_acl = get_option('acl') want_acl = get_option('acl')
if want_acl != 'false' and not fuzzer_build if want_acl != 'false' and not skip_deps
libacl = cc.find_library('acl', required : want_acl == 'true') libacl = cc.find_library('acl', required : want_acl == 'true')
have = libacl.found() have = libacl.found()
else else
@ -880,7 +885,7 @@ endif
conf.set10('HAVE_ACL', have) conf.set10('HAVE_ACL', have)
want_audit = get_option('audit') want_audit = get_option('audit')
if want_audit != 'false' and not fuzzer_build if want_audit != 'false' and not skip_deps
libaudit = dependency('audit', required : want_audit == 'true') libaudit = dependency('audit', required : want_audit == 'true')
have = libaudit.found() have = libaudit.found()
else else
@ -890,7 +895,7 @@ endif
conf.set10('HAVE_AUDIT', have) conf.set10('HAVE_AUDIT', have)
want_blkid = get_option('blkid') want_blkid = get_option('blkid')
if want_blkid != 'false' and not fuzzer_build if want_blkid != 'false' and not skip_deps
libblkid = dependency('blkid', required : want_blkid == 'true') libblkid = dependency('blkid', required : want_blkid == 'true')
have = libblkid.found() have = libblkid.found()
else else
@ -900,7 +905,7 @@ endif
conf.set10('HAVE_BLKID', have) conf.set10('HAVE_BLKID', have)
want_kmod = get_option('kmod') want_kmod = get_option('kmod')
if want_kmod != 'false' and not fuzzer_build if want_kmod != 'false' and not skip_deps
libkmod = dependency('libkmod', libkmod = dependency('libkmod',
version : '>= 15', version : '>= 15',
required : want_kmod == 'true') required : want_kmod == 'true')
@ -912,7 +917,7 @@ endif
conf.set10('HAVE_KMOD', have) conf.set10('HAVE_KMOD', have)
want_pam = get_option('pam') want_pam = get_option('pam')
if want_pam != 'false' and not fuzzer_build if want_pam != 'false' and not skip_deps
libpam = cc.find_library('pam', required : want_pam == 'true') libpam = cc.find_library('pam', required : want_pam == 'true')
libpam_misc = cc.find_library('pam_misc', required : want_pam == 'true') libpam_misc = cc.find_library('pam_misc', required : want_pam == 'true')
have = libpam.found() and libpam_misc.found() have = libpam.found() and libpam_misc.found()
@ -924,7 +929,7 @@ endif
conf.set10('HAVE_PAM', have) conf.set10('HAVE_PAM', have)
want_microhttpd = get_option('microhttpd') want_microhttpd = get_option('microhttpd')
if want_microhttpd != 'false' and not fuzzer_build if want_microhttpd != 'false' and not skip_deps
libmicrohttpd = dependency('libmicrohttpd', libmicrohttpd = dependency('libmicrohttpd',
version : '>= 0.9.33', version : '>= 0.9.33',
required : want_microhttpd == 'true') required : want_microhttpd == 'true')
@ -936,7 +941,7 @@ endif
conf.set10('HAVE_MICROHTTPD', have) conf.set10('HAVE_MICROHTTPD', have)
want_libcryptsetup = get_option('libcryptsetup') want_libcryptsetup = get_option('libcryptsetup')
if want_libcryptsetup != 'false' and not fuzzer_build if want_libcryptsetup != 'false' and not skip_deps
libcryptsetup = dependency('libcryptsetup', libcryptsetup = dependency('libcryptsetup',
version : '>= 1.6.0', version : '>= 1.6.0',
required : want_libcryptsetup == 'true') required : want_libcryptsetup == 'true')
@ -954,7 +959,7 @@ conf.set10('HAVE_LIBCRYPTSETUP', have)
conf.set10('HAVE_LIBCRYPTSETUP_SECTOR_SIZE', have_sector) conf.set10('HAVE_LIBCRYPTSETUP_SECTOR_SIZE', have_sector)
want_libcurl = get_option('libcurl') want_libcurl = get_option('libcurl')
if want_libcurl != 'false' and not fuzzer_build if want_libcurl != 'false' and not skip_deps
libcurl = dependency('libcurl', libcurl = dependency('libcurl',
version : '>= 7.32.0', version : '>= 7.32.0',
required : want_libcurl == 'true') required : want_libcurl == 'true')
@ -971,7 +976,7 @@ if want_libidn == 'true' and want_libidn2 == 'true'
error('libidn and libidn2 cannot be requested simultaneously') error('libidn and libidn2 cannot be requested simultaneously')
endif endif
if want_libidn != 'false' and want_libidn2 != 'true' and not fuzzer_build if want_libidn != 'false' and want_libidn2 != 'true' and not skip_deps
libidn = dependency('libidn', libidn = dependency('libidn',
required : want_libidn == 'true') required : want_libidn == 'true')
have = libidn.found() have = libidn.found()
@ -980,7 +985,7 @@ else
libidn = [] libidn = []
endif endif
conf.set10('HAVE_LIBIDN', have) conf.set10('HAVE_LIBIDN', have)
if not have and want_libidn2 != 'false' and not fuzzer_build if not have and want_libidn2 != 'false' and not skip_deps
# libidn is used for both libidn and libidn2 objects # libidn is used for both libidn and libidn2 objects
libidn = dependency('libidn2', libidn = dependency('libidn2',
required : want_libidn2 == 'true') required : want_libidn2 == 'true')
@ -991,7 +996,7 @@ endif
conf.set10('HAVE_LIBIDN2', have) conf.set10('HAVE_LIBIDN2', have)
want_libiptc = get_option('libiptc') want_libiptc = get_option('libiptc')
if want_libiptc != 'false' and not fuzzer_build if want_libiptc != 'false' and not skip_deps
libiptc = dependency('libiptc', libiptc = dependency('libiptc',
required : want_libiptc == 'true') required : want_libiptc == 'true')
have = libiptc.found() have = libiptc.found()
@ -1002,7 +1007,7 @@ endif
conf.set10('HAVE_LIBIPTC', have) conf.set10('HAVE_LIBIPTC', have)
want_qrencode = get_option('qrencode') want_qrencode = get_option('qrencode')
if want_qrencode != 'false' and not fuzzer_build if want_qrencode != 'false' and not skip_deps
libqrencode = dependency('libqrencode', libqrencode = dependency('libqrencode',
required : want_qrencode == 'true') required : want_qrencode == 'true')
have = libqrencode.found() have = libqrencode.found()
@ -1013,7 +1018,7 @@ endif
conf.set10('HAVE_QRENCODE', have) conf.set10('HAVE_QRENCODE', have)
want_gcrypt = get_option('gcrypt') want_gcrypt = get_option('gcrypt')
if want_gcrypt != 'false' and not fuzzer_build if want_gcrypt != 'false' and not skip_deps
libgcrypt = cc.find_library('gcrypt', required : want_gcrypt == 'true') libgcrypt = cc.find_library('gcrypt', required : want_gcrypt == 'true')
libgpg_error = cc.find_library('gpg-error', required : want_gcrypt == 'true') libgpg_error = cc.find_library('gpg-error', required : want_gcrypt == 'true')
have = libgcrypt.found() and libgpg_error.found() have = libgcrypt.found() and libgpg_error.found()
@ -1028,7 +1033,7 @@ endif
conf.set10('HAVE_GCRYPT', have) conf.set10('HAVE_GCRYPT', have)
want_gnutls = get_option('gnutls') want_gnutls = get_option('gnutls')
if want_gnutls != 'false' and not fuzzer_build if want_gnutls != 'false' and not skip_deps
libgnutls = dependency('gnutls', libgnutls = dependency('gnutls',
version : '>= 3.1.4', version : '>= 3.1.4',
required : want_gnutls == 'true') required : want_gnutls == 'true')
@ -1040,7 +1045,7 @@ endif
conf.set10('HAVE_GNUTLS', have) conf.set10('HAVE_GNUTLS', have)
want_openssl = get_option('openssl') want_openssl = get_option('openssl')
if want_openssl != 'false' and not fuzzer_build if want_openssl != 'false' and not skip_deps
libopenssl = dependency('openssl', libopenssl = dependency('openssl',
version : '>= 1.1.0', version : '>= 1.1.0',
required : want_openssl == 'true') required : want_openssl == 'true')
@ -1052,7 +1057,7 @@ endif
conf.set10('HAVE_OPENSSL', have) conf.set10('HAVE_OPENSSL', have)
want_elfutils = get_option('elfutils') want_elfutils = get_option('elfutils')
if want_elfutils != 'false' and not fuzzer_build if want_elfutils != 'false' and not skip_deps
libdw = dependency('libdw', libdw = dependency('libdw',
required : want_elfutils == 'true') required : want_elfutils == 'true')
have = libdw.found() have = libdw.found()
@ -1063,7 +1068,7 @@ endif
conf.set10('HAVE_ELFUTILS', have) conf.set10('HAVE_ELFUTILS', have)
want_zlib = get_option('zlib') want_zlib = get_option('zlib')
if want_zlib != 'false' and not fuzzer_build if want_zlib != 'false' and not skip_deps
libz = dependency('zlib', libz = dependency('zlib',
required : want_zlib == 'true') required : want_zlib == 'true')
have = libz.found() have = libz.found()
@ -1074,7 +1079,7 @@ endif
conf.set10('HAVE_ZLIB', have) conf.set10('HAVE_ZLIB', have)
want_bzip2 = get_option('bzip2') want_bzip2 = get_option('bzip2')
if want_bzip2 != 'false' and not fuzzer_build if want_bzip2 != 'false' and not skip_deps
libbzip2 = cc.find_library('bz2', libbzip2 = cc.find_library('bz2',
required : want_bzip2 == 'true') required : want_bzip2 == 'true')
have = libbzip2.found() have = libbzip2.found()
@ -1085,7 +1090,7 @@ endif
conf.set10('HAVE_BZIP2', have) conf.set10('HAVE_BZIP2', have)
want_xz = get_option('xz') want_xz = get_option('xz')
if want_xz != 'false' and not fuzzer_build if want_xz != 'false' and not skip_deps
libxz = dependency('liblzma', libxz = dependency('liblzma',
required : want_xz == 'true') required : want_xz == 'true')
have = libxz.found() have = libxz.found()
@ -1096,7 +1101,7 @@ endif
conf.set10('HAVE_XZ', have) conf.set10('HAVE_XZ', have)
want_lz4 = get_option('lz4') want_lz4 = get_option('lz4')
if want_lz4 != 'false' and not fuzzer_build if want_lz4 != 'false' and not skip_deps
liblz4 = dependency('liblz4', liblz4 = dependency('liblz4',
version : '>= 1.3.0', version : '>= 1.3.0',
required : want_lz4 == 'true') required : want_lz4 == 'true')
@ -1108,7 +1113,7 @@ endif
conf.set10('HAVE_LZ4', have) conf.set10('HAVE_LZ4', have)
want_xkbcommon = get_option('xkbcommon') want_xkbcommon = get_option('xkbcommon')
if want_xkbcommon != 'false' and not fuzzer_build if want_xkbcommon != 'false' and not skip_deps
libxkbcommon = dependency('xkbcommon', libxkbcommon = dependency('xkbcommon',
version : '>= 0.3.0', version : '>= 0.3.0',
required : want_xkbcommon == 'true') required : want_xkbcommon == 'true')
@ -1131,7 +1136,7 @@ endif
conf.set10('HAVE_PCRE2', have) conf.set10('HAVE_PCRE2', have)
want_glib = get_option('glib') want_glib = get_option('glib')
if want_glib != 'false' and not fuzzer_build if want_glib != 'false' and not skip_deps
libglib = dependency('glib-2.0', libglib = dependency('glib-2.0',
version : '>= 2.22.0', version : '>= 2.22.0',
required : want_glib == 'true') required : want_glib == 'true')
@ -1150,7 +1155,7 @@ endif
conf.set10('HAVE_GLIB', have) conf.set10('HAVE_GLIB', have)
want_dbus = get_option('dbus') want_dbus = get_option('dbus')
if want_dbus != 'false' and not fuzzer_build if want_dbus != 'false' and not skip_deps
libdbus = dependency('dbus-1', libdbus = dependency('dbus-1',
version : '>= 1.3.2', version : '>= 1.3.2',
required : want_dbus == 'true') required : want_dbus == 'true')
@ -1162,7 +1167,7 @@ endif
conf.set10('HAVE_DBUS', have) conf.set10('HAVE_DBUS', have)
default_dnssec = get_option('default-dnssec') default_dnssec = get_option('default-dnssec')
if fuzzer_build if skip_deps
default_dnssec = 'no' default_dnssec = 'no'
endif endif
if default_dnssec != 'no' and conf.get('HAVE_GCRYPT') == 0 if default_dnssec != 'no' and conf.get('HAVE_GCRYPT') == 0
@ -1203,7 +1208,7 @@ conf.set10('DNS_OVER_TLS_USE_GNUTLS', have_gnutls)
conf.set10('DNS_OVER_TLS_USE_OPENSSL', have_openssl) conf.set10('DNS_OVER_TLS_USE_OPENSSL', have_openssl)
default_dns_over_tls = get_option('default-dns-over-tls') default_dns_over_tls = get_option('default-dns-over-tls')
if fuzzer_build if skip_deps
default_dns_over_tls = 'no' default_dns_over_tls = 'no'
endif endif
if default_dns_over_tls != 'no' and conf.get('ENABLE_DNS_OVER_TLS') == 0 if default_dns_over_tls != 'no' and conf.get('ENABLE_DNS_OVER_TLS') == 0
@ -2824,6 +2829,10 @@ foreach tuple : fuzzers
sources += 'src/fuzz/fuzz-main.c' sources += 'src/fuzz/fuzz-main.c'
endif endif
if want_fuzzbuzz
sources += 'src/fuzz/fuzzer-entry-point.c'
endif
name = sources[0].split('/')[-1].split('.')[0] name = sources[0].split('/')[-1].split('.')[0]
fuzzer_exes += executable( fuzzer_exes += executable(

View File

@ -329,3 +329,9 @@ option('oss-fuzz', type : 'boolean', value : 'false',
description : 'build against oss-fuzz') description : 'build against oss-fuzz')
option('llvm-fuzz', type : 'boolean', value : 'false', option('llvm-fuzz', type : 'boolean', value : 'false',
description : 'build against LLVM libFuzzer') description : 'build against LLVM libFuzzer')
option('fuzzbuzz', type : 'boolean', value : 'false',
description : 'build against FuzzBuzz')
option('fuzzbuzz-engine', type : 'string',
description : 'the name of the FuzzBuzz fuzzing engine')
option('fuzzbuzz-engine-dir', type : 'string',
description : 'the directory where the FuzzBuzz fuzzing engine is')

View File

@ -6,3 +6,6 @@
/* The entry point into the fuzzer */ /* The entry point into the fuzzer */
int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size); int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size);
/* https://docs.fuzzbuzz.io/developer-documentation/porting-targets-to-fuzzbuzz/libfuzzer-targets */
int FuzzerEntrypoint(const uint8_t *data, size_t size);

View File

@ -0,0 +1,5 @@
#include "fuzz.h"
int FuzzerEntrypoint(const uint8_t *data, size_t size) {
return LLVMFuzzerTestOneInput(data, size);
}

View File

@ -987,7 +987,10 @@ tests += [
] ]
if cxx_cmd != '' # test-bus-vtable-cc.cc is a symlink and symlinks get lost in containers on FuzzBuzz.
# The issue has been reported to the developers of FuzzBuzz and hopefully will be fixed soon.
# In the meantime, let's just skip the symlink there.
if cxx_cmd != '' and not want_fuzzbuzz
tests += [ tests += [
[['src/libsystemd/sd-bus/test-bus-vtable-cc.cc'], [['src/libsystemd/sd-bus/test-bus-vtable-cc.cc'],
[], [],