2011-12-23 13:04:29 +00:00
|
|
|
|
|
|
|
if {[have_spec always_hybrid]} {
|
|
|
|
puts "Run script does not support hybrid Linux/Genode."; exit 0 }
|
|
|
|
|
2011-12-22 15:19:25 +00:00
|
|
|
build "core init test/ldso"
|
|
|
|
|
|
|
|
create_boot_directory
|
|
|
|
|
|
|
|
install_config {
|
|
|
|
<config>
|
|
|
|
<parent-provides>
|
|
|
|
<service name="ROM"/>
|
|
|
|
<service name="LOG"/>
|
|
|
|
<service name="RM" />
|
|
|
|
</parent-provides>
|
|
|
|
<default-route>
|
|
|
|
<any-service> <parent/> </any-service>
|
|
|
|
</default-route>
|
|
|
|
<start name="test-ldso">
|
2013-05-06 14:29:23 +00:00
|
|
|
<resource name="RAM" quantum="2M"/>
|
2014-04-14 09:57:22 +00:00
|
|
|
<config>
|
|
|
|
<libc stdout="/dev/log">
|
|
|
|
<vfs> <dir name="dev"> <log/> </dir> </vfs>
|
|
|
|
</libc>
|
|
|
|
</config>
|
2011-12-22 15:19:25 +00:00
|
|
|
</start>
|
|
|
|
</config>
|
|
|
|
}
|
|
|
|
|
2014-02-05 13:46:59 +00:00
|
|
|
build_boot_image "core init test-ldso test-ldso_lib_1.lib.so test-ldso_lib_2.lib.so libc.lib.so libm.lib.so ld.lib.so"
|
2011-12-22 15:19:25 +00:00
|
|
|
|
|
|
|
append qemu_args "-nographic -m 64"
|
|
|
|
|
2014-02-05 13:46:59 +00:00
|
|
|
run_genode_until "child exited with exit value 123.*\n" 10
|
2011-12-22 15:19:25 +00:00
|
|
|
|
|
|
|
# pay only attention to the output of init and its children
|
2013-01-14 11:13:05 +00:00
|
|
|
grep_output {^\[init }
|
2011-12-22 15:19:25 +00:00
|
|
|
|
|
|
|
compare_output_to {
|
2014-02-05 13:46:59 +00:00
|
|
|
[init -> test-ldso] Lib_2_global 11223343
|
|
|
|
[init -> test-ldso] Lib_1_global_1 5060707
|
|
|
|
[init -> test-ldso] Lib_1_global_2 1020303
|
|
|
|
[init -> test-ldso] lib_1_attr_constructor_2 4030200f
|
|
|
|
[init -> test-ldso] lib_1_attr_constructor_1 8070604f
|
|
|
|
[init -> test-ldso] Global_1 5060707
|
|
|
|
[init -> test-ldso] Global_2 1020303
|
|
|
|
[init -> test-ldso] attr_constructor_2 4030200f
|
|
|
|
[init -> test-ldso] attr_constructor_1 8070604f
|
|
|
|
[init -> test-ldso]
|
|
|
|
[init -> test-ldso] Dynamic-linker test
|
|
|
|
[init -> test-ldso] ===================
|
|
|
|
[init -> test-ldso]
|
|
|
|
[init -> test-ldso] Global objects and local static objects of program
|
|
|
|
[init -> test-ldso] --------------------------------------------------
|
|
|
|
[init -> test-ldso] global_1 5060706
|
|
|
|
[init -> test-ldso] global_2 1020302
|
|
|
|
[init -> test-ldso] Local_1 5060707f
|
|
|
|
[init -> test-ldso] local_1 5060707e
|
|
|
|
[init -> test-ldso] Local_2 1020303f
|
|
|
|
[init -> test-ldso] local_2 1020303e
|
|
|
|
[init -> test-ldso] pod_1 8070604e
|
|
|
|
[init -> test-ldso] pod_2 4030200e
|
|
|
|
[init -> test-ldso]
|
|
|
|
[init -> test-ldso] Access shared lib from program
|
|
|
|
[init -> test-ldso] ------------------------------
|
|
|
|
[init -> test-ldso] lib_2_global 11223342
|
|
|
|
[init -> test-ldso] Lib_1_local_3 12345677
|
|
|
|
[init -> test-ldso] lib_1_local_3 12345676
|
|
|
|
[init -> test-ldso] lib_1_pod_1 8070604d
|
|
|
|
[init -> test-ldso] Libc::read:
|
|
|
|
[init -> test-ldso] no plugin found for read(0)
|
|
|
|
[init -> test-ldso] Libc::abs(-10): 10
|
|
|
|
[init -> test-ldso]
|
|
|
|
[init -> test-ldso] Catch exceptions in program
|
|
|
|
[init -> test-ldso] ---------------------------
|
|
|
|
[init -> test-ldso] exception in remote procedure call:
|
|
|
|
[init -> test-ldso] Could not open file "unknown_file"
|
|
|
|
[init -> test-ldso] caught
|
|
|
|
[init -> test-ldso] exception in program: caught
|
|
|
|
[init -> test-ldso] exception in shared lib: caught
|
|
|
|
[init -> test-ldso] exception in dynamic linker: caught
|
|
|
|
[init -> test-ldso]
|
|
|
|
[init -> test-ldso] global objects and local static objects of shared lib
|
|
|
|
[init -> test-ldso] -----------------------------------------------------
|
|
|
|
[init -> test-ldso] lib_1_global_1 5060706
|
|
|
|
[init -> test-ldso] lib_1_global_2 1020302
|
|
|
|
[init -> test-ldso] Lib_1_local_1 5060707f
|
|
|
|
[init -> test-ldso] lib_1_local_1 5060707e
|
|
|
|
[init -> test-ldso] Lib_1_local_2 1020303f
|
|
|
|
[init -> test-ldso] lib_1_local_2 1020303e
|
|
|
|
[init -> test-ldso] lib_1_pod_1 8070604e
|
|
|
|
[init -> test-ldso] lib_1_pod_2 4030200e
|
|
|
|
[init -> test-ldso]
|
|
|
|
[init -> test-ldso] Access shared lib from another shared lib
|
|
|
|
[init -> test-ldso] -----------------------------------------
|
|
|
|
[init -> test-ldso] lib_2_global 11223341
|
|
|
|
[init -> test-ldso] Lib_2_local 55667787
|
|
|
|
[init -> test-ldso] lib_2_local 55667786
|
|
|
|
[init -> test-ldso] lib_2_pod_1 87654320
|
|
|
|
[init -> test-ldso]
|
|
|
|
[init -> test-ldso] Catch exceptions in shared lib
|
|
|
|
[init -> test-ldso] ------------------------------
|
|
|
|
[init -> test-ldso] exception in lib: caught
|
|
|
|
[init -> test-ldso] exception in another shared lib: caught
|
|
|
|
[init -> test-ldso]
|
2014-02-06 16:09:53 +00:00
|
|
|
[init -> test-ldso] test stack alignment
|
|
|
|
[init -> test-ldso] --------------------
|
|
|
|
[init -> test-ldso] <warning: unsupported format string argument>
|
|
|
|
[init -> test-ldso] <warning: unsupported format string argument>
|
|
|
|
[init -> test-ldso] <warning: unsupported format string argument>
|
|
|
|
[init -> test-ldso] <warning: unsupported format string argument>
|
|
|
|
[init -> test-ldso]
|
2014-02-05 13:46:59 +00:00
|
|
|
[init -> test-ldso] ~Lib_2_local 55667785
|
|
|
|
[init -> test-ldso] ~Lib_1_local_2 1020303d
|
|
|
|
[init -> test-ldso] ~Lib_1_local_1 5060707d
|
|
|
|
[init -> test-ldso] ~Lib_1_local_3 12345675
|
|
|
|
[init -> test-ldso] ~Local_2 1020303d
|
|
|
|
[init -> test-ldso] ~Local_1 5060707d
|
|
|
|
[init -> test-ldso] attr_destructor_2 4030200d
|
|
|
|
[init -> test-ldso] attr_destructor_1 8070604c
|
|
|
|
[init -> test-ldso] ~Global_2 1020301
|
|
|
|
[init -> test-ldso] ~Global_1 5060705
|
|
|
|
[init -> test-ldso] ~Lib_1_global_2 1020301
|
|
|
|
[init -> test-ldso] ~Lib_1_global_1 5060705
|
|
|
|
[init -> test-ldso] ~Lib_2_global 11223340
|
2011-12-22 15:19:25 +00:00
|
|
|
}
|
|
|
|
|