Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/external/gpl3/gcc/dist merge GCC 8.3.0 pass 2. still will n...
details: https://anonhg.NetBSD.org/src/rev/f679b2cbe8e7
branches: trunk
changeset: 1003800:f679b2cbe8e7
user: mrg <mrg%NetBSD.org@localhost>
date: Tue Oct 01 11:49:12 2019 +0000
description:
merge GCC 8.3.0 pass 2. still will not compile yet. these
files are yet to merge:
C gcc/config/rs6000/rs6000.c
C libsanitizer/lsan/lsan_allocator.cc
C libsanitizer/sanitizer_common/sanitizer_internal_defs.h
diffstat:
external/gpl3/gcc/dist/gcc/config/vax/builtins.md | 2 +-
external/gpl3/gcc/dist/gcc/config/vax/vax.c | 60 +-
external/gpl3/gcc/dist/gcc/gcc.c | 200 ++-
external/gpl3/gcc/dist/libsanitizer/asan/asan_linux.cc | 22 +-
external/gpl3/gcc/dist/libsanitizer/asan/asan_malloc_linux.cc | 77 +-
external/gpl3/gcc/dist/libsanitizer/asan/asan_thread.cc | 91 +-
external/gpl3/gcc/dist/libsanitizer/interception/interception.h | 37 +-
external/gpl3/gcc/dist/libsanitizer/interception/interception_linux.cc | 14 +-
external/gpl3/gcc/dist/libsanitizer/lsan/lsan_common.h | 83 +-
external/gpl3/gcc/dist/libsanitizer/lsan/lsan_interceptors.cc | 264 +++-
external/gpl3/gcc/dist/libsanitizer/sanitizer_common/sanitizer_libignore.cc | 65 +-
external/gpl3/gcc/dist/libsanitizer/sanitizer_common/sanitizer_linux.cc | 543 ++++++++-
external/gpl3/gcc/dist/libsanitizer/sanitizer_common/sanitizer_linux_libcdep.cc | 113 +-
external/gpl3/gcc/dist/libsanitizer/sanitizer_common/sanitizer_platform.h | 30 +-
external/gpl3/gcc/dist/libsanitizer/sanitizer_common/sanitizer_platform_interceptors.h | 344 +++--
external/gpl3/gcc/dist/libsanitizer/sanitizer_common/sanitizer_platform_limits_posix.h | 69 +-
external/gpl3/gcc/dist/libsanitizer/sanitizer_common/sanitizer_procmaps.h | 92 +-
external/gpl3/gcc/dist/libsanitizer/sanitizer_common/sanitizer_stoptheworld_linux_libcdep.cc | 122 +-
external/gpl3/gcc/dist/libsanitizer/sanitizer_common/sanitizer_syscall_generic.inc | 28 +-
external/gpl3/gcc/dist/libsanitizer/tsan/tsan_interceptors.cc | 215 ++-
external/gpl3/gcc/dist/libsanitizer/ubsan/ubsan_platform.h | 10 +-
external/gpl3/gcc/dist/libstdc++-v3/include/bits/locale_facets.tcc | 22 +-
22 files changed, 1729 insertions(+), 774 deletions(-)
diffs (truncated from 4710 to 300 lines):
diff -r 5f5ff0c0cba6 -r f679b2cbe8e7 external/gpl3/gcc/dist/gcc/config/vax/builtins.md
--- a/external/gpl3/gcc/dist/gcc/config/vax/builtins.md Tue Oct 01 10:59:49 2019 +0000
+++ b/external/gpl3/gcc/dist/gcc/config/vax/builtins.md Tue Oct 01 11:49:12 2019 +0000
@@ -1,5 +1,5 @@
;; builtin definitions for DEC VAX.
-;; Copyright (C) 2007-2017 Free Software Foundation, Inc.
+;; Copyright (C) 2007-2018 Free Software Foundation, Inc.
;;
;; This file is part of GCC.
;;
diff -r 5f5ff0c0cba6 -r f679b2cbe8e7 external/gpl3/gcc/dist/gcc/config/vax/vax.c
--- a/external/gpl3/gcc/dist/gcc/config/vax/vax.c Tue Oct 01 10:59:49 2019 +0000
+++ b/external/gpl3/gcc/dist/gcc/config/vax/vax.c Tue Oct 01 11:49:12 2019 +0000
@@ -1,5 +1,5 @@
/* Subroutines for insn-output.c for VAX.
- Copyright (C) 1987-2017 Free Software Foundation, Inc.
+ Copyright (C) 1987-2018 Free Software Foundation, Inc.
This file is part of GCC.
@@ -17,6 +17,8 @@
along with GCC; see the file COPYING3. If not see
<http://www.gnu.org/licenses/>. */
+#define IN_TARGET_CODE 1
+
#include "config.h"
#include "system.h"
#include "coretypes.h"
@@ -24,6 +26,8 @@
#include "target.h"
#include "rtl.h"
#include "tree.h"
+#include "stringpool.h"
+#include "attribs.h"
#include "df.h"
#include "memmodel.h"
#include "tm_p.h"
@@ -58,8 +62,9 @@
static rtx vax_builtin_setjmp_frame_value (void);
static void vax_asm_trampoline_template (FILE *);
static void vax_trampoline_init (rtx, tree, rtx);
-static int vax_return_pops_args (tree, tree, int);
+static poly_int64 vax_return_pops_args (tree, tree, poly_int64);
static bool vax_mode_dependent_address_p (const_rtx, addr_space_t);
+static HOST_WIDE_INT vax_starting_frame_offset (void);
/* Initialize the GCC target structure. */
#undef TARGET_ASM_ALIGNED_HI_OP
@@ -130,6 +135,9 @@
}
#endif
+#undef TARGET_STARTING_FRAME_OFFSET
+#define TARGET_STARTING_FRAME_OFFSET vax_starting_frame_offset
+
struct gcc_target targetm = TARGET_INITIALIZER;
/* Set global variables as needed for the options enabled. */
@@ -230,7 +238,7 @@
/* Allocate the local stack frame. */
size = get_frame_size ();
- size -= STARTING_FRAME_OFFSET;
+ size -= vax_starting_frame_offset ();
emit_insn (gen_addsi3 (stack_pointer_rtx,
stack_pointer_rtx, GEN_INT (-size)));
@@ -871,18 +879,18 @@
case MULT:
switch (mode)
{
- case DFmode:
+ case E_DFmode:
*total = 16; /* 4 on VAX 9000 */
break;
- case SFmode:
+ case E_SFmode:
*total = 9; /* 4 on VAX 9000, 12 on VAX 2 */
break;
- case DImode:
+ case E_DImode:
*total = 16; /* 6 on VAX 9000, 28 on VAX 2 */
break;
- case SImode:
- case HImode:
- case QImode:
+ case E_SImode:
+ case E_HImode:
+ case E_QImode:
*total = 10; /* 3-4 on VAX 9000, 20-28 on VAX 2 */
break;
default:
@@ -1194,7 +1202,7 @@
switch (mode)
{
- case DImode:
+ case E_DImode:
if (operands[1] == const0_rtx)
return "clrq %0";
if (TARGET_QMATH && optimize_size
@@ -1307,7 +1315,7 @@
}
return "movq %1,%0";
- case SImode:
+ case E_SImode:
if (symbolic_operand (operands[1], SImode))
{
if (push_operand (operands[0], SImode))
@@ -1350,7 +1358,7 @@
return "pushl %1";
return "movl %1,%0";
- case HImode:
+ case E_HImode:
if (CONST_INT_P (operands[1]))
{
HOST_WIDE_INT i = INTVAL (operands[1]);
@@ -1367,7 +1375,7 @@
}
return "movw %1,%0";
- case QImode:
+ case E_QImode:
if (CONST_INT_P (operands[1]))
{
HOST_WIDE_INT i = INTVAL (operands[1]);
@@ -1402,7 +1410,7 @@
{
switch (mode)
{
- case DImode:
+ case E_DImode:
{
rtx low[3];
const char *pattern;
@@ -1488,7 +1496,7 @@
return "adwc %2,%0";
}
- case SImode:
+ case E_SImode:
if (rtx_equal_p (operands[0], operands[1]))
{
if (operands[2] == const1_rtx)
@@ -1564,7 +1572,7 @@
return "addl3 %1,%2,%0";
- case HImode:
+ case E_HImode:
if (rtx_equal_p (operands[0], operands[1]))
{
if (operands[2] == const1_rtx)
@@ -1583,7 +1591,7 @@
return "subw3 $%n2,%1,%0";
return "addw3 %1,%2,%0";
- case QImode:
+ case E_QImode:
if (rtx_equal_p (operands[0], operands[1]))
{
if (operands[2] == const1_rtx)
@@ -1612,7 +1620,7 @@
{
switch (mode)
{
- case DImode:
+ case E_DImode:
{
rtx low[3];
const char *pattern;
@@ -2194,7 +2202,7 @@
if (REG_P (lo))
return mode == SImode && REGNO (lo) + 1 == REGNO (hi);
if (CONST_INT_P (lo))
- return INTVAL (hi) == 0 && 0 <= INTVAL (lo) && INTVAL (lo) < 64;
+ return INTVAL (hi) == 0 && UINTVAL (lo) < 64;
if (CONST_INT_P (lo))
return mode != SImode;
@@ -2305,11 +2313,11 @@
On the VAX, the RET insn pops a maximum of 255 args for any function. */
-static int
+static poly_int64
vax_return_pops_args (tree fundecl ATTRIBUTE_UNUSED,
- tree funtype ATTRIBUTE_UNUSED, int size)
+ tree funtype ATTRIBUTE_UNUSED, poly_int64 size)
{
- return size > 255 * 4 ? 0 : size;
+ return size > 255 * 4 ? 0 : (HOST_WIDE_INT) size;
}
/* Define where to put the arguments to a function.
@@ -2351,6 +2359,14 @@
: (int_size_in_bytes (type) + 3) & ~3);
}
+static HOST_WIDE_INT
+vax_starting_frame_offset (void)
+{
+ /* On ELF targets, reserve the top of the stack for exception handler
+ stackadj value. */
+ return TARGET_ELF ? -4 : 0;
+}
+
bool
vax_decomposed_dimode_operand_p (rtx lo, rtx hi)
{
diff -r 5f5ff0c0cba6 -r f679b2cbe8e7 external/gpl3/gcc/dist/gcc/gcc.c
--- a/external/gpl3/gcc/dist/gcc/gcc.c Tue Oct 01 10:59:49 2019 +0000
+++ b/external/gpl3/gcc/dist/gcc/gcc.c Tue Oct 01 11:49:12 2019 +0000
@@ -1,5 +1,5 @@
/* Compiler driver program that can handle many languages.
- Copyright (C) 1987-2017 Free Software Foundation, Inc.
+ Copyright (C) 1987-2018 Free Software Foundation, Inc.
This file is part of GCC.
@@ -170,9 +170,10 @@
/* By default there is no special suffix for target executables. */
-/* FIXME: when autoconf is fixed, remove the host check - dj */
-#if defined(TARGET_EXECUTABLE_SUFFIX) && defined(HOST_EXECUTABLE_SUFFIX)
+#ifdef TARGET_EXECUTABLE_SUFFIX
#define HAVE_TARGET_EXECUTABLE_SUFFIX
+#else
+#define TARGET_EXECUTABLE_SUFFIX ""
#endif
/* By default there is no special suffix for host executables. */
@@ -584,6 +585,12 @@
%(Spec) processes a specification defined in a specs file as *Spec:
+The switch matching text S in a %{S}, %{S:X}, or similar construct can use
+a backslash to ignore the special meaning of the character following it,
+thus allowing literal matching of a character that is otherwise specially
+treated. For example, %{std=iso9899\:1999:X} substitutes X if the
+-std=iso9899:1999 option is given.
+
The conditional text X in a %{S:X} or similar construct may contain
other nested % constructs or spaces, or even newlines. They are
processed as usual, as described above. Trailing white space in X is
@@ -1009,9 +1016,10 @@
#endif
/* -u* was put back because both BSD and SysV seem to support it. */
-/* %{static|no-pie:} simply prevents an error message:
+/* %{static|no-pie|static-pie:} simply prevents an error message:
1. If the target machine doesn't handle -static.
2. If PIE isn't enabled by default.
+ 3. If the target machine doesn't handle -static-pie.
*/
/* We want %{T*} after %{L*} and %D so that it can be used to specify linker
scripts which exist in user specified directories, or in standard
@@ -1029,11 +1037,10 @@
"%{fuse-ld=*:-fuse-ld=%*} " LINK_COMPRESS_DEBUG_SPEC \
"%X %{o*} %{e*} %{N} %{n} %{r}\
%{s} %{t} %{u*} %{z} %{Z} %{!nostdlib:%{!nostartfiles:%S}} \
- %{static|no-pie:} %{L*} %(mfwrap) %(link_libgcc) " \
+ %{static|no-pie|static-pie:} %{L*} %(mfwrap) %(link_libgcc) " \
VTABLE_VERIFICATION_SPEC " " SANITIZER_EARLY_SPEC " %o " CHKP_SPEC " \
%{fopenacc|fopenmp|%:gt(%{ftree-parallelize-loops=*:%*} 1):\
%:include(libgomp.spec)%(link_gomp)}\
- %{fcilkplus:%:include(libcilkrts.spec)%(link_cilkrts)}\
%{fgnu-tm:%:include(libitm.spec)%(link_itm)}\
%(mflib) " STACK_SPLIT_SPEC "\
%{fprofile-arcs|fprofile-generate*|coverage:-lgcov} " SANITIZER_SPEC " \
@@ -1110,7 +1117,7 @@
%{MMD:-MMD %{!o:%b.d}%{o*:%.d%*}}\
%{M} %{MM} %{MF*} %{MG} %{MP} %{MQ*} %{MT*}\
%{!E:%{!M:%{!MM:%{!MT:%{!MQ:%{MD|MMD:%{o*:-MQ %*}}}}}}}\
- %{remap} %{g3|ggdb3|gstabs3|gcoff3|gxcoff3|gvms3:-dD}\
+ %{remap} %{g3|ggdb3|gstabs3|gxcoff3|gvms3:-dD}\
%{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
%{H} %C %{D*&U*&A*} %{i*} %Z %i\
%{E|M|MM:%W{o*}}";
@@ -1208,15 +1215,9 @@
#define GTM_SELF_SPECS "%{fgnu-tm: -pthread}"
#endif
-/* Likewise for -fcilkplus. */
-#ifndef CILK_SELF_SPECS
-#define CILK_SELF_SPECS "%{fcilkplus: -pthread}"
-#endif
-
static const char *const driver_self_specs[] = {
"%{fdump-final-insns:-fdump-final-insns=.} %<fdump-final-insns",
- DRIVER_SELF_SPECS, CONFIGURE_SPECS, GOMP_SELF_SPECS, GTM_SELF_SPECS,
- CILK_SELF_SPECS
+ DRIVER_SELF_SPECS, CONFIGURE_SPECS, GOMP_SELF_SPECS, GTM_SELF_SPECS
};
#ifndef OPTION_DEFAULT_SPECS
Home |
Main Index |
Thread Index |
Old Index