Add -ftrapv to CFLAGS and CXXFLAGS when –enable-debug is used. Enable -ftrapv in Travis. #12686
pull practicalswift wants to merge 2 commits into bitcoin:master from practicalswift:trapv changing 2 files +2 −1-
practicalswift commented at 10:42 am on March 14, 2018: contributorBy generating a trap for signed overflow on addition, subtraction, multiplication operations in the Travis testing we are more likely to identify problematic code prior to merging it.
-
fanquake added the label Tests on Mar 14, 2018
-
fanquake commented at 2:36 pm on March 14, 2018: member
HOST=x86_64-unknown-linux-gnu
0The command "test -n "$USE_SHELL" && eval '"$USE_SHELL" -c "./autogen.sh"' || ./autogen.sh" exited with 0. 1$ mkdir build && cd build 2 3The command "mkdir build && cd build" exited with 0. 4$ ../configure --cache-file=config.cache $BITCOIN_CONFIG_ALL $BITCOIN_CONFIG || ( cat config.log && false) 5configure: error: unrecognized option: `-ftrapv'' 6Try `../configure --help' for more information 7cat: config.log: No such file or directory 8 9The command "../configure --cache-file=config.cache $BITCOIN_CONFIG_ALL $BITCOIN_CONFIG || ( cat config.log && false)" exited with 1. 10$ make distdir VERSION=$HOST 11make: *** No rule to make target `distdir'. Stop.
-
eklitzke commented at 10:36 pm on March 14, 2018: contributor
This is cool, concept ack.
Looks like there are some problems:
- -fwrapv belongs in CXXFLAGS not in CPPFLAGS
- Travis is being weird. The builders that passed seem to have used some kind of cached config and didn’t actually pick up -ftrapv. The one that’s failing is failing because there’s a shell quoting issue with how configure is invoked.
GCC 4.8 also supports -fsanitize=address and -fsanitize=thread (and newer GCC versions have a whole plethora or really interesting options). What do you think about using those options in Travis as well?
-
eklitzke changes_requested
-
eklitzke commented at 10:58 pm on March 14, 2018: contributorThere’s a shell quoting issue with how travis is running this.
-
eklitzke commented at 11:07 pm on March 14, 2018: contributor
Here’s an idea for another way to do this: https://github.com/eklitzke/bitcoin/commit/635e378383c41c8ef3ac03fca1755001c947b7f7 . The idea is to add
-ftrapv
when--enable-debug
is used, and then use that option on all of the Travis jobs.--enable-debug
also sets-DDEBUG_LOCKORDER
.What do you think of this approach?
-
eklitzke commented at 6:36 am on March 15, 2018: contributor
BTW the right way to fix the quoting issue in Travis is to use a bash array. It looks like Travis doesn’t support these properly. If you still wanted to use this approach instead of modifying configure.ac as in my example two options:
IFS
hacks- Create yet-another-Travis-variable and pass it down to the configure call
-
practicalswift force-pushed on Mar 15, 2018
-
practicalswift commented at 7:20 am on March 15, 2018: contributor
@eklitzke Thanks for reviewing. I’ve now cherry-picked your commit (which is the better solution) into this PR.
Please re-review :-)
-
practicalswift commented at 7:23 am on March 15, 2018: contributor@eklitzke Enabling
-fsanitize=address
and-fsanitize=thread
in Travis (after cleaning up remaining violations) would be really really nice! -
eklitzke commented at 8:06 am on March 15, 2018: contributor
It looks like this doesn’t work for the MingW builds, I got timeouts in my travis runs that match the ones you just cherry-picked: https://travis-ci.org/eklitzke/bitcoin/builds/353587968 . Let’s disable the option for those two builders.
I added some -fsanitize support to the configure script in #12692, which is a good start since it will make using those flags easier (even if the code isn’t currently clean under asan/tsan).
-
practicalswift force-pushed on Mar 15, 2018
-
practicalswift renamed this:
travis: Generate a trap for signed arithmetic overflows (enable -ftrapv)
Add -ftrapv to CFLAGS and CXXFLAGS when --enable-debug is used. Enable -ftrapv in Travis.
on Mar 15, 2018 -
practicalswift commented at 3:16 pm on March 15, 2018: contributor
@eklitzke To keep the changes as small as possible I’ve now enabled
-ftrapv
(via--enable-debug
) only for one of the Travis jobs (job: “Qt4 & system libs”). Makes sense?Please re-review :-)
-
fanquake commented at 2:09 am on March 16, 2018: member@practicalswift I don’t think you’ve cherry-picked correctly, looks like you just swapped out the changes in your commit with @eklitzke’s ?
-
eklitzke commented at 5:16 am on March 16, 2018: contributorThis looks right to me, utACK e23dfbb01df044e6d0dc65f6b9333e6547202fa7.
-
practicalswift commented at 5:46 pm on March 18, 2018: contributor@fanquake The cherry-pick was a previous version. e23dfbb01df044e6d0dc65f6b9333e6547202fa7 is correct. Please review :-)
-
laanwj assigned theuni on Apr 2, 2018
-
practicalswift force-pushed on Apr 14, 2018
-
practicalswift commented at 1:09 pm on April 14, 2018: contributorRebased! Please re-review :-)
-
practicalswift force-pushed on Apr 14, 2018
-
practicalswift force-pushed on Apr 16, 2018
-
practicalswift commented at 9:10 am on April 23, 2018: contributorInteresting – judging from the Travis testing it seems that the trap is trigged indicating that we have a signed overflow taking place when running the tests. Let’s find out where!
-
in .travis.yml:35 in bb2d161746 outdated
29@@ -30,7 +30,7 @@ env: 30 # 32-bit + dash 31 - HOST=i686-pc-linux-gnu PACKAGES="g++-multilib python3-zmq" DEP_OPTS="NO_QT=1" RUN_TESTS=true GOAL="install" BITCOIN_CONFIG="--enable-zmq --enable-glibc-back-compat --enable-reduce-exports LDFLAGS=-static-libstdc++" USE_SHELL="/bin/dash" 32 # x86_64 Linux (uses qt5 dev package instead of depends Qt to speed up build and avoid timeout) 33- - HOST=x86_64-unknown-linux-gnu PACKAGES="python3-zmq qtbase5-dev qttools5-dev-tools protobuf-compiler libdbus-1-dev libharfbuzz-dev" DEP_OPTS="NO_QT=1 NO_UPNP=1 DEBUG=1 ALLOW_HOST_PACKAGES=1" RUN_TESTS=true GOAL="install" BITCOIN_CONFIG="--enable-zmq --with-gui=qt5 --enable-glibc-back-compat --enable-reduce-exports CPPFLAGS=-DDEBUG_LOCKORDER"
theuni commented at 6:05 pm on April 23, 2018:Removing
DEBUG=1
here should cause depends to no longer build as debug.+1 on using –enable-debug, though.
practicalswift commented at 1:21 pm on May 5, 2018:Updated: Re-introducedDEBUG=1
:-)practicalswift force-pushed on May 5, 2018practicalswift force-pushed on May 14, 2018practicalswift force-pushed on May 14, 2018practicalswift commented at 2:02 pm on May 14, 2018: contributorNow using
AX_CHECK_COMPILE_FLAG
for checking-trapv
availability when compiled under--enable-debug
:0$ ./configure --enable-debug 1… 2checking whether C++ compiler accepts -ftrapv... yes 3… 4 CXXFLAGS = -Og -g3 -ftrapv -Wstack-protector -fstack-protector-all -g -O2 -Wall -Wextra -Wformat -Wvla -Wformat-security -Wno-unused-parameter 5…
theuni commented at 10:51 pm on May 15, 2018: memberPlease add the CXXFLAG_WERROR argument so that we’ll see false-positives. utACK otherwise.practicalswift force-pushed on May 16, 2018practicalswift force-pushed on May 16, 2018practicalswift commented at 7:28 am on May 16, 2018: contributor@TheBlueMatt Added theCXXFLAG_WERROR
argument. Please re-review :-)practicalswift force-pushed on May 29, 2018practicalswift commented at 10:06 pm on May 29, 2018: contributorRebased!theuni commented at 10:33 pm on June 12, 2018: memberutACK 8bf481fe2e99e6a0e16a6127d7df826dd4bfa2e9DrahtBot added the label Needs rebase on Jun 24, 2018DrahtBot commented at 2:21 pm on June 24, 2018: memberAdd -ftrapv to DEBUG_CXXFLAGS when --enable-debug is used 94e52d13dbtravis: Build with --enable-debug (x86_64-unknown-linux-gnu) 98d842cb52practicalswift force-pushed on Jun 24, 2018practicalswift commented at 6:36 pm on June 24, 2018: contributorRebased!MarcoFalke commented at 6:41 pm on June 24, 2018: memberACK 98d842cb52 (that the rebase was done correctly, didn’t look at anything else)DrahtBot removed the label Needs rebase on Jun 24, 2018sipa commented at 0:54 am on June 27, 2018: memberutACK 98d842cb52e69ea1f9961d908385c896e37fb877sipa merged this on Jun 27, 2018sipa closed this on Jun 27, 2018
sipa referenced this in commit 2643fa5086 on Jun 27, 2018MarcoFalke referenced this in commit 7a9bca61fa on Jul 24, 2018zkbot referenced this in commit 8e8a9350c3 on Jan 30, 2020MarcoFalke referenced this in commit 7027c67cac on Jul 2, 2020practicalswift deleted the branch on Apr 10, 2021UdjinM6 referenced this in commit 5836a28644 on Jun 29, 2021UdjinM6 referenced this in commit a0426da513 on Jun 29, 2021UdjinM6 referenced this in commit ad039fd4f0 on Jul 1, 2021vijaydasmp referenced this in commit dfa262c93f on Oct 4, 2021Munkybooty referenced this in commit 3285e21cfd on Apr 26, 2022DrahtBot locked this on Aug 16, 2022
This is a metadata mirror of the GitHub repository bitcoin/bitcoin. This site is not affiliated with GitHub. Content is generated from a GitHub metadata backup.
generated: 2025-01-22 06:12 UTC
More mirrored repositories can be found on mirror.b10c.me