1. 20 Nov, 2019 5 commits
    • Make 0-series device specs work with older versions of avr-gcc. · c04341ec
      	PR target/92545
      	* config/avr/specs.h (LINK_SPEC) <%(link_pm_base_address)>: Remove.
      	* config/avr/gen-avr-mmcu-specs.c (print_mcu)
      	<*link_pm_base_address>: Don't write spec.
      	<*link_arch>: Add --defsym=__RODATA_PM_OFFSET__= as needed.
      
      From-SVN: r278478
      Georg-Johann Lay committed
    • re PR c/92088 (aggregates with VLAs and nested functions are broken) · 3e00ba47
      2019-11-20  Richard Biener  <rguenther@suse.de>
      
      	PR c/92088
      	c/
      	* c-decl.c (grokdeclarator): Prevent inlining of nested
      	function with VLA arguments.
      
      	* builtins.c (compute_objsize): Deal with VLAs.
      
      	* gcc.dg/torture/pr92088-1.c: New testcase.
      	* gcc.dg/torture/pr92088-2.c: Likewise.
      
      From-SVN: r278477
      Richard Biener committed
    • cvt.c (ocp_convert): Use additional warning sentinel. · 54bf2539
      /cp
      2019-11-20  Paolo Carlini  <paolo.carlini@oracle.com>
      
      	* cvt.c (ocp_convert): Use additional warning sentinel.
      
      /testsuite
      2019-11-20  Paolo Carlini  <paolo.carlini@oracle.com>
      
      	* g++.dg/warn/multiple-sign-compare-warn-1.C: New.
      
      From-SVN: r278475
      Paolo Carlini committed
    • Daily bump. · 56d475ca
      From-SVN: r278474
      GCC Administrator committed
    • Add more pedwarns for [[]] C attributes on types. · 8c5b727a
      The standard [[]] attributes currently defined in C2x are all not
      valid on types not being defined at the time.
      
      Use on such types results in a warning from attribs.c about attributes
      appertaining to types (the warning that I think is bogus in general
      for both C and C++, applying as it does to all [[]] attributes
      including gnu:: ones that are perfectly meaningful on types not being
      defined and work fine when __attribute__ syntax is used instead).  If
      that warning is removed (as I intend to do in a subsequent patch),
      warnings may or may not result from the attribute handlers, depending
      on whether those particular attribute handlers consider the attributes
      meaningful in such a context.  In C, however, the rules about where
      each [[]] attribute is valid are constraints, so a pedwarn, not a
      warning, is required.
      
      Because some handlers are shared between standard and gnu::
      attributes, there can be cases that are valid for the GNU attribute
      variant but not for the standard one.  So in general it is not correct
      to rely on the attribute handlers to give all required pedwarns
      (although in some cases, a pedwarn in the attribute handler is in
      appropriate way of diagnosing an invalid use); they not have the
      information about whether the attribute was a gnu:: one and can
      legitimately accept a wider range of uses for the gnu:: attributes.
      
      This patch ensures appropriate diagnostics for invalid uses of C2x
      standard attributes on types, and so helps pave the way for the
      subsequent removal of the bogus check in attribs.c, by adding a check
      run in the front end before calling decl_attributes; this check
      removes the attributes from the list after calling pedwarn to avoid
      subsequent duplicate warnings.
      
      Bootstrapped with no regressions for x86_64-pc-linux-gnu.
      
      gcc/c:
      	* c-decl.c (c_warn_type_attributes): New function.
      	(groktypename, grokdeclarator, finish_declspecs): Call
      	c_warn_type_attributes before applying attributes to types.
      	* c-tree.h (c_warn_type_attributes): Declare.
      
      gcc/testsuite:
      	* gcc.dg/c2x-attr-deprecated-2.c, gcc.dg/c2x-attr-fallthrough-2.c,
      	gcc.dg/c2x-attr-maybe_unused-2.c: Expect errors for invalid uses
      	of standard attributes on types.  Add more tests of invalid uses
      	on types.
      
      From-SVN: r278471
      Joseph Myers committed
  2. 19 Nov, 2019 30 commits
    • libgo: better cmd/cgo handling for '.' in pkgpath · 0c6ce0ae
          
          Updates cgo's gccgoPkgpathToSymbolNew() to bring it into
          conformance with the way that gccgo now handles package
          paths with embedded dots (see CL 200838). See also
          https://gcc.gnu.org/PR61880, a related bug. This CL is a
          copy of CL 207957 in the main Go repo.
          
          Updates golang/go#35623.
          
          Reviewed-on: https://go-review.googlesource.com/c/gofrontend/+/207977
      
      From-SVN: r278470
      Ian Lance Taylor committed
    • re PR c++/92414 (internal compiler error: tree check: expected constructor, have… · fce6467b
      re PR c++/92414 (internal compiler error: tree check: expected constructor, have error_mark in cxx_eval_store_expression, at cp/constexpr.c:4009)
      
      	PR c++/92414
      	* constexpr.c (cxx_eval_outermost_constant_expr): If DECL_INITIAL
      	on object is erroneous, return t without trying to evaluate
      	a constexpr dtor.
      
      	* g++.dg/cpp2a/constexpr-dtor4.C: New test.
      
      From-SVN: r278468
      Jakub Jelinek committed
    • Consider parm types equivalence for operator rewrite tiebreaker. · 8d5d9087
      The C++ committee continues to discuss how best to avoid breaking existing
      code with the new rules for reversed operators.  A recent suggestion was to
      base the tie-breaker on the parameter types of the candidates, which made a
      lot of sense to me, so this patch implements that.
      
      This patch also mentions that a candidate was reversed or rewritten when
      printing the list of candidates, and warns about a comparison that becomes
      recursive under the new rules.  There is no flag for this warning; people
      can silence it by swapping the operands.
      
      	* call.c (same_fn_or_template): Change to cand_parms_match.
      	(joust): Adjust.
      	(print_z_candidate): Mark rewritten/reversed candidates.
      	(build_new_op_1): Warn about recursive call with reversed arguments.
      
      From-SVN: r278465
      Jason Merrill committed
    • rs6000.c (move_to_end_of_ready): New, factored out from common code. · 9a8819b8
      	* config/rs6000/rs6000.c (move_to_end_of_ready): New, factored out
      	from common code.
      	(power6_sched_reorder2): Factored out from rs6000_sched_reorder2,
      	call new function.
      	(power9_sched_reorder2): Call new function.
      	(rs6000_sched_reorder2): Likewise.
      
      From-SVN: r278463
      Pat Haugen committed
    • Move ChangeLog entry to correct file · dd46a542
      From-SVN: r278461
      Richard Sandiford committed
    • Remove unused parameter PROB in ipa-fnsummary.c · 98450d19
              * ipa-fnsummary.c (estimate_edge_size_and_time): Drop parameter PROB.
      	(estimate_calls_size_and_time): Update.
      
      From-SVN: r278460
      Jan Hubicka committed
    • Avoid redundant computations in edge_badness. · ea8dd3b6
              * ipa-inline.c (inlining_speedup): New function.
      	(edge_badness): Use it.
      
      From-SVN: r278459
      Jan Hubicka committed
    • [MIPS] Prevent MSA branches from being put into delay slots · 4aa5fd8a
       This patch tightens the instruction definitions to make sure
       that MSA branch instructions cannot be put into delay slots and have their
       delay slots eligible for being filled. Also, MSA *div*3 patterns use MSA
       branches for zero checks but are not marked as being multi instruction and
       thus could be put into delay slots. This patch fixes that.
      
      gcc/ChangeLog:
      
      2019-11-19  Zoran Jovanovic <zoran.jovanovic@mips.com>
      		Dragan Mladjenovic  <dmladjenovic@wavecomp.com>
      
      	* config/mips/mips-msa.md (msa_<msabr>_<msafmt_f>, msa_<msabr>_v_<msafmt_f>):
      	Mark as not having "likely" version.
      	* config/mips/mips.md (insn_count): The simd_div instruction with
      	TARGET_CHECK_ZERO_DIV consists of 3 instructions.
      	(can_delay): Exclude simd_branch.
      	(defile_delay *): Add simd_branch instructions.
      	They have one regular delay slot.
      
      gcc/testsuite/ChangeLog:
      
      2019-11-19  Dragan Mladjenovic  <dmladjenovic@wavecomp.com>
      
      	* gcc.target/mips/msa-ds.c: New test.
      
      From-SVN: r278458
      Dragan Mladjenovic committed
    • Revert r278441 · aa535578
      To restore powerpc bootstrap.
      
      2019-11-19  Richard Sandiford  <richard.sandiford@arm.com>
      gcc/
      	Revert:
      	2019-11-18  Richard Sandiford  <richard.sandiford@arm.com>
      
      	* cse.c (cse_insn): Delete no-op register moves too.
      	* simplify-rtx.c (comparison_to_mask): Handle unsigned comparisons.
      	Take a second comparison to control the value for NE.
      	(mask_to_comparison): Handle unsigned comparisons.
      	(simplify_logical_relational_operation): Likewise.  Update call
      	to comparison_to_mask.  Handle AND if !HONOR_NANs.
      	(simplify_binary_operation_1): Call the above for AND too.
      
      gcc/testsuite/
      	Revert:
      	2019-11-18  Richard Sandiford  <richard.sandiford@arm.com>
      
      	* gcc.target/aarch64/sve/acle/asm/ptest_pmore.c: New test.
      
      From-SVN: r278455
      Richard Sandiford committed
    • [AArch64] PR79262: Adjust vector cost · 4bf29d15
      PR79262 has been fixed for almost all AArch64 cpus, however the example is still
      vectorized in a few cases, resulting in lower performance.  Adjust the vector
      cost slightly so that so that -mcpu=cortex-a53 now has identical performance as
      -mcpu=cortex-a57 on libquantum.
      
          gcc/
      	PR target/79262
      	* config/aarch64/aarch64.c (generic_vector_cost): Adjust
      	vec_to_scalar_cost.
      
      From-SVN: r278452
      Wilco Dijkstra committed
    • re PR c++/89913 (ICE with invalid using declaration) · c286fb4e
      PR c++/89913
      
      gcc/cp/
      	* pt.c (get_underlying_template): Exit loop if the original type
      	of the alias is null.
      
      gcc/testsuite/
      	* g++.dg/cpp2a/pr89913.C: New test.
      
      From-SVN: r278451
      Andrew Sutton committed
    • re PR c++/92078 (error: 'struct std::ptr<Iter>' redeclared with different access) · cce3c9db
      PR c++/92078
      
      gcc/cp/
      	* pt.c (maybe_new_partial_specialization): Apply access to newly
      	created partial specializations. Update comment style.
      
      gcc/testsuite/
      	* g++.dg/cpp2a/concepts-pr92078.C: New.
        * g++.dg/cpp2a/concepts-requires18.C: Update diagnostics.
      
      From-SVN: r278450
      Andrew Sutton committed
    • Suppress diagnostics substituting into a requires-expression (PR c++/92403). · 7aabd67f
      gcc/cp/
      	* pt.c (tsubst_copy_and_build): Perform the first substitution without
      	diagnostics and a second only if tsubst_requries_expr returns an error.
      
      From-SVN: r278449
      Andrew Sutton committed
    • Restore init_ggc_heuristics. · 8b24d594
      2019-11-19  Martin Liska  <mliska@suse.cz>
      
      	* toplev.c (general_init): Move the call...
      	(toplev::main): ... here as we need init_options_struct
      	being called.
      
      From-SVN: r278448
      Martin Liska committed
    • [Arm] Set Armv7-A tune to Cortex-A53 · 24851701
      By default Armv7-A tunes for Cortex-A8. This is an ancient core
      today and the settings are no longer useful for newer cores. So
      switch to Cortex-A53 tuning since it works well across a wide range
      of modern cores.
      
      On SPECINT2006 the performance gain is 0.7% compared to Cortex-A8 tuning,
      and codesize reduces by 0.2%.
      
          gcc/
      	* config/arm/arm-cpus.in (armv7): Set tune to Cortex-A53.
      	(armv7-a): Likewise.
      	(armv7ve): Likewise.
      
      From-SVN: r278447
      Wilco Dijkstra committed
    • Update loop-1.c test for amdgcn · 89842a51
      2019-11-19  Andrew Stubbs  <ams@codesourcery.com>
      
      	gcc/testsuite/
      	* gcc.dg/tree-ssa/loop-1.c: Change amdgcn assembler scan.
      
      From-SVN: r278446
      Andrew Stubbs committed
    • re PR tree-optimization/92581 (condition chains vectorized wrongly) · ef8777c1
      2019-11-19  Richard Biener  <rguenther@suse.de>
      
      	PR tree-optimization/92581
      	* tree-vect-loop.c (vect_create_epilog_for_reduction): For
      	condition reduction chains gather all conditions involved
      	for computing the index reduction vector.
      
      	* gcc.dg/vect/vect-cond-reduc-5.c: New testcase.
      
      From-SVN: r278445
      Richard Biener committed
    • [AArch64] Implement Armv8.5-A memory tagging (MTE) intrinsics · ef01e6bb
      2019-11-19  Dennis Zhang  <dennis.zhang@arm.com>
      
      	* config/aarch64/aarch64-builtins.c (enum aarch64_builtins): Add
      	AARCH64_MEMTAG_BUILTIN_START, AARCH64_MEMTAG_BUILTIN_IRG,
      	AARCH64_MEMTAG_BUILTIN_GMI, AARCH64_MEMTAG_BUILTIN_SUBP,
      	AARCH64_MEMTAG_BUILTIN_INC_TAG, AARCH64_MEMTAG_BUILTIN_SET_TAG,
      	AARCH64_MEMTAG_BUILTIN_GET_TAG, and AARCH64_MEMTAG_BUILTIN_END.
      	(aarch64_init_memtag_builtins): New.
      	(AARCH64_INIT_MEMTAG_BUILTINS_DECL): New macro.
      	(aarch64_general_init_builtins): Call aarch64_init_memtag_builtins.
      	(aarch64_expand_builtin_memtag): New.
      	(aarch64_general_expand_builtin): Call aarch64_expand_builtin_memtag.
      	(AARCH64_BUILTIN_SUBCODE): New macro.
      	(aarch64_resolve_overloaded_memtag): New.
      	(aarch64_resolve_overloaded_builtin_general): New. Call
      	aarch64_resolve_overloaded_memtag to handle overloaded MTE builtins.
      	* config/aarch64/aarch64-c.c (aarch64_update_cpp_builtins): Define
      	__ARM_FEATURE_MEMORY_TAGGING when enabled.
      	(aarch64_resolve_overloaded_builtin): Call
      	aarch64_resolve_overloaded_builtin_general.
      	* config/aarch64/aarch64-protos.h
      	(aarch64_resolve_overloaded_builtin_general): New declaration.
      	* config/aarch64/aarch64.h (AARCH64_ISA_MEMTAG): New macro.
      	(TARGET_MEMTAG): Likewise.
      	* config/aarch64/aarch64.md (UNSPEC_GEN_TAG): New unspec.
      	(UNSPEC_GEN_TAG_RND, and UNSPEC_TAG_SPACE): Likewise.
      	(irg, gmi, subp, addg, ldg, stg): New instructions.
      	* config/aarch64/arm_acle.h (__arm_mte_create_random_tag): New macro.
      	(__arm_mte_exclude_tag, __arm_mte_ptrdiff): Likewise.
      	(__arm_mte_increment_tag, __arm_mte_set_tag): Likewise.
      	(__arm_mte_get_tag): Likewise.
      	* config/aarch64/predicates.md (aarch64_memtag_tag_offset): New.
      	(aarch64_granule16_uimm6, aarch64_granule16_simm9): New.
      	* config/arm/types.md (memtag): New.
      	* doc/invoke.texi (-memtag): Update description.
      
      2019-11-19  Dennis Zhang  <dennis.zhang@arm.com>
      
      	* gcc.target/aarch64/acle/memtag_1.c: New test.
      	* gcc.target/aarch64/acle/memtag_2.c: New test.
      	* gcc.target/aarch64/acle/memtag_3.c: New test.
      
      From-SVN: r278444
      Dennis Zhang committed
    • arm: Fixes for asm-flags vs thumb1 and ilp32 · 35ba842f
      Thumb1 cannot support asm-flags currently, because we don't expose the
      flags register to the compiler.  Disable the support for that case.
      
      Adjust the asm-flag-6 test for aarch64 ilp32 correctness.
      
      gcc/
      	* config/arm/arm-c.c (arm_cpu_builtins): Use def_or_undef_macro
      	to define __GCC_ASM_FLAG_OUTPUTS__.
      	* config/arm/arm.c (thumb1_md_asm_adjust): New function.
      	(arm_option_params_internal): Swap out targetm.md_asm_adjust
      	depending on TARGET_THUMB1.
      	* doc/extend.texi (FlagOutputOperands): Document thumb1 restriction.
      
      gcc/testsuite/
      	* testsuite/gcc.target/arm/asm-flag-3.c: Skip for thumb1.
      	* testsuite/gcc.target/arm/asm-flag-5.c: Likewise.
      	* testsuite/gcc.target/arm/asm-flag-6.c: Likewise.
      	* testsuite/gcc.target/arm/asm-flag-4.c: New test.
      
      	* testsuite/gcc.target/aarch64/asm-flag-6.c: Use %w for
      	asm inputs to cmp instruction for ILP32.
      
      From-SVN: r278443
      Richard Henderson committed
    • libstdc++: Fix declarations of variable templates · 5ecaaf98
      This code is invalid and rejected by other compilers (see PR 92576).
      
      	* include/bits/regex.h (ranges::__detail::__enable_view_impl): Fix
      	declaration.
      	* include/bits/stl_multiset.h (ranges::__detail::__enable_view_impl):
      	Likewise.
      	* include/bits/stl_set.h (ranges::__detail::__enable_view_impl):
      	Likewise.
      	* include/bits/unordered_set.h (ranges::__detail::__enable_view_impl):
      	Likewise.
      	* include/debug/multiset.h (ranges::__detail::__enable_view_impl):
      	Likewise.
      	* include/debug/set.h (ranges::__detail::__enable_view_impl): Likewise.
      	* include/debug/unordered_set (ranges::__detail::__enable_view_impl):
      	Likewise.
      
      From-SVN: r278440
      Jonathan Wakely committed
    • re PR target/92549 (Use x86 xchg instruction more) · 63b88711
      	PR target/92549
      	* config/i386/i386.md (peephole2 for *swap<mode>): New peephole2.
      
      	* gcc.target/i386/pr92549.c: New test.
      
      From-SVN: r278439
      Jakub Jelinek committed
    • re PR middle-end/91450 (__builtin_mul_overflow(A,B,R) wrong code if product < 0,… · beeac4c2
      re PR middle-end/91450 (__builtin_mul_overflow(A,B,R) wrong code if product < 0, *R is unsigned, and !(A&B))
      
      	PR middle-end/91450
      	* internal-fn.c (expand_mul_overflow): For s1 * s2 -> ur, if one
      	operand is negative and one non-negative, compare the non-negative
      	one against 0 rather than comparing s1 & s2 against 0.  Otherwise,
      	don't compare (s1 & s2) == 0, but compare separately both s1 == 0
      	and s2 == 0, unless one of them is known to be negative.  Remove
      	tem2 variable, use tem where tem2 has been used before.
      
      	* gcc.c-torture/execute/pr91450-1.c: New test.
      	* gcc.c-torture/execute/pr91450-2.c: New test.
      
      From-SVN: r278437
      Jakub Jelinek committed
    • re PR c++/92504 (ICE on gcc-9 -fopenmp: internal compiler error: tree check:… · 863bbe2b
      re PR c++/92504 (ICE on gcc-9 -fopenmp: internal compiler error: tree check: expected tree that contains 'decl common' structure, have 'baselink' in get_inner_reference, at expr.c:7238)
      
      	PR c++/92504
      	* semantics.c (handle_omp_for_class_iterator): Don't call
      	cp_fully_fold on cond.
      
      	* g++.dg/gomp/pr92504.C: New test.
      
      From-SVN: r278433
      Jakub Jelinek committed
    • re PR tree-optimization/92557 (ICE in omp_clause_aligned_alignment, at omp-low.c:4090) · b51d4ebc
      	PR tree-optimization/92557
      	* omp-low.c (omp_clause_aligned_alignment): Punt if TYPE_MODE is not
      	vmode rather than asserting it always is.
      
      	* gcc.dg/gomp/pr92557.c: New test.
      
      From-SVN: r278432
      Jakub Jelinek committed
    • re PR tree-optimization/92554 (ICE in vect_create_epilog_for_reduction, at tree-vect-loop.c:4325) · 04c4599d
      2019-11-19  Richard Biener  <rguenther@suse.de>
      
      	PR tree-optimization/92554
      	* tree-vect-loop.c (vect_create_epilog_for_reduction): Look
      	for the actual condition stmt and deal with sign-changes.
      
      	* gcc.dg/vect/pr92554.c: New testcase.
      
      From-SVN: r278431
      Richard Biener committed
    • re PR tree-optimization/92555 (ICE in exact_div, at poly-int.h:2162) · f1e0c7e0
      2019-09-19  Richard Biener  <rguenther@suse.de>
      
      	PR tree-optimization/92555
      	* tree-vect-loop.c (vect_update_vf_for_slp): Also scan PHIs
      	for non-SLP stmts.
      
      	* gcc.dg/vect/pr92555.c: New testcase.
      
      From-SVN: r278430
      Richard Biener committed
    • Initialize a variable due to -Wmaybe-uninitialized. · e89a689f
      2019-11-19  Martin Liska  <mliska@suse.cz>
      
      	PR bootstrap/92540
      	* config/riscv/riscv.c (riscv_address_insns): Initialize
      	addr in order to remove boostrap -Wmaybe-uninitialized
      	error.
      
      From-SVN: r278429
      Martin Liska committed
    • Change some bad uses of C2x attributes into pedwarns. · 192961ff
      Certain bad uses of C2x standard attributes (that is, attributes
      inside [[]] with only a name but no namespace specified) are
      constraint violations, and so should be diagnosed with a pedwarn (or
      error) where GCC currently uses a warning.  This patch implements this
      in some cases (not yet for attributes used on types, nor for some bad
      uses of fallthrough attributes).  Specifically, this applies to
      unknown standard attributes (taking care not to pedwarn for nodiscard,
      which is known but not implemented for C), and to all currently
      implemented standard attributes in attribute declarations (including
      when mixed with fallthrough) and on statements.
      
      Bootstrapped with no regressions on x86_64-pc-linux-gnu.
      
      gcc/c:
      	* c-decl.c (c_warn_unused_attributes): Use pedwarn not warning for
      	standard attributes.
      	* c-parser.c (c_parser_std_attribute): Take argument for_tm.  Use
      	pedwarn for unknown standard attributes and return error_mark_node
      	for them.
      
      gcc/c-family:
      	* c-common.c (attribute_fallthrough_p): In C, use pedwarn not
      	warning for standard attributes mixed with fallthrough attributes.
      
      gcc/testsuite:
      	* gcc.dg/c2x-attr-fallthrough-5.c, gcc.dg/c2x-attr-syntax-5.c: New
      	tests.
      	* gcc.dg/c2x-attr-deprecated-2.c, gcc.dg/c2x-attr-deprecated-4.c,
      	gcc.dg/c2x-attr-fallthrough-2.c, gcc.dg/c2x-attr-maybe_unused-2.c,
      	gcc.dg/c2x-attr-maybe_unused-4.c: Expect errors in place of some
      	warnings.
      
      From-SVN: r278428
      Joseph Myers committed
    • Daily bump. · 95d4434f
      From-SVN: r278427
      GCC Administrator committed
  3. 18 Nov, 2019 5 commits
    • typeck.c (cp_build_addr_expr_1): Use cp_expr_loc_or_input_loc in three places. · f5a191ef
      /cp
      2019-11-18  Paolo Carlini  <paolo.carlini@oracle.com>
      
      	* typeck.c (cp_build_addr_expr_1): Use cp_expr_loc_or_input_loc
      	in three places.
      	(cxx_sizeof_expr): Use it in one additional place.
      	(cxx_alignof_expr): Likewise.
      	(lvalue_or_else): Likewise.
      
      /testsuite
      2019-11-18  Paolo Carlini  <paolo.carlini@oracle.com>
      
      	* g++.dg/cpp0x/addressof2.C: Test locations too.
      	* g++.dg/cpp0x/rv-lvalue-req.C: Likewise.
      	* g++.dg/expr/crash2.C: Likewise.
      	* g++.dg/expr/lval1.C: Likewise.
      	* g++.dg/expr/unary2.C: Likewise.
      	* g++.dg/ext/lvaddr.C: Likewise.
      	* g++.dg/ext/lvalue1.C: Likewise.
      	* g++.dg/tree-ssa/pr20280.C: Likewise.
      	* g++.dg/warn/Wplacement-new-size.C: Likewise.
      	* g++.old-deja/g++.brendan/alignof.C: Likewise.
      	* g++.old-deja/g++.brendan/sizeof2.C: Likewise.
      	* g++.old-deja/g++.law/temps1.C: Likewise.
      
      From-SVN: r278424
      Paolo Carlini committed
    • PR middle-end/92493 - ICE in get_origin_and_offset at gimple-ssa-sprintf.c · de83907a
      gcc/ChangeLog:
      
      	PR tree-optimization/92493
      	* gimple-ssa-sprintf.c (get_origin_and_offset): Remove spurious
      	assignment.
      
      gcc/testsuite/ChangeLog:
      
      	PR tree-optimization/92493
      	* gcc.dg/pr92493.c: New test.
      
      From-SVN: r278423
      Martin Sebor committed
    • Refactor tree-loop-distribution.c for thread safety · eef99cd9
      This patch refactors tree-loop-distribution.c for thread safety without
      use of C11 __thread feature. All global variables were moved to
      `class loop_distribution` which is initialized at ::execute time.
      
      From-SVN: r278421
      Giuliano Belinassi committed
    • re PR ipa/92508 (ICE in do_estimate_edge_time, at ipa-inline-analysis.c:223 since r278159) · 8d890d37
      
      	PR ipa/92508
      	* ipa-inline.c (inline_small_functions): Add new edges after reseting
      	caches.
      	* ipa-inline-analysis.c (do_estimate_edge_time): Fix sanity check.
      
      From-SVN: r278419
      Jan Hubicka committed
    • Add more C2x attributes tests. · 092508a0
      This patch adds more tests of C2x attributes, where I found cases that
      were handled correctly by my patches but missing from the original
      tests.  Tests are added for -std=c11 -pedantic handling of C2x
      attribute syntax and corresponding -Wc11-c2x-compat handling; for
      struct [[deprecated]]; and for the [[__fallthrough__]] spelling of
      [[fallthrough]] in the case of valid fallthrough attributes.
      
      Tested for x86_64-pc-linux-gnu.
      
      	* gcc.dg/c11-attr-syntax-1.c, gcc.dg/c11-attr-syntax-2.c,
      	gcc.dg/c11-attr-syntax-3.c, gcc.dg/c2x-attr-syntax-4.c: New tests.
      	* gcc.dg/c2x-attr-deprecated-1.c: Also test struct [[deprecated]].
      	* gcc.dg/c2x-attr-fallthrough-1.c: Also test [[__fallthrough__]].
      
      From-SVN: r278418
      Joseph Myers committed