2014-05-28 12:48:33 +00:00
|
|
|
#
|
|
|
|
# This script is used to test the shared folder support of Vbox@Genode/NOVA.
|
|
|
|
#
|
|
|
|
# Requirements to run this script:
|
|
|
|
# - hard disk with 4 primary partitions
|
|
|
|
# - on the 4. partition an ext2 filesystem is expected with following files:
|
|
|
|
# -- /win7.vdi
|
|
|
|
# -- /ram/overlay-original.vdi
|
|
|
|
#
|
|
|
|
# The overlay file must be generated beforehand, e.g.:
|
|
|
|
#
|
|
|
|
# vboxmanage showhdinfo win7.vdi
|
|
|
|
#
|
|
|
|
# to find out the size of the vdi and then to create the overlay:
|
|
|
|
#
|
|
|
|
# vboxmanage createhd --filename overlay-original.vdi --size [vdi_size] --format vdi
|
|
|
|
#
|
|
|
|
#
|
|
|
|
#
|
|
|
|
#
|
|
|
|
# The Windows image (win7.vdi) is prepared to contain a bat file with following
|
|
|
|
# content:
|
|
|
|
#
|
|
|
|
# :check
|
|
|
|
# IF EXIST E:\test.bat (GOTO start) ELSE (timeout /t 3 >nul)
|
|
|
|
# GOTO check
|
|
|
|
#
|
|
|
|
# :start
|
|
|
|
#
|
|
|
|
# call E:\test.bat
|
|
|
|
#
|
|
|
|
# This file must be configured to be autostarted by Windows, e.g change the
|
|
|
|
# value in the registry entry at
|
|
|
|
#
|
|
|
|
# HKEY_CURRENT_USER\Software/Microsoft\Windows\CurrentVersion\Run
|
|
|
|
#
|
|
|
|
# to the batch file in the Windows vdi image as described above.
|
|
|
|
#
|
|
|
|
#
|
|
|
|
# What this script does:
|
|
|
|
#
|
|
|
|
# A VM containing a Win7 image is started configured with two different
|
|
|
|
# Virtualbox fileshares (D: and E:). One contains a test file (test.bin),
|
|
|
|
# which will be copied by the Windows VM from the one file share over to the
|
|
|
|
# second one.
|
|
|
|
# On Genode side a Noux instance is running a bash shell with the two
|
|
|
|
# filesystems mounted. The shell is scripted by this script to wait for
|
|
|
|
# completion of the copy operation performed by the Windows VM. If this is
|
|
|
|
# detected, the bash scripts use sha1sum to generate hashes of the original
|
|
|
|
# test file of the one file system share and of the copy on the second file
|
|
|
|
# system share. This run scripts then compares the hashes and reports
|
|
|
|
# "Test succeeded" if they are identical.
|
|
|
|
#
|
|
|
|
# This script generates the test file out of /dev/urandom and generates a
|
|
|
|
# batch file test.bat which is placed in the shared folder for the VM. test.bat
|
|
|
|
# is invoked by the batch file running already in the Windows VM as described
|
|
|
|
# beforehand. test.bat contains the actual instructions to be performed by
|
|
|
|
# the VM - for this script to copy the test.bin file from D: to E:.
|
|
|
|
|
2015-01-08 21:09:08 +00:00
|
|
|
if {[have_include "power_on/qemu"]} {
|
2014-07-10 06:35:23 +00:00
|
|
|
puts "\nRun script does not support Qemu.\n"
|
2015-01-08 21:09:08 +00:00
|
|
|
exit 0
|
2014-07-10 06:35:23 +00:00
|
|
|
}
|
2014-05-28 12:48:33 +00:00
|
|
|
|
2015-06-08 22:45:34 +00:00
|
|
|
# Tested for nova and hw_x86_64_muen.
|
|
|
|
if {(![have_spec nova] && ![have_spec hw_x86_64_muen])} {
|
|
|
|
puts "Platform is unsupported."
|
|
|
|
exit 0
|
|
|
|
}
|
2014-05-28 12:48:33 +00:00
|
|
|
|
2015-02-19 10:59:31 +00:00
|
|
|
set flavor "win7"
|
2016-08-15 10:27:54 +00:00
|
|
|
|
|
|
|
set use_vbox4 1
|
|
|
|
set use_vbox5 0
|
|
|
|
|
2015-02-19 10:59:31 +00:00
|
|
|
set vdi_image "${flavor}.vdi"
|
2014-09-23 11:01:47 +00:00
|
|
|
# Write overlay back to harddisk if set to 0
|
|
|
|
set use_ram_fs 0
|
2016-08-01 09:40:21 +00:00
|
|
|
set use_overlay_from_disk 0
|
2015-02-19 10:59:31 +00:00
|
|
|
set overlay_image "overlay_${flavor}.vdi"
|
2016-10-12 13:20:04 +00:00
|
|
|
set use_rumpfs 1
|
2014-05-28 12:48:33 +00:00
|
|
|
|
2015-02-22 18:04:55 +00:00
|
|
|
set use_usb 0
|
|
|
|
set use_ps2 [have_spec ps2]
|
|
|
|
|
2016-10-19 12:52:59 +00:00
|
|
|
set use_vms 1
|
|
|
|
set use_cpu_load 0
|
|
|
|
|
2014-05-28 12:48:33 +00:00
|
|
|
#
|
|
|
|
# Create .bat file to be executed by Win VM
|
|
|
|
#
|
|
|
|
set template_bat_fd [open "bin/template.bat" w]
|
|
|
|
puts $template_bat_fd {:check
|
|
|
|
IF EXIST E:\start.txt (GOTO start) ELSE (timeout /t 3 >nul)
|
|
|
|
GOTO check
|
|
|
|
|
|
|
|
:start
|
|
|
|
|
|
|
|
copy D:\test.bin E:\test.bin
|
|
|
|
copy D:\template.bat E:\done.txt
|
|
|
|
shutdown /s /t 00}
|
|
|
|
|
|
|
|
close $template_bat_fd
|
|
|
|
|
|
|
|
# Convert bat file to dos format
|
|
|
|
catch { exec unix2dos bin/template.bat }
|
|
|
|
|
|
|
|
#
|
|
|
|
# Create random test binary to be copied via shared folder of vbox
|
|
|
|
#
|
|
|
|
catch { exec dd if=/dev/urandom of=bin/test.bin bs=4096 count=8160 }
|
|
|
|
|
|
|
|
#
|
2014-09-23 11:01:47 +00:00
|
|
|
# Step 1: prepare and start the actual VM
|
2014-05-28 12:48:33 +00:00
|
|
|
#
|
2014-09-23 11:01:47 +00:00
|
|
|
set build_components {
|
2015-03-30 16:00:43 +00:00
|
|
|
server/ram_fs server/report_rom
|
2014-09-23 11:01:47 +00:00
|
|
|
server/tcp_terminal drivers/nic
|
|
|
|
lib/libc_noux
|
|
|
|
noux/minimal
|
2014-05-28 12:48:33 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#
|
2014-09-23 11:01:47 +00:00
|
|
|
# Build Noux packages only once
|
2014-05-28 12:48:33 +00:00
|
|
|
#
|
2014-09-23 11:01:47 +00:00
|
|
|
foreach pkg {bash coreutils} {
|
|
|
|
lappend_if [expr ![file exists bin/$pkg]] build_components noux-pkg/$pkg }
|
2014-05-28 12:48:33 +00:00
|
|
|
|
|
|
|
set boot_modules {
|
|
|
|
ram_fs
|
|
|
|
noux libc_noux.lib.so bash.tar coreutils.tar
|
2015-03-30 16:00:43 +00:00
|
|
|
tcp_terminal lwip.lib.so nic_drv report_rom
|
2014-05-28 12:48:33 +00:00
|
|
|
test.bin template.bat
|
2014-09-23 11:01:47 +00:00
|
|
|
vm_auto_share.vbox
|
2014-05-28 12:48:33 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
set config_of_app {
|
2014-07-02 10:11:20 +00:00
|
|
|
<start name="nic_drv" priority="-1">
|
2014-05-28 12:48:33 +00:00
|
|
|
<resource name="RAM" quantum="4M"/>
|
|
|
|
<provides> <service name="Nic"/> </provides>
|
|
|
|
<route>
|
2016-03-09 14:32:23 +00:00
|
|
|
<service name="IRQ"><child name="acpi"/></service>
|
|
|
|
<any-service> <parent/> <any-child/></any-service>
|
2014-05-28 12:48:33 +00:00
|
|
|
</route>
|
|
|
|
</start>
|
|
|
|
|
2014-07-02 10:11:20 +00:00
|
|
|
<start name="tcp_terminal" priority="-1">
|
2014-05-28 12:48:33 +00:00
|
|
|
<resource name="RAM" quantum="5M"/>
|
|
|
|
<provides> <service name="Terminal"/> </provides>
|
|
|
|
<config>
|
|
|
|
<policy label="noux" port="8888"/>
|
|
|
|
</config>
|
|
|
|
</start>
|
|
|
|
|
2014-07-02 10:11:20 +00:00
|
|
|
<start name="noux" priority="-1">
|
2016-03-09 14:32:23 +00:00
|
|
|
<resource name="RAM" quantum="32M"/>
|
2014-05-28 12:48:33 +00:00
|
|
|
<config>
|
|
|
|
<fstab>
|
2016-03-09 14:32:23 +00:00
|
|
|
<tar name="coreutils.tar"/>
|
|
|
|
<tar name="bash.tar"/>
|
2014-05-28 12:48:33 +00:00
|
|
|
|
2016-03-09 14:32:23 +00:00
|
|
|
<dir name="from"> <fs label="share_from"/> </dir>
|
|
|
|
<dir name="to"> <fs label="share_to"/> </dir>
|
2014-05-28 12:48:33 +00:00
|
|
|
</fstab>
|
|
|
|
<start name="/bin/bash">
|
2016-03-09 14:32:23 +00:00
|
|
|
<env name="TERM" value="linux"/>
|
2014-05-28 12:48:33 +00:00
|
|
|
</start>
|
|
|
|
</config>
|
|
|
|
<route>
|
|
|
|
<service name="File_system">
|
2016-03-09 14:32:23 +00:00
|
|
|
<if-arg key="label" value="share_from"/>
|
2014-05-28 12:48:33 +00:00
|
|
|
<child name="ram_fs_from"/>
|
|
|
|
</service>
|
|
|
|
<service name="File_system">
|
2016-03-09 14:32:23 +00:00
|
|
|
<if-arg key="label" value="share_to"/>
|
2014-05-28 12:48:33 +00:00
|
|
|
<child name="ram_fs_to"/>
|
|
|
|
</service>
|
2016-03-09 14:32:23 +00:00
|
|
|
<any-service> <parent/> <any-child/> </any-service>
|
2014-05-28 12:48:33 +00:00
|
|
|
</route>
|
|
|
|
</start>
|
|
|
|
|
2014-07-02 10:11:20 +00:00
|
|
|
<start name="ram_fs_from" priority="-1">
|
2016-03-09 14:32:23 +00:00
|
|
|
<binary name="ram_fs"/>
|
2014-05-28 12:48:33 +00:00
|
|
|
<resource name="RAM" quantum="64M"/>
|
|
|
|
<provides><service name="File_system"/></provides>
|
|
|
|
<config>
|
|
|
|
<content>
|
2016-03-09 14:32:23 +00:00
|
|
|
<rom name="test.bin"/>
|
|
|
|
<rom name="template.bat"/>
|
2014-05-28 12:48:33 +00:00
|
|
|
</content>
|
2016-03-09 14:32:23 +00:00
|
|
|
<default-policy root="/" writeable="no"/>
|
2014-05-28 12:48:33 +00:00
|
|
|
</config>
|
|
|
|
</start>
|
|
|
|
|
2014-07-02 10:11:20 +00:00
|
|
|
<start name="ram_fs_to" priority="-1">
|
2016-03-09 14:32:23 +00:00
|
|
|
<binary name="ram_fs"/>
|
2014-05-28 12:48:33 +00:00
|
|
|
<resource name="RAM" quantum="64M"/>
|
|
|
|
<provides><service name="File_system"/></provides>
|
|
|
|
<config>
|
2016-03-09 14:32:23 +00:00
|
|
|
<default-policy root="/" writeable="yes"/>
|
2014-05-28 12:48:33 +00:00
|
|
|
</config>
|
|
|
|
</start>
|
|
|
|
|
2015-03-30 16:00:43 +00:00
|
|
|
<start name="report_rom">
|
|
|
|
<resource name="RAM" quantum="1M"/>
|
|
|
|
<provides> <service name="Report"/> <service name="ROM"/> </provides>
|
2016-03-09 14:32:23 +00:00
|
|
|
<config> <rom/> </config>
|
2015-03-30 16:00:43 +00:00
|
|
|
</start>
|
|
|
|
|
2014-07-02 10:11:20 +00:00
|
|
|
<start name="vbox" priority="-2">
|
2016-03-09 14:32:23 +00:00
|
|
|
<binary name="virtualbox"/>
|
2014-09-23 11:01:47 +00:00
|
|
|
<resource name="RAM" quantum="1280M"/>
|
|
|
|
<config vbox_file="vm_auto_share.vbox" vm_name="AutoDisk">
|
2015-01-13 16:38:04 +00:00
|
|
|
<libc stdout="/dev/log" stderr="/dev/log" rtc="/dev/rtc">
|
2014-05-28 12:48:33 +00:00
|
|
|
<vfs>
|
2015-01-13 16:38:04 +00:00
|
|
|
<dir name="dev"> <log/> <rtc/> </dir>
|
2016-03-09 14:32:23 +00:00
|
|
|
<rom name="vm_auto_share.vbox"/>}
|
2014-09-23 11:01:47 +00:00
|
|
|
|
|
|
|
append_if [expr $use_ram_fs] config_of_app {
|
|
|
|
<dir name="ram"> <fs label="from_ram_fs"/> </dir>}
|
|
|
|
|
|
|
|
append config_of_app {
|
2014-05-28 12:48:33 +00:00
|
|
|
<dir name="from"> <fs label="share_ram_fs_from"/> </dir>
|
|
|
|
<dir name="to"> <fs label="share_ram_fs_to"/> </dir>
|
2016-03-09 14:32:23 +00:00
|
|
|
<fs/>
|
2014-05-28 12:48:33 +00:00
|
|
|
</vfs>
|
|
|
|
</libc>
|
|
|
|
</config>
|
2015-05-26 18:12:17 +00:00
|
|
|
<route>
|
2016-03-09 14:32:23 +00:00
|
|
|
<service name="Report"> <child name="report_rom"/> </service>}
|
2014-09-23 11:01:47 +00:00
|
|
|
|
|
|
|
append_if [expr $use_ram_fs] config_of_app {
|
|
|
|
<service name="File_system">
|
2016-03-09 14:32:23 +00:00
|
|
|
<if-arg key="label" value="from_ram_fs"/>
|
2014-09-23 11:01:47 +00:00
|
|
|
<child name="ram_fs"/>
|
|
|
|
</service>}
|
|
|
|
|
|
|
|
append config_of_app {
|
2014-05-28 12:48:33 +00:00
|
|
|
<service name="File_system">
|
2016-03-09 14:32:23 +00:00
|
|
|
<if-arg key="label" value="share_ram_fs_from"/>
|
2014-05-28 12:48:33 +00:00
|
|
|
<child name="ram_fs_from"/>
|
|
|
|
</service>
|
|
|
|
<service name="File_system">
|
2016-03-09 14:32:23 +00:00
|
|
|
<if-arg key="label" value="share_ram_fs_to"/>
|
2014-05-28 12:48:33 +00:00
|
|
|
<child name="ram_fs_to"/>
|
|
|
|
</service>
|
|
|
|
<service name="File_system"> <child name="rump_fs"/> </service>
|
2016-03-09 14:32:23 +00:00
|
|
|
<any-service> <parent/> <any-child/> </any-service>
|
2014-05-28 12:48:33 +00:00
|
|
|
</route>
|
|
|
|
</start>
|
|
|
|
}
|
|
|
|
|
|
|
|
source ${genode_dir}/repos/ports/run/virtualbox_auto.inc
|
|
|
|
|
2014-09-23 11:01:47 +00:00
|
|
|
exec tar cfv bin/bash.tar -h -C bin/bash .
|
|
|
|
exec tar cfv bin/coreutils.tar -h -C bin/coreutils .
|
|
|
|
exec cp ${genode_dir}/repos/ports/run/vm_auto_share.vbox bin/.
|
|
|
|
|
|
|
|
build_boot_image $boot_modules
|
|
|
|
|
2014-05-28 12:48:33 +00:00
|
|
|
#
|
|
|
|
# Step 2: Read out TCP/IP address of tcp_terminal running on Genode target
|
|
|
|
#
|
base: avoid use of deprecated base/printf.h
Besides adapting the components to the use of base/log.h, the patch
cleans up a few base headers, i.e., it removes unused includes from
root/component.h, specifically base/heap.h and
ram_session/ram_session.h. Hence, components that relied on the implicit
inclusion of those headers have to manually include those headers now.
While adjusting the log messages, I repeatedly stumbled over the problem
that printing char * arguments is ambiguous. It is unclear whether to
print the argument as pointer or null-terminated string. To overcome
this problem, the patch introduces a new type 'Cstring' that allows the
caller to express that the argument should be handled as null-terminated
string. As a nice side effect, with this type in place, the optional len
argument of the 'String' class could be removed. Instead of supplying a
pair of (char const *, size_t), the constructor accepts a 'Cstring'.
This, in turn, clears the way let the 'String' constructor use the new
output mechanism to assemble a string from multiple arguments (and
thereby getting rid of snprintf within Genode in the near future).
To enforce the explicit resolution of the char * ambiguity, the 'char *'
overload of the 'print' function is marked as deleted.
Issue #1987
2016-07-13 17:07:09 +00:00
|
|
|
run_genode_until {\[init -> tcp_terminal\] got IP address [0-9]+\.[0-9]+\.[0-9]+\.[0-9]+} 20
|
2015-01-08 21:09:08 +00:00
|
|
|
set serial_id [output_spawn_id]
|
2014-05-28 12:48:33 +00:00
|
|
|
|
base: avoid use of deprecated base/printf.h
Besides adapting the components to the use of base/log.h, the patch
cleans up a few base headers, i.e., it removes unused includes from
root/component.h, specifically base/heap.h and
ram_session/ram_session.h. Hence, components that relied on the implicit
inclusion of those headers have to manually include those headers now.
While adjusting the log messages, I repeatedly stumbled over the problem
that printing char * arguments is ambiguous. It is unclear whether to
print the argument as pointer or null-terminated string. To overcome
this problem, the patch introduces a new type 'Cstring' that allows the
caller to express that the argument should be handled as null-terminated
string. As a nice side effect, with this type in place, the optional len
argument of the 'String' class could be removed. Instead of supplying a
pair of (char const *, size_t), the constructor accepts a 'Cstring'.
This, in turn, clears the way let the 'String' constructor use the new
output mechanism to assemble a string from multiple arguments (and
thereby getting rid of snprintf within Genode in the near future).
To enforce the explicit resolution of the char * ambiguity, the 'char *'
overload of the 'print' function is marked as deleted.
Issue #1987
2016-07-13 17:07:09 +00:00
|
|
|
regexp {\[init -> tcp_terminal\] got IP address [0-9]+\.[0-9]+\.[0-9]+\.[0-9]+} $output serial_ip_addr
|
2014-05-28 12:48:33 +00:00
|
|
|
regexp {[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+} $serial_ip_addr serial_ip_addr
|
|
|
|
|
|
|
|
#
|
|
|
|
# Step 3: Wait until Windows is up for sure
|
|
|
|
#
|
2014-09-23 11:01:47 +00:00
|
|
|
|
|
|
|
|
2014-05-28 12:48:33 +00:00
|
|
|
run_genode_until {\[init -\> vbox\].*Guest Additions capability report:.*seamless: yes, hostWindowMapping: no, graphics: yes} 300 $serial_id
|
|
|
|
|
|
|
|
|
|
|
|
#
|
|
|
|
# Step 4 : connect to Noux of the running Genode target and issue bash commands
|
|
|
|
# via netcat
|
|
|
|
#
|
|
|
|
puts "\nTest shared folder\n"
|
|
|
|
|
|
|
|
spawn netcat $serial_ip_addr 8888
|
|
|
|
set noux_id $spawn_id
|
|
|
|
|
|
|
|
run_genode_until {\[init -> tcp_terminal\] connection established} 20 $serial_id
|
|
|
|
|
|
|
|
#
|
|
|
|
# Step 5 : interact with netcat -> ... -> tcp_terminal -> Noux -> bash
|
|
|
|
#
|
|
|
|
|
|
|
|
# Windows does not like trailing zeros introduced by our ROM service.
|
|
|
|
# -> .bat script does not find labels like 'check' with zero bytes
|
|
|
|
# so - delete zero bytes
|
|
|
|
puts $noux_id "cat from/template\.bat | tr -d \"\\0\" >to/test\.bat"
|
|
|
|
|
|
|
|
# SHA1 of original file
|
|
|
|
puts $noux_id "sha1sum from/test.bin"
|
|
|
|
|
|
|
|
# Tell Windows VM to start copying
|
|
|
|
puts $noux_id "echo \"start\" > to/start\.txt"
|
|
|
|
|
|
|
|
# Wait until Windows finished copying
|
|
|
|
puts $noux_id "while \[ ! -f to/done\.txt ]"
|
|
|
|
puts $noux_id "do"
|
|
|
|
puts $noux_id "sleep 5"
|
|
|
|
puts $noux_id "done"
|
|
|
|
|
|
|
|
# Wait until VM signaled shutdown state
|
2016-10-05 14:51:35 +00:00
|
|
|
run_genode_until {\[init\] child "vbox" exited with exit value 0} 120 $serial_id
|
2014-05-28 12:48:33 +00:00
|
|
|
|
|
|
|
# SHA1 of copied file
|
|
|
|
puts $noux_id "sha1sum to/test.bin"
|
|
|
|
|
|
|
|
# Wait for output of bash shell until last SHA1 sum is calculated
|
|
|
|
run_genode_until {[[:xdigit:]]+ to/test\.bin} 50 $noux_id
|
|
|
|
|
|
|
|
|
|
|
|
# cleanup created files
|
|
|
|
foreach pkg {bash coreutils} { exec rm -f bin/$pkg.tar }
|
|
|
|
exec rm -f bin/test.bin
|
|
|
|
exec rm -f bin/template.bat
|
2014-09-23 11:01:47 +00:00
|
|
|
exec rm -f bin/vm_auto_share.vbox
|
2014-05-28 12:48:33 +00:00
|
|
|
|
|
|
|
|
|
|
|
#
|
|
|
|
# Step 5: Compare sha1sum of original file and of copy made by .bat file in VM
|
|
|
|
#
|
|
|
|
set sha1sum_original [regexp -inline {[[:xdigit:]]+ from/test\.bin} $output]
|
|
|
|
set sha1sum_copy [regexp -inline {[[:xdigit:]]+ to/test\.bin} $output]
|
|
|
|
set sha1sum_original [regexp -inline {[[:xdigit:]]+} $sha1sum_original]
|
|
|
|
set sha1sum_copy [regexp -inline {[[:xdigit:]]+} $sha1sum_copy]
|
|
|
|
|
|
|
|
puts -nonewline "\n$sha1sum_original ?= $sha1sum_copy --> "
|
|
|
|
if {$sha1sum_original eq ""} {
|
|
|
|
puts " empty -> no "
|
|
|
|
} else {
|
|
|
|
if {$sha1sum_original != $sha1sum_copy} {
|
|
|
|
puts "no"
|
2015-01-08 21:09:08 +00:00
|
|
|
exit -1
|
2014-05-28 12:48:33 +00:00
|
|
|
} else {
|
|
|
|
puts "yes"
|
|
|
|
}
|
|
|
|
}
|