summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2016-02-22 14:07:58 -0500
committerNick Mathewson <nickm@torproject.org>2016-02-23 14:05:34 -0500
commit67e5d49d8a995c6d3b8bf4177046271a7d4dd157 (patch)
treefa936203f3dd47a2240ed9281458fa5020649320
parentbe6174f8f6aaaf8f990eb56c5cba16bc5ec0fcea (diff)
downloadtor-67e5d49d8a995c6d3b8bf4177046271a7d4dd157.tar.gz
tor-67e5d49d8a995c6d3b8bf4177046271a7d4dd157.zip
Make clang asan work with FORTIFIED_SOURCE again.
Short version: clang asan hates the glibc strcmp macro in bits/string2.h if you are passing it a constant string argument of length two or less. (I could be off by one here, but that's the basic idea.) Closes issue 14821.
-rw-r--r--changes/bug148214
-rw-r--r--src/common/compat.h9
2 files changed, 13 insertions, 0 deletions
diff --git a/changes/bug14821 b/changes/bug14821
new file mode 100644
index 0000000000..0920d1fffc
--- /dev/null
+++ b/changes/bug14821
@@ -0,0 +1,4 @@
+ o Major bugfixes (compilation):
+ - Correctly repair hardened builds under the clang compiler. Previously,
+ our use of _FORTIFY_SOURCE would conflict with clang's address
+ sanitizer. Closes ticket 14821.
diff --git a/src/common/compat.h b/src/common/compat.h
index c7c468c754..66cc079259 100644
--- a/src/common/compat.h
+++ b/src/common/compat.h
@@ -42,6 +42,15 @@
#include <netinet6/in6.h>
#endif
+#if defined(__has_feature)
+# if __has_feature(address_sanitizer)
+/* Some of the fancy glibc strcmp() macros include references to memory that
+ * clang rejects because it is off the end of a less-than-3. Clang hates this,
+ * even though those references never actually happen. */
+# undef strcmp
+# endif
+#endif
+
#include <stdio.h>
#include <errno.h>