diff options
author | Mark Wielaard <mjw@redhat.com> | 2009-08-18 22:01:53 +0200 |
---|---|---|
committer | Mark Wielaard <mjw@redhat.com> | 2009-08-18 22:05:29 +0200 |
commit | 766d05e2cabc44805a9e12c4c309d1232f681f10 (patch) | |
tree | 58b24fe7c9f13560c834dfe199c8d04de0a649c8 /testsuite/systemtap.base/inlinedvars.c | |
parent | 7bce6f87482ece5b55db98b589666a2adac9cd1f (diff) | |
download | systemtap-steved-766d05e2cabc44805a9e12c4c309d1232f681f10.tar.gz systemtap-steved-766d05e2cabc44805a9e12c4c309d1232f681f10.tar.xz systemtap-steved-766d05e2cabc44805a9e12c4c309d1232f681f10.zip |
Add testcase for PR10533 (inlined vars) and 10537 (inlined labels - disabled)
Partial testcase for PR10533 (inlined vars) and 10537 (inlined labels)
currently we cannot use the full testcase since stap doesn't support
probing multiple instances of inlined labels.
* testsuite/systemtap.base/inlinedvars.exp: New file.
* testsuite/systemtap.base/inlinedvars.stp: Likewise.
* testsuite/systemtap.base/inlinedvars.c: Likewise.
Diffstat (limited to 'testsuite/systemtap.base/inlinedvars.c')
-rw-r--r-- | testsuite/systemtap.base/inlinedvars.c | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/testsuite/systemtap.base/inlinedvars.c b/testsuite/systemtap.base/inlinedvars.c new file mode 100644 index 00000000..2756323e --- /dev/null +++ b/testsuite/systemtap.base/inlinedvars.c @@ -0,0 +1,43 @@ +static inline int +m(char *name, int i, long j) +{ + // Random syntactical block to be inlined. + // Mimics what STAP_PROBE macro does a bit. + do { + volatile __typeof__(name) p_name = name; + volatile __typeof__(i) p_i = i; + volatile __typeof__(j) p_j = j; + // empty asm to force locals into regs. + inlined_label: asm volatile ("" :: "g"(p_name), "g"(p_i), "g"(p_j)); + } while (0); + return i + 32; +} + +/* XXX PR10537 label() doesn't select multiple instances. +static inline int +call(int pi, long pj) +{ + volatile ic = pi - 42; + volatile jc = pj + 42; + return m("call", ic, jc); +} + +static inline int +call2(int pi2, long pj2) +{ + volatile ic2 = pi2 + 64; + volatile jc2 = pj2 - 64; + return m("call2", ic2, jc2); +} +*/ + +int +main (int argc, char **argv) +{ + volatile int i = 64; + volatile long j = 42; + i = 54;// XXX PR10537 call(i, j); + j = 150; // XXX PR10537 call2(i, j); + m("main", i, j); + return 0; +} |