2021-02-18 09:04:39 +01:00
|
|
|
if {[get_cmd_switch --autopilot]} {
|
2018-10-30 14:40:20 +01:00
|
|
|
if {[have_include "power_on/qemu"]} {
|
|
|
|
puts "\nRun script does not support Qemu.\n"
|
|
|
|
exit 0
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-02-18 09:04:39 +01:00
|
|
|
if {[have_board linux]} {
|
2020-06-19 16:41:20 +02:00
|
|
|
puts "\n Run script is not supported on this platform. \n";
|
|
|
|
exit 0
|
|
|
|
}
|
|
|
|
|
2019-06-11 18:23:30 +02:00
|
|
|
build "core init timer test/cpu_bench"
|
2018-10-30 14:40:20 +01:00
|
|
|
|
|
|
|
create_boot_directory
|
|
|
|
|
|
|
|
install_config {
|
2020-06-19 16:41:20 +02:00
|
|
|
<config>
|
|
|
|
<parent-provides>
|
|
|
|
<service name="LOG"/>
|
|
|
|
<service name="CPU"/>
|
|
|
|
<service name="ROM"/>
|
|
|
|
<service name="PD"/>
|
|
|
|
</parent-provides>
|
|
|
|
<default-route>
|
|
|
|
<any-service> <parent/> </any-service>
|
|
|
|
</default-route>
|
|
|
|
<default caps="100"/>
|
|
|
|
<start name="cpu_bench">
|
|
|
|
<resource name="RAM" quantum="10M"/>
|
|
|
|
</start>
|
|
|
|
</config>
|
2018-10-30 14:40:20 +01:00
|
|
|
}
|
|
|
|
|
2020-06-19 16:41:20 +02:00
|
|
|
build_boot_image { core init cpu_bench ld.lib.so }
|
2018-10-30 14:40:20 +01:00
|
|
|
|
|
|
|
append qemu_args " -nographic "
|
|
|
|
|
2020-06-19 16:41:20 +02:00
|
|
|
#
|
|
|
|
# Those value relate to hardware used in CI testsuite used at Genode Labs,
|
|
|
|
# as well as the initialization of their bootloaders, we use this to measure
|
|
|
|
# regressions in the platform initialization code
|
|
|
|
#
|
|
|
|
proc bogomips_max_time { } {
|
2021-01-07 19:15:55 +01:00
|
|
|
if {[have_board rpi]} { return 14300 }
|
|
|
|
if {[have_board imx53_qsb]} { return 7520 }
|
|
|
|
if {[have_board imx53_qsb_tz]} { return 7520 }
|
|
|
|
if {[have_board imx6q_sabrelite]} { return 6320 }
|
|
|
|
if {[have_board imx7d_sabre]} { return 9470 }
|
|
|
|
if {[have_board imx8q_evk]} { return 7510 }
|
|
|
|
if {[have_board pc]} {
|
|
|
|
if {[have_spec x86_64]} { return 600 }
|
|
|
|
if {[have_spec x86_32]} { return 3150 }
|
2020-07-08 13:36:15 +02:00
|
|
|
}
|
2020-06-19 16:41:20 +02:00
|
|
|
return 0
|
2018-10-30 14:40:20 +01:00
|
|
|
}
|
|
|
|
|
2020-06-19 16:41:20 +02:00
|
|
|
# run the test
|
|
|
|
run_genode_until {\[init -\> cpu_bench\] Execute 10G BogoMIPS.*\n} 120
|
2018-10-30 14:40:20 +01:00
|
|
|
set serial_id [output_spawn_id]
|
2020-06-19 16:41:20 +02:00
|
|
|
set t1 [clock milliseconds]
|
|
|
|
run_genode_until "Finished execution.*\n" 30 $serial_id
|
|
|
|
set t2 [clock milliseconds]
|
|
|
|
set result [expr {$t2 - $t1}]
|
|
|
|
set bogomips [expr {10000000000 / $result}]
|
|
|
|
set maximum [bogomips_max_time]
|
|
|
|
puts "10G bogus instructions in $result msecs ($bogomips BogoMIPS)"
|
|
|
|
if {$result > $maximum} {
|
|
|
|
puts "Test failed: bogomips loop lasted longer than $maximum msecs"
|
|
|
|
exit 1
|
|
|
|
}
|