aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNick Coghlan <ncoghlan@gmail.com>2013-09-29 00:28:55 +1000
committerNick Coghlan <ncoghlan@gmail.com>2013-09-29 00:28:55 +1000
commit6ba64f454da7710f0dcbb28fd574ac3fda7eb00c (patch)
treeebbe7911f4344b84cbbaa411e30bef4013066d0a
parentClose #18990: remove root attribute from XMLPullParser (diff)
downloadcpython-6ba64f454da7710f0dcbb28fd574ac3fda7eb00c.tar.gz
cpython-6ba64f454da7710f0dcbb28fd574ac3fda7eb00c.tar.bz2
cpython-6ba64f454da7710f0dcbb28fd574ac3fda7eb00c.zip
Close #18596: Support address sanity checking in clang/GCC
This patch appropriately marks known false alarms in the small object allocator when address sanity checking is enabled (patch contributed by Dhiru Kholia).
-rw-r--r--Misc/ACKS1
-rw-r--r--Misc/NEWS7
-rw-r--r--Objects/obmalloc.c20
3 files changed, 28 insertions, 0 deletions
diff --git a/Misc/ACKS b/Misc/ACKS
index cb823d1ec1a..5b7b630b948 100644
--- a/Misc/ACKS
+++ b/Misc/ACKS
@@ -650,6 +650,7 @@ Jim Kerr
Magnus Kessler
Lawrence Kesteloot
Vivek Khera
+Dhiru Kholia
Mads Kiilerich
Jason Killen
Jan Kim
diff --git a/Misc/NEWS b/Misc/NEWS
index ae8631f06a0..449d915eaf8 100644
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -94,6 +94,13 @@ Documentation
- Issue #17003: Unified the size argument names in the io module with common
practice.
+Build
+-----
+
+- Issue #18596: Support the use of address sanity checking in recent versions
+ of clang and GCC by appropriately marking known false alarms in the small
+ object allocator. Patch contributed by Dhiru Kholia.
+
Tools/Demos
-----------
diff --git a/Objects/obmalloc.c b/Objects/obmalloc.c
index 4437bf9a659..f7b3e491ca4 100644
--- a/Objects/obmalloc.c
+++ b/Objects/obmalloc.c
@@ -12,6 +12,24 @@ static void _PyObject_DebugDumpAddress(const void *p);
static void _PyMem_DebugCheckAddress(char api_id, const void *p);
#endif
+#if defined(__has_feature) /* Clang */
+ #if __has_feature(address_sanitizer) /* is ASAN enabled? */
+ #define ATTRIBUTE_NO_ADDRESS_SAFETY_ANALYSIS \
+ __attribute__((no_address_safety_analysis)) \
+ __attribute__ ((noinline))
+ #else
+ #define ATTRIBUTE_NO_ADDRESS_SAFETY_ANALYSIS
+ #endif
+#else
+ #if defined(__SANITIZE_ADDRESS__) /* GCC 4.8.x, is ASAN enabled? */
+ #define ATTRIBUTE_NO_ADDRESS_SAFETY_ANALYSIS \
+ __attribute__((no_address_safety_analysis)) \
+ __attribute__ ((noinline))
+ #else
+ #define ATTRIBUTE_NO_ADDRESS_SAFETY_ANALYSIS
+ #endif
+#endif
+
#ifdef WITH_PYMALLOC
#ifdef MS_WINDOWS
@@ -1300,6 +1318,7 @@ redirect:
/* free */
+ATTRIBUTE_NO_ADDRESS_SAFETY_ANALYSIS
static void
_PyObject_Free(void *ctx, void *p)
{
@@ -1528,6 +1547,7 @@ redirect:
* return a non-NULL result.
*/
+ATTRIBUTE_NO_ADDRESS_SAFETY_ANALYSIS
static void *
_PyObject_Realloc(void *ctx, void *p, size_t nbytes)
{