forked from pool/systemtap
Accepting request 958209 from devel:tools
OBS-URL: https://build.opensuse.org/request/show/958209 OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/systemtap?expand=0&rev=114
This commit is contained in:
commit
d12a77640f
126
Handle-user-supplied-sdt-probe-argument-template.patch
Normal file
126
Handle-user-supplied-sdt-probe-argument-template.patch
Normal file
@ -0,0 +1,126 @@
|
|||||||
|
From ecab2afea46099b4e7dfd551462689224afdbe3a Mon Sep 17 00:00:00 2001
|
||||||
|
From: Stan Cox <scox@redhat.com>
|
||||||
|
Date: Wed, 1 Dec 2021 16:19:22 -0500
|
||||||
|
Subject: [PATCH] Handle user supplied sdt probe argument template
|
||||||
|
|
||||||
|
User supplied templates were erroneously removed by commit eaa15b047,
|
||||||
|
which complicated the template expansion. To do the above the
|
||||||
|
expansion of STAP_PROBE_ASM(provider, fooprobe,
|
||||||
|
STAP_PROBE_ASM_TEMPLATE(3)) adds an unused argument:
|
||||||
|
STAP_PROBE_ASM(provider, fooprobe, /*template expansion*/ "%[SDT..]..",
|
||||||
|
"use _SDT_ASM_TEMPLATE") A supplied template
|
||||||
|
STAP_PROBE_ASM(provider, fooprobe, "4@%rdx 8@%rax") is left alone. If
|
||||||
|
the varargs has 2 args (the fake "use ..") then macro expansion
|
||||||
|
inserts the expanded string, otherwise "4@.." becomes an ascii op.
|
||||||
|
---
|
||||||
|
includes/sys/sdt.h | 14 ++++++++++----
|
||||||
|
testsuite/systemtap.base/sdt_casm.c | 5 +++++
|
||||||
|
testsuite/systemtap.base/sdt_casm.exp | 3 ++-
|
||||||
|
testsuite/systemtap.base/sdt_casm.stp | 8 ++++++++
|
||||||
|
4 files changed, 25 insertions(+), 5 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/includes/sys/sdt.h b/includes/sys/sdt.h
|
||||||
|
index 28d236d91..24d5e01c3 100644
|
||||||
|
--- a/includes/sys/sdt.h
|
||||||
|
+++ b/includes/sys/sdt.h
|
||||||
|
@@ -290,7 +290,7 @@ __extension__ extern unsigned long long __sdt_unsp;
|
||||||
|
_SDT_ASM_1(.purgem _SDT_TYPE_) \
|
||||||
|
_SDT_ASM_1(.purgem _SDT_TYPE)
|
||||||
|
|
||||||
|
-#define _SDT_ASM_BODY(provider, name, pack_args, args) \
|
||||||
|
+#define _SDT_ASM_BODY(provider, name, pack_args, args, ...) \
|
||||||
|
_SDT_DEF_MACROS \
|
||||||
|
_SDT_ASM_1(990: _SDT_NOP) \
|
||||||
|
_SDT_ASM_3( .pushsection .note.stapsdt,_SDT_ASM_AUTOGROUP,"note") \
|
||||||
|
@@ -417,9 +417,9 @@ __extension__ extern unsigned long long __sdt_unsp;
|
||||||
|
counted, so we don't have to worry about the behavior of macros
|
||||||
|
called without any arguments. */
|
||||||
|
|
||||||
|
-#ifdef SDT_USE_VARIADIC
|
||||||
|
#define _SDT_NARG(...) __SDT_NARG(__VA_ARGS__, 12,11,10,9,8,7,6,5,4,3,2,1,0)
|
||||||
|
#define __SDT_NARG(_0,_1,_2,_3,_4,_5,_6,_7,_8,_9,_10,_11,_12, N, ...) N
|
||||||
|
+#ifdef SDT_USE_VARIADIC
|
||||||
|
#define _SDT_PROBE_N(provider, name, N, ...) \
|
||||||
|
_SDT_PROBE(provider, name, N, (__VA_ARGS__))
|
||||||
|
#define STAP_PROBEV(provider, name, ...) \
|
||||||
|
@@ -468,9 +468,15 @@ __extension__ extern unsigned long long __sdt_unsp;
|
||||||
|
Note that these can use operand templates like %0 or %[name],
|
||||||
|
and likewise they must write %%reg for a literal operand of %reg. */
|
||||||
|
|
||||||
|
+#define _SDT_ASM_BODY_1(p,n,...) _SDT_ASM_BODY(p,n,_SDT_ASM_SUBSTR,(__VA_ARGS__))
|
||||||
|
+#define _SDT_ASM_BODY_2(p,n,...) _SDT_ASM_BODY(p,n,/*_SDT_ASM_STRING */,__VA_ARGS__)
|
||||||
|
+#define _SDT_ASM_BODY_N2(p,n,no,...) _SDT_ASM_BODY_ ## no(p,n,__VA_ARGS__)
|
||||||
|
+#define _SDT_ASM_BODY_N1(p,n,no,...) _SDT_ASM_BODY_N2(p,n,no,__VA_ARGS__)
|
||||||
|
+#define _SDT_ASM_BODY_N(p,n,...) _SDT_ASM_BODY_N1(p,n,_SDT_NARG(0, __VA_ARGS__),__VA_ARGS__)
|
||||||
|
+
|
||||||
|
#if __STDC_VERSION__ >= 199901L
|
||||||
|
# define STAP_PROBE_ASM(provider, name, ...) \
|
||||||
|
- _SDT_ASM_BODY(provider, name, /*_SDT_ASM_STRING */, __VA_ARGS__) \
|
||||||
|
+ _SDT_ASM_BODY_N(provider, name, __VA_ARGS__) \
|
||||||
|
_SDT_ASM_BASE
|
||||||
|
# define STAP_PROBE_ASM_OPERANDS(n, ...) _SDT_ASM_OPERANDS_##n(__VA_ARGS__)
|
||||||
|
#else
|
||||||
|
@@ -478,7 +484,7 @@ __extension__ extern unsigned long long __sdt_unsp;
|
||||||
|
_SDT_ASM_BODY(provider, name, /* _SDT_ASM_STRING */, (args)) \
|
||||||
|
_SDT_ASM_BASE
|
||||||
|
#endif
|
||||||
|
-#define STAP_PROBE_ASM_TEMPLATE(n) _SDT_ASM_TEMPLATE_##n
|
||||||
|
+#define STAP_PROBE_ASM_TEMPLATE(n) _SDT_ASM_TEMPLATE_##n,"use _SDT_ASM_TEMPLATE_"
|
||||||
|
|
||||||
|
|
||||||
|
/* DTrace compatible macro names. */
|
||||||
|
diff --git a/testsuite/systemtap.base/sdt_casm.c b/testsuite/systemtap.base/sdt_casm.c
|
||||||
|
index 1cff23c5f..9b357086c 100644
|
||||||
|
--- a/testsuite/systemtap.base/sdt_casm.c
|
||||||
|
+++ b/testsuite/systemtap.base/sdt_casm.c
|
||||||
|
@@ -3,6 +3,7 @@
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
int x = 42;
|
||||||
|
+ int y = 43;
|
||||||
|
__asm__ __volatile__ (
|
||||||
|
STAP_PROBE_ASM(testsuite, probe0, STAP_PROBE_ASM_TEMPLATE(0))
|
||||||
|
);
|
||||||
|
@@ -10,5 +11,9 @@ int main()
|
||||||
|
STAP_PROBE_ASM(testsuite, probe1, STAP_PROBE_ASM_TEMPLATE(1))
|
||||||
|
:: STAP_PROBE_ASM_OPERANDS(1, x)
|
||||||
|
);
|
||||||
|
+ // Create a template to test explicit template support
|
||||||
|
+ __asm__ __volatile__ (
|
||||||
|
+ STAP_PROBE_ASM(testsuite, probe2, -4@%[ARG1] -4@%[ARG2])
|
||||||
|
+ :: [ARG1] "rm" (x), [ARG2] "rm" (y));
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
diff --git a/testsuite/systemtap.base/sdt_casm.exp b/testsuite/systemtap.base/sdt_casm.exp
|
||||||
|
index 5791cb2b9..0cd1cb517 100644
|
||||||
|
--- a/testsuite/systemtap.base/sdt_casm.exp
|
||||||
|
+++ b/testsuite/systemtap.base/sdt_casm.exp
|
||||||
|
@@ -18,7 +18,8 @@ proc cleanup_handler { verbose } {
|
||||||
|
|
||||||
|
set script $srcdir/$subdir/$test.stp
|
||||||
|
set ::result_string {PASS: probe0
|
||||||
|
-PASS: probe1}
|
||||||
|
+PASS: probe1
|
||||||
|
+PASS: probe2}
|
||||||
|
|
||||||
|
set asm_flags [sdt_includes]
|
||||||
|
set asm_flags "$asm_flags additional_flags=-std=c99"
|
||||||
|
diff --git a/testsuite/systemtap.base/sdt_casm.stp b/testsuite/systemtap.base/sdt_casm.stp
|
||||||
|
index 4f2539c93..530a79175 100644
|
||||||
|
--- a/testsuite/systemtap.base/sdt_casm.stp
|
||||||
|
+++ b/testsuite/systemtap.base/sdt_casm.stp
|
||||||
|
@@ -10,3 +10,11 @@ probe process.mark("probe1")
|
||||||
|
else
|
||||||
|
printf("FAIL: %s (%d != 42)\n", $$name, $arg1)
|
||||||
|
}
|
||||||
|
+
|
||||||
|
+probe process.mark("probe2")
|
||||||
|
+{
|
||||||
|
+ if ($arg1 == 42 && $arg2 == 43)
|
||||||
|
+ printf("PASS: %s\n", $$name)
|
||||||
|
+ else
|
||||||
|
+ printf("FAIL: %s (%d/%d != 42/43)\n", $$name, $arg1, $arg2)
|
||||||
|
+}
|
||||||
|
--
|
||||||
|
2.35.0
|
||||||
|
|
@ -1,3 +1,9 @@
|
|||||||
|
-------------------------------------------------------------------
|
||||||
|
Mon Feb 21 10:56:37 UTC 2022 - Andreas Schwab <schwab@suse.de>
|
||||||
|
|
||||||
|
- Handle-user-supplied-sdt-probe-argument-template.patch: Fix glibc build
|
||||||
|
failure on s390x
|
||||||
|
|
||||||
-------------------------------------------------------------------
|
-------------------------------------------------------------------
|
||||||
Mon Feb 14 15:46:00 UTC 2022 - Tony Jones <tonyj@suse.com>
|
Mon Feb 14 15:46:00 UTC 2022 - Tony Jones <tonyj@suse.com>
|
||||||
|
|
||||||
|
@ -35,6 +35,7 @@ Patch1: systemtap-build-source-dir.patch
|
|||||||
Patch2: sys-sdt.h-fp-constraints-arm32.patch
|
Patch2: sys-sdt.h-fp-constraints-arm32.patch
|
||||||
Patch3: sys-sdt.h-fp-constraints-x86_64.patch
|
Patch3: sys-sdt.h-fp-constraints-x86_64.patch
|
||||||
Patch4: sys-sdt.h-fp-constraints-aarch64-s390.patch
|
Patch4: sys-sdt.h-fp-constraints-aarch64-s390.patch
|
||||||
|
Patch5: Handle-user-supplied-sdt-probe-argument-template.patch
|
||||||
|
|
||||||
BuildArch: noarch
|
BuildArch: noarch
|
||||||
|
|
||||||
|
@ -1,3 +1,9 @@
|
|||||||
|
-------------------------------------------------------------------
|
||||||
|
Mon Feb 21 10:56:37 UTC 2022 - Andreas Schwab <schwab@suse.de>
|
||||||
|
|
||||||
|
- Handle-user-supplied-sdt-probe-argument-template.patch: Fix glibc build
|
||||||
|
failure on s390x
|
||||||
|
|
||||||
-------------------------------------------------------------------
|
-------------------------------------------------------------------
|
||||||
Mon Feb 14 15:46:00 UTC 2022 - Tony Jones <tonyj@suse.com>
|
Mon Feb 14 15:46:00 UTC 2022 - Tony Jones <tonyj@suse.com>
|
||||||
|
|
||||||
|
@ -40,6 +40,7 @@ Patch1: systemtap-build-source-dir.patch
|
|||||||
Patch2: sys-sdt.h-fp-constraints-arm32.patch
|
Patch2: sys-sdt.h-fp-constraints-arm32.patch
|
||||||
Patch3: sys-sdt.h-fp-constraints-x86_64.patch
|
Patch3: sys-sdt.h-fp-constraints-x86_64.patch
|
||||||
Patch4: sys-sdt.h-fp-constraints-aarch64-s390.patch
|
Patch4: sys-sdt.h-fp-constraints-aarch64-s390.patch
|
||||||
|
Patch5: Handle-user-supplied-sdt-probe-argument-template.patch
|
||||||
|
|
||||||
# sdt-devel provides the same header files as us, so we
|
# sdt-devel provides the same header files as us, so we
|
||||||
# must conflict
|
# must conflict
|
||||||
@ -55,7 +56,6 @@ systemtap-sdt-devel, which also contains these headers.
|
|||||||
%setup -q -n systemtap-%{version}
|
%setup -q -n systemtap-%{version}
|
||||||
%autopatch -p1
|
%autopatch -p1
|
||||||
|
|
||||||
|
|
||||||
%build
|
%build
|
||||||
# Our binutils always support '?' in the section characters on all
|
# Our binutils always support '?' in the section characters on all
|
||||||
# architectures, no need for configure tests
|
# architectures, no need for configure tests
|
||||||
|
@ -1,3 +1,9 @@
|
|||||||
|
-------------------------------------------------------------------
|
||||||
|
Mon Feb 21 10:56:37 UTC 2022 - Andreas Schwab <schwab@suse.de>
|
||||||
|
|
||||||
|
- Handle-user-supplied-sdt-probe-argument-template.patch: Fix glibc build
|
||||||
|
failure on s390x
|
||||||
|
|
||||||
-------------------------------------------------------------------
|
-------------------------------------------------------------------
|
||||||
Mon Feb 14 15:46:00 UTC 2022 - Tony Jones <tonyj@suse.com>
|
Mon Feb 14 15:46:00 UTC 2022 - Tony Jones <tonyj@suse.com>
|
||||||
|
|
||||||
|
@ -36,6 +36,7 @@ Patch1: systemtap-build-source-dir.patch
|
|||||||
Patch2: sys-sdt.h-fp-constraints-arm32.patch
|
Patch2: sys-sdt.h-fp-constraints-arm32.patch
|
||||||
Patch3: sys-sdt.h-fp-constraints-x86_64.patch
|
Patch3: sys-sdt.h-fp-constraints-x86_64.patch
|
||||||
Patch4: sys-sdt.h-fp-constraints-aarch64-s390.patch
|
Patch4: sys-sdt.h-fp-constraints-aarch64-s390.patch
|
||||||
|
Patch5: Handle-user-supplied-sdt-probe-argument-template.patch
|
||||||
|
|
||||||
BuildRequires: autoconf
|
BuildRequires: autoconf
|
||||||
BuildRequires: automake
|
BuildRequires: automake
|
||||||
|
Loading…
Reference in New Issue
Block a user