2013-04-08 18:51:28 +00:00
|
|
|
#
|
|
|
|
# \brief Test ping
|
|
|
|
# \author Josef Soentgen
|
|
|
|
# \date 2013-01-06
|
|
|
|
#
|
|
|
|
|
|
|
|
#
|
|
|
|
# Client parameters
|
|
|
|
#
|
2013-04-10 13:55:03 +00:00
|
|
|
set packet_payload_size 10
|
2013-04-08 18:51:28 +00:00
|
|
|
set packet_count 1000000
|
|
|
|
|
|
|
|
#
|
|
|
|
# Build
|
|
|
|
#
|
|
|
|
|
|
|
|
set build_components {
|
|
|
|
core init
|
2013-04-10 13:55:03 +00:00
|
|
|
drivers/timer drivers/nic
|
2013-04-08 18:51:28 +00:00
|
|
|
test/lwip/pingpong/server
|
|
|
|
}
|
|
|
|
|
|
|
|
lappend_if $use_nic_bridge build_components server/nic_bridge
|
|
|
|
|
|
|
|
lappend_if [expr [have_spec omap4] || [have_spec exynos5]] build_components drivers/usb
|
2013-04-10 13:55:03 +00:00
|
|
|
lappend_if [have_spec acpi] build_components drivers/acpi
|
|
|
|
lappend_if [have_spec pci] build_components drivers/pci/device_pd
|
|
|
|
lappend_if [have_spec pci] build_components drivers/pci
|
2013-04-08 18:51:28 +00:00
|
|
|
|
|
|
|
build $build_components
|
|
|
|
|
|
|
|
create_boot_directory
|
|
|
|
|
|
|
|
#
|
|
|
|
# Generate config
|
|
|
|
#
|
|
|
|
|
|
|
|
set config {
|
|
|
|
<config verbose="yes">
|
|
|
|
<parent-provides>
|
|
|
|
<service name="ROM"/>
|
|
|
|
<service name="RAM"/>
|
|
|
|
<service name="IRQ"/>
|
|
|
|
<service name="IO_MEM"/>
|
|
|
|
<service name="IO_PORT"/>
|
|
|
|
<service name="CAP"/>
|
|
|
|
<service name="PD"/>
|
|
|
|
<service name="RM"/>
|
|
|
|
<service name="CPU"/>
|
|
|
|
<service name="LOG"/>
|
|
|
|
<service name="SIGNAL"/>
|
|
|
|
</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_if $use_nic_bridge config {
|
|
|
|
<start name="nic_bridge">
|
|
|
|
<resource name="RAM" quantum="2M"/>
|
|
|
|
<provides><service name="Nic"/></provides>
|
|
|
|
<route>
|
|
|
|
<service name="Nic"> }
|
|
|
|
append_if [expr $use_nic_bridge && ([have_spec omap4] || [have_spec exynos5])] config {
|
|
|
|
<child name="usb_drv"/> }
|
|
|
|
append_if [expr $use_nic_bridge && (![have_spec omap4] && ![have_spec exynos5])] config {
|
|
|
|
<child name="nic_drv"/> }
|
|
|
|
append_if $use_nic_bridge config {
|
|
|
|
</service>
|
|
|
|
<any-service> <parent/> <any-child/> </any-service>
|
|
|
|
</route>
|
|
|
|
</start> }
|
|
|
|
|
|
|
|
append config "
|
|
|
|
<start name=\"$test_server_name\">"
|
|
|
|
append config {
|
|
|
|
<resource name="RAM" quantum="16M"/>
|
|
|
|
<config>
|
|
|
|
<argv verbose="0" listenip="0.0.0.0" />
|
|
|
|
</config>
|
|
|
|
<route> }
|
|
|
|
append_if $use_nic_bridge config {
|
|
|
|
<service name="Nic"> <child name="nic_bridge"/> </service> }
|
|
|
|
append config {
|
|
|
|
<any-service> <parent/> <any-child/> </any-service>
|
|
|
|
</route>
|
|
|
|
</start> }
|
|
|
|
|
|
|
|
append_if [expr [have_spec omap4] || [have_spec exynos5]] config {
|
|
|
|
<start name="usb_drv" priority="-1">
|
|
|
|
<resource name="RAM" quantum="12M"/>
|
|
|
|
<provides>
|
|
|
|
<service name="Nic"/>
|
|
|
|
</provides>
|
|
|
|
<config>
|
|
|
|
<nic mac="2e:60:90:0c:4e:02" />
|
|
|
|
<!--<nic mac="aa:bb:cc:dd:ee:00" />-->
|
|
|
|
</config>
|
|
|
|
</start>}
|
|
|
|
|
|
|
|
append_if [expr ![have_spec omap4] && ![have_spec exynos5]] config {
|
|
|
|
<start name="nic_drv">
|
|
|
|
<resource name="RAM" quantum="4M"/>
|
|
|
|
<provides><service name="Nic"/></provides>
|
|
|
|
</start>}
|
|
|
|
|
2013-04-10 13:55:03 +00:00
|
|
|
append_if [have_spec acpi] config {
|
|
|
|
<start name="acpi">
|
|
|
|
<resource name="RAM" quantum="6M"/>
|
|
|
|
<binary name="acpi_drv"/>
|
|
|
|
<provides>
|
|
|
|
<service name="PCI"/>
|
|
|
|
<service name="IRQ" />
|
|
|
|
</provides>
|
|
|
|
<route>
|
|
|
|
<service name="PCI"> <any-child /> </service>
|
|
|
|
<any-service> <parent/> <any-child /> </any-service>
|
|
|
|
</route>
|
|
|
|
</start>}
|
|
|
|
|
|
|
|
append_if [expr ![have_spec acpi] && [have_spec pci]] config {
|
2013-04-08 18:51:28 +00:00
|
|
|
<start name="pci_drv">
|
2013-04-10 13:55:03 +00:00
|
|
|
<resource name="RAM" quantum="3M"/>
|
2013-04-08 18:51:28 +00:00
|
|
|
<provides> <service name="PCI"/> </provides>
|
|
|
|
</start> }
|
|
|
|
|
|
|
|
append config {
|
|
|
|
</config>
|
|
|
|
}
|
|
|
|
|
|
|
|
install_config $config
|
|
|
|
|
|
|
|
#
|
|
|
|
# Boot modules
|
|
|
|
#
|
|
|
|
|
|
|
|
# generic modules
|
|
|
|
set boot_modules {
|
|
|
|
core init timer
|
|
|
|
ld.lib.so libc.lib.so lwip.lib.so libc_log.lib.so
|
|
|
|
}
|
|
|
|
|
|
|
|
lappend_if $use_nic_bridge boot_modules nic_bridge
|
|
|
|
|
|
|
|
lappend boot_modules $test_server_name
|
|
|
|
|
|
|
|
# platform-specific modules
|
|
|
|
lappend_if [have_spec pci] boot_modules pci_drv
|
2013-04-10 13:55:03 +00:00
|
|
|
lappend_if [have_spec acpi] boot_modules acpi_drv
|
2013-04-08 18:51:28 +00:00
|
|
|
lappend_if [expr [have_spec omap4] || [have_spec exynos5]] boot_modules usb_drv
|
|
|
|
lappend_if [expr ![have_spec omap4] && ![have_spec exynos5]] boot_modules nic_drv
|
2013-04-10 13:55:03 +00:00
|
|
|
lappend_if [have_spec nova] boot_modules pci_device_pd
|
2013-04-08 18:51:28 +00:00
|
|
|
|
|
|
|
build_boot_image $boot_modules
|
|
|
|
|
2013-04-10 13:55:03 +00:00
|
|
|
# get IP address from server
|
|
|
|
set match_string "got IP address (.*)\033.*\n"
|
|
|
|
run_genode_until $match_string 30
|
2013-04-08 18:51:28 +00:00
|
|
|
set server_spawn_id $spawn_id
|
|
|
|
|
2013-04-10 13:55:03 +00:00
|
|
|
regexp $match_string $output all ip_addr
|
2013-04-08 18:51:28 +00:00
|
|
|
puts "got server IP address: $ip_addr"
|
|
|
|
|
2013-04-10 13:55:03 +00:00
|
|
|
set match_string "wait....*\n"
|
|
|
|
if {![regexp $match_string $output] } {
|
|
|
|
# wait until the server is ready
|
|
|
|
run_genode_until $match_string 30 $server_spawn_id
|
|
|
|
}
|
2013-04-08 18:51:28 +00:00
|
|
|
|
|
|
|
# build the client
|
|
|
|
set pingpong_dir $genode_dir/libports/src/test/lwip/pingpong
|
|
|
|
exec g++ -o bin/network_test_client \
|
|
|
|
$pingpong_dir/client/main.cc \
|
|
|
|
$pingpong_dir/pingpong.cc \
|
|
|
|
-I $pingpong_dir
|
|
|
|
|
|
|
|
# start the client
|
|
|
|
spawn bin/network_test_client \
|
|
|
|
-serverip $ip_addr \
|
|
|
|
-startsize $packet_payload_size \
|
|
|
|
-endsize $packet_payload_size \
|
|
|
|
-count $packet_count
|
|
|
|
|
|
|
|
# wait until the client is connected to the server
|
2013-04-10 13:55:03 +00:00
|
|
|
run_genode_until "client \[1|3\] connected..." 60 $server_spawn_id
|
2013-04-08 18:51:28 +00:00
|
|
|
|
|
|
|
# start counting the execution time
|
|
|
|
set time_start [clock milliseconds]
|
|
|
|
|
|
|
|
# wait until the server received all packets
|
2013-04-10 13:55:03 +00:00
|
|
|
run_genode_until "received .*\n" 600 $server_spawn_id
|
2013-04-08 18:51:28 +00:00
|
|
|
|
|
|
|
# stop counting the execution time
|
|
|
|
set time_end [clock milliseconds]
|
|
|
|
|
2013-04-10 13:55:03 +00:00
|
|
|
# get received packet size and count from target
|
|
|
|
set target_packet_size [regexp -inline {received [0-9]+ packets of size [0-9]+} $output]
|
|
|
|
set target_packet_size [regexp -all -inline {[0-9]+} $target_packet_size]
|
|
|
|
set target_packet_count [lindex $target_packet_size 0]
|
|
|
|
set target_packet_size [lindex $target_packet_size 1]
|
|
|
|
|
|
|
|
# calculate troughput
|
2013-04-08 18:51:28 +00:00
|
|
|
set milliseconds [expr $time_end - $time_start]
|
2013-04-10 13:55:03 +00:00
|
|
|
set payload_total [expr $target_packet_count * $target_packet_size]
|
2013-04-08 18:51:28 +00:00
|
|
|
set payload_bytes_per_second [expr $payload_total * 1000 / $milliseconds ]
|
|
|
|
|
2013-04-10 13:55:03 +00:00
|
|
|
|
|
|
|
puts "! PERF: $target_packet_size\_data [expr $payload_bytes_per_second * 8 / 1000 / 1000] MBit/s ok"
|
|
|
|
|
|
|
|
set test_result "$milliseconds ms. payload ($target_packet_size Byte): $payload_bytes_per_second Byte/s"
|
2013-04-08 18:51:28 +00:00
|
|
|
|
|
|
|
puts "\nTest succeeded in $test_result."
|
|
|
|
|
|
|
|
# disconnect from server system
|
2013-04-10 13:55:03 +00:00
|
|
|
if {[expr [have_spec omap4] || [have_spec exynos5]]} {
|
|
|
|
send -i $server_spawn_id "\x01\x18" ;# Ctrl-A Ctrl-X
|
|
|
|
run_genode_until "Thanks for using picocom" 60 $server_spawn_id
|
2013-04-08 18:51:28 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
exec rm -f bin/network_test_client
|
|
|
|
|
|
|
|
# vi: set ft=tcl :
|