summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2008-07-09 15:23:23 +0000
committerNick Mathewson <nickm@torproject.org>2008-07-09 15:23:23 +0000
commitc5ec7a367766a301a53318eb0f790b57b046b353 (patch)
tree4a1958cfc8428ca15403747f83a7286b1a736cd2 /src
parent33a1210ec38639d213cd9dda9a9d2ad2f6d02e2e (diff)
downloadtor-c5ec7a367766a301a53318eb0f790b57b046b353.tar.gz
tor-c5ec7a367766a301a53318eb0f790b57b046b353.zip
Stop using __attribute__((nonnull)): It gets us occcasional warnings when we do something so foolish it can be detected without dataflow analysis, but it also eliminates some of our error checking code. Suggested by Peter Gutmann.
svn:r15803
Diffstat (limited to 'src')
-rw-r--r--src/common/compat.h12
1 files changed, 11 insertions, 1 deletions
diff --git a/src/common/compat.h b/src/common/compat.h
index 5ec969fa11..7ad964c75d 100644
--- a/src/common/compat.h
+++ b/src/common/compat.h
@@ -122,7 +122,17 @@ extern INLINE double U64_TO_DBL(uint64_t x) {
#define ATTR_CONST __attribute__((const))
#define ATTR_MALLOC __attribute__((malloc))
#define ATTR_NORETURN __attribute__((noreturn))
-#define ATTR_NONNULL(x) __attribute__((nonnull x))
+/* Alas, nonnull is not at present a good idea for us. We'd like to get
+ * warnings when we pass NULL where we shouldn't (which nonnull does, albeit
+ * spottily), but we don't want to tell the compiler to make optimizations
+ * with the assumption that the argument can't be NULL (since this would make
+ * many of our checks go away, and make our code less robust against
+ * programming errors). Unfortunately, nonnull currently does both of these
+ * things, and there's no good way to split them up.
+ *
+ * #define ATTR_NONNULL(x) __attribute__((nonnull x)) */
+#define ATTR_NONNULL(x)
+
/** Macro: Evaluates to <b>exp</b> and hints the compiler that the value
* of <b>exp</b> will probably be true. */
#define PREDICT_LIKELY(exp) __builtin_expect((exp), 1)