2016-12-09 22:09:17 +00:00
|
|
|
proc binary_name_ld_lib_so { } { return "ld-hw.lib.so" }
|
2017-04-05 08:18:35 +00:00
|
|
|
proc binary_name_core_o { } { return "core-hw.o" }
|
2016-12-10 22:22:13 +00:00
|
|
|
proc binary_name_timer { } { return "hw_timer_drv" }
|
2016-12-09 22:09:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
proc run_boot_string { } { return "\nkernel initialized" }
|
2012-05-30 18:13:09 +00:00
|
|
|
|
2016-11-07 17:00:24 +00:00
|
|
|
proc bootstrap_link_address { } {
|
2019-01-14 14:39:46 +00:00
|
|
|
if {[have_spec "odroid_xu"]} { return "0x88000000" }
|
|
|
|
if {[have_spec "pbxa9"]} { return "0x70000000" }
|
|
|
|
if {[have_spec "usb_armory"]} { return "0x72000000" }
|
|
|
|
if {[have_spec "x86_64"]} { return "0x00200000" }
|
|
|
|
if {[have_spec "wand_quad"]} { return "0x10001000" }
|
|
|
|
if {[have_spec "imx6q_sabrelite"]} { return "0x10001000" }
|
|
|
|
if {[have_spec "imx53_qsb"]} { return "0x70010000" }
|
2019-03-22 13:23:07 +00:00
|
|
|
if {[have_spec "imx7d_sabre"]} { return "0x88000000" }
|
2019-07-11 11:00:32 +00:00
|
|
|
if {[have_spec "imx8q_evk"]} { return "0x40010000" }
|
2019-01-14 14:39:46 +00:00
|
|
|
if {[have_spec "arndale"]} { return "0x88000000" }
|
|
|
|
if {[have_spec "panda"]} { return "0x88000000" }
|
|
|
|
if {[have_spec "zynq"]} { return "0x00100000" }
|
|
|
|
if {[have_spec "riscv"]} { return "0x81000000" }
|
|
|
|
if {[have_spec "rpi"]} { return "0x00800000" }
|
2019-05-21 14:27:37 +00:00
|
|
|
if {[have_spec "rpi3"]} { return "0x00800000" }
|
2017-10-19 08:39:11 +00:00
|
|
|
if {[have_spec "nit6_solox"]} { return "0x88000000" }
|
2016-09-15 14:08:33 +00:00
|
|
|
|
|
|
|
puts "unknown platform no linker address known"
|
|
|
|
exit -1
|
2015-02-06 17:02:55 +00:00
|
|
|
}
|
|
|
|
|
2016-11-07 17:00:24 +00:00
|
|
|
proc core_link_address { } {
|
2017-06-20 13:25:04 +00:00
|
|
|
if {[have_spec "64bit"]} { return "0xffffffc000000000" }
|
|
|
|
if {[have_spec "32bit"]} { return "0x80000000" }
|
|
|
|
return 0;
|
2016-11-07 17:00:24 +00:00
|
|
|
}
|
|
|
|
|
2015-02-06 17:02:55 +00:00
|
|
|
|
2015-01-08 21:08:48 +00:00
|
|
|
##
|
|
|
|
# Populate boot directory with binaries on hw
|
|
|
|
#
|
2015-03-20 11:30:18 +00:00
|
|
|
proc run_boot_dir {binaries} {
|
|
|
|
|
2016-01-29 16:15:35 +00:00
|
|
|
# generate static ACPI report for platform driver on Muen
|
2017-01-17 16:15:25 +00:00
|
|
|
if {[have_spec "muen"]} {
|
2016-01-29 16:15:35 +00:00
|
|
|
set fh [open "bin/acpi" "WRONLY CREAT TRUNC"]
|
2018-05-08 14:00:11 +00:00
|
|
|
puts $fh "<acpi><bdf start=\"0\" count=\"16384\" base=\"0xf8000000\"/><drhd/></acpi>"
|
2016-01-29 16:15:35 +00:00
|
|
|
close $fh
|
|
|
|
}
|
|
|
|
|
2017-04-03 13:39:36 +00:00
|
|
|
#
|
|
|
|
# Build bootstrap, the core object, and the dynamic linker on demand
|
|
|
|
#
|
|
|
|
# If those parts were imported from the depot, the build step is skipped.
|
|
|
|
#
|
|
|
|
set bootstrap_arg ""
|
|
|
|
set core_arg ""
|
|
|
|
set ld_arg ""
|
|
|
|
|
|
|
|
if {![file exists [run_dir]/genode/ld.lib.so]} { set ld_arg lib/ld/hw }
|
|
|
|
if {![file exists [run_dir]/genode/core-hw.o]} { set core_arg core/hw }
|
|
|
|
if {![file exists [run_dir]/genode/bootstrap-hw.o]} { set bootstrap_arg bootstrap/hw }
|
|
|
|
|
|
|
|
set build_args "$bootstrap_arg $core_arg $ld_arg"
|
|
|
|
if {[llength $build_args]} { build $build_args }
|
|
|
|
|
|
|
|
if {$ld_arg != ""} { file copy -force bin/ld-hw.lib.so [run_dir]/genode/ld.lib.so }
|
2019-05-09 12:04:03 +00:00
|
|
|
if {$core_arg != ""} { file copy -force bin/core-hw-[board].o [run_dir]/genode/core-hw.o }
|
|
|
|
if {$bootstrap_arg != ""} { file copy -force bin/bootstrap-hw-[board].o [run_dir]/genode/bootstrap-hw.o }
|
2017-04-03 13:39:36 +00:00
|
|
|
|
|
|
|
#
|
|
|
|
# Copy specified modules to the run directory, excluding core.
|
|
|
|
#
|
2016-11-07 17:00:24 +00:00
|
|
|
set idx [lsearch $binaries "core"]
|
|
|
|
set modules [lreplace $binaries $idx $idx]
|
2017-04-03 13:39:36 +00:00
|
|
|
copy_genode_binaries_to_run_dir $modules
|
2016-11-07 17:00:24 +00:00
|
|
|
|
|
|
|
puts "core link address is [core_link_address]"
|
|
|
|
|
2017-04-03 13:39:36 +00:00
|
|
|
set core_obj core-hw.o
|
|
|
|
set bootstrap_obj bootstrap-hw.o
|
2016-11-07 17:00:24 +00:00
|
|
|
|
|
|
|
# create core and bootstrap binary without modules for debugging
|
2019-05-09 12:04:03 +00:00
|
|
|
if {[file exists debug/core-hw-[board].o]} {
|
|
|
|
build_core debug/core-hw-[board].o {} [run_dir].core [core_link_address]
|
2018-03-02 08:50:35 +00:00
|
|
|
build_core [run_dir]/genode/$bootstrap_obj {} [run_dir].bootstrap [bootstrap_link_address]
|
|
|
|
}
|
2017-04-03 13:39:36 +00:00
|
|
|
|
|
|
|
# determine modules to be incorporated into the core image
|
|
|
|
set modules [glob -tails -directory [run_dir]/genode/ *]
|
|
|
|
set excluded_modules {}
|
|
|
|
lappend excluded_modules $core_obj $bootstrap_obj
|
|
|
|
foreach excluded $excluded_modules {
|
|
|
|
set modules [lsearch -inline -not -all $modules $excluded] }
|
|
|
|
|
|
|
|
# check syntax of all boot modules named *.config
|
|
|
|
foreach file [glob -nocomplain [run_dir]/genode/*.config] {
|
|
|
|
check_xml_syntax $file }
|
2016-12-09 22:09:17 +00:00
|
|
|
|
2016-11-07 17:00:24 +00:00
|
|
|
# create core binary containing the boot modules
|
2017-04-03 13:39:36 +00:00
|
|
|
build_core [run_dir]/genode/$core_obj $modules [run_dir]/genode/core.elf [core_link_address]
|
2016-11-07 17:00:24 +00:00
|
|
|
exec [cross_dev_prefix]strip [run_dir]/genode/core.elf
|
2017-04-03 13:39:36 +00:00
|
|
|
build_core [run_dir]/genode/$bootstrap_obj { core.elf } [run_dir]/image.elf [bootstrap_link_address]
|
2019-02-27 13:17:03 +00:00
|
|
|
|
|
|
|
# Save config part of the image.elf for easy inspection
|
|
|
|
exec cp -f [run_dir]/genode/config [run_dir].config
|
|
|
|
|
2018-05-16 09:03:59 +00:00
|
|
|
remove_genode_dir
|
2016-11-07 17:00:24 +00:00
|
|
|
exec [cross_dev_prefix]strip [run_dir]/image.elf
|
2015-02-06 16:27:44 +00:00
|
|
|
|
2018-05-02 16:26:59 +00:00
|
|
|
exec mkdir -p [run_dir]/boot
|
|
|
|
exec mv [run_dir]/image.elf [run_dir]/boot/image.elf
|
|
|
|
|
2017-09-20 20:56:00 +00:00
|
|
|
if {[have_include "image/iso"] || [have_include "image/disk"] || [have_include image/uefi]} {
|
2017-11-18 14:22:22 +00:00
|
|
|
#
|
|
|
|
# Compress Genode image, to be uncompressed by GRUB
|
|
|
|
#
|
2018-05-02 16:26:59 +00:00
|
|
|
exec gzip [run_dir]/boot/image.elf
|
2017-11-18 14:22:22 +00:00
|
|
|
|
|
|
|
set serial_bender_opt ""
|
2015-02-06 16:27:44 +00:00
|
|
|
|
2017-09-20 20:56:00 +00:00
|
|
|
if {[have_include "image/disk"]} {
|
|
|
|
exec mkdir -p [run_dir]/boot/grub
|
|
|
|
exec cp [genode_dir]/tool/boot/bender [run_dir]/boot/bender
|
|
|
|
}
|
|
|
|
|
|
|
|
if {[have_include "image/iso"]} {
|
|
|
|
install_iso_bootloader_to_run_dir
|
2015-08-21 16:12:42 +00:00
|
|
|
}
|
2013-02-04 15:27:54 +00:00
|
|
|
|
2017-09-20 20:56:00 +00:00
|
|
|
if {[have_include image/uefi]} {
|
|
|
|
set grub2_path [get_grub2_dir]
|
|
|
|
|
|
|
|
exec mkdir -p [run_dir]/efi/boot
|
|
|
|
exec cp $grub2_path/boot/grub2/grub2_32.efi [run_dir]/efi/boot/bootia32.efi
|
|
|
|
exec cp $grub2_path/boot/grub2/grub2_64.efi [run_dir]/efi/boot/bootx64.efi
|
|
|
|
exec mkdir -p [run_dir]/boot/grub
|
|
|
|
exec cp [genode_dir]/tool/boot/bender [run_dir]/boot/bender
|
2017-11-18 14:22:22 +00:00
|
|
|
|
|
|
|
set serial_bender_opt "serial_fallback"
|
2017-09-20 20:56:00 +00:00
|
|
|
}
|
2017-02-02 13:25:06 +00:00
|
|
|
|
|
|
|
#
|
|
|
|
# Generate GRUB2 config file
|
|
|
|
#
|
|
|
|
set fh [open "[run_dir]/boot/grub/grub.cfg" "WRONLY CREAT TRUNC"]
|
|
|
|
puts $fh "set timeout=0"
|
2017-11-18 14:53:02 +00:00
|
|
|
# tell grub2 to prefer 32bit framebuffer resolution
|
|
|
|
puts $fh "set gfxpayload=\"0x0x32\""
|
2017-02-02 13:25:06 +00:00
|
|
|
puts $fh "menuentry 'Genode on base-hw' {"
|
2017-11-18 14:22:22 +00:00
|
|
|
puts $fh " insmod multiboot2"
|
|
|
|
puts $fh " multiboot2 /boot/bender $serial_bender_opt"
|
2018-05-02 16:26:59 +00:00
|
|
|
puts $fh " module2 /boot/image.elf.gz image.elf"
|
2017-02-02 13:25:06 +00:00
|
|
|
puts $fh "}"
|
|
|
|
close $fh
|
|
|
|
}
|
|
|
|
|
2018-05-02 16:26:59 +00:00
|
|
|
run_image [run_dir]/boot/image.elf
|
2013-05-07 10:18:56 +00:00
|
|
|
|
|
|
|
# set symbolic link to image.elf file in TFTP directory for PXE boot
|
2019-05-21 14:27:37 +00:00
|
|
|
if {[expr [have_spec arm] || [have_spec arm_64]] && [have_include "load/tftp"]} {
|
2018-05-02 16:26:59 +00:00
|
|
|
exec ln -sf [run_dir]/boot/image.elf [load_tftp_base_dir][load_tftp_offset_dir]
|
2013-05-07 10:18:56 +00:00
|
|
|
|
2015-01-08 21:08:48 +00:00
|
|
|
if {[have_include "image/uboot"]} {
|
|
|
|
exec ln -sf [pwd]/[run_dir]/uImage [load_tftp_base_dir][load_tftp_offset_dir]
|
2013-05-07 10:18:56 +00:00
|
|
|
}
|
2013-02-04 15:27:54 +00:00
|
|
|
}
|
2013-05-07 10:18:56 +00:00
|
|
|
|
2017-03-27 10:45:07 +00:00
|
|
|
if {[have_spec x86] && [have_include "load/tftp"]} {
|
2015-06-01 13:17:54 +00:00
|
|
|
#
|
|
|
|
# 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"]
|
2017-03-27 10:45:07 +00:00
|
|
|
if {[have_spec "muen"]} {
|
|
|
|
exec gzip [run_dir]/image.bin
|
|
|
|
puts $fh " exec /boot/unzip"
|
|
|
|
puts $fh " load /image.bin.gz"
|
|
|
|
} else {
|
|
|
|
puts $fh " exec /boot/bender"
|
2018-05-02 16:26:59 +00:00
|
|
|
puts $fh " load /boot/image.elf"
|
2017-03-27 10:45:07 +00:00
|
|
|
}
|
2015-06-01 13:17:54 +00:00
|
|
|
close $fh
|
|
|
|
|
|
|
|
generate_tftp_config
|
|
|
|
}
|
|
|
|
|
2015-12-18 12:09:39 +00:00
|
|
|
if {[have_spec x86] && [have_include "load/ipxe"]} {
|
|
|
|
#
|
|
|
|
# Generate iPXE config file
|
|
|
|
#
|
|
|
|
set fh [open "[run_dir]/boot.cfg" "WRONLY CREAT TRUNC"]
|
|
|
|
puts $fh "#!ipxe"
|
|
|
|
|
|
|
|
if {[have_spec "muen"]} {
|
|
|
|
puts $fh "kernel image.bin"
|
|
|
|
} else {
|
2017-03-27 10:45:07 +00:00
|
|
|
install_pxe_bootloader_to_run_dir
|
2015-12-18 12:09:39 +00:00
|
|
|
puts $fh "kernel boot/bender"
|
2018-05-02 16:26:59 +00:00
|
|
|
puts $fh "module boot/image.elf"
|
2015-12-18 12:09:39 +00:00
|
|
|
}
|
|
|
|
puts $fh "boot"
|
|
|
|
close $fh
|
|
|
|
|
|
|
|
update_ipxe_boot_dir
|
|
|
|
}
|
2012-05-30 18:13:09 +00:00
|
|
|
}
|
2017-03-29 14:04:07 +00:00
|
|
|
|
|
|
|
|
|
|
|
##
|
|
|
|
# Base source archive within depot
|
|
|
|
#
|
|
|
|
proc base_src { } {
|
|
|
|
|
2018-11-05 11:53:12 +00:00
|
|
|
if {[have_spec x86_64] && ![have_spec muen]} { return base-hw-pc }
|
2018-12-04 17:37:47 +00:00
|
|
|
if {[have_spec x86_64] && [have_spec muen]} { return base-hw-muen }
|
2018-11-05 11:53:12 +00:00
|
|
|
if {[have_spec pbxa9]} { return base-hw-pbxa9 }
|
|
|
|
if {[have_spec rpi]} { return base-hw-rpi }
|
2019-06-11 12:57:58 +00:00
|
|
|
if {[have_spec rpi3]} { return base-hw-rpi3 }
|
2019-01-14 14:39:46 +00:00
|
|
|
if {[have_spec imx6q_sabrelite]} { return base-hw-imx6q_sabrelite }
|
2019-04-16 08:17:43 +00:00
|
|
|
if {[have_spec imx7d_sabre]} { return base-hw-imx7d_sabre }
|
2019-07-01 18:08:41 +00:00
|
|
|
if {[have_spec imx8q_evk]} { return base-hw-imx8q_evk }
|
2017-10-19 08:39:11 +00:00
|
|
|
if {[have_spec nit6_solox]} { return base-hw-nit6_solox }
|
2018-11-05 11:53:12 +00:00
|
|
|
if {[have_spec odroid_xu]} { return base-hw-odroid_xu }
|
|
|
|
if {[have_spec imx53_qsb] && ![have_spec trustzone]} { return base-hw-imx53_qsb }
|
|
|
|
if {[have_spec imx53_qsb] && [have_spec trustzone]} { return base-hw-imx53_qsb_tz }
|
|
|
|
if {[have_spec arndale]} { return base-hw-arndale }
|
|
|
|
if {[have_spec panda]} { return base-hw-panda }
|
2018-11-30 09:54:38 +00:00
|
|
|
if {[have_spec zynq_qemu]} { return base-hw-zynq_qemu }
|
2017-03-29 14:04:07 +00:00
|
|
|
|
2018-04-16 11:33:20 +00:00
|
|
|
global specs
|
|
|
|
|
|
|
|
puts stderr "Test requires base-hw kernel archive, which is missing for this build configuration"
|
|
|
|
puts stderr " SPECS=\"$specs\""
|
|
|
|
exit 0
|
2017-03-29 14:04:07 +00:00
|
|
|
}
|