setup meson to allow building multiple fuzzers easily

This commit is contained in:
John Turner
2025-11-18 22:43:22 +00:00
parent e0cc7f6a03
commit e01637fd3a
6 changed files with 62 additions and 36 deletions

View File

@@ -13,9 +13,9 @@ thiserror = "2.0.17"
debug = true debug = true
[[bin]] [[bin]]
path = "fuzz/gencorpus.rs" path = "fuzz/atom/parser/gencorpus.rs"
name = "gencorpus" name = "atom_parser_gencorpus"
[[test]] [[test]]
path = "fuzz/fuzz.rs" path = "fuzz/atom/parser/fuzz.rs"
name = "fuzz" name = "atom_parser_fuzz"

1
fuzz/atom/meson.build Normal file
View File

@@ -0,0 +1 @@
subdir('parser')

View File

@@ -0,0 +1,6 @@
fuzzers += {
'atom_parser': [
meson.current_source_dir() / 'gencorpus.rs',
meson.current_source_dir() / 'fuzz.rs',
],
}

View File

@@ -1,30 +1,38 @@
cbindgen = find_program('cbindgen') cbindgen = find_program('cbindgen')
gencorpus = executable( fuzzers = {}
'gencorpus',
'gencorpus.rs', subdir('atom')
foreach fuzzer, sources : fuzzers
gencorpus_rs = sources[0]
fuzz_rs = sources[1]
gencorpus = executable(
fuzzer + '_' + 'gencorpus',
gencorpus_rs,
dependencies: [mon], dependencies: [mon],
link_with: [gentoo_utils], link_with: [gentoo_utils],
) )
corpus_directory = meson.current_build_dir() / 'corpus' corpus_directory = fuzzer + '_' + 'corpus'
corpus = custom_target( corpus = custom_target(
'corpus', fuzzer + '_' + 'corpus',
output: 'corpus', output: fuzzer + '_' + 'corpus',
command: [gencorpus, corpus_directory], command: [gencorpus, corpus_directory],
) )
fuzz_h = custom_target( fuzz_h = custom_target(
'fuzz_h', fuzzer + '_' + 'fuzz_h',
input: 'fuzz.rs', input: fuzz_rs,
output: 'fuzz.h', output: fuzzer + '_' + 'fuzz.h',
command: [cbindgen, '@INPUT@', '-o', '@OUTPUT'], command: [cbindgen, '@INPUT@', '-o', '@OUTPUT'],
) )
fuzz_rs = static_library( fuzz_rs = static_library(
'fuzz_rs', fuzzer + '.rs',
'fuzz.rs', fuzz_rs,
rust_abi: 'c', rust_abi: 'c',
rust_args: [ rust_args: [
'-Cpasses=sancov-module', '-Cpasses=sancov-module',
@@ -33,8 +41,19 @@ fuzz_rs = static_library(
], ],
dependencies: [mon], dependencies: [mon],
link_with: [gentoo_utils], link_with: [gentoo_utils],
) )
fuzz = executable('fuzz', link_args: ['-fsanitize=fuzzer'], link_with: [fuzz_rs]) fuzz = executable(
fuzzer + '_' + 'fuzzer',
link_args: ['-fsanitize=fuzzer'],
link_with: [fuzz_rs],
)
test('fuzz', fuzz, args: [corpus_directory], depends: [corpus], timeout: 0) test(
fuzzer + '_' + 'fuzz',
fuzz,
args: [corpus_directory],
depends: [corpus],
timeout: 0,
)
endforeach