summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2018-07-20 11:18:11 -0400
committerNick Mathewson <nickm@torproject.org>2018-07-20 11:19:54 -0400
commitc515dc8d0d17b9ce5e8c4f31ba2bd58c15fb90bf (patch)
tree05fe95bf0770a97c121cb75a2e406b757cfce874
parent9ae35975402a823a420cd5efb81a1c3a76f6c4d6 (diff)
downloadtor-c515dc8d0d17b9ce5e8c4f31ba2bd58c15fb90bf.tar.gz
tor-c515dc8d0d17b9ce5e8c4f31ba2bd58c15fb90bf.zip
Remove over-cleverness from our coverity BUG() definition.
Our previous definition implied that code would never keep running if a BUG occurred (which it does), and that BUG(x) might be true even if x was false (which it can't be). Closes ticket 26890. Bugfix on 0.3.1.4-alpha.
-rw-r--r--src/lib/log/util_bug.c4
-rw-r--r--src/lib/log/util_bug.h3
2 files changed, 1 insertions, 6 deletions
diff --git a/src/lib/log/util_bug.c b/src/lib/log/util_bug.c
index 42b3670a71..b23f4edc97 100644
--- a/src/lib/log/util_bug.c
+++ b/src/lib/log/util_bug.c
@@ -20,10 +20,6 @@
#include <string.h>
-#ifdef __COVERITY__
-int bug_macro_deadcode_dummy__ = 0;
-#endif
-
#ifdef TOR_UNIT_TESTS
static void (*failed_assertion_cb)(void) = NULL;
static int n_bugs_to_capture = 0;
diff --git a/src/lib/log/util_bug.h b/src/lib/log/util_bug.h
index 61ee60f729..2ef5be8d3f 100644
--- a/src/lib/log/util_bug.h
+++ b/src/lib/log/util_bug.h
@@ -86,13 +86,12 @@
*/
#ifdef __COVERITY__
-extern int bug_macro_deadcode_dummy__;
#undef BUG
// Coverity defines this in global headers; let's override it. This is a
// magic coverity-only preprocessor thing.
// We use this "deadcode_dummy__" trick to prevent coverity from
// complaining about unreachable bug cases.
-#nodef BUG(x) ((x)?(__coverity_panic__(),1):(0+bug_macro_deadcode_dummy__))
+#nodef BUG(x) (x)
#endif /* defined(__COVERITY__) */
#if defined(__COVERITY__) || defined(__clang_analyzer__)