mirror of
https://github.com/genodelabs/genode.git
synced 2025-01-02 03:56:42 +00:00
Update ping tests
On real hardware, the tests expect an IPv4 subnet such that UDP requests to 10.0.0.2 port 12345 get answered with an ICMP destination port unreachable. Issue #2775 support USB NIC Issue #2788 Set DHCP discover timeout to 1 second because, for some reason, the first DHCP discover attempt of the NIC router on the PandaBoard times out with the nightly test infrastructure. Issue #2788 Adaption to mac-address allocation changes
This commit is contained in:
parent
2d229a2b72
commit
505d30cc42
@ -2,19 +2,32 @@
|
|||||||
# Build
|
# Build
|
||||||
#
|
#
|
||||||
|
|
||||||
if {![have_include power_on/qemu]} {
|
set on_hardware [expr ![have_include power_on/qemu]]
|
||||||
puts "Run script is only supported on Qemu"
|
|
||||||
exit 0
|
|
||||||
}
|
|
||||||
|
|
||||||
set build_components {
|
set build_components {
|
||||||
core
|
core
|
||||||
init
|
init
|
||||||
drivers/timer
|
drivers/timer
|
||||||
drivers/nic
|
drivers/nic
|
||||||
|
server/nic_bridge
|
||||||
app/ping
|
app/ping
|
||||||
}
|
}
|
||||||
|
|
||||||
|
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 }
|
||||||
|
|
||||||
|
|
||||||
|
lappend_if [have_spec gpio] build_components drivers/gpio
|
||||||
|
|
||||||
|
proc dst_ip { } {
|
||||||
|
if {![have_include power_on/qemu]} {
|
||||||
|
return "10.0.0.2"
|
||||||
|
} else {
|
||||||
|
return "10.0.2.2"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
source ${genode_dir}/repos/base/run/platform_drv.inc
|
source ${genode_dir}/repos/base/run/platform_drv.inc
|
||||||
append_platform_drv_build_components
|
append_platform_drv_build_components
|
||||||
|
|
||||||
@ -45,24 +58,65 @@ append config {
|
|||||||
|
|
||||||
append_platform_drv_config
|
append_platform_drv_config
|
||||||
|
|
||||||
|
append_if [have_spec gpio] config "
|
||||||
|
<start name=\"[gpio_drv]\">
|
||||||
|
<resource name=\"RAM\" quantum=\"4M\"/>
|
||||||
|
<provides><service name=\"Gpio\"/></provides>
|
||||||
|
<config/>
|
||||||
|
</start>"
|
||||||
|
|
||||||
append config {
|
append config {
|
||||||
<start name="timer">
|
<start name="timer">
|
||||||
<resource name="RAM" quantum="1M"/>
|
<resource name="RAM" quantum="1M"/>
|
||||||
<provides><service name="Timer"/></provides>
|
<provides><service name="Timer"/></provides>
|
||||||
</start>
|
</start>
|
||||||
|
|
||||||
<start name="nic_drv">
|
<start name="nic_drv">
|
||||||
<binary name="} [nic_drv_binary] {"/>
|
<binary name="} [nic_drv_binary] {"/>
|
||||||
<resource name="RAM" quantum="4M"/>
|
<resource name="RAM" quantum="20M"/>
|
||||||
<provides><service name="Nic"/></provides>
|
<provides><service name="Nic"/></provides>
|
||||||
|
} [nic_drv_config] {
|
||||||
</start>
|
</start>
|
||||||
<start name="ping">
|
|
||||||
|
<start name="nic_bridge" caps="200">
|
||||||
|
<resource name="RAM" quantum="10M"/>
|
||||||
|
<provides><service name="Nic"/></provides>
|
||||||
|
<config>
|
||||||
|
<policy label_prefix="ping_1"/>
|
||||||
|
<policy label_prefix="ping_2"/>
|
||||||
|
</config>
|
||||||
|
<route>
|
||||||
|
<service name="Nic"> <child name="nic_drv"/> </service>
|
||||||
|
<any-service> <parent/> <any-child/> </any-service>
|
||||||
|
</route>
|
||||||
|
</start>}
|
||||||
|
|
||||||
|
append_if $on_hardware config {
|
||||||
|
<start name="ping_2">
|
||||||
|
<binary name="ping"/>
|
||||||
<resource name="RAM" quantum="8M"/>
|
<resource name="RAM" quantum="8M"/>
|
||||||
<config dst_ip="10.0.2.2"
|
<config period_sec="1"
|
||||||
|
verbose="no"
|
||||||
|
count="1"
|
||||||
|
protocol="udp"
|
||||||
|
dst_ip="} [dst_ip] {"
|
||||||
|
dst_port="12345"/>
|
||||||
|
<route>
|
||||||
|
<service name="Nic"> <child name="nic_bridge"/> </service>
|
||||||
|
<any-service> <parent/> <any-child/> </any-service>
|
||||||
|
</route>
|
||||||
|
</start>}
|
||||||
|
|
||||||
|
append config {
|
||||||
|
<start name="ping_1">
|
||||||
|
<binary name="ping"/>
|
||||||
|
<resource name="RAM" quantum="8M"/>
|
||||||
|
<config dst_ip="} [dst_ip] {"
|
||||||
period_sec="1"
|
period_sec="1"
|
||||||
verbose="no"
|
verbose="no"
|
||||||
count="3"/>
|
count="3"/>
|
||||||
<route>
|
<route>
|
||||||
<service name="Nic"> <child name="nic_drv"/> </service>
|
<service name="Nic"> <child name="nic_bridge"/> </service>
|
||||||
<any-service> <parent/> <any-child/> </any-service>
|
<any-service> <parent/> <any-child/> </any-service>
|
||||||
</route>
|
</route>
|
||||||
</start>
|
</start>
|
||||||
@ -81,10 +135,12 @@ append boot_modules {
|
|||||||
} [nic_drv_binary] {
|
} [nic_drv_binary] {
|
||||||
ping
|
ping
|
||||||
ld.lib.so
|
ld.lib.so
|
||||||
|
nic_bridge
|
||||||
}
|
}
|
||||||
|
|
||||||
# platform-specific modules
|
# platform-specific modules
|
||||||
lappend_if [have_spec linux] boot_modules fb_sdl
|
lappend_if [have_spec linux] boot_modules fb_sdl
|
||||||
|
lappend_if [have_spec gpio] boot_modules [gpio_drv]
|
||||||
|
|
||||||
append_platform_drv_boot_modules
|
append_platform_drv_boot_modules
|
||||||
|
|
||||||
@ -95,4 +151,8 @@ append_if [have_spec lan9118] qemu_args " -net nic,model=lan9118 "
|
|||||||
|
|
||||||
append qemu_args " -net user -nographic "
|
append qemu_args " -net user -nographic "
|
||||||
|
|
||||||
run_genode_until ".*\"ping\" exited with exit value 0.*\n" 25
|
set done_string ".*\"ping_1\" exited with exit value 0.*\n"
|
||||||
|
|
||||||
|
append_if $on_hardware done_string ".*ping_2\] From [dst_ip] Destination Unreachable.*\n"
|
||||||
|
|
||||||
|
run_genode_until $done_string 30
|
||||||
|
@ -2,10 +2,7 @@
|
|||||||
# Build
|
# Build
|
||||||
#
|
#
|
||||||
|
|
||||||
if {![have_include power_on/qemu]} {
|
set on_hardware [expr ![have_include power_on/qemu]]
|
||||||
puts "Run script is only supported on Qemu"
|
|
||||||
exit 0
|
|
||||||
}
|
|
||||||
|
|
||||||
set build_components {
|
set build_components {
|
||||||
core
|
core
|
||||||
@ -16,6 +13,24 @@ set build_components {
|
|||||||
app/ping
|
app/ping
|
||||||
}
|
}
|
||||||
|
|
||||||
|
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 }
|
||||||
|
|
||||||
|
|
||||||
|
lappend_if [have_spec gpio] build_components drivers/gpio
|
||||||
|
|
||||||
|
proc good_dst_ip { } {
|
||||||
|
if {![have_include power_on/qemu]} {
|
||||||
|
return "10.0.0.2"
|
||||||
|
} else {
|
||||||
|
return "10.0.2.2"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
proc bad_dst_port { } { return "12345" }
|
||||||
|
proc bad_dst_ip { } { return "10.0.1.2" }
|
||||||
|
|
||||||
|
|
||||||
source ${genode_dir}/repos/base/run/platform_drv.inc
|
source ${genode_dir}/repos/base/run/platform_drv.inc
|
||||||
append_platform_drv_build_components
|
append_platform_drv_build_components
|
||||||
|
|
||||||
@ -46,6 +61,13 @@ append config {
|
|||||||
|
|
||||||
append_platform_drv_config
|
append_platform_drv_config
|
||||||
|
|
||||||
|
append_if [have_spec gpio] config "
|
||||||
|
<start name=\"[gpio_drv]\">
|
||||||
|
<resource name=\"RAM\" quantum=\"4M\"/>
|
||||||
|
<provides><service name=\"Gpio\"/></provides>
|
||||||
|
<config/>
|
||||||
|
</start>"
|
||||||
|
|
||||||
append config {
|
append config {
|
||||||
<start name="timer">
|
<start name="timer">
|
||||||
<resource name="RAM" quantum="1M"/>
|
<resource name="RAM" quantum="1M"/>
|
||||||
@ -54,8 +76,9 @@ append config {
|
|||||||
|
|
||||||
<start name="nic_drv">
|
<start name="nic_drv">
|
||||||
<binary name="} [nic_drv_binary] {"/>
|
<binary name="} [nic_drv_binary] {"/>
|
||||||
<resource name="RAM" quantum="4M"/>
|
<resource name="RAM" quantum="20M"/>
|
||||||
<provides><service name="Nic"/></provides>
|
<provides><service name="Nic"/></provides>
|
||||||
|
} [nic_drv_config] {
|
||||||
</start>
|
</start>
|
||||||
|
|
||||||
<start name="nic_router" caps="200">
|
<start name="nic_router" caps="200">
|
||||||
@ -63,23 +86,26 @@ append config {
|
|||||||
<provides><service name="Nic"/></provides>
|
<provides><service name="Nic"/></provides>
|
||||||
<config verbose="no"
|
<config verbose="no"
|
||||||
verbose_packets="no"
|
verbose_packets="no"
|
||||||
icmp_idle_timeout_sec="6"
|
dhcp_discover_timeout_sec="1"
|
||||||
mac_first="2:2:2:2:2:0">
|
icmp_idle_timeout_sec="6">
|
||||||
|
|
||||||
<policy label_prefix="ping_1" domain="ping_1"/>
|
<policy label_prefix="ping_1" domain="ping_1"/>
|
||||||
<policy label_prefix="ping_2" domain="ping_2"/>
|
<policy label_prefix="ping_2" domain="ping_2"/>
|
||||||
|
|
||||||
<domain name="uplink" interface="10.0.2.55/24">
|
<domain name="uplink">
|
||||||
<ip dst="10.0.4.0/24" domain="ping_2"/>
|
<nat domain="ping_1" icmp-ids="100"/>
|
||||||
<nat domain="ping_1" icmp-ids="5"/>
|
<nat domain="ping_2" icmp-ids="100" udp-ports="100"/>
|
||||||
</domain>
|
</domain>
|
||||||
|
|
||||||
<domain name="ping_2" interface="10.0.4.1/24">
|
<domain name="ping_2" interface="10.0.4.1/24">
|
||||||
<ip dst="10.0.2.0/24" domain="uplink"/>
|
<icmp dst="} [good_dst_ip] {/24" domain="uplink"/>
|
||||||
|
<udp dst="} [good_dst_ip] {/24">
|
||||||
|
<permit port="} [bad_dst_port] {" domain="uplink"/>
|
||||||
|
</udp>
|
||||||
</domain>
|
</domain>
|
||||||
|
|
||||||
<domain name="ping_1" interface="10.0.3.1/24">
|
<domain name="ping_1" interface="10.0.3.1/24">
|
||||||
<icmp dst="10.0.2.0/24" domain="uplink"/>
|
<icmp dst="} [good_dst_ip] {/24" domain="uplink"/>
|
||||||
</domain>
|
</domain>
|
||||||
|
|
||||||
</config>
|
</config>
|
||||||
@ -95,18 +121,23 @@ append config {
|
|||||||
<provides><service name="Nic"/></provides>
|
<provides><service name="Nic"/></provides>
|
||||||
<config verbose="no"
|
<config verbose="no"
|
||||||
verbose_packets="no"
|
verbose_packets="no"
|
||||||
icmp_idle_timeout_sec="10"
|
icmp_idle_timeout_sec="10">
|
||||||
mac_first="12:12:12:12:12:0">
|
|
||||||
|
|
||||||
<policy label_prefix="ping_2" domain="ping_2"/>
|
<policy label_prefix="ping_2" domain="ping_2"/>
|
||||||
|
|
||||||
<domain name="uplink" interface="10.0.4.2/24" gateway="10.0.4.1">
|
<domain name="uplink" interface="10.0.4.2/24" gateway="10.0.4.1">
|
||||||
<nat domain="ping_2" icmp-ids="5"/>
|
<nat domain="ping_2" icmp-ids="100" udp-ports="100"/>
|
||||||
</domain>
|
</domain>
|
||||||
|
|
||||||
<domain name="ping_2" interface="10.0.5.1/24">
|
<domain name="ping_2" interface="10.0.5.1/24">
|
||||||
<icmp dst="10.0.1.0/24" domain="uplink"/>
|
<dhcp-server ip_first="10.0.5.100"
|
||||||
<icmp dst="10.0.2.0/24" domain="uplink"/>
|
ip_last="10.0.5.200"/>
|
||||||
|
|
||||||
|
<icmp dst="} [bad_dst_ip] {/24" domain="uplink"/>
|
||||||
|
<icmp dst="} [good_dst_ip] {/24" domain="uplink"/>
|
||||||
|
<udp dst="} [good_dst_ip] {/24">
|
||||||
|
<permit port="} [bad_dst_port] {" domain="uplink"/>
|
||||||
|
</udp>
|
||||||
</domain>
|
</domain>
|
||||||
|
|
||||||
</config>
|
</config>
|
||||||
@ -121,7 +152,7 @@ append config {
|
|||||||
<resource name="RAM" quantum="8M"/>
|
<resource name="RAM" quantum="8M"/>
|
||||||
<config interface="10.0.3.2/24"
|
<config interface="10.0.3.2/24"
|
||||||
gateway="10.0.3.1"
|
gateway="10.0.3.1"
|
||||||
dst_ip="10.0.2.2"
|
dst_ip="} [good_dst_ip] {"
|
||||||
period_sec="1"
|
period_sec="1"
|
||||||
verbose="no"/>
|
verbose="no"/>
|
||||||
<route>
|
<route>
|
||||||
@ -135,7 +166,7 @@ append config {
|
|||||||
<resource name="RAM" quantum="8M"/>
|
<resource name="RAM" quantum="8M"/>
|
||||||
<config interface="10.0.3.3/24"
|
<config interface="10.0.3.3/24"
|
||||||
gateway="10.0.3.1"
|
gateway="10.0.3.1"
|
||||||
dst_ip="10.0.2.2"
|
dst_ip="} [good_dst_ip] {"
|
||||||
period_sec="1"
|
period_sec="1"
|
||||||
verbose="no"/>
|
verbose="no"/>
|
||||||
<route>
|
<route>
|
||||||
@ -149,7 +180,7 @@ append config {
|
|||||||
<resource name="RAM" quantum="8M"/>
|
<resource name="RAM" quantum="8M"/>
|
||||||
<config interface="10.0.5.2/24"
|
<config interface="10.0.5.2/24"
|
||||||
gateway="10.0.5.1"
|
gateway="10.0.5.1"
|
||||||
dst_ip="10.0.2.2"
|
dst_ip="} [good_dst_ip] {"
|
||||||
period_sec="1"
|
period_sec="1"
|
||||||
verbose="no"/>
|
verbose="no"/>
|
||||||
<route>
|
<route>
|
||||||
@ -163,14 +194,32 @@ append config {
|
|||||||
<resource name="RAM" quantum="8M"/>
|
<resource name="RAM" quantum="8M"/>
|
||||||
<config interface="10.0.5.3/24"
|
<config interface="10.0.5.3/24"
|
||||||
gateway="10.0.5.1"
|
gateway="10.0.5.1"
|
||||||
dst_ip="10.0.1.2"
|
dst_ip="} [bad_dst_ip] {"
|
||||||
period_sec="1"
|
period_sec="1"
|
||||||
verbose="no"/>
|
verbose="no"/>
|
||||||
<route>
|
<route>
|
||||||
<service name="Nic"> <child name="ping_2_nic_router"/> </service>
|
<service name="Nic"> <child name="ping_2_nic_router"/> </service>
|
||||||
<any-service> <parent/> <any-child/> </any-service>
|
<any-service> <parent/> <any-child/> </any-service>
|
||||||
</route>
|
</route>
|
||||||
</start>
|
</start>}
|
||||||
|
|
||||||
|
append_if $on_hardware config {
|
||||||
|
<start name="ping_23">
|
||||||
|
<binary name="ping"/>
|
||||||
|
<resource name="RAM" quantum="8M"/>
|
||||||
|
<config period_sec="1"
|
||||||
|
verbose="no"
|
||||||
|
count="1"
|
||||||
|
protocol="udp"
|
||||||
|
dst_ip="} [good_dst_ip] {"
|
||||||
|
dst_port="} [bad_dst_port] {"/>
|
||||||
|
<route>
|
||||||
|
<service name="Nic"> <child name="ping_2_nic_router"/> </service>
|
||||||
|
<any-service> <parent/> <any-child/> </any-service>
|
||||||
|
</route>
|
||||||
|
</start>}
|
||||||
|
|
||||||
|
append config {
|
||||||
</config>}
|
</config>}
|
||||||
|
|
||||||
install_config $config
|
install_config $config
|
||||||
@ -191,6 +240,7 @@ append boot_modules {
|
|||||||
|
|
||||||
# platform-specific modules
|
# platform-specific modules
|
||||||
lappend_if [have_spec linux] boot_modules fb_sdl
|
lappend_if [have_spec linux] boot_modules fb_sdl
|
||||||
|
lappend_if [have_spec gpio] boot_modules [gpio_drv]
|
||||||
|
|
||||||
append_platform_drv_boot_modules
|
append_platform_drv_boot_modules
|
||||||
|
|
||||||
@ -205,6 +255,8 @@ set done_string ""
|
|||||||
for {set i 0} {$i < 3} {incr i 1} {
|
for {set i 0} {$i < 3} {incr i 1} {
|
||||||
append done_string ".*child \"ping...\" exited with exit value 0.*\n"
|
append done_string ".*child \"ping...\" exited with exit value 0.*\n"
|
||||||
}
|
}
|
||||||
append done_string ".*From 10.0.4.1 icmp_seq=.* Destination Unreachable.*\n"
|
append done_string ".*ping_22\] From 10.0.4.1 icmp_seq=.* Destination Unreachable.*\n"
|
||||||
|
|
||||||
run_genode_until $done_string 25
|
append_if $on_hardware done_string ".*ping_23\] From [good_dst_ip] Destination Unreachable.*\n"
|
||||||
|
|
||||||
|
run_genode_until $done_string 20
|
||||||
|
Loading…
Reference in New Issue
Block a user