1. 30 Jan, 2019 5 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 18 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
    • compiler: improve recursive type detection · ab1be99f
          
          Detect recursive type definition like
          "type T0 T1; type T1 T2; ...... type Tn T0".
          
          Fixes golang/go#25320.
          
          Reviewed-on: https://go-review.googlesource.com/c/159837
      
      From-SVN: r268347
      Ian Lance Taylor committed
    • re PR middle-end/89002 (ICE in scan_omp_1_op, at omp-low.c:3166) · 52bfbb69
      	PR middle-end/89002
      	* gimplify.c (gimplify_omp_for): When adding OMP_CLAUSE_*_GIMPLE_SEQ
      	for lastprivate/linear IV, push gimplify context around gimplify_assign
      	and, if it needed any temporaries, pop it into a gimple bind around the
      	sequence.
      
      	* testsuite/libgomp.c/pr89002.c: New test.
      
      From-SVN: r268346
      Jakub Jelinek committed
    • re PR middle-end/89002 (ICE in scan_omp_1_op, at omp-low.c:3166) · be3a87e7
      	PR middle-end/89002
      	* gimplify.c (gimplify_omp_for): When adding OMP_CLAUSE_*_GIMPLE_SEQ
      	for lastprivate/linear IV, push gimplify context around gimplify_assign
      	and, if it needed any temporaries, pop it into a gimple bind around the
      	sequence.
      
      	* testsuite/libgomp.c/pr89002.c: New test.
      
      From-SVN: r268345
      Jakub Jelinek committed
    • [libbacktrace] Fix and simplify xcoff_%.c pattern rule · 62d4a355
      When generating xcoff_%.c, the last command is a sed command.  In case of a
      sed failure, this will leave an incomplete file, which will appear as up to
      date to make, so consequently it will not be regenerated.  Fix this by
      sedding into a temporary file instead.
      
      Also, use $< to access the prerequisite xcoff.c, instead of spelling out the
      file name once more.
      
      2019-01-28  Tom de Vries  <tdevries@suse.de>
      
      	* Makefile.am (xcoff_%.c): Generate sed result into temporary file.
      	Use $< to access prerequisite.
      	* Makefile.in: Regenerate.
      
      From-SVN: r268344
      Tom de Vries committed
    • PR c++/88358 - name wrongly treated as type. · b6d0f41a
      	* parser.c (cp_parser_direct_declarator): Don't assume a qualified-id
      	in parameter-list is a type if the function's declarator-id is not
      	qualified.
      
      	* g++.dg/cpp2a/typename1.C: Add dg-error.
      	* g++.dg/cpp2a/typename13.C: New test.
      	* g++.dg/cpp2a/typename6.C: Make a function name qualified.
      	Add typename.
      
      From-SVN: r268343
      Marek Polacek committed
    • Makefile.in: Really regenerate. · 2c5b3920
      	* Makefile.in: Really regenerate.
      
      From-SVN: r268342
      Uros Bizjak committed
    • * g++.dg/cpp0x/enum37.C: Add dg-error. · cf142085
      From-SVN: r268341
      Marek Polacek committed
    • c-warn.c (check_address_or_pointer_of_packed_member): Handle the case when rhs… · 2a06eba5
      c-warn.c (check_address_or_pointer_of_packed_member): Handle the case when rhs is of array type correctly.
      
      2019-01-28  Bernd Edlinger  <bernd.edlinger@hotmail.de>
      
              * c-warn.c (check_address_or_pointer_of_packed_member): Handle the case
              when rhs is of array type correctly.  Fix handling of nested structures.
              Fix handling of indirect_ref together with nop_expr and/or addr_expr.
              (check_and_warn_address_or_pointer_of_packed_member): Fix handling of
              type casts within nested compound expressions.
      
      testsuite:
      2019-01-28  Bernd Edlinger  <bernd.edlinger@hotmail.de>
      
              * c-c++-common/Waddress-of-packed-member-1.c: Extended test case.
              * c-c++-common/Waddress-of-packed-member-2.c: New test case.
      
      From-SVN: r268337
      Bernd Edlinger committed
    • common.opt (-Wattribute-alias): Remove "no-" from name. · 5ebfd62b
      2019-01-28  Bernd Edlinger  <bernd.edlinger@hotmail.de>
      
              * common.opt (-Wattribute-alias): Remove "no-" from name.
              Make -Wattribute-alias command line option and
              #pragma GCC diagnostic ignored "-Wattribute-alias" work again.
      
      testsuite:
      2019-01-28  Bernd Edlinger  <bernd.edlinger@hotmail.de>
      
              * gcc.dg/Wattribute-alias.c: Add test for #pragma GCC diagnostic ignored
              "-Wattribute-alias".
      
      From-SVN: r268336
      Bernd Edlinger committed
    • re PR target/89073 (x86 __attribute__ ((target("sha"))) not documented) · 811a6710
      	PR target/89073
      	* doc/invoke.texi (-mclwb, -mprfchw, -mrdpid, -mrdseed, -msgx,
      	-madx, -mhle, -mavx5124fmaps, -mavx512vnni, -mavx5124vnniw): Document
      	x86 ISA options.
      	(bmi2): Add missing @opindex.
      	* doc/extend.texi (x86 target attribute): Move fma4, lwp, ssse3
      	options alphabetically.  Add missing 3dnow, 3dnowa, adx, avx, avx2,
      	avx5124fmaps, avx5124vnniw, avx512bitalg, avx512bw, avx512cd,
      	avx512dq, avx512er, avx512f, avx512ifma, avx512pf, avx512vbmi,
      	avx512vbmi2, avx512vl, avx512vnni, avx512vpopcntdq, bmi, bmi2,
      	cldemote, clflushopt, clwb, clzero, crc32, cx16, f16c, fma, fsgsbase,
      	fxsr, gfni, hle, lzcnt, movbe, movdir64b, movdiri, mwaitx, pconfig,
      	pku, prefetchwt1, prfchw, ptwrite, rdpid, rdrnd, rdseed, rtm, sahf,
      	sgx, sha, shstk, tbm, vaes, vpclmulqdq, waitpkg, wbnoinvd, xsave,
      	xsavec, xsaveopt and xsaves options.
      
      From-SVN: r268335
      Jakub Jelinek committed
    • re PR debug/89076 (gcc/dwarf2out.c:23270:9: warning: duplicated ‘if’ condition) · 44ed55d5
      2019-01-28  Richard Biener  <rguenther@suse.de>
      
      	PR debug/89076
      	* dwarf2out.c (gen_subprogram_die): Remove leftover from MPX
      	support removal.
      
      From-SVN: r268334
      Richard Biener committed
    • re PR testsuite/89064 (libgomp.graphite/force-parallel-5.c fails starting with r268257) · 497ef4d7
      2019-01-28  Richard Biener  <rguenther@suse.de>
      
      	PR testsuite/89064
      	PR tree-optimization/86865
      	* testsuite/libgomp.graphite/force-parallel-5.c: XFAIL.
      
      From-SVN: r268333
      Richard Biener committed
    • re PR tree-optimization/88739 (Big-endian union bug) · ef310a95
      2019-01-28  Richard Biener  <rguenther@suse.de>
      
      	PR tree-optimization/88739
      	* tree-cfg.c (verify_types_in_gimple_reference): Verify
      	BIT_FIELD_REFs only are applied to mode-precision operands
      	when they are integral.
      	(verify_gimple_assign_ternary): Likewise for BIT_INSERT_EXPR.
      	* tree-ssa-sccvn.c (vn_reference_lookup_3): Avoid generating
      	BIT_FIELD_REFs of non-mode-precision integral operands.
      
      From-SVN: r268332
      Richard Biener committed
    • libgfortran: Use proper gthr.h API · 92ab6b83
      libgfortran/
      
      	* io/async.c (init_adv_cond): Use __GTHREAD_COND_INIT_FUNCTION().
      
      From-SVN: r268331
      Sebastian Huber committed
    • Daily bump. · 32ed8fa2
      From-SVN: r268330
      GCC Administrator committed
  4. 27 Jan, 2019 1 commit