* [Bug server/26839] Systemtap build failures with clang
2020-11-04 8:27 [Bug server/26839] New: Systemtap build failures with clang tbaeder at redhat dot com
@ 2020-11-05 1:11 ` fche at redhat dot com
2020-11-05 1:23 ` fche at redhat dot com
` (9 subsequent siblings)
10 siblings, 0 replies; 12+ messages in thread
From: fche at redhat dot com @ 2020-11-05 1:11 UTC (permalink / raw)
To: systemtap
https://sourceware.org/bugzilla/show_bug.cgi?id=26839
Frank Ch. Eigler <fche at redhat dot com> changed:
What |Removed |Added
----------------------------------------------------------------------------
CC| |fche at redhat dot com
--- Comment #1 from Frank Ch. Eigler <fche at redhat dot com> ---
Timm, thanks for the report.
We'd appreciate your help in fixing these c++ hygiene issues.
Regarding class/struct, sure please go ahead.
Regarding overrides / hidden overloads ... um, news to me. :-)
We may have some dead code, will look into it further.
Regarding labs() in util.cxx, we intended to use signed values,
so abs() would make sense.
--
You are receiving this mail because:
You are the assignee for the bug.
^ permalink raw reply [flat|nested] 12+ messages in thread
* [Bug server/26839] Systemtap build failures with clang
2020-11-04 8:27 [Bug server/26839] New: Systemtap build failures with clang tbaeder at redhat dot com
2020-11-05 1:11 ` [Bug server/26839] " fche at redhat dot com
@ 2020-11-05 1:23 ` fche at redhat dot com
2020-11-05 9:21 ` tbaeder at redhat dot com
` (8 subsequent siblings)
10 siblings, 0 replies; 12+ messages in thread
From: fche at redhat dot com @ 2020-11-05 1:23 UTC (permalink / raw)
To: systemtap
https://sourceware.org/bugzilla/show_bug.cgi?id=26839
--- Comment #2 from Frank Ch. Eigler <fche at redhat dot com> ---
Regarding overrides, I believe we're just seeing a side-effect of the partial
gradual c++11-ization of the code base. We haven't added the
cxx_override/override specifier systematically, and it appears g++ hasn't been
insisting either. I believe that in just about every case, we mean to override
rather than hide member functions.
--
You are receiving this mail because:
You are the assignee for the bug.
^ permalink raw reply [flat|nested] 12+ messages in thread
* [Bug server/26839] Systemtap build failures with clang
2020-11-04 8:27 [Bug server/26839] New: Systemtap build failures with clang tbaeder at redhat dot com
2020-11-05 1:11 ` [Bug server/26839] " fche at redhat dot com
2020-11-05 1:23 ` fche at redhat dot com
@ 2020-11-05 9:21 ` tbaeder at redhat dot com
2020-11-23 19:12 ` tstellar at redhat dot com
` (7 subsequent siblings)
10 siblings, 0 replies; 12+ messages in thread
From: tbaeder at redhat dot com @ 2020-11-05 9:21 UTC (permalink / raw)
To: systemtap
https://sourceware.org/bugzilla/show_bug.cgi?id=26839
--- Comment #3 from Timm Bäder <tbaeder at redhat dot com> ---
Thanks for the reply, I'll work on this.
I changed the labs() line to:
unsigned min_score = abs(static_cast<signed>(target.size()) -
static_cast<signed>(it->size()));
since using the unsigned values generates another error:
util.cxx:1545:28: error: call to 'abs' is ambiguous
unsigned min_score = abs(target.size() - it->size());
^~~
/usr/include/stdlib.h:840:12: note: candidate function
extern int abs (int __x) __THROW __attribute__ ((__const__)) __wur;
^
/usr/bin/../lib/gcc/x86_64-redhat-linux/10/../../../../include/c++/10/bits/std_abs.h:56:3:
note: candidate function
abs(long __i) { return __builtin_labs(__i); }
^
/usr/bin/../lib/gcc/x86_64-redhat-linux/10/../../../../include/c++/10/bits/std_abs.h:61:3:
note: candidate function
abs(long long __x) { return __builtin_llabs (__x); }
^
/usr/bin/../lib/gcc/x86_64-redhat-linux/10/../../../../include/c++/10/bits/std_abs.h:71:3:
note: candidate function
abs(double __x)
^
/usr/bin/../lib/gcc/x86_64-redhat-linux/10/../../../../include/c++/10/bits/std_abs.h:75:3:
note: candidate function
abs(float __x)
^
/usr/bin/../lib/gcc/x86_64-redhat-linux/10/../../../../include/c++/10/bits/std_abs.h:79:3:
note: candidate function
abs(long double __x)
^
/usr/bin/../lib/gcc/x86_64-redhat-linux/10/../../../../include/c++/10/bits/std_abs.h:85:3:
note: candidate function
abs(__GLIBCXX_TYPE_INT_N_0 __x) { return __x >= 0 ? __x : -__x; }
^
/usr/bin/../lib/gcc/x86_64-redhat-linux/10/../../../../include/c++/10/bits/std_abs.h:103:3:
note: candidate function
abs(__float128 __x)
^
After adding the 'override' to emit_function() and emit_probe() in
translate.cxx as well as collect_derivation_chain() and
collect_derivation_pp_chain() in elaborate.h, I run into a few other issues:
1) set2 in bpf-bitset.h does not return anything from its assignment operator
but specifies a set2& return value. I fixed this with a 'return *this', but
maybe this is just dead code and should be removed?
2) set1_ref and set1_const_ref have a user-defined copy-assignment operator but
use the implicitly defined copy constructor, which clang warns about:
./bpf-bitset.h:108:19: error: definition of implicit copy constructor for
'set1_const_ref' is deprecated because it has a user-declared copy assignment
operator [-Werror,-Wdeprecated-copy]
set1_const_ref& operator= (const set1_const_ref &); // not present
^
./bpf-bitset.h:256:12: note: in implicit copy constructor for
'bpf::bitset::set1_const_ref' first required here
return set1_const_ref(data + w2 * i, w2);
Solved this by just defining those missing copy constructors explicitly, e.g.:
+ set1_const_ref(const set1_const_ref &o) : data(o.data), words(o.words) { }
After this, I'm looking at clang and gcc handling -Wformat-nonliteral
differently. Clang warns about this but gcc does not:
common.c:691:20: error: format string is not a string literal
[-Werror,-Wformat-nonliteral]
vsyslog(LOG_ERR, fmt, va);
^~~
common.c:693:20: error: format string is not a string literal
[-Werror,-Wformat-nonliteral]
vfprintf(stderr, fmt, va);
^~~
And another time in stapbpf.cxx:
stapbpf.cxx:257:20: error: format string is not a string literal
[-Werror,-Wformat-nonliteral]
vfprintf(stderr, str, va);
Not quite sure how to best handle these. Adding a
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Wformat-nonliteral"
// Code
#pragma GCC diagnostic pop
block works for clang as well and is also done in e.g. stapbpf/bpfinterp.cxx
for other code. What do you think?
Other than that, the only problem left is the printsig() stuff from above.
--
You are receiving this mail because:
You are the assignee for the bug.
^ permalink raw reply [flat|nested] 12+ messages in thread
* [Bug server/26839] Systemtap build failures with clang
2020-11-04 8:27 [Bug server/26839] New: Systemtap build failures with clang tbaeder at redhat dot com
` (2 preceding siblings ...)
2020-11-05 9:21 ` tbaeder at redhat dot com
@ 2020-11-23 19:12 ` tstellar at redhat dot com
2020-11-24 7:52 ` tbaeder at redhat dot com
` (6 subsequent siblings)
10 siblings, 0 replies; 12+ messages in thread
From: tstellar at redhat dot com @ 2020-11-23 19:12 UTC (permalink / raw)
To: systemtap
https://sourceware.org/bugzilla/show_bug.cgi?id=26839
Tom Stellard <tstellar at redhat dot com> changed:
What |Removed |Added
----------------------------------------------------------------------------
CC| |tstellar at redhat dot com
--- Comment #4 from Tom Stellard <tstellar at redhat dot com> ---
How far did you get on these fixes? Do you have any patches to share?
--
You are receiving this mail because:
You are the assignee for the bug.
^ permalink raw reply [flat|nested] 12+ messages in thread
* [Bug server/26839] Systemtap build failures with clang
2020-11-04 8:27 [Bug server/26839] New: Systemtap build failures with clang tbaeder at redhat dot com
` (3 preceding siblings ...)
2020-11-23 19:12 ` tstellar at redhat dot com
@ 2020-11-24 7:52 ` tbaeder at redhat dot com
2021-01-18 12:06 ` tbaeder at redhat dot com
` (5 subsequent siblings)
10 siblings, 0 replies; 12+ messages in thread
From: tbaeder at redhat dot com @ 2020-11-24 7:52 UTC (permalink / raw)
To: systemtap
https://sourceware.org/bugzilla/show_bug.cgi?id=26839
--- Comment #5 from Timm Bäder <tbaeder at redhat dot com> ---
I have four patches locally. I think the only problems remaining are the
derived_probe::printsig() and the -Wformat-literal one. Those are up for the
maintainers to decide I believe.
There are additional problems in the test suite, but I haven't looked at those
in detail yet.
--
You are receiving this mail because:
You are the assignee for the bug.
^ permalink raw reply [flat|nested] 12+ messages in thread
* [Bug server/26839] Systemtap build failures with clang
2020-11-04 8:27 [Bug server/26839] New: Systemtap build failures with clang tbaeder at redhat dot com
` (4 preceding siblings ...)
2020-11-24 7:52 ` tbaeder at redhat dot com
@ 2021-01-18 12:06 ` tbaeder at redhat dot com
2021-01-18 15:10 ` tstellar at redhat dot com
` (4 subsequent siblings)
10 siblings, 0 replies; 12+ messages in thread
From: tbaeder at redhat dot com @ 2021-01-18 12:06 UTC (permalink / raw)
To: systemtap
https://sourceware.org/bugzilla/show_bug.cgi?id=26839
--- Comment #6 from Timm Bäder <tbaeder at redhat dot com> ---
Adding the GCC diagnostic pragmas to the printf-like functions was wrong btw
and just adding the appropriate __attribute__((format(printf, x, y)))
attributes is better, fixes the problems with clang and gives us better error
reporting.
It also shows a few problems with the current un-annotated functions like this
one in staprun/relay.c:
--- a/staprun/relay.c
+++ b/staprun/relay.c
@@ -272,7 +272,7 @@ static void switchfile_handler(int sig)
pthread_mutex_lock(&mutex[avail_cpus[i]]);
if (reader[avail_cpus[i]] && switch_file[avail_cpus[i]]) {
pthread_mutex_unlock(&mutex[avail_cpus[i]]);
- dbug(2, "file switching is progressing, signal
ignored.\n", sig);
+ dbug(2, "file switching is progressing, signal %d
ignored.\n", sig);
return;
}
pthread_mutex_unlock(&mutex[avail_cpus[i]]);
diff --git a/staprun/staprun.h b/staprun/staprun.h
Frank, do you have an opinion about the printsig() issue? Or should I just post
the patches I already have?
Thanks,
Timm
--
You are receiving this mail because:
You are the assignee for the bug.
^ permalink raw reply [flat|nested] 12+ messages in thread
* [Bug server/26839] Systemtap build failures with clang
2020-11-04 8:27 [Bug server/26839] New: Systemtap build failures with clang tbaeder at redhat dot com
` (5 preceding siblings ...)
2021-01-18 12:06 ` tbaeder at redhat dot com
@ 2021-01-18 15:10 ` tstellar at redhat dot com
2021-05-11 12:00 ` tbaeder at redhat dot com
` (3 subsequent siblings)
10 siblings, 0 replies; 12+ messages in thread
From: tstellar at redhat dot com @ 2021-01-18 15:10 UTC (permalink / raw)
To: systemtap
https://sourceware.org/bugzilla/show_bug.cgi?id=26839
--- Comment #7 from Tom Stellard <tstellar at redhat dot com> ---
Timm, I sent in your patches plus a few others back in November, but forgot to
update the bug. See
https://sourceware.org/pipermail/systemtap/2020q4/027085.html
--
You are receiving this mail because:
You are the assignee for the bug.
^ permalink raw reply [flat|nested] 12+ messages in thread
* [Bug server/26839] Systemtap build failures with clang
2020-11-04 8:27 [Bug server/26839] New: Systemtap build failures with clang tbaeder at redhat dot com
` (6 preceding siblings ...)
2021-01-18 15:10 ` tstellar at redhat dot com
@ 2021-05-11 12:00 ` tbaeder at redhat dot com
2021-05-13 2:17 ` amerey at redhat dot com
` (2 subsequent siblings)
10 siblings, 0 replies; 12+ messages in thread
From: tbaeder at redhat dot com @ 2021-05-11 12:00 UTC (permalink / raw)
To: systemtap
https://sourceware.org/bugzilla/show_bug.cgi?id=26839
--- Comment #8 from Timm Bäder <tbaeder at redhat dot com> ---
Hey Frank do you have any update on this? We've been carrying the patches
around for a while now and they need maintenance and start to collide with
upstream changes, e.g.
https://sourceware.org/git/?p=systemtap.git;a=commit;h=439fb4cc4c08166dccb85ba202a5762c4c46ba42
I think only the probe::printsig() problems need clarification, the other ones
are straight forward.
--
You are receiving this mail because:
You are the assignee for the bug.
^ permalink raw reply [flat|nested] 12+ messages in thread
* [Bug server/26839] Systemtap build failures with clang
2020-11-04 8:27 [Bug server/26839] New: Systemtap build failures with clang tbaeder at redhat dot com
` (7 preceding siblings ...)
2021-05-11 12:00 ` tbaeder at redhat dot com
@ 2021-05-13 2:17 ` amerey at redhat dot com
2021-05-14 7:57 ` tbaeder at redhat dot com
2021-05-19 21:46 ` amerey at redhat dot com
10 siblings, 0 replies; 12+ messages in thread
From: amerey at redhat dot com @ 2021-05-13 2:17 UTC (permalink / raw)
To: systemtap
https://sourceware.org/bugzilla/show_bug.cgi?id=26839
Aaron Merey <amerey at redhat dot com> changed:
What |Removed |Added
----------------------------------------------------------------------------
CC| |amerey at redhat dot com
--- Comment #9 from Aaron Merey <amerey at redhat dot com> ---
(In reply to Timm Bäder from comment #8)
> Hey Frank do you have any update on this? We've been carrying the patches
> around for a while now and they need maintenance and start to collide with
> upstream changes, e.g.
> https://sourceware.org/git/?p=systemtap.git;a=commit;
> h=439fb4cc4c08166dccb85ba202a5762c4c46ba42
>
> I think only the probe::printsig() problems need clarification, the other
> ones are straight forward.
Hi Timm. When I merged that commit I didn't realise you had a similar patch
pending. Regarding the printsig patch, I would suggest dropping the 'bool nest
= true' definitions and instead call printsig_nested unconditionally.
Otherwise the patch set looks ok. With it, gcc still compiles systemtap without
error and we are closer to being able to compile systemtap with clang. I still
get an errors when compiling with clang however. ex. `unsupported argument
'auto' to option 'flto='` when compiling
systemtap/python/HelperSDT/_HelperSDT.c
--
You are receiving this mail because:
You are the assignee for the bug.
^ permalink raw reply [flat|nested] 12+ messages in thread
* [Bug server/26839] Systemtap build failures with clang
2020-11-04 8:27 [Bug server/26839] New: Systemtap build failures with clang tbaeder at redhat dot com
` (8 preceding siblings ...)
2021-05-13 2:17 ` amerey at redhat dot com
@ 2021-05-14 7:57 ` tbaeder at redhat dot com
2021-05-19 21:46 ` amerey at redhat dot com
10 siblings, 0 replies; 12+ messages in thread
From: tbaeder at redhat dot com @ 2021-05-14 7:57 UTC (permalink / raw)
To: systemtap
https://sourceware.org/bugzilla/show_bug.cgi?id=26839
--- Comment #10 from Timm Bäder <tbaeder at redhat dot com> ---
(In reply to Aaron Merey from comment #9)
> (In reply to Timm Bäder from comment #8)
> > Hey Frank do you have any update on this? We've been carrying the patches
> > around for a while now and they need maintenance and start to collide with
> > upstream changes, e.g.
> > https://sourceware.org/git/?p=systemtap.git;a=commit;
> > h=439fb4cc4c08166dccb85ba202a5762c4c46ba42
> >
> > I think only the probe::printsig() problems need clarification, the other
> > ones are straight forward.
>
> Hi Timm. When I merged that commit I didn't realise you had a similar patch
> pending. Regarding the printsig patch, I would suggest dropping the 'bool
> nest = true' definitions and instead call printsig_nested unconditionally.
No problem, in the end it's one patch less we carry around. Dropping the nest
bool is fine with me of course, I have a patch doing that. I can't seem to find
where to send patches however, the mailing list seems to have remarkably few of
them and the HACKING document doesn't seem to mention? Where does systemtap
development happen?
> Otherwise the patch set looks ok. With it, gcc still compiles systemtap
> without error and we are closer to being able to compile systemtap with
> clang. I still get an errors when compiling with clang however. ex.
> `unsupported argument 'auto' to option 'flto='` when compiling
> systemtap/python/HelperSDT/_HelperSDT.c
I can't seem to find where -flto=auto could come from within the systemtap
sources, is that in your env somehow? That shouldn't be used when compiling
with clang. If you need a workaround, setting
CCC_OVERRIDE_OPTIONS="x-flto=auto" should work.
Later versions of clang will also ignore -flto=auto:
https://github.com/llvm/llvm-project/commit/1628486548420f85b3467026d54663d1516404f5
--
You are receiving this mail because:
You are the assignee for the bug.
^ permalink raw reply [flat|nested] 12+ messages in thread
* [Bug server/26839] Systemtap build failures with clang
2020-11-04 8:27 [Bug server/26839] New: Systemtap build failures with clang tbaeder at redhat dot com
` (9 preceding siblings ...)
2021-05-14 7:57 ` tbaeder at redhat dot com
@ 2021-05-19 21:46 ` amerey at redhat dot com
10 siblings, 0 replies; 12+ messages in thread
From: amerey at redhat dot com @ 2021-05-19 21:46 UTC (permalink / raw)
To: systemtap
https://sourceware.org/bugzilla/show_bug.cgi?id=26839
Aaron Merey <amerey at redhat dot com> changed:
What |Removed |Added
----------------------------------------------------------------------------
Status|NEW |RESOLVED
Resolution|--- |FIXED
--- Comment #11 from Aaron Merey <amerey at redhat dot com> ---
Thanks for your patience Timm. I've merged your patch set, see the following
commits:
14f04522b5
930b541193
6de815bcaa
0f4bd32197
545535f823
b3a3929751
8e5145ae4c
I also merged a patch to fix a couple more -Wformat-nonliteral and
-Wmismatched-tags I ran into (commit 3e9bcd7b1fcf).
With these patches and CCC_OVERRIDE_OPTIONS="x-flto=auto" I can successfully
build systemtap with clang.
--
You are receiving this mail because:
You are the assignee for the bug.
^ permalink raw reply [flat|nested] 12+ messages in thread