125 lines
3.8 KiB
Diff
125 lines
3.8 KiB
Diff
From 847aec764540636ec654fd7a012e271afa8d4e0f Mon Sep 17 00:00:00 2001
|
|
From: Khem Raj <raj.khem@gmail.com>
|
|
Date: Fri, 29 Apr 2016 20:03:28 +0000
|
|
Subject: [PATCH 44/47] libgcc: Add knob to use ldbl-128 on ppc
|
|
|
|
musl does not support ldbl 128 so we can not assume
|
|
that linux as a whole supports ldbl-128 bits, instead
|
|
act upon configure option passed to gcc and assume no
|
|
on musl and yes otherwise if no option is passed since
|
|
default behaviour is to assume ldbl128 it does not
|
|
change the defaults
|
|
|
|
Signed-off-by: Khem Raj <raj.khem@gmail.com>
|
|
Upstream-Status: Pending
|
|
---
|
|
libgcc/Makefile.in | 1 +
|
|
libgcc/config/rs6000/t-linux | 5 ++++-
|
|
libgcc/configure | 18 ++++++++++++++++++
|
|
libgcc/configure.ac | 12 ++++++++++++
|
|
4 files changed, 35 insertions(+), 1 deletion(-)
|
|
mode change 100644 => 100755 libgcc/configure
|
|
|
|
diff --git a/libgcc/Makefile.in b/libgcc/Makefile.in
|
|
index a1a392de88d..2fe6889a342 100644
|
|
--- a/libgcc/Makefile.in
|
|
+++ b/libgcc/Makefile.in
|
|
@@ -48,6 +48,7 @@ unwind_header = @unwind_header@
|
|
md_unwind_header = @md_unwind_header@
|
|
sfp_machine_header = @sfp_machine_header@
|
|
thread_header = @thread_header@
|
|
+with_ldbl128 = @with_ldbl128@
|
|
|
|
host_noncanonical = @host_noncanonical@
|
|
real_host_noncanonical = @real_host_noncanonical@
|
|
diff --git a/libgcc/config/rs6000/t-linux b/libgcc/config/rs6000/t-linux
|
|
index 4f6d4c4a4d2..c50dd94a2da 100644
|
|
--- a/libgcc/config/rs6000/t-linux
|
|
+++ b/libgcc/config/rs6000/t-linux
|
|
@@ -1,3 +1,6 @@
|
|
SHLIB_MAPFILES += $(srcdir)/config/rs6000/libgcc-glibc.ver
|
|
|
|
-HOST_LIBGCC2_CFLAGS += -mlong-double-128 -mno-minimal-toc
|
|
+ifeq ($(with_ldbl128),yes)
|
|
+HOST_LIBGCC2_CFLAGS += -mlong-double-128
|
|
+endif
|
|
+HOST_LIBGCC2_CFLAGS += -mno-minimal-toc
|
|
diff --git a/libgcc/configure b/libgcc/configure
|
|
old mode 100644
|
|
new mode 100755
|
|
index 45c459788c3..e2d19b144b8
|
|
--- a/libgcc/configure
|
|
+++ b/libgcc/configure
|
|
@@ -618,6 +618,7 @@ build_vendor
|
|
build_cpu
|
|
build
|
|
with_aix_soname
|
|
+with_ldbl128
|
|
enable_vtable_verify
|
|
enable_shared
|
|
libgcc_topdir
|
|
@@ -667,6 +668,7 @@ with_cross_host
|
|
with_ld
|
|
enable_shared
|
|
enable_vtable_verify
|
|
+with_long_double_128
|
|
with_aix_soname
|
|
enable_version_specific_runtime_libs
|
|
with_slibdir
|
|
@@ -1324,6 +1326,7 @@ Optional Packages:
|
|
--with-target-subdir=SUBDIR Configuring in a subdirectory for target
|
|
--with-cross-host=HOST Configuring with a cross compiler
|
|
--with-ld arrange to use the specified ld (full pathname)
|
|
+ --with-long-double-128 use 128-bit long double by default
|
|
--with-aix-soname=aix|svr4|both
|
|
shared library versioning (aka "SONAME") variant to
|
|
provide on AIX
|
|
@@ -2208,6 +2211,21 @@ fi
|
|
|
|
|
|
|
|
+# Check whether --with-long-double-128 was given.
|
|
+if test "${with_long_double_128+set}" = set; then :
|
|
+ withval=$with_long_double_128; with_ldbl128="$with_long_double_128"
|
|
+else
|
|
+ case "${host}" in
|
|
+ power*-*-musl*)
|
|
+ with_ldbl128="no";;
|
|
+ *) with_ldbl128="yes";;
|
|
+ esac
|
|
+
|
|
+fi
|
|
+
|
|
+
|
|
+
|
|
+
|
|
# Check whether --with-aix-soname was given.
|
|
if test "${with_aix_soname+set}" = set; then :
|
|
withval=$with_aix_soname; case "${host}:${enable_shared}" in
|
|
diff --git a/libgcc/configure.ac b/libgcc/configure.ac
|
|
index af151473709..dada52416da 100644
|
|
--- a/libgcc/configure.ac
|
|
+++ b/libgcc/configure.ac
|
|
@@ -77,6 +77,18 @@ AC_ARG_ENABLE(vtable-verify,
|
|
[enable_vtable_verify=no])
|
|
AC_SUBST(enable_vtable_verify)
|
|
|
|
+AC_ARG_WITH(long-double-128,
|
|
+[AS_HELP_STRING([--with-long-double-128],
|
|
+ [use 128-bit long double by default])],
|
|
+ with_ldbl128="$with_long_double_128",
|
|
+[case "${host}" in
|
|
+ power*-*-musl*)
|
|
+ with_ldbl128="no";;
|
|
+ *) with_ldbl128="yes";;
|
|
+ esac
|
|
+])
|
|
+AC_SUBST(with_ldbl128)
|
|
+
|
|
AC_ARG_WITH(aix-soname,
|
|
[AS_HELP_STRING([--with-aix-soname=aix|svr4|both],
|
|
[shared library versioning (aka "SONAME") variant to provide on AIX])],
|
|
--
|
|
2.12.2
|
|
|