mirror of
https://github.com/genodelabs/genode.git
synced 2025-01-17 10:19:48 +00:00
84ee970e9b
When running the same kernel in a VM as on the host system and the kernel boot message from the VM appears on the log output, the run tool assumes that the host machine has rebooted unexpectedly. With this commit, an unexpected reboot is assumed only if the kernel boot message appears at the beginning of a line. On base-hw, we enforce a line feed at the beginning of the boot message as the SPIKE emulator log starts with the first message of the kernel lacking a line feed. Fixes #2041
262 lines
6.4 KiB
Plaintext
262 lines
6.4 KiB
Plaintext
#
|
|
# \brief Fiasco.OC-specific test-environment supplements
|
|
# \author Stefan Kalkowski
|
|
# \date 2010-11-22
|
|
#
|
|
# This file is meant to be used as '--include' argument for 'tool/run'.
|
|
#
|
|
|
|
##
|
|
# Return the location of the Fiasco.OC user directory
|
|
#
|
|
proc l4_dir { } {
|
|
global _l4_dir
|
|
|
|
if {![info exists _l4_dir]} {
|
|
if {[file exists etc/foc.conf]} {
|
|
set _l4_dir [exec sed -n "/^L4_BUILD_DIR/s/^.*=\\s*//p" etc/foc.conf]
|
|
if {[file exists $_l4_dir]} { return $_l4_dir }
|
|
}
|
|
|
|
set _l4_dir "[pwd]/l4"
|
|
if {![file exists $_l4_dir]} {
|
|
puts -nonewline stderr "Error: Could neither find the L4 build directory "
|
|
puts -nonewline stderr "within '<genode-build-dir>/l4' nor at a location "
|
|
puts -nonewline stderr "specified via 'L4_BUILD_DIR = <l4re-build-dir>' "
|
|
puts stderr "in <genode-build-dir>/etc/foc.conf'."
|
|
exit 1
|
|
}
|
|
}
|
|
return $_l4_dir
|
|
}
|
|
|
|
##
|
|
# Return whether the l4-buid-directory is provided from the outside
|
|
#
|
|
proc l4_dir_external { } {
|
|
if {[l4_dir] == "[pwd]/l4"} { return 0 }
|
|
return 1
|
|
}
|
|
|
|
##
|
|
# Return the location of the Fiasco.OC kernel directory
|
|
#
|
|
proc fiasco { } {
|
|
global _fiasco
|
|
|
|
if {![info exists _fiasco]} {
|
|
if {[file exists etc/foc.conf]} {
|
|
set _fiasco [exec sed -n "/^KERNEL/s/^.*=\\s*//p" etc/foc.conf]
|
|
if {[file exists $_fiasco]} { return $_fiasco }
|
|
}
|
|
|
|
# try to fall back to version hosted with the Genode build directory
|
|
set _fiasco "[pwd]/kernel/fiasco.oc/fiasco"
|
|
}
|
|
return $_fiasco
|
|
}
|
|
|
|
##
|
|
# Return whether fiasco kernel is provided from the outside
|
|
#
|
|
proc fiasco_external { } {
|
|
if {[fiasco] == "[pwd]/kernel/fiasco.oc/fiasco"} { return 0 }
|
|
return 1
|
|
}
|
|
|
|
##
|
|
# Reset the target system via the Fiasco.OC kernel debugger
|
|
#
|
|
proc reset_target { {spawn_id_arg -1} } {
|
|
global spawn_id
|
|
if { $spawn_id_arg == -1 } {
|
|
set spawn_id_arg $spawn_id
|
|
}
|
|
send -i $spawn_id_arg "\033^^"
|
|
}
|
|
|
|
|
|
proc copy_and_strip_binaries {binaries} {
|
|
|
|
#
|
|
# Collect contents of the boot image
|
|
#
|
|
foreach binary $binaries {
|
|
exec cp bin/$binary [run_dir]/genode
|
|
catch {
|
|
exec [cross_dev_prefix]strip [run_dir]/genode/$binary }
|
|
}
|
|
}
|
|
|
|
|
|
proc bin_dir { } {
|
|
if {[have_spec x86_32]} { return "[l4_dir]/bin/x86_586" }
|
|
if {[have_spec x86_64]} { return "[l4_dir]/bin/amd64_K8" }
|
|
if {[have_spec arm_v7a]} { return "[l4_dir]/bin/arm_armv7a" }
|
|
if {[have_spec arm_v6]} { return "[l4_dir]/bin/arm_armv6" }
|
|
|
|
puts stderr "Error: Cannot determine bin directory"
|
|
exit 1
|
|
}
|
|
|
|
set fiasco_serial_esc_arg "-serial_esc "
|
|
|
|
proc run_boot_dir_x86 {binaries} {
|
|
|
|
global fiasco_serial_esc_arg
|
|
|
|
exec mkdir -p [run_dir]/fiasco
|
|
|
|
copy_and_strip_binaries $binaries
|
|
|
|
set foc_targets { }
|
|
if {![fiasco_external] && ![file exists kernel]} { lappend foc_targets kernel }
|
|
if {![l4_dir_external]} {
|
|
if {![file exists bootstrap]} { lappend foc_targets bootstrap }
|
|
if {![file exists sigma0]} { lappend foc_targets sigma0 }
|
|
}
|
|
if {[llength $foc_targets] > 0} { build $foc_targets }
|
|
|
|
# assert existence of the L4 build directory
|
|
l4_dir
|
|
|
|
puts "using fiasco kernel [fiasco]"
|
|
exec cp [fiasco] [run_dir]/fiasco
|
|
puts "using sigma0/bootstrap at [l4_dir]"
|
|
exec cp [bin_dir]/l4f/sigma0 [run_dir]/fiasco
|
|
exec cp [bin_dir]/bootstrap [run_dir]/fiasco
|
|
|
|
if {[have_include "image/iso"] || [have_include "image/disk"]} {
|
|
#
|
|
# Install isolinux/GRUB files and bender
|
|
#
|
|
install_iso_bootloader_to_run_dir
|
|
|
|
#
|
|
# Generate grub config file
|
|
#
|
|
# The core binary is part of the 'binaries' list but it must
|
|
# appear right after 'sigma0' as boot module. Hence the special case.
|
|
#
|
|
set fh [open "[run_dir]/boot/grub/menu.lst" "WRONLY CREAT TRUNC"]
|
|
puts $fh "timeout 0"
|
|
puts $fh "default 0"
|
|
puts $fh "\ntitle Genode on Fiasco.OC"
|
|
puts $fh " kernel /boot/bender"
|
|
puts $fh " module /fiasco/bootstrap"
|
|
puts $fh " module /fiasco/fiasco $fiasco_serial_esc_arg"
|
|
puts $fh " module /fiasco/sigma0"
|
|
puts $fh " module /genode/core"
|
|
puts $fh " module /genode/config"
|
|
foreach binary $binaries {
|
|
if {$binary != "core"} {
|
|
puts $fh " module /genode/$binary" } }
|
|
puts $fh " vbeset 0x117 506070"
|
|
close $fh
|
|
}
|
|
|
|
#
|
|
# Build image
|
|
#
|
|
run_image
|
|
|
|
if {[have_include "load/tftp"]} {
|
|
#
|
|
# Install PXE bootloader pulsar
|
|
#
|
|
install_pxe_bootloader_to_run_dir
|
|
|
|
#
|
|
# Generate pulsar config file
|
|
#
|
|
set fh [open "[run_dir]/config-52-54-00-12-34-56" "WRONLY CREAT TRUNC"]
|
|
puts $fh " exec /boot/bender"
|
|
puts $fh " load /fiasco/bootstrap"
|
|
puts $fh " load /fiasco/fiasco -serial_esc"
|
|
puts $fh " load /fiasco/sigma0"
|
|
puts $fh " load /genode/core"
|
|
puts $fh " load /genode/config"
|
|
foreach binary $binaries {
|
|
if {$binary != "core"} {
|
|
puts $fh " load /genode/$binary" } }
|
|
close $fh
|
|
|
|
generate_tftp_config
|
|
}
|
|
|
|
if {[have_include "load/ipxe"]} {
|
|
create_ipxe_iso_config
|
|
update_ipxe_boot_dir
|
|
create_symlink_for_iso
|
|
}
|
|
}
|
|
|
|
|
|
proc run_boot_dir_arm {binaries} {
|
|
|
|
global run_target
|
|
global fiasco_serial_esc_arg
|
|
|
|
copy_and_strip_binaries $binaries
|
|
|
|
build "kernel sigma0 bootstrap"
|
|
|
|
#
|
|
# Generate bootstrap config
|
|
#
|
|
set fh [open "[run_dir]/modules.list" "WRONLY CREAT TRUNC"]
|
|
|
|
puts $fh "modaddr 0x01100000\n"
|
|
puts $fh "entry genode"
|
|
puts $fh "kernel [fiasco] $fiasco_serial_esc_arg"
|
|
puts $fh "roottask genode/core"
|
|
puts $fh "module genode/config"
|
|
foreach binary $binaries {
|
|
if {$binary != "core"} {
|
|
puts $fh "module genode/$binary" } }
|
|
close $fh
|
|
|
|
|
|
set gen_img_cmd "make -C [l4_dir]/source O=[l4_dir] E=genode "
|
|
append gen_img_cmd "MODULES_LIST=[pwd]/[run_dir]/modules.list "
|
|
append gen_img_cmd "MODULE_SEARCH_PATH=[pwd]/[run_dir]:[file dirname [fiasco]]:[l4_dir] "
|
|
append gen_img_cmd "SYSTEM_TARGET=[cross_dev_prefix] elfimage"
|
|
|
|
set pid [eval "spawn sh -c \"$gen_img_cmd\""]
|
|
expect { eof { } }
|
|
if {[lindex [wait $pid] end] != 0} {
|
|
puts stderr "Error: Single-image creation failed"
|
|
exit -4
|
|
}
|
|
|
|
exec cp [bin_dir]/bootstrap.elf [run_dir]/image.elf
|
|
run_image [run_dir]/image.elf
|
|
|
|
puts "\nboot image: [run_dir]/image.elf\n"
|
|
|
|
# set symbolic link to image.elf file in TFTP directory for PXE boot
|
|
if {[have_include "load/tftp"]} {
|
|
set tftp_base_dir [load_tftp_base_dir]
|
|
set tftp_offset_dir [load_tftp_offset_dir]
|
|
|
|
exec ln -sf [pwd]/[run_dir]/image.elf $tftp_base_dir$tftp_offset_dir
|
|
if {[have_include "image/uboot"]} {
|
|
exec ln -sf [pwd]/[run_dir]/uImage $tftp_base_dir$tftp_offset_dir/uImage
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
proc run_boot_string { } {
|
|
return "\nL4 Bootstrapper"
|
|
}
|
|
|
|
|
|
##
|
|
# Populate boot directory with binaries on fiasco.OC
|
|
#
|
|
proc run_boot_dir {binaries} {
|
|
if {[have_spec x86]} { return [run_boot_dir_x86 $binaries] }
|
|
if {[have_spec arm]} { return [run_boot_dir_arm $binaries] }
|
|
}
|