mirror of
https://github.com/genodelabs/genode.git
synced 2025-01-17 18:29:55 +00:00
0ab5310b8a
Kernel tests are done by replacing the implementation of an otherwise empty function 'Kernel::test' that gets called once at the primary CPU as soon as all kernel initialization is done. To achieve this, the test binary that implements 'Kernel::test' must be linked against the core lib and must then replace the core binary when composing the boot image. The latter can be done conveniently in a run script by setting the new argument 'core_type' of the function 'build_boot_image' to the falue 'test'. If no kernel test is needed the argument does not have to be given - it is set to 'core' by default which results in a "normal" Genode image. ref #1225
223 lines
5.6 KiB
Plaintext
223 lines
5.6 KiB
Plaintext
#!/usr/bin/expect
|
|
|
|
#
|
|
# \brief Implementation of the 'tool/run' interface
|
|
# \author Martin Stein
|
|
# \date 2011-12-16
|
|
#
|
|
|
|
|
|
###############
|
|
## Utilities ##
|
|
###############
|
|
|
|
#
|
|
# Ensure that the next Genode build includes no target specific boot modules
|
|
#
|
|
proc clean_boot_modules { } {
|
|
exec rm -rf boot_modules.s var/libcache/boot_modules/boot_modules.o }
|
|
|
|
|
|
##########################
|
|
## 'tool/run' interface ##
|
|
##########################
|
|
|
|
proc build {targets} {
|
|
|
|
# skip targets that shall not be build
|
|
if {[get_cmd_switch --skip-build]} return
|
|
|
|
# handle false remnants of previous builds
|
|
clean_boot_modules
|
|
|
|
#
|
|
# Build all remaining targets.
|
|
# Core is build with a dummy boot-modules file first.
|
|
#
|
|
regsub -all {\s\s+} $targets " " targets
|
|
set timeout 10000
|
|
set pid [eval "spawn make $targets"]
|
|
expect { eof { } }
|
|
if {[lindex [wait $pid] end] != 0} {
|
|
puts stderr "Error: Genode build failed"
|
|
exit -1
|
|
}
|
|
}
|
|
|
|
|
|
proc create_boot_directory { } {
|
|
|
|
exec rm -rf [run_dir]
|
|
exec mkdir -p [run_dir]/genode
|
|
}
|
|
|
|
|
|
proc build_boot_image {binaries {core_type core}} {
|
|
if {$core_type == "test"} {
|
|
set core_bin "test-[run_name]"
|
|
set core_target "test/[run_name]"
|
|
} elseif {$core_type == "core"} {
|
|
set core_bin "core"
|
|
set core_target "core"
|
|
} else {
|
|
puts stderr "Error: Unknown core type '$core_type'"
|
|
exit -1
|
|
}
|
|
|
|
global run_target
|
|
|
|
# strip binaries
|
|
copy_and_strip_genode_binaries_to_run_dir $binaries
|
|
|
|
# append init config
|
|
if {[file exists "[run_dir]/genode/config"] == 1} {
|
|
append binaries " config"
|
|
}
|
|
|
|
#
|
|
# Compose a platform specific assembly file 'boot_modules.s', that
|
|
# enables the creation of a single boot image. The file rawly includes
|
|
# all binaries given in 'binaries', minus 'core', if given, plus 'config',
|
|
# if available. It also provides a simple file system, that enables Genode
|
|
# to access these BLOBs. To build a single image this file is simply
|
|
# linked against core. To build core stand-alone this file is substituted
|
|
# by a dummy version. 'boot_modules.s' must be composed on demand, because
|
|
# it depends on the individual run scenario.
|
|
#
|
|
set boot_modules "[run_dir]/boot_modules.s"
|
|
|
|
# introduce boot module headers
|
|
exec echo -e \
|
|
"/**" \
|
|
"\n * This file was automatically generated by the procedure" \
|
|
"\n * 'build_boot_image' in 'base-hw/run/env'." \
|
|
"\n */" \
|
|
"\n" \
|
|
"\n /* core includes */" \
|
|
"\n.include \"macros.s\"" \
|
|
"\n" \
|
|
"\n.section .data" \
|
|
"\n" \
|
|
"\n.p2align DATA_ACCESS_ALIGNM_LOG2" \
|
|
"\n.global _boot_modules_headers_begin" \
|
|
"\n_boot_modules_headers_begin:" > $boot_modules
|
|
|
|
# generate header for each boot module except core
|
|
set i 1
|
|
foreach binary $binaries {
|
|
if {$binary == $core_bin} { continue }
|
|
exec echo -e \
|
|
"\n.long _boot_module_${i}_name" \
|
|
"\n.long _boot_module_${i}_begin" \
|
|
"\n.long _boot_module_${i}_end - _boot_module_${i}_begin" \
|
|
>> $boot_modules
|
|
incr i
|
|
}
|
|
|
|
# end boot module headers
|
|
exec echo -e \
|
|
"\n.global _boot_modules_headers_end" \
|
|
"\n_boot_modules_headers_end:" >> $boot_modules
|
|
|
|
# generate name string for each module except core
|
|
set i 1
|
|
foreach binary $binaries {
|
|
if {$binary == $core_bin} { continue }
|
|
exec echo -e \
|
|
"\n.p2align DATA_ACCESS_ALIGNM_LOG2" \
|
|
"\n_boot_module_${i}_name:" \
|
|
"\n.string \"${binary}\"" \
|
|
"\n.byte 0" >> $boot_modules
|
|
incr i
|
|
}
|
|
|
|
exec echo -e \
|
|
"\n.section .data.boot_modules_binaries" \
|
|
"\n" \
|
|
"\n.global _boot_modules_binaries_begin" \
|
|
"\n_boot_modules_binaries_begin:" >> $boot_modules
|
|
|
|
# include raw data of modules consecutively but page aligned
|
|
set i 1
|
|
foreach binary $binaries {
|
|
if {$binary == $core_bin} { continue }
|
|
exec echo -e \
|
|
"\n.p2align MIN_PAGE_SIZE_LOG2" \
|
|
"\n_boot_module_${i}_begin:" \
|
|
"\n.incbin \"[run_dir]/genode/${binary}\"" \
|
|
"\n_boot_module_${i}_end:" >> $boot_modules
|
|
incr i
|
|
}
|
|
|
|
# finish boot modules file
|
|
exec echo -e \
|
|
"\n.global _boot_modules_binaries_end" \
|
|
"\n_boot_modules_binaries_end:" >> $boot_modules
|
|
|
|
clean_boot_modules
|
|
exec ln -s $boot_modules boot_modules.s
|
|
|
|
# recompile core with boot modules
|
|
exec cp -L bin/$core_bin $core_target/$core_bin.standalone
|
|
exec find . -type f -name $core_bin -delete
|
|
set timeout 10000
|
|
set pid [eval "spawn make $core_target"]
|
|
expect { eof { } }
|
|
if {[lindex [wait $pid] end] != 0} {
|
|
clean_boot_modules
|
|
puts stderr "Error: Genode build failed"
|
|
exit -1
|
|
}
|
|
clean_boot_modules
|
|
exec rm -rf "[run_dir]/genode"
|
|
|
|
# offer ELF image
|
|
set elf_img "[run_dir]/image.elf"
|
|
exec cp -L bin/$core_bin $elf_img
|
|
exec [cross_dev_prefix]strip $elf_img
|
|
|
|
build_uboot_image $elf_img
|
|
|
|
# set symbolic link to image.elf file in TFTP directory for PXE boot
|
|
if {[info exists ::env(PXE_TFTP_DIR_BASE)] &&
|
|
[info exists ::env(PXE_TFTP_DIR_OFFSET)]} {
|
|
exec ln -sf "[pwd]/$elf_img" "$::env(PXE_TFTP_DIR_BASE)$::env(PXE_TFTP_DIR_OFFSET)"
|
|
|
|
if {[regexp "uboot" $run_target]} {
|
|
exec ln -sf "[pwd]/[run_dir]/uImage" "$::env(PXE_TFTP_DIR_BASE)$::env(PXE_TFTP_DIR_OFFSET)"
|
|
}
|
|
}
|
|
|
|
# retrieve stand-alone core
|
|
exec cp $core_target/$core_bin.standalone bin/$core_bin
|
|
exec rm $core_target/$core_bin.standalone
|
|
}
|
|
|
|
|
|
proc run_genode_until {{wait_for_re forever} {timeout_value 0} {running_spawn_id -1}} {
|
|
#
|
|
# If a running_spawn_id is specified, wait for the expected output
|
|
#
|
|
if {$running_spawn_id != -1} {
|
|
wait_for_output $wait_for_re $timeout_value $running_spawn_id
|
|
return
|
|
}
|
|
|
|
#
|
|
# Try to use one of the supported backends for running the scripts
|
|
#
|
|
if {[is_qemu_available]} {
|
|
spawn_qemu $wait_for_re $timeout_value
|
|
return
|
|
}
|
|
if {[is_serial_available]} {
|
|
spawn_serial $wait_for_re $timeout_value "kernel initialized"
|
|
return
|
|
}
|
|
|
|
global run_target
|
|
puts stderr "Error: Can't execute automatically on target '$run_target'"
|
|
exit -1
|
|
}
|
|
|