2013-01-24 15:36:10 +00:00
|
|
|
#
|
|
|
|
# \brief Test ping
|
|
|
|
# \author Josef Soentgen
|
|
|
|
# \date 2013-01-06
|
|
|
|
#
|
|
|
|
|
|
|
|
#
|
|
|
|
# Build
|
|
|
|
#
|
|
|
|
|
2017-01-03 12:17:41 +00:00
|
|
|
if {[have_spec odroid_xu]} {
|
2015-02-24 13:53:15 +00:00
|
|
|
puts "Run script does not support this platform."
|
|
|
|
exit 0
|
|
|
|
}
|
|
|
|
|
2013-01-24 15:36:10 +00:00
|
|
|
set build_components {
|
|
|
|
core init
|
2015-06-08 07:05:32 +00:00
|
|
|
drivers/timer drivers/nic
|
2013-01-24 15:36:10 +00:00
|
|
|
test/lwip/pingpong/client
|
|
|
|
}
|
|
|
|
|
2015-09-03 12:55:05 +00:00
|
|
|
lappend_if [expr [have_spec omap4] || [have_spec arndale]] build_components drivers/usb
|
2013-11-13 13:10:49 +00:00
|
|
|
lappend_if [have_spec gpio] build_components drivers/gpio
|
2013-01-24 15:36:10 +00:00
|
|
|
|
2017-02-08 12:28:11 +00:00
|
|
|
proc gpio_drv { } { if {[have_spec rpi] && [have_spec hw]} { return hw_gpio_drv }
|
|
|
|
if {[have_spec rpi] && [have_spec foc]} { return foc_gpio_drv }
|
|
|
|
return gpio_drv }
|
|
|
|
|
2015-06-08 07:05:32 +00:00
|
|
|
source ${genode_dir}/repos/base/run/platform_drv.inc
|
|
|
|
append_platform_drv_build_components
|
|
|
|
|
2013-01-24 15:36:10 +00:00
|
|
|
build $build_components
|
|
|
|
|
|
|
|
create_boot_directory
|
|
|
|
|
|
|
|
#
|
|
|
|
# Generate config
|
|
|
|
#
|
|
|
|
|
|
|
|
set config {
|
|
|
|
<config verbose="yes">
|
|
|
|
<parent-provides>
|
|
|
|
<service name="ROM"/>
|
|
|
|
<service name="IRQ"/>
|
|
|
|
<service name="IO_MEM"/>
|
|
|
|
<service name="IO_PORT"/>
|
|
|
|
<service name="PD"/>
|
|
|
|
<service name="RM"/>
|
|
|
|
<service name="CPU"/>
|
|
|
|
<service name="LOG"/>
|
|
|
|
</parent-provides>
|
|
|
|
<default-route>
|
|
|
|
<any-service> <parent/> <any-child/> </any-service>
|
|
|
|
</default-route>
|
|
|
|
<start name="timer">
|
|
|
|
<resource name="RAM" quantum="1M"/>
|
|
|
|
<provides> <service name="Timer"/> </provides>
|
|
|
|
</start> }
|
|
|
|
|
2017-02-08 12:28:11 +00:00
|
|
|
append_if [have_spec gpio] config "
|
|
|
|
<start name=\"[gpio_drv]\">
|
|
|
|
<resource name=\"RAM\" quantum=\"4M\"/>
|
|
|
|
<provides><service name=\"Gpio\"/></provides>
|
2013-11-13 13:10:49 +00:00
|
|
|
<config/>
|
2017-02-08 12:28:11 +00:00
|
|
|
</start>"
|
2013-11-13 13:10:49 +00:00
|
|
|
|
2015-09-03 12:55:05 +00:00
|
|
|
append_if [expr [have_spec omap4] || [have_spec arndale]] config {
|
2013-01-24 15:36:10 +00:00
|
|
|
<start name="usb_drv" priority="-1">
|
|
|
|
<resource name="RAM" quantum="12M"/>
|
|
|
|
<provides>
|
|
|
|
<service name="Nic"/>
|
|
|
|
</provides>
|
2013-05-22 09:38:16 +00:00
|
|
|
<config ehci="yes">
|
2014-04-22 09:50:56 +00:00
|
|
|
<nic mac="02:00:00:00:01:01" />
|
2013-01-24 15:36:10 +00:00
|
|
|
</config>
|
|
|
|
</start>}
|
|
|
|
|
2015-09-03 12:55:05 +00:00
|
|
|
append_if [expr ![have_spec omap4] && ![have_spec arndale]] config {
|
2013-01-24 15:36:10 +00:00
|
|
|
<start name="nic_drv">
|
|
|
|
<resource name="RAM" quantum="4M"/>
|
|
|
|
<provides><service name="Nic"/></provides>
|
|
|
|
</start>}
|
|
|
|
|
2015-06-08 07:05:32 +00:00
|
|
|
append_platform_drv_config
|
2013-01-24 15:36:10 +00:00
|
|
|
|
2013-04-08 18:51:28 +00:00
|
|
|
# establish serial connection with the server system
|
|
|
|
spawn picocom -b 115200 /dev/ttyUSB0
|
|
|
|
set server_spawn_id $spawn_id
|
|
|
|
set timeout -1
|
|
|
|
expect -i $server_spawn_id "Terminal ready"
|
|
|
|
|
|
|
|
# get IP address from server
|
|
|
|
expect {
|
|
|
|
-i $server_spawn_id
|
|
|
|
-re "got IP address (.*)\033.*\n" { set ip_addr $expect_out(1,string) }
|
|
|
|
}
|
|
|
|
puts "got server IP address: $ip_addr"
|
|
|
|
|
|
|
|
append config {
|
|
|
|
<start name="test-ping_client_libc_lwip">
|
|
|
|
<resource name="RAM" quantum="16M"/>
|
|
|
|
<config>
|
|
|
|
<arg value="test-ping_client"/>
|
|
|
|
<arg value="-verbose"/>
|
|
|
|
<arg value="0"/>
|
|
|
|
<arg value="-startsize"/>
|
|
|
|
<arg value="1024"/>
|
|
|
|
<arg value="-endsize"/>
|
|
|
|
<arg value="1024"/>
|
2014-04-14 09:57:22 +00:00
|
|
|
<arg value="-serverip"/>}
|
2013-04-08 18:51:28 +00:00
|
|
|
append config "
|
2014-04-14 09:57:22 +00:00
|
|
|
<arg value=\"$ip_addr\"/>"
|
|
|
|
append config {
|
|
|
|
<argv verbose="0" listenip="0.0.0.0" />
|
2017-03-20 11:04:55 +00:00
|
|
|
<vfs> <dir name="dev"> <log/> </dir> </vfs>
|
|
|
|
<libc stdout="/dev/log" stderr="/dev/log"/>
|
2013-04-08 18:51:28 +00:00
|
|
|
</config>
|
2014-04-14 09:57:22 +00:00
|
|
|
</start>}
|
2013-04-08 18:51:28 +00:00
|
|
|
|
2013-01-24 15:36:10 +00:00
|
|
|
append config {
|
|
|
|
</config>
|
|
|
|
}
|
|
|
|
|
|
|
|
install_config $config
|
|
|
|
|
|
|
|
#
|
|
|
|
# Boot modules
|
|
|
|
#
|
|
|
|
|
|
|
|
# generic modules
|
|
|
|
set boot_modules {
|
|
|
|
core init timer
|
2017-05-14 19:55:57 +00:00
|
|
|
ld.lib.so libc.lib.so lwip.lib.so posix.lib.so
|
2013-04-08 18:51:28 +00:00
|
|
|
test-ping_client_libc_lwip
|
2013-01-24 15:36:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
# platform-specific modules
|
2015-09-03 12:55:05 +00:00
|
|
|
lappend_if [expr [have_spec omap4] || [have_spec arndale]] boot_modules usb_drv
|
|
|
|
lappend_if [expr ![have_spec omap4] && ![have_spec arndale]] boot_modules nic_drv
|
2017-02-08 12:28:11 +00:00
|
|
|
lappend_if [have_spec gpio] boot_modules [gpio_drv]
|
2013-01-24 15:36:10 +00:00
|
|
|
|
2015-06-08 07:05:32 +00:00
|
|
|
append_platform_drv_boot_modules
|
|
|
|
|
2013-01-24 15:36:10 +00:00
|
|
|
build_boot_image $boot_modules
|
|
|
|
|
|
|
|
#
|
|
|
|
# Execute test case
|
|
|
|
#
|
|
|
|
|
|
|
|
# qemu config
|
2017-05-23 13:05:55 +00:00
|
|
|
append qemu_args " -nographic "
|
2013-01-24 15:36:10 +00:00
|
|
|
|
|
|
|
append_if [have_spec x86] qemu_args " -net nic,model=e1000 "
|
|
|
|
append_if [have_spec lan9118] qemu_args " -net nic,model=lan9118 "
|
|
|
|
|
|
|
|
append qemu_args " -net user "
|
|
|
|
|
2013-04-08 18:51:28 +00:00
|
|
|
expect -i $server_spawn_id "wait..."
|
|
|
|
|
|
|
|
run_genode_until {Sucessfully connected to server.} 60
|
|
|
|
|
|
|
|
expect -i $server_spawn_id "client 3 connected..."
|
|
|
|
|
|
|
|
set time_start [clock milliseconds]
|
|
|
|
|
|
|
|
set timeout -1
|
|
|
|
expect {
|
|
|
|
-i $server_spawn_id
|
|
|
|
-re "received .*\n" { }
|
|
|
|
}
|
|
|
|
|
|
|
|
set time_end [clock milliseconds]
|
|
|
|
|
|
|
|
puts "\nTest succeeded in [expr $time_end - $time_start] milliseconds."
|
2013-01-24 15:36:10 +00:00
|
|
|
|
|
|
|
# vi: set ft=tcl :
|