1. 30 Jan, 2019 21 commits
  2. 29 Jan, 2019 16 commits
    • re PR fortran/57048 (Handling of C_PTR and C_FUNPTR leads to reject valid) · 5af5f1de
      2019-01-29  Thomas Koenig  <tkoenig@gcc.gnu.org>
      
      	PR fortran/57048
      	* interface.c (gfc_compare_types): If a derived type and an
      	integer both have a derived type, and they are identical,
      	this is a C binding type and compares equal.
      
      2019-01-29  Thomas Koenig  <tkoenig@gcc.gnu.org>
      
      	PR fortran/57048
      	* gfortran.dg/c_funptr_1.f90: New file.
      	* gfortran.dg/c_funptr_1_mod.f90: New file.
      
      From-SVN: r268372
      Thomas Koenig committed
    • re PR c++/66676 (pragma omp simd aligned(x) results in "internal compiler error:… · b33d65e3
      re PR c++/66676 (pragma omp simd aligned(x) results in "internal compiler error: Segmentation fault")
      
      	PR c++/66676
      	PR ipa/89104
      	* omp-simd-clone.c (simd_clone_clauses_extract)
      	<case OMP_CLAUSE_ALIGNED>: Ignore clauses with NULL
      	OMP_CLAUSE_ALIGNED_ALIGNMENT.
      
      	* gcc.dg/gomp/pr89104.c: New test.
      
      From-SVN: r268370
      Jakub Jelinek committed
    • [libbacktrace] Add test-cases exercising build-id and dwz · fddbc193
      Add test-cases b2test_buildid and b3test_dwz_buildid.
      
      The last one triggers the segfault fixed by "[backtrace] Avoid segfault"
      ( r268275 ).
      
      2019-01-29  Tom de Vries  <tdevries@suse.de>
      
      	* install-debuginfo-for-buildid.sh.in: New script.
      	* Makefile.am (check_PROGRAMS): Add b2test and b3test.
      	(TESTS): Add b2test_buildid and b3test_dwz_buildid.
      	* Makefile.in: Regenerate.
      	* configure.ac (HAVE_ELF): Set with AM_CONDITIONAL.
      	(READELF): Set with AC_CHECK_PROG.
      	(install-debuginfo-for-buildid.sh): Generate with AC_CONFIG_FILES.
      	* configure: Regenerate.
      	* elf.c (SYSTEM_BUILD_ID_DIR): Factor out of ...
      	(elf_open_debugfile_by_buildid): ... here.
      
      From-SVN: r268369
      Tom de Vries committed
    • PR c++/89089 - ICE with [[no_unique_address]]. · 7e574f68
      In 89089, we were never actually setting DECL_SIZE on an empty data member,
      because its type is a POD, so we didn't set it in the maybe-overlapping
      section.  Fixed by also handling empty types there.
      
      In 88865, we were failing to consider empty data members in
      include_empty_classes.  Fixed by making end_of_class always include them.
      
      While looking at these I noticed that the ABI says that a
      potentially-overlapping data member makes its class non-layout-POD, and that
      an empty data member doesn't prevent its class from being empty, so I've
      implemented those points as well.
      
      	PR c++/88865 - wrong layout with [[no_unique_address]].
      	* class.c (check_field_decls): A potentially-overlapping field makes
      	the class non-layout-POD, but not non-empty.
      	(end_of_class): Always consider empty data members.
      	(layout_class_type): Set DECL_SIZE for empty fields.
      
      From-SVN: r268368
      Jason Merrill committed
    • runtime: fix sigprof frame counting · 6065f1c5
          
          If sigtramp and sigtrampgo are both on stack, n -= framesToDiscard
          is executed twice, which should actually run only once.
          
          Reviewed-on: https://go-review.googlesource.com/c/159238
      
      From-SVN: r268366
      Ian Lance Taylor committed
    • [ARC] Enable init_array support. · fac31afe
      gcc's common configure script has a subtle flaw that it only tests
      {init,fini.preinit}_array support when NOT cross compiling. This causes
      cross builds to erroneously deduce that the feature is not supported by
      the target.
      
      | host-gcc-final-ab544139bfee/build/gcc/config.log
      |
      |configure:22941: checking for .preinit_array/.init_array/.fini_array support
      |configure:23106: checking cross compile... guessing
      |configure:23111: result: no
      
      The right fix is to enable this for *all* cross setups (and address any
      fallouts). However in the short-term to enable ARC glibc port to upstream,
      force enable this for ARC.
      
      This has been discussed at length on glibc mailing list [1], [2]
      
      [1] https://sourceware.org/ml/libc-alpha/2018-11/msg00870.html
      [2] https://sourceware.org/ml/libc-alpha/2019-01/msg00656.html
      
      gcc/
      
      2019-xx-xx  Vineet Gupta <vgupta@synopsys.com>
      
      	* gcc/config.gcc: Force .init_array for ARC
      
      From-SVN: r268365
      Vineet Gupta committed
    • Mark gdc.dg/pr89042?.d as compile tests · 97b9ebc8
      	* gdc.dg/pr89042a.d: Mark as compile test.
      	* gdc.dg/pr89042b.d: Likewise.
      
      From-SVN: r268362
      Rainer Orth committed
    • re PR debug/87295 ([early debug] ICE with -ffat-lto-objects -fdebug-types-section -g) · 5ee41782
      2019-01-29  Richard Biener  <rguenther@suse.de>
      
      	PR debug/87295
      	* dwarf2out.c (collect_skeleton_dies): New helper.
      	(copy_decls_for_unworthy_types): Call it.
      	(build_abbrev_table): Assert we do not try to replace
      	DW_AT_signature refs with local refs.
      
      	* g++.dg/lto/pr87295_0.C: New testcase.
      
      From-SVN: r268361
      Richard Biener committed
    • [libbacktrace] Don't assign check_PROGRAMS to TESTS · 57f0d303
      In automake files, the check_PROGRAMS variable lists programs that need to be
      build for testing, and TESTS lists the programs that need to be run.
      
      The libbacktrace/Makefile.am uses a shortcut:
      ...
      TESTS = $(check_PROGRAMS)
      ...
      to make sure that each program added with:
      ...
      check_PROGRAMS += foo
      ...
      is both build and run.
      
      However, for the allocfail.sh test, we need allocfail to be build and
      allocfail.sh to be run:
      ...
      check_PROGRAMS += allocfail
      TESTS += allocfail.sh
      ...
      but the shortcut causes allocfail also to be run, which is not required.
      
      Fix this by removing the short-cut, allowing check_PROGRAMS to retain its
      original semantics, and introducing a variable BUILDTESTS for programs that
      need to be both build and run.
      
      2019-01-29  Tom de Vries  <tdevries@suse.de>
      
      	* Makefile.am: Replace check_PROGRAMS with BUILDTESTS, except for
      	allocfail.
      	(TESTS): Don't add check_PROGRAMS. Add BUILDTESTS.
      	(check_PROGRAMS): Add BUILDTESTS.
      	* Makefile.in: Regenerate.
      
      From-SVN: r268360
      Tom de Vries committed
    • Fix tests for complex overloads of std::arg and std::proj · 375d5984
      The test for the synopsis of <complex> incorrectly adds constexpr to
      two functions in C++2a mode, but the C++2a draft and the <complex>
      header do not declare them constexpr.
      
      	* testsuite/26_numerics/headers/complex/synopsis.cc: Remove incorrect
      	constexpr specifiers from arg and proj.
      
      From-SVN: r268359
      Jonathan Wakely committed
    • runtime: use the call instruction's PC for panic-in-runtime detection · 053a1f23
          
          If a panic happens in the runtime we turn that into a fatal error.
          We use the caller's PC to determine if the panic call is inside
          the runtime. getcallerpc returns the PC immediately after the
          call instruction. If the call is the very last instruction of a
          function, it may not find this PC belong to a runtime function,
          giving false result. We need to back off the PC by 1 to the call
          instruction.
          
          The gc runtime doesn't do this because the gc compiler always
          emit an instruction following a panic call, presumably an UNDEF
          instruction which turns into an architecture-specific illegal
          instruction. Our compiler doesn't do this.
          
          Reviewed-on: https://go-review.googlesource.com/c/159437
      
      From-SVN: r268358
      Ian Lance Taylor committed
    • Add missing exports for symbols used by directory iterators · 45e7df85
      	* config/abi/pre/gnu.ver (GLIBCXX_3.4.26): Add missing exports for
      	__shared_ptr instantiations used by gcc4-compatible ABI.
      
      From-SVN: r268357
      Jonathan Wakely committed
    • Avoid ambiguity between C++2a std::erase_if and LFTS version · f7f07df5
      These calls should have been qualified to avoid ADL anyway, but in C++2a
      it becomes essential to qualify the calls in experimental::erase because
      std::erase_if is also declared and the calls become ambiguous.
      
      	* include/experimental/forward_list (experimental::erase): Qualify
      	call to erase_if.
      	* include/experimental/list (experimental::erase): Likewise.
      	* include/std/forward_list (std::erase): Likewise.
      	* include/std/list (std::erase): Likewise.
      
      From-SVN: r268356
      Jonathan Wakely committed
    • Fix tests that fail in C++2a mode · 2104ca71
      The nested typedefs in std::reference_wrapper are no longer present in
      C++2a mode, so skip the tests that check for them.
      
      The addition of the [[nodiscard]] attribute to a few functions causes
      some failures in tests that intentionally ignore the return value.
      Casting the result to void suppresses the new warnings.
      
      	* testsuite/20_util/reference_wrapper/result_type.cc: Disable for
      	C++2a.
      	* testsuite/20_util/reference_wrapper/typedefs-2.cc: Likewise.
      	* testsuite/20_util/reference_wrapper/typedefs-3.cc: Likewise.
      	* testsuite/20_util/reference_wrapper/typedefs.cc: Likewise.
      	* testsuite/30_threads/async/54297.cc: Suppress nodiscard warning.
      	* testsuite/ext/array_allocator/26875.cc: Likewise.
      	* testsuite/ext/pool_allocator/allocate_chunk.cc: Likewise.
      	* testsuite/util/replacement_memory_operators.h: Likewise.
      	* testsuite/util/testsuite_allocator.h: Likewise.
      
      From-SVN: r268355
      Jonathan Wakely committed
    • Ensure pool resources always use normal mode vector · 1f48525d
      The __pool_resource::_M_unpooled member was declared with type
      std::vector, which means that the type depends on whether debug mode is
      active or not. Because the non-inline definitions in
      src/c++17/memory_resource.cc are never compiled with debug mode, the
      type declared in the header doesn't match the type in the library
      definitions, leading to undefined behaviour.
      
      The solution is to ensure the header always uses the non-debug vector,
      even when debug mode is active. To make this easier a new alias template
      is defined: _GLIBCXX_STD_C::pmr::vector.
      
      	* include/std/memory_resource (__pool_resource::_M_unpooled): Use
      	normal mode vector, even for debug mode.
      	* include/std/vector [_GLIBCXX_DEBUG] (_GLIBCXX_STD_C::pmr::vector):
      	Define alias template for normal mode vector.
      
      From-SVN: r268354
      Jonathan Wakely committed
    • Daily bump. · a097ba8a
      From-SVN: r268353
      GCC Administrator committed
  3. 28 Jan, 2019 3 commits
    • PR libstdc++/68737 Do not use vsnprintf on HPUX · c98f2551
      It doesn't conform to the spec, so use vsprintf with a large buffer
      instead.
      
      	PR libstdc++/68737
      	* config/locale/generic/c_locale.h (__convert_from_v)
      	[_GLIBCXX_USE_C99_STDIO]: Also check _GLIBCXX_HAVE_BROKEN_VSNPRINTF.
      	* config/os/hpux/os_defines.h: Define _GLIBCXX_HAVE_BROKEN_VSNPRINTF.
      	* include/bits/locale_facets.tcc (num_put::_M_insert_float)
      	[_GLIBCXX_USE_C99_STDIO]: Also check _GLIBCXX_HAVE_BROKEN_VSNPRINTF.
      
      From-SVN: r268350
      Jonathan Wakely committed
    • re PR c/89045 (ICE in get_parm_info, at c/c-decl.c:7518) · f4b7e754
      	PR c/89045
      	* c-decl.c (build_compound_literal): Don't pushdecl if in parameter
      	scope.
      
      	* gcc.dg/pr89045.c: New test.
      
      From-SVN: r268349
      Jakub Jelinek committed
    • re PR c/86125 (missing -Wbuiltin-declaration-mismatch on a mismatched return type) · 6a335b96
      	PR c/86125
      	* c-decl.c (last_fileptr_type): Remove.
      	(last_structptr_types): New variable.
      	(match_builtin_function_types): Compare TYPE_MAIN_VARIANT of
      	{old,new}rettype instead of the types themselves.  Assert
      	last_structptr_types array has the same number of elements
      	as builtin_structptr_types array.  Use TYPE_MAIN_VARIANT for
      	argument oldtype and newtype.  Instead of handling
      	just fileptr_type_node specially, handle all builtin_structptr_types
      	pointer nodes.  Formatting fix.
      
      	* c-common.c (c_common_nodes_and_builtins): Build type variants for
      	builtin_structptr_types types even for C.
      
      	* gcc.dg/Wbuiltin-declaration-mismatch-7.c: Guard testcase for
      	lp64, ilp32 and llp64 only.
      	(fputs): Use unsigned long long instead of size_t for return type.
      	(vfprintf, vfscanf): Accept arbitrary target specific type for
      	va_list.
      
      From-SVN: r268348
      Jakub Jelinek committed