diff options
author | matz <matz@138bc75d-0d04-0410-961f-82ee72b054a4> | 2016-01-26 16:34:24 +0000 |
---|---|---|
committer | matz <matz@138bc75d-0d04-0410-961f-82ee72b054a4> | 2016-01-26 16:34:24 +0000 |
commit | 4176ce096510479b797ea78d60ec753e340b32dc (patch) | |
tree | 9edc53bf63b981b4a43ccf59323db191f3ef1075 | |
parent | 7a3a29d0d81ad02727273aed6655166034d786e8 (diff) | |
download | gcc-4176ce096510479b797ea78d60ec753e340b32dc.tar.gz |
* configure.ac (ac_cv_std_swap_in_utility): New test.
* system.h (<algorithm>): Check HAVE_SWAP_IN_UTILITY as well.
* configure: Regenerate.
* config.in: Regenerate.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@232836 138bc75d-0d04-0410-961f-82ee72b054a4
-rw-r--r-- | gcc/ChangeLog | 19 | ||||
-rw-r--r-- | gcc/config.in | 9 | ||||
-rwxr-xr-x | gcc/configure | 38 | ||||
-rw-r--r-- | gcc/configure.ac | 9 | ||||
-rw-r--r-- | gcc/system.h | 2 |
5 files changed, 67 insertions, 10 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 6518a3b1841..71e96024dd4 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,11 +1,18 @@ +2016-01-26 Michael Matz <matz@suse.de> + + * configure.ac (ac_cv_std_swap_in_utility): New test. + * system.h (<algorithm>): Check HAVE_SWAP_IN_UTILITY as well. + * configure: Regenerate. + * config.in: Regenerate. + 2016-01-26 Claudiu Zissulescu <claziss@synopsys.com> - * config/arc/arc.md (cstoresi4): Force operand into register. - (arcset<code>): Fix predicate. - (arcsetltu): Likewise. - (arcsetgeu): Likewise. - (arcsethi): Likewise. - (arcsetls): Likewise. + * config/arc/arc.md (cstoresi4): Force operand into register. + (arcset<code>): Fix predicate. + (arcsetltu): Likewise. + (arcsetgeu): Likewise. + (arcsethi): Likewise. + (arcsetls): Likewise. 2016-01-26 Jakub Jelinek <jakub@redhat.com> diff --git a/gcc/config.in b/gcc/config.in index 1796e1d895e..115cb61639d 100644 --- a/gcc/config.in +++ b/gcc/config.in @@ -1705,6 +1705,12 @@ #endif +/* Define if <utility> defines std::swap. */ +#ifndef USED_FOR_TARGET +#undef HAVE_SWAP_IN_UTILITY +#endif + + /* Define to 1 if you have the `sysconf' function. */ #ifndef USED_FOR_TARGET #undef HAVE_SYSCONF @@ -1865,7 +1871,8 @@ #endif -/* Define if your assembler supports .dwsect 0xB0000 */ +/* Define if your assembler supports AIX debug frame section label reference. + */ #ifndef USED_FOR_TARGET #undef HAVE_XCOFF_DWARF_EXTRAS #endif diff --git a/gcc/configure b/gcc/configure index ff646e8fcac..8ea4281cce4 100755 --- a/gcc/configure +++ b/gcc/configure @@ -6534,6 +6534,40 @@ fi rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for std::swap in <utility>" >&5 +$as_echo_n "checking for std::swap in <utility>... " >&6; } +if test "${ac_cv_std_swap_in_utility+set}" = set; then : + $as_echo_n "(cached) " >&6 +else + +cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +#include <utility> + +int +main () +{ +int a, b; std::swap(a,b); + ; + return 0; +} +_ACEOF +if ac_fn_cxx_try_compile "$LINENO"; then : + ac_cv_std_swap_in_utility=yes +else + ac_cv_std_swap_in_utility=no +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_std_swap_in_utility" >&5 +$as_echo "$ac_cv_std_swap_in_utility" >&6; } +if test $ac_cv_std_swap_in_utility = yes; then + +$as_echo "#define HAVE_SWAP_IN_UTILITY 1" >>confdefs.h + +fi + # Check whether compiler is affected by placement new aliasing bug (PR 29286). # If the host compiler is affected by the bug, and we build with optimization # enabled (which happens e.g. when cross-compiling), the pool allocator may @@ -18419,7 +18453,7 @@ else lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 lt_status=$lt_dlunknown cat > conftest.$ac_ext <<_LT_EOF -#line 18422 "configure" +#line 18456 "configure" #include "confdefs.h" #if HAVE_DLFCN_H @@ -18525,7 +18559,7 @@ else lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 lt_status=$lt_dlunknown cat > conftest.$ac_ext <<_LT_EOF -#line 18528 "configure" +#line 18562 "configure" #include "confdefs.h" #if HAVE_DLFCN_H diff --git a/gcc/configure.ac b/gcc/configure.ac index 4dc7c109a26..6cfb68a8520 100644 --- a/gcc/configure.ac +++ b/gcc/configure.ac @@ -416,6 +416,15 @@ struct X<long long> { typedef long long t; }; ]], [[X<int64_t>::t x;]])],[],[AC_MSG_ERROR([error verifying int64_t uses long long])]) fi +AC_CACHE_CHECK(for std::swap in <utility>, ac_cv_std_swap_in_utility, [ +AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[ +#include <utility> +]], [[int a, b; std::swap(a,b);]])],[ac_cv_std_swap_in_utility=yes],[ac_cv_std_swap_in_utility=no])]) +if test $ac_cv_std_swap_in_utility = yes; then + AC_DEFINE(HAVE_SWAP_IN_UTILITY, 1, + [Define if <utility> defines std::swap.]) +fi + # Check whether compiler is affected by placement new aliasing bug (PR 29286). # If the host compiler is affected by the bug, and we build with optimization # enabled (which happens e.g. when cross-compiling), the pool allocator may diff --git a/gcc/system.h b/gcc/system.h index 8151e0a7b2a..445073c5cae 100644 --- a/gcc/system.h +++ b/gcc/system.h @@ -217,7 +217,7 @@ extern int errno; #endif #ifdef __cplusplus -#ifdef INCLUDE_ALGORITHM +#if defined (INCLUDE_ALGORITHM) || !defined (HAVE_SWAP_IN_UTILITY) # include <algorithm> #endif # include <cstring> |