summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVictor Stinner <vstinner@redhat.com>2019-05-14 17:29:53 (GMT)
committerGitHub <noreply@github.com>2019-05-14 17:29:53 (GMT)
commitd97adfb409290a1e4ad549e4af58cacea86d3358 (patch)
treee5f681ef6b84a121cc115b10c1c2a503f4f7606b
parentc1f5667be1e3ec5871560c677402c1252c6018a6 (diff)
downloadcpython-d97adfb409290a1e4ad549e4af58cacea86d3358.zip
cpython-d97adfb409290a1e4ad549e4af58cacea86d3358.tar.gz
cpython-d97adfb409290a1e4ad549e4af58cacea86d3358.tar.bz2
bpo-36618: Don't add -fmax-type-align=8 flag for clang (GH-13320)
Python 3.8 now respects the x86-64 ABI: memory allocations are aligned on 16 bytes. The clang flag was only used as a temporary workaround.
-rwxr-xr-xconfigure20
-rw-r--r--configure.ac20
2 files changed, 0 insertions, 40 deletions
diff --git a/configure b/configure
index e6e4007..6da65dd 100755
--- a/configure
+++ b/configure
@@ -6905,26 +6905,6 @@ then
esac
fi
-if test -n "${cc_is_clang}"
-then
- # bpo-36618: Add -fmax-type-align=8 to CFLAGS when clang compiler is
- # detected. The pymalloc memory allocator aligns memory on 8 bytes. On
- # x86-64, clang expects alignment on 16 bytes by default and so uses MOVAPS
- # instruction which can lead to segmentation fault. Instruct clang that
- # Python is limited to alignemnt on 8 bytes to use MOVUPS instruction
- # instead: slower but don't trigger a SIGSEGV if the memory is not aligned
- # on 16 bytes.
- #
- # Sadly, the flag must be added to CFLAGS and not just CFLAGS_NODIST,
- # since third party C extensions can have the same issue.
- #
- # Check if -fmax-type-align flag is supported (it's not supported by old
- # clang versions):
- if "$CC" -v --help 2>/dev/null |grep -- -fmax-type-align > /dev/null; then
- CFLAGS="$CFLAGS -fmax-type-align=8"
- fi
-fi
-
diff --git a/configure.ac b/configure.ac
index a02597d..e673e13 100644
--- a/configure.ac
+++ b/configure.ac
@@ -1543,26 +1543,6 @@ then
esac
fi
-if test -n "${cc_is_clang}"
-then
- # bpo-36618: Add -fmax-type-align=8 to CFLAGS when clang compiler is
- # detected. The pymalloc memory allocator aligns memory on 8 bytes. On
- # x86-64, clang expects alignment on 16 bytes by default and so uses MOVAPS
- # instruction which can lead to segmentation fault. Instruct clang that
- # Python is limited to alignemnt on 8 bytes to use MOVUPS instruction
- # instead: slower but don't trigger a SIGSEGV if the memory is not aligned
- # on 16 bytes.
- #
- # Sadly, the flag must be added to CFLAGS and not just CFLAGS_NODIST,
- # since third party C extensions can have the same issue.
- #
- # Check if -fmax-type-align flag is supported (it's not supported by old
- # clang versions):
- if "$CC" -v --help 2>/dev/null |grep -- -fmax-type-align > /dev/null; then
- CFLAGS="$CFLAGS -fmax-type-align=8"
- fi
-fi
-
AC_SUBST(BASECFLAGS)
AC_SUBST(CFLAGS_NODIST)
AC_SUBST(LDFLAGS_NODIST)