diff options
author | Mark Wielaard <mjw@redhat.com> | 2009-10-06 15:22:21 +0200 |
---|---|---|
committer | Mark Wielaard <mjw@redhat.com> | 2009-10-06 15:22:21 +0200 |
commit | 5aa987f2edc5c60b61d66fc0e5b7e0fb33423586 (patch) | |
tree | ca85daf49c52fb8dea0e605a5fe22ce0eb9d6f96 /testsuite | |
parent | 6b517475576ac5f2209e5231d14d0b8aa0b6a4d5 (diff) | |
download | systemtap-steved-5aa987f2edc5c60b61d66fc0e5b7e0fb33423586.tar.gz systemtap-steved-5aa987f2edc5c60b61d66fc0e5b7e0fb33423586.tar.xz systemtap-steved-5aa987f2edc5c60b61d66fc0e5b7e0fb33423586.zip |
PR10739 testcase. Split const_value test in two. Absolute const addr fails.
* testsuite/systemtap.base/const_value.exp: Handle both const_value blocks
and address separately. XFAIL second test as PR10739.
* testsuite/systemtap.base/const_value.stp: Only query baz const value.
* testsuite/systemtap.base/const_value_func.c: New test for bar address.
* testsuite/systemtap.base/const_value_func.stp: Likewise.
Diffstat (limited to 'testsuite')
-rw-r--r-- | testsuite/systemtap.base/const_value.exp | 48 | ||||
-rw-r--r-- | testsuite/systemtap.base/const_value.stp | 1 | ||||
-rw-r--r-- | testsuite/systemtap.base/const_value_func.c | 22 | ||||
-rw-r--r-- | testsuite/systemtap.base/const_value_func.stp | 4 |
4 files changed, 68 insertions, 7 deletions
diff --git a/testsuite/systemtap.base/const_value.exp b/testsuite/systemtap.base/const_value.exp index 5d5ceaee..afffebca 100644 --- a/testsuite/systemtap.base/const_value.exp +++ b/testsuite/systemtap.base/const_value.exp @@ -1,6 +1,6 @@ +# DW_AT_const_value (blocks). set test "const_value" -set ::result_string {f: bar -i: 2 +set ::result_string {i: 2 j: 21} set test_flags "additional_flags=-g" @@ -18,17 +18,53 @@ if { $res != "" } { pass "$test.c compile" } -# Test only when we are running an install test (can execute) and when gcc -# vta generated DW_AT_const_values for us. We are interested in both blocks -# and pure constant addresses (technically only the second was added by vta). +# Test only when we are running an install test (can execute) and when +# gcc generated DW_AT_const_values for us. We are interested in block +# constant values. if {[installtest_p] && [uprobes_p]} { set dw_at_c {DW_AT_const_value} if {![catch {exec readelf --debug-dump=info $test.exe | grep "$dw_at_c"}]} { stap_run2 $srcdir/$subdir/$test.stp -c ./$test.exe } { - untested "$test (no-gcc-vta)" + untested "$test (no-const-value)" } } else { untested "$test" } catch {exec rm -f $test.exe} + + +# DW_AT_const_value (address). +set test "const_value_func" +set ::result_string {f: bar} + +set test_flags "additional_flags=-g" +# We need -O2 to get const_value encodings in dwarf. +set test_flags "$test_flags additional_flags=-O2" +set test_flags "$test_flags additional_flags=-I$srcdir/../includes/sys" + +set res [target_compile $srcdir/$subdir/$test.c $test.exe executable "$test_flags"] +if { $res != "" } { + verbose "target_compile failed: $res" 2 + fail "$test.c compile" + untested "$test" + return +} else { + pass "$test.c compile" +} + +# Test only when we are running an install test (can execute) and when +# gcc generated DW_AT_const_values for us. We are interested in pure +# constant addresses. +if {[installtest_p] && [uprobes_p]} { + set dw_at_c {DW_AT_const_value} + if {![catch {exec readelf --debug-dump=info $test.exe | grep "$dw_at_c"}]} { + setup_xfail 10739 "*-*-*" + stap_run2 $srcdir/$subdir/$test.stp -c ./$test.exe + } { + untested "$test (no-const-value)" + } +} else { + untested "$test" +} +catch {exec rm -f $test.exe}
\ No newline at end of file diff --git a/testsuite/systemtap.base/const_value.stp b/testsuite/systemtap.base/const_value.stp index 109d3d46..7aded0f2 100644 --- a/testsuite/systemtap.base/const_value.stp +++ b/testsuite/systemtap.base/const_value.stp @@ -1,6 +1,5 @@ probe process("const_value.exe").mark("constvalues") { - printf("f: %s\n", usymname($f)); printf("i: %d\n", $baz->i); printf("j: %d\n", $baz->j); }
\ No newline at end of file diff --git a/testsuite/systemtap.base/const_value_func.c b/testsuite/systemtap.base/const_value_func.c new file mode 100644 index 00000000..23f2f0bc --- /dev/null +++ b/testsuite/systemtap.base/const_value_func.c @@ -0,0 +1,22 @@ +#include "sdt.h" + +static int +bar (int i, long j) +{ + return i * j; +} + +static int +func (int (*f) ()) +{ + volatile int i = 2; + volatile long j = 21; + STAP_PROBE (test, constvalues); + return f(i, j); +} + +int +main (int argc, char *argv[], char *envp[]) +{ + return func (&bar) - 42; +} diff --git a/testsuite/systemtap.base/const_value_func.stp b/testsuite/systemtap.base/const_value_func.stp new file mode 100644 index 00000000..9dad9150 --- /dev/null +++ b/testsuite/systemtap.base/const_value_func.stp @@ -0,0 +1,4 @@ +probe process("const_value_func.exe").mark("constvalues") +{ + printf("f: %s\n", usymname($f)); +}
\ No newline at end of file |