mirror of
https://github.com/genodelabs/genode.git
synced 2025-01-09 22:43:01 +00:00
5a1cef6381
This patch unconditionally applies the labeling of sessions and thereby removes the most common use case of 'Child_policy::filter_session_args'. Furthermore, the patch removes an ambiguity of the session labels of sessions created by the parent of behalf of its child, e.g., the PD session created as part of 'Child' now has the label "<child-name>" whereas an unlabeled PD-session request originating from the child has the label "<child-name> -> ". This way, the routing-policy of 'Child_policy::resolve_session_request' can differentiate both cases. As a consequence, the stricter labeling must now be considered wherever a precise label was specified as a key for a session route or a server- side policy selection. The simplest way to adapt those cases is to use a 'label_prefix' instead of the 'label' attribute. Alternatively, the 'label' attribute may used by appending " -> " (note the whitespace). Fixes #2171
268 lines
5.8 KiB
Tcl
268 lines
5.8 KiB
Tcl
#
|
|
# \brief Test using netperf with l4linux
|
|
# \author Sebastian Sumpf
|
|
# \date 2013-07-08
|
|
#
|
|
|
|
assert_spec foc
|
|
assert_spec 32bit
|
|
|
|
assert_spec foc_arndale
|
|
|
|
set ip [check_installed ip]
|
|
set wget [check_installed wget]
|
|
set md5 [check_installed md5sum]
|
|
|
|
|
|
if {$use_nic_bridge == 1} {
|
|
set route_nic "nic_bridge"
|
|
} else {
|
|
set route_nic "usb_drv"
|
|
}
|
|
|
|
set version "2.4.4"
|
|
|
|
# sanity check that the right version is used
|
|
set wrong_version [catch {
|
|
spawn netperf-$version -V
|
|
expect {
|
|
"Netperf version $version" { }
|
|
eof { return }
|
|
timeout { return }
|
|
}
|
|
spawn netserver-$version -V
|
|
expect {
|
|
"Netperf version $version" { }
|
|
eof { return }
|
|
timeout { return }
|
|
}
|
|
}]
|
|
|
|
if {$wrong_version} {
|
|
puts -nonewline "\nPlease compile a netperf client of version $version "
|
|
puts "for your host system."
|
|
puts -nonewline "The sources are available via "
|
|
puts "ftp://ftp.netperf.org/netperf/archive/netperf-2.4.4.tar.bz2"
|
|
puts "Please name the binary netperf-$version and netserver-$version\n"
|
|
exit 1;
|
|
}
|
|
|
|
#
|
|
# Build
|
|
#
|
|
set build_components {
|
|
core
|
|
init
|
|
drivers/usb
|
|
drivers/timer
|
|
drivers/uart
|
|
server/nic_bridge
|
|
l4linux
|
|
}
|
|
|
|
source ${genode_dir}/repos/base/run/platform_drv.inc
|
|
append_platform_drv_build_components
|
|
|
|
build $build_components
|
|
|
|
create_boot_directory
|
|
|
|
#
|
|
# Config
|
|
#
|
|
set config {
|
|
<config>
|
|
<parent-provides>
|
|
<service name="ROM"/>
|
|
<service name="RAM"/>
|
|
<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>
|
|
}
|
|
|
|
append_platform_drv_config
|
|
|
|
append config {
|
|
<start name="kdb_uart_drv">
|
|
<resource name="RAM" quantum="1M"/>
|
|
<provides>
|
|
<service name="Terminal"/>
|
|
<service name="Uart"/>
|
|
</provides>
|
|
<config><policy label_prefix="l4linux" uart="0"/></config>
|
|
</start>
|
|
<start name="usb_drv">
|
|
<binary name="usb_drv"/>
|
|
<resource name="RAM" quantum="12M"/>
|
|
<provides>
|
|
<service name="Nic"/>
|
|
</provides>
|
|
}
|
|
append config "
|
|
<config uhci=\"$use_usb_11\" ehci=\"$use_usb_20\" xhci=\"$use_usb_30\">"
|
|
append config {
|
|
<nic mac="02:00:00:00:01:01" />
|
|
</config>
|
|
<route>
|
|
<any-service> <parent/> <any-child/> </any-service>
|
|
</route>
|
|
</start>
|
|
}
|
|
|
|
append config {
|
|
<start name="l4linux">
|
|
<resource name="RAM" quantum="512M"/>
|
|
<config args="mem=400M console=ttyS0 l4x_rd=initrd.gz l4x_cpus=1 l4x_cpus_map=0"/>
|
|
<route>
|
|
}
|
|
append config "\t\t<service name=\"Nic\"><child name=\"$route_nic\" /> </service>"
|
|
append config {
|
|
<any-service> <any-child /><parent/> </any-service>
|
|
</route>
|
|
</start>
|
|
}
|
|
|
|
append_if $use_nic_bridge config {
|
|
<start name="nic_bridge">
|
|
<resource name="RAM" quantum="6M"/>
|
|
<provides><service name="Nic"/></provides>
|
|
<config/>
|
|
<route>
|
|
<service name="Nic"> <child name="usb_drv"/> </service>
|
|
<any-service> <parent/> <any-child/> </any-service>
|
|
</route>
|
|
</start>
|
|
}
|
|
|
|
|
|
append config {
|
|
</config>
|
|
}
|
|
|
|
install_config $config
|
|
|
|
#
|
|
# Boot modules
|
|
#
|
|
set boot_modules {
|
|
core
|
|
init
|
|
timer
|
|
l4linux
|
|
initrd.gz
|
|
usb_drv
|
|
nic_bridge
|
|
kdb_uart_drv
|
|
}
|
|
|
|
set uri "http://genode.org/files/l4linux/initrd-arm-netperf.gz"
|
|
if {[have_spec x86]} {
|
|
set uri "http://genode.org/files/l4linux/busybox-initrd-x86-20140506.gz"
|
|
} elseif {[have_spec arm]} {
|
|
set uri "http://genode.org/files/l4linux/initrd-arm-mdev.gz"
|
|
}
|
|
|
|
if {![file exists bin/initrd.gz]} {
|
|
puts "Download initramfs ..."
|
|
exec >& /dev/null $wget -c -O bin/initrd.gz $uri
|
|
exec >& /dev/null $wget -O bin/initrd.gz.md5 $uri.md5
|
|
cd bin
|
|
exec $md5 -c initrd.gz.md5
|
|
cd ..
|
|
}
|
|
|
|
append_platform_drv_boot_modules
|
|
|
|
build_boot_image $boot_modules
|
|
|
|
|
|
#
|
|
# Execute test case
|
|
#
|
|
set ip_match "(\[0-9]{1,3})\\.(\[0-9]{1,3})\\.(\[0-9]{1,3})\\.(\[0-9]{1,3})"
|
|
|
|
#
|
|
# Local IP
|
|
#
|
|
set ip_string [ exec $ip addr show dev eth0 ]
|
|
regexp $ip_match $ip_string ip_local
|
|
|
|
|
|
#
|
|
# Remote IP
|
|
#
|
|
run_genode_until "netif_info: register.*\n" 60
|
|
set serial_id [output_spawn_id]
|
|
sleep 8
|
|
send -i $serial_id "ip addr show dev eth0\n"
|
|
run_genode_until "inet.*\n" 3 $serial_id
|
|
regexp $ip_match $output ip_remote
|
|
|
|
puts "Using local IP: $ip_local remote IP: $ip_remote"
|
|
|
|
|
|
#
|
|
# TX (from board to local)
|
|
#
|
|
puts "\nTransmission test:"
|
|
|
|
exec netserver-$version -p 8888 &
|
|
send -i $serial_id "netperf -p 8888 -H $ip_local -c -C -t TCP_STREAM && uname\n"
|
|
run_genode_until "Linux.*" 30 $serial_id
|
|
|
|
puts "\n\n"
|
|
|
|
# get throughput_tx from netperf output
|
|
set throughput_tx [regexp -all -inline {([0-9]+[ ]+){3}[0-9]+\.[0-9]+[ ]+[0-9]+\.[0-9]+} $output]
|
|
set throughput_tx [regexp -all -inline {[0-9]+\.[0-9]+} $throughput_tx]
|
|
|
|
#
|
|
# RX
|
|
#
|
|
puts "Receive test:"
|
|
|
|
set results [exec netperf-$version -p 8888 -H $ip_remote -t TCP_STREAM]
|
|
puts $results
|
|
|
|
# get throughput from netperf output
|
|
set throughput_rx [regexp -all -inline {([0-9]+[ ]+){3}[0-9]+\.[0-9]+[ ]+[0-9]+\.[0-9]+} $results]
|
|
set throughput_rx [regexp -all -inline {[0-9]+\.[0-9]+} $throughput_rx]
|
|
|
|
puts "\n"
|
|
|
|
#
|
|
# format output parseable for post proccessing scripts
|
|
#
|
|
puts -nonewline "! PERF: TCP_TX"
|
|
if {$use_nic_bridge} { puts -nonewline "_bridge" }
|
|
if {![string compare $use_usb_11 "yes"]} { puts -nonewline "_uhci" }
|
|
if {![string compare $use_usb_20 "yes"]} { puts -nonewline "_ohci" }
|
|
if {![string compare $use_usb_30 "yes"]} { puts -nonewline "_xhci" }
|
|
puts " [lindex $throughput_tx 1] MBit/s ok"
|
|
|
|
puts -nonewline "! PERF: TCP_RX"
|
|
if {$use_nic_bridge} { puts -nonewline "_bridge" }
|
|
if {![string compare $use_usb_11 "yes"]} { puts -nonewline "_uhci" }
|
|
if {![string compare $use_usb_20 "yes"]} { puts -nonewline "_ohci" }
|
|
if {![string compare $use_usb_30 "yes"]} { puts -nonewline "_xhci" }
|
|
puts " [lindex $throughput_rx 1] MBit/s ok"
|
|
|
|
exec rm bin/initrd.gz bin/initrd.gz.md5
|
|
|
|
close -i $serial_id
|
|
exec killall netserver-$version
|
|
|
|
# vi: set ft=tcl :
|