make fail flags and .wamr_aot configurable from build menu

This commit is contained in:
2026-05-29 02:34:01 +02:00
parent 78733403f5
commit 9c42618028
3 changed files with 133 additions and 42 deletions

View File

@ -12,6 +12,7 @@ LIBIWASM_LINUX_DEBUG := env("LIBIWASM_LINUX_DEBUG")
LIBIWASM_LINUX_RELEASE := env("LIBIWASM_LINUX_RELEASE")
CROSS_CC := env("CROSS_CC")
LINUX_CC := env("LINUX_CC")
WAMR_USE_AOT_SECTION := env_var_or_default("WAMR_USE_AOT_SECTION", "false")
# =================================================================================================================== #
# Helper recipes
@ -181,9 +182,9 @@ build-wasm-aot module target="fail":
[group("1: build module")]
build-wasm-aot-array module:
{{ XXD }} -i {{ BUILD_DIR }}-{{ module }}/wasm_module.aot > {{ BUILD_DIR }}-{{ module }}/wasm_aot_array.c
# Add __attribute__((section...)) to this array, so it is located into the .text.wamr_aot segment...
sed -i '1s/^/__attribute__((section(".text.wamr_aot"), aligned(4096)))\n/' {{ BUILD_DIR }}-{{ module }}/wasm_aot_array.c
if [ "{{ WAMR_USE_AOT_SECTION }}" = "true" ]; then \
sed -i '1s/^/__attribute__((section(".text.wamr_aot"), aligned(4096)))\n/' {{ BUILD_DIR }}-{{ module }}/wasm_aot_array.c; \
fi
[doc("WASM -> C-Array: Dump a WASM module to a binary array")]
[group("1: build module")]

View File

@ -23,8 +23,9 @@ my @targets = ( "fail", "linux", "linux-baremetal" );
my @modes = ( "c", "aot", "interp" );
sub just {
say "Running: just @_...";
system("$justbin -d $local_root -f $justfile @_")
say
"Running: WAMR_USE_AOT_SECTION=$ENV{WAMR_USE_AOT_SECTION} WAMR_USE_MMAP=$ENV{WAMR_USE_MMAP} WAMR_USE_XIP=$ENV{WAMR_USE_XIP} just @_...";
system("$justbin -d $local_root -f $justfile @_ >/dev/null 2>&1")
and die "Build failed";
sleep(1);
}
@ -45,11 +46,24 @@ my @selected_modes =
TUI::select_from_list( "Select Execution Modes", 1, @modes );
die "No mode selected" unless @selected_modes;
# Select .text.wamr_aot section variant
my @aot_section_variants = (
"Place AOT array in .text.wamr_aot",
"Let the linker decide where the AOT array is located",
);
my @selected_aot_variants =
TUI::select_from_list( "Select WAMR Array.Text Variant",
1, @aot_section_variants );
die "No AOT section variant selected" unless @selected_aot_variants;
# Select WAMR mmap variant
my @wamr_variants = ( "Locate mmap_space in .text.wamr_mmap", "Let the compiler decide where mmap_space is located" );
my @selected_variants =
TUI::select_from_list( "Select WAMR mmap Variant", 1, @wamr_variants );
die "No variant selected" unless @selected_variants;
my @mmap_variants = (
"Locate mmap_space in .text.wamr_mmap",
"Let the linker decide where mmap_space is located"
);
my @selected_mmap_variants =
TUI::select_from_list( "Select WAMR Mmap.Text Variant", 1, @mmap_variants );
die "No variant selected" unless @selected_mmap_variants;
# Select XIP variant
my @xip_variants = ( "Compile AOT with --xip", "Compile AOT without --xip" );
@ -57,15 +71,23 @@ my @selected_xip_variants =
TUI::select_from_list( "Select WAMRC XIP Variant", 1, @xip_variants );
die "No XIP variant selected" unless @selected_xip_variants;
# Select FAIL catch flags (written to runner_flags in each build dir, not a build loop)
my %catch_flag_map = (
"--catch-outer" => "--catch-outerspace",
"--catch-text" => "--catch-write-textsegment",
);
my @selected_catch_tags =
TUI::select_from_list( "Select FAIL Flags", 1, sort keys %catch_flag_map );
# Select 0.info contents
my $info = join " ", TUI::select_from_list( "Select '0.info' Contents for ", 1, (
"baseline",
"--catch-outer",
"--catch-text",
"wamr_aot",
# "wamr_mmap",
# "--xip",
));
my $info = join " ", TUI::select_from_list(
"Select '0.info' Contents for ",
1,
(
# mmap, xip, wamr_aot, --catch-outer, --catch-text are auto-included from variant selections
"baseline",
)
);
# Build everything
# TODO: linux-baremetal target is broken
@ -73,29 +95,93 @@ system( "mkdir", "-p", "$local_builds_dir" );
foreach my $experiment (@selected_experiments) {
foreach my $target (@selected_targets) {
foreach my $mode (@selected_modes) {
foreach my $variant (@selected_variants) {
foreach my $mmap_variant (@selected_mmap_variants) {
foreach my $xip_variant (@selected_xip_variants) {
# These variables control which libiwasm and wamrc flags are used
local $ENV{WAMR_USE_MMAP} = ( $variant eq "Locate mmap_space in .text.wamr_mmap" ) ? "true" : "false";
local $ENV{WAMR_USE_XIP} = ( $xip_variant eq "Compile AOT with --xip" ) ? "true" : "false";
foreach my $aot_variant (@selected_aot_variants) {
my $date = strftime("%m-%d_%H-%M-%S", localtime);
just( "build", $experiment, $target, $mode );
# Skip redundant combinations where variants don't apply to this mode
# "c" uses no WAMR at all
# "interp" uses mmap but no AOT
next
if $mode eq "c"
&& ( $mmap_variant ne $mmap_variants[0]
|| $xip_variant ne $xip_variants[0]
|| $aot_variant ne $aot_section_variants[0] );
next
if $mode eq "interp"
&& ( $xip_variant ne $xip_variants[0]
|| $aot_variant ne $aot_section_variants[0] );
my $mmap = $variant eq "Locate mmap_space in .text.wamr_mmap" ? "mmap" : "";
my $xip = $xip_variant eq "Compile AOT with --xip" ? "xip" : "";
system( "echo '$mode $mmap $info $xip' > $local_root/build-$experiment/0.info" );
# These variables control which libiwasm, wamrc flags, and build options are used
local $ENV{WAMR_USE_MMAP} =
( $mmap_variant eq
"Locate mmap_space in .text.wamr_mmap" )
? "true"
: "false";
local $ENV{WAMR_USE_XIP} =
( $xip_variant eq "Compile AOT with --xip" )
? "true"
: "false";
local $ENV{WAMR_USE_AOT_SECTION} =
( $aot_variant eq
"Place AOT array in .text.wamr_aot" )
? "true"
: "false";
my $mmap_name = $mmap eq "mmap" ? "_mmap" : "";
my $xip_name = $xip eq "xip" ? "_xip" : "";
system(
join " ",
(
"mv",
"$local_root/build-$experiment",
"$local_builds_dir/${date}_${experiment}_${target}_${mode}${mmap_name}${xip_name}",
)
);
my $aot_info =
( $mode eq "aot"
&& $aot_variant eq
"Place AOT array in .text.wamr_aot" )
? "wamr_aot"
: "";
my $mmap_info =
( ( $mode eq "aot" || $mode eq "interp" )
&& $mmap_variant eq
"Locate mmap_space in .text.wamr_mmap" )
? "wamr_mmap"
: "";
my $xip_info =
( $mode eq "aot"
&& $xip_variant eq "Compile AOT with --xip" )
? "xip"
: "";
my $flags_info = join " ", @selected_catch_tags;
my $info_str = join " ",
grep { length } (
$mode, $aot_info, $mmap_info,
$xip_info, $flags_info, $info
);
# Build experiment
my $date = strftime( "%m-%d_%H-%M-%S", localtime );
just( "build", $experiment, $target, $mode );
# Write extra info for the menu
system(
"echo '$info_str' > $local_root/build-$experiment/0.info"
);
# Write runner_flags so runner.pl knows which FAIL flags to use
my $runner_flags_path =
"$local_root/build-$experiment/runner_flags";
open( my $rfh, '>', $runner_flags_path )
or die "Cannot write $runner_flags_path: $!";
print $rfh "$catch_flag_map{$_}\n"
for @selected_catch_tags;
close($rfh);
my $aot_name = $aot_info ? "_aot-text" : "";
my $mmap_name = $mmap_info ? "_mmap-text" : "";
my $xip_name = $xip_info ? "_xip" : "";
system(
join " ",
(
"mv",
"$local_root/build-$experiment",
"$local_builds_dir/${date}_${experiment}_${mode}_${target}${aot_name}${mmap_name}${xip_name}",
)
);
}
}
}
}

View File

@ -206,6 +206,15 @@ sub inject {
);
say "Server command: $server_command";
# Read catch flags written by build.pl into the experiment directory
my $runner_flags_file = "$remote_builds_dir/$experiment/runner_flags";
my @catch_flags = ();
if ( -e $runner_flags_file ) {
open( my $rfh, '<', $runner_flags_file ) or die "Cannot open $runner_flags_file: $!";
@catch_flags = map { chomp; "-Wf,$_" } grep { /\S/ } <$rfh>;
close($rfh);
}
my $client_command = join " ", (
"nice $bochs_runner",
"-V $fail_share/vgabios.bin",
@ -220,12 +229,7 @@ sub inject {
"-Wf,--state-dir=$remote_builds_dir/$experiment/state",
"-Wf,--trap",
# Catch invalid instruction pointers
"-Wf,--catch-outerspace",
# Messes with Wasm compilation targets if mmap memory is part of .text
# (because the linear memory is allocated using os_mmap)
"-Wf,--catch-write-textsegment",
@catch_flags,
"-Wf,--timeout=500000",
"-Wf,--ok-marker=fail_marker_positive",