1. 09 Jan, 2020 21 commits
    • [AArch64] Tweak iterator usage for [SU]Q{ADD,SUB} · 694e6b19
      The pattern:
      
      ;; <su>q<addsub>
      
      (define_insn "aarch64_<su_optab><optab><mode>"
        [(set (match_operand:VSDQ_I 0 "register_operand" "=w")
      	(BINQOPS:VSDQ_I (match_operand:VSDQ_I 1 "register_operand" "w")
      			  (match_operand:VSDQ_I 2 "register_operand" "w")))]
        "TARGET_SIMD"
        "<su_optab><optab>\\t%<v>0<Vmtype>, %<v>1<Vmtype>, %<v>2<Vmtype>"
        [(set_attr "type" "neon_<optab><q>")]
      )
      
      meant that we overloaded "optab" to be "qadd" for both SQADD and
      UQADD.  Most other "optab" entries are instead the full optab name,
      which for these patterns would be "ssadd" and "usadd" respectively.
      (Unfortunately, the optabs don't extend to vectors yet, something
      that would be good to fix in GCC 11.)
      
      This patch therefore does what the comment implies and uses
      q<addsub> to distinguish qadd and qsub instead.
      
      2020-01-09  Richard Sandiford  <richard.sandiford@arm.com>
      
      gcc/
      	* config/aarch64/iterators.md (addsub): New code attribute.
      	* config/aarch64/aarch64-simd.md (aarch64_<su_optab><optab><mode>):
      	Re-express as...
      	(aarch64_<su_optab>q<addsub><mode>): ...this, making the same change
      	in the asm string and attributes.  Fix indentation.
      	* config/aarch64/aarch64-sve.md (@aarch64_<su_optab><optab><mode>):
      	Re-express as...
      	(@aarch64_sve_<optab><mode>): ...this.
      	* config/aarch64/aarch64-sve-builtins.h
      	(function_expander::expand_signed_unpred_op): Delete.
      	* config/aarch64/aarch64-sve-builtins.cc
      	(function_expander::expand_signed_unpred_op): Likewise.
      	(function_expander::map_to_rtx_codes): If the optab isn't defined,
      	try using code_for_aarch64_sve instead.
      	* config/aarch64/aarch64-sve-builtins-base.cc (svqadd_impl): Delete.
      	(svqsub_impl): Likewise.
      	(svqadd, svqsub): Use rtx_code_function instead.
      
      From-SVN: r280050
      Richard Sandiford committed
    • [AArch64] Remove fictitious [SU]RHSUB instructions · 2e828dfe
      We've had skeleton support for "SRHSUB" and "URHSUB" since the initial
      commit of the port, but no such instructions exist.
      
      2020-01-09  Richard Sandiford  <richard.sandiford@arm.com>
      
      gcc/
      	* config/aarch64/iterators.md (SRHSUB, URHSUB): Delete.
      	(HADDSUB, sur, addsub): Remove them.
      
      From-SVN: r280049
      Richard Sandiford committed
    • Fix tree-nrv.c ICE for direct internal functions · 9ecb4221
      pass_return_slot::execute has:
      
      	      /* Ignore internal functions without direct optabs,
      		 those are expanded specially and aggregate_value_p
      		 on their result might result in undesirable warnings
      		 with some backends.  */
      	      && (!gimple_call_internal_p (stmt)
      		  || direct_internal_fn_p (gimple_call_internal_fn (stmt)))
      	      && aggregate_value_p (TREE_TYPE (gimple_call_lhs (stmt)),
      				    gimple_call_fndecl (stmt)))
      
      But what the comment says applies to directly-mapped internal functions
      too, since they're only used if the target supports them without a
      libcall.
      
      This was triggering an ICE on the attached testcase.  The svld3 call
      is folded to an IFN_LOAD_LANES, which returns an array of vectors with
      VNx48QImode.  Since no such return type can exist in C, the target hook
      was complaining about an unexpected use of SVE modes.  (And we want to
      keep asserting for that, so that we don't accidentally define an ABI for
      an unexpected corner case.)
      
      2020-01-09  Richard Sandiford  <richard.sandiford@arm.com>
      
      gcc/
      	* tree-nrv.c (pass_return_slot::execute): Handle all internal
      	functions the same way, rather than singling out those that
      	aren't mapped directly to optabs.
      
      gcc/testsuite/
      	* gcc.target/aarch64/sve/acle/general/nrv_1.c: New test.
      
      From-SVN: r280048
      Richard Sandiford committed
    • Add a compatible_vector_types_p target hook · 482b2b43
      One problem with adding an N-bit vector extension to an existing
      architecture is to decide how N-bit vectors should be passed to
      functions and returned from functions.  Allowing all N-bit vector
      types to be passed in registers breaks backwards compatibility,
      since N-bit vectors could be used (and emulated) before the vector
      extension was added.  But always passing N-bit vectors on the
      stack would be inefficient for things like vector libm functions.
      
      For SVE we took the compromise position of predefining new SVE vector
      types that are distinct from all existing vector types, including
      GNU-style vectors.  The new types are passed and returned in an
      efficient way while existing vector types are passed and returned
      in the traditional way.  In the right circumstances, the two types
      are inter-convertible.
      
      The SVE types are created using:
      
            vectype = build_distinct_type_copy (vectype);
            SET_TYPE_STRUCTURAL_EQUALITY (vectype);
            TYPE_ARTIFICIAL (vectype) = 1;
      
      The C frontend maintains this distinction, using VIEW_CONVERT_EXPR
      to convert from one type to the other.  However, the distinction can
      be lost during gimple, which treats two vector types with the same
      mode, number of elements, and element type as equivalent.  And for
      most targets that's the right thing to do.
      
      This patch therefore adds a hook that lets the target choose
      whether such vector types are indeed equivalent.
      
      Note that the new tests fail for -mabi=ilp32 in the same way as other
      ACLE-based tests.  I'm still planning to fix that as a follow-on.
      
      2020-01-09  Richard Sandiford  <richard.sandiford@arm.com>
      
      gcc/
      	* target.def (compatible_vector_types_p): New target hook.
      	* hooks.h (hook_bool_const_tree_const_tree_true): Declare.
      	* hooks.c (hook_bool_const_tree_const_tree_true): New function.
      	* doc/tm.texi.in (TARGET_COMPATIBLE_VECTOR_TYPES_P): New hook.
      	* doc/tm.texi: Regenerate.
      	* gimple-expr.c: Include target.h.
      	(useless_type_conversion_p): Use targetm.compatible_vector_types_p.
      	* config/aarch64/aarch64.c (aarch64_compatible_vector_types_p): New
      	function.
      	(TARGET_COMPATIBLE_VECTOR_TYPES_P): Define.
      	* config/aarch64/aarch64-sve-builtins.cc (gimple_folder::convert_pred):
      	Use the original predicate if it already has a suitable type.
      
      gcc/testsuite/
      	* gcc.target/aarch64/sve/pcs/gnu_vectors_1.c: New test.
      	* gcc.target/aarch64/sve/pcs/gnu_vectors_2.c: Likewise.
      
      From-SVN: r280047
      Richard Sandiford committed
    • Fortran] PR84135 fix merging dimension into codimension array spec · 15df0040
              PR fortran/84135
              * array.c (gfc_set_array_spec): Fix shifting of codimensions
              when adding a dimension.
              * decl.c (merge_array_spec): Ditto. Fix using correct codimensions.
      
              PR fortran/84135
              * gfortran.dg/coarray/codimension_3.f90: New.
      
      From-SVN: r280046
      Tobias Burnus committed
    • libstdc++: Define memory resource key functions non-inline (PR93208) · d574c8aa
      This prevents the vtables and RTTI from being emitted in every object
      file that uses memory_resource and monotonic_buffer_resource.
      
      Objects compiled by GCC 9.1 or 9.2 will contain inline definitions of
      the destructors, vtable and RTTI, but this is harmless. The inline
      definitions have identical effects to the ones that are now defined in
      libstdc++.so so it doesn't matter if the inline ones are used instead of
      calling the symbols exported from the runtime library.
      
      	PR libstdc++/93208
      	* config/abi/pre/gnu.ver: Add new exports.
      	* include/std/memory_resource (memory_resource::~memory_resource()):
      	Do not define inline.
      	(monotonic_buffer_resource::~monotonic_buffer_resource()): Likewise.
      	* src/c++17/memory_resource.cc (memory_resource::~memory_resource()):
      	Define.
      	(monotonic_buffer_resource::~monotonic_buffer_resource()): Define.
      	* testsuite/20_util/monotonic_buffer_resource/93208.cc: New test.
      
      From-SVN: r280044
      Jonathan Wakely committed
    • Make cgraph_edge::resolve-speculation static · 27c5a177
      2020-01-09  Martin Jambor  <mjambor@suse.cz>
      
      	* cgraph.h (cgraph_edge): Make remove, set_call_stmt, make_direct,
      	resolve_speculation and redirect_call_stmt_to_callee static.  Change
      	return type of set_call_stmt to cgraph_edge *.
      	* auto-profile.c (afdo_indirect_call): Adjust call to
      	redirect_call_stmt_to_callee.
      	* cgraph.c (cgraph_edge::set_call_stmt): Make return cgraph-edge *,
      	make the this pointer explicit, adjust self-recursive calls and the
      	call top make_direct.  Return the resulting edge.
      	(cgraph_edge::remove): Make this pointer explicit.
      	(cgraph_edge::resolve_speculation): Likewise, adjust call to remove.
      	(cgraph_edge::make_direct): Likewise, adjust call to
      	resolve_speculation.
      	(cgraph_edge::redirect_call_stmt_to_callee): Likewise, also adjust
      	call to set_call_stmt.
      	(cgraph_update_edges_for_call_stmt_node): Update call to
      	set_call_stmt and remove.
      	* cgraphclones.c (cgraph_node::set_call_stmt_including_clones):
      	Renamed edge to master_edge.  Adjusted calls to set_call_stmt.
      	(cgraph_node::create_edge_including_clones): Moved "first" definition
      	of edge to the block where it was used.  Adjusted calls to
      	set_call_stmt.
      	(cgraph_node::remove_symbol_and_inline_clones): Adjust call to
      	cgraph_edge::remove.
      	* cgraphunit.c (walk_polymorphic_call_targets): Adjusted calls to
      	make_direct and redirect_call_stmt_to_callee.
      	* ipa-fnsummary.c (redirect_to_unreachable): Adjust calls to
      	resolve_speculation and make_direct.
      	* ipa-inline-transform.c (inline_transform): Adjust call to
      	redirect_call_stmt_to_callee.
      	(check_speculations_1):: Adjust call to resolve_speculation.
      	* ipa-inline.c (resolve_noninline_speculation): Adjust call to
      	resolve-speculation.
      	(inline_small_functions): Adjust call to resolve_speculation.
      	(ipa_inline): Likewise.
      	* ipa-prop.c (ipa_make_edge_direct_to_target): Adjust call to
      	make_direct.
      	* ipa-visibility.c (function_and_variable_visibility): Make iteration
      	safe with regards to edge removal, adjust calls to
      	redirect_call_stmt_to_callee.
      	* ipa.c (walk_polymorphic_call_targets): Adjust calls to make_direct
      	and redirect_call_stmt_to_callee.
      	* multiple_target.c (create_dispatcher_calls): Adjust call to
      	redirect_call_stmt_to_callee
      	(redirect_to_specific_clone): Likewise.
      	* tree-cfgcleanup.c (delete_unreachable_blocks_update_callgraph):
      	Adjust calls to cgraph_edge::remove.
      	* tree-inline.c (copy_bb): Adjust call to set_call_stmt.
      	(redirect_all_calls): Adjust call to redirect_call_stmt_to_callee.
      	(expand_call_inline): Adjust call to cgraph_edge::remove.
      
      From-SVN: r280043
      Martin Jambor committed
    • Set Optimization for param_max_speculative_devirt_maydefs. · 87f9579a
      2020-01-09  Martin Liska  <mliska@suse.cz>
      
      	* params.opt: Set Optimization for
      	param_max_speculative_devirt_maydefs.
      
      From-SVN: r280042
      Martin Liska committed
    • PR middle-end/93200 - spurious -Wstringop-overflow due to assignment… · 2b5d3dc2
      PR middle-end/93200 - spurious -Wstringop-overflow due to assignment vectorization to multiple members
      
      PR middle-end/93200 - spurious -Wstringop-overflow due to assignment vectorization to multiple members
      PR fortran/92956 - 'libgomp.fortran/examples-4/async_target-2.f90' fails with offloading due to bogus -Wstringop-overflow warning
      
      gcc/testsuite/ChangeLog:
      
      	PR middle-end/93200
      	* gcc.dg/Wstringop-overflow-30.c: New test.
      
      gcc/ChangeLog:
      
      	PR middle-end/93200
      	PR fortran/92956
      	* builtins.c (compute_objsize): Avoid handling MEM_REFs of vector type.
      
      From-SVN: r280041
      Martin Sebor committed
    • Add Optimization for various IPA parameters. · fdfd7f53
      2020-01-09  Martin Liska  <mliska@suse.cz>
      
      	* auto-profile.c (auto_profile): Use opt_for_fn
      	for a parameter.
      	* ipa-cp.c (ipcp_lattice::add_value): Likewise.
      	(propagate_vals_across_arith_jfunc): Likewise.
      	(hint_time_bonus): Likewise.
      	(incorporate_penalties): Likewise.
      	(good_cloning_opportunity_p): Likewise.
      	(perform_estimation_of_a_value): Likewise.
      	(estimate_local_effects): Likewise.
      	(ipcp_propagate_stage): Likewise.
      	* ipa-fnsummary.c (decompose_param_expr): Likewise.
      	(set_switch_stmt_execution_predicate): Likewise.
      	(analyze_function_body): Likewise.
      	* ipa-inline-analysis.c (offline_size): Likewise.
      	* ipa-inline.c (early_inliner): Likewise.
      	* ipa-prop.c (ipa_analyze_node): Likewise.
      	(ipcp_transform_function): Likewise.
      	* ipa-sra.c (process_scan_results): Likewise.
      	(ipa_sra_summarize_function): Likewise.
      	* params.opt: Rename ipcp-unit-growth to
      	ipa-cp-unit-growth.  Add Optimization for various
      	IPA-related parameters.
      
      From-SVN: r280040
      Martin Liska committed
    • re PR tree-optimization/93054 (ICE in gimple_set_lhs, at gimple.c:1820) · 00294b18
      2020-01-09  Richard Biener  <rguenther@suse.de>
      
      	PR middle-end/93054
      	* gimplify.c (gimplify_expr): Deal with NOP definitions.
      
      	* gcc.dg/pr93054.c: New testcase.
      
      From-SVN: r280039
      Richard Biener committed
    • re PR tree-optimization/93040 (gcc doesn't optimize unaligned accesses to a… · 0f507a36
      re PR tree-optimization/93040 (gcc doesn't optimize unaligned accesses to a 16-bit value on the x86 as well as it does a 32-bit value (or clang))
      
      2020-01-09  Richard Biener  <rguenther@suse.de>
      
      	PR tree-optimization/93040
      	* gimple-ssa-store-merging.c (find_bswap_or_nop): Raise search limit.
      
      	* gcc.dg/optimize-bswaphi-1.c: Amend.
      	* gcc.dg/optimize-bswapsi-2.c: Likewise.
      
      From-SVN: r280034
      Richard Biener committed
    • avr-common.c (avr_option_optimization_table): Set -fsplit-wide-types-early. · ddc8786f
      	* common/config/avr/avr-common.c (avr_option_optimization_table)
      	[OPT_LEVELS_1_PLUS]: Set -fsplit-wide-types-early.
      
      From-SVN: r280033
      Georg-Johann Lay committed
    • One more usage of cgraph_node::dump_name. · edbe1f3b
      2020-01-09  Martin Liska  <mliska@suse.cz>
      
      	* cgraphclones.c (symbol_table::materialize_all_clones):
      	Use cgraph_node::dump_name.
      
      From-SVN: r280031
      Martin Liska committed
    • re PR inline-asm/93202 ([RISCV] ICE when using inline asm 'h' operand modifier) · a0ab54de
      	PR inline-asm/93202
      	* config/riscv/riscv.c (riscv_print_operand_reloc): Use
      	output_operand_lossage instead of gcc_unreachable.
      	* doc/md.texi (riscv f constraint): Fix typo.
      
      	* gcc.target/riscv/pr93202.c: New test.
      
      From-SVN: r280030
      Jakub Jelinek committed
    • re PR target/93141 (Missed optimization : Use of adc when checking overflow) · ec9b602c
      	PR target/93141
      	* config/i386/i386.md (subv<mode>4): Use SWIDWI iterator instead of
      	SWI.  Use <general_hilo_operand> instead of <general_operand>.  Use
      	CONST_SCALAR_INT_P instead of CONST_INT_P.
      	(*subv<mode>4_1): Rename to ...
      	(subv<mode>4_1): ... this.
      	(*subv<dwi>4_doubleword, *addv<dwi>4_doubleword_1): New
      	define_insn_and_split patterns.
      	(*subv<mode>4_overflow_1, *addv<mode>4_overflow_2): New define_insn
      	patterns.
      
      	* gcc.target/i386/pr93141-1.c: Add tests with constants that have MSB
      	of the low half of the constant set.
      	* gcc.target/i386/pr93141-2.c: New test.
      
      From-SVN: r280029
      Jakub Jelinek committed
    • PR libstdc++/92124 fix incorrect unordered container move assignment · b9c84e95
      	* include/bits/hashtable.h (_Hashtable<>::__alloc_node_gen_t): New
      	template alias.
      	(_Hashtable<>::__fwd_value_for): New.
      	(_Hashtable<>::_M_assign_elements<>): Remove _NodeGenerator template
      	parameter.
      	(_Hashtable<>::_M_assign<>): Add _Ht template parameter.
      	(_Hashtable<>::operator=(const _Hashtable<>&)): Adapt.
      	(_Hashtable<>::_M_move_assign): Adapt. Replace std::move_if_noexcept
      	with std::move.
      	(_Hashtable<>::_Hashtable(const _Hashtable&)): Adapt.
      	(_Hashtable<>::_Hashtable(const _Hashtable&, const allocator_type&)):
      	Adapt.
      	(_Hashtable<>::_Hashtable(_Hashtable&&, const allocator_type&)):
      	Adapt.
      	* testsuite/23_containers/unordered_set/92124.cc: New.
      
      From-SVN: r280028
      François Dumont committed
    • vec.h: add auto_delete_vec · e4d2203e
      This patch adds a class auto_delete_vec<T>, a subclass of auto_vec <T *>
      that deletes all of its elements on destruction; it's used in many
      places in the analyzer patch kit.
      
      This is a crude way for a vec to "own" the objects it points to
      and clean up automatically (essentially a workaround for not being able
      to use unique_ptr, due to C++98).
      
      gcc/ChangeLog:
      	* vec.c (class selftest::count_dtor): New class.
      	(selftest::test_auto_delete_vec): New test.
      	(selftest::vec_c_tests): Call it.
      	* vec.h (class auto_delete_vec): New class template.
      	(auto_delete_vec<T>::~auto_delete_vec): New dtor.
      
      From-SVN: r280027
      David Malcolm committed
    • sbitmap.h: add operator const_sbitmap to auto_sbitmap · b3de347f
      gcc/ChangeLog:
      	* sbitmap.h (auto_sbitmap): Add operator const_sbitmap.
      
      From-SVN: r280026
      David Malcolm committed
    • RISC-V: Disable use of TLS copy relocs. · dca7e570
      Musl and lld don't support TLS copy relocs, and don't want to add support
      for this feature which is unique to RISC-V.  Only GNU ld and glibc support
      them.  In the pasbi discussion, people have pointed out various problems
      with using them, so we are deprecating them.  There doesn't seem to be an
      ABI break from dropping them so this patch modifies gcc to stop creating
      them.  I'm using an ifdef for now in case a problem turns up and the code
      has to be re-enabled.  The plan is to add an initial to local exec
      relaxation as a replacement, though this has not been defined or
      implemented yet.
      
      	gcc/
      	* config/riscv/riscv.c (riscv_legitimize_tls_address): Ifdef out
      	use of TLS_MODEL_LOCAL_EXEC when not pic.
      
      From-SVN: r280025
      Jim Wilson committed
    • Daily bump. · 199caa70
      From-SVN: r280024
      GCC Administrator committed
  2. 08 Jan, 2020 19 commits
    • Add TARGET_EXPR_DIRECT_INIT_P sanity check. · 08f594eb
      	* cp-gimplify.c (cp_gimplify_expr) [TARGET_EXPR]: Check
      	TARGET_EXPR_DIRECT_INIT_P.
      	* constexpr.c (cxx_eval_constant_expression): Likewise.
      
      From-SVN: r280019
      Jason Merrill committed
    • PR c++/91369 - constexpr destructor and member initializer. · 10d2f801
      Previously it didn't matter whether we looked through a TARGET_EXPR in
      constexpr evaluation, but now that we have constexpr destructors it does.
      On IRC I mentioned the idea of clearing TARGET_EXPR_CLEANUP in
      digest_nsdmi_init, but since this initialization is expressed by an
      INIT_EXPR, it's better to handle all INIT_EXPR, not just those for a member
      initializer.
      
      	* constexpr.c (cxx_eval_store_expression): Look through TARGET_EXPR
      	when not preevaluating.
      
      From-SVN: r280018
      Jason Merrill committed
    • Remove constexpr support for DECL_BY_REFERENCE. · cd3ca6cb
      Since we switched to doing constexpr evaluation on pre-GENERIC trees,
      we don't have to handle DECL_BY_REFERENCE.
      
      	* constexpr.c (cxx_eval_call_expression): Remove DECL_BY_REFERENCE
      	support.
      
      From-SVN: r280017
      Jason Merrill committed
    • * gcc.dg/Wstringop-overflow-27.c: Make testnames unique. · 5b18be0b
      From-SVN: r280016
      Jeff Law committed
    • hash-map-tests.c: fix memory leak · 51f90235
      This commit makes "make selftest-valgrind" clean by fixing this leak:
      
      4 bytes in 1 blocks are definitely lost in loss record 1 of 734
         at 0x483AB1A: calloc (vg_replace_malloc.c:762)
         by 0x261DBE0: xcalloc (xmalloc.c:162)
         by 0x2538C46: selftest::test_map_of_strings_to_int() (hash-map-tests.c:87)
         by 0x253ABD2: selftest::hash_map_tests_c_tests() (hash-map-tests.c:307)
         by 0x24A885B: selftest::run_tests() (selftest-run-tests.c:65)
         by 0x1373D80: toplev::run_self_tests() (toplev.c:2339)
         by 0x1373FA7: toplev::main(int, char**) (toplev.c:2421)
         by 0x2550EFF: main (main.c:39)
      
      gcc/ChangeLog:
      	* hash-map-tests.c (selftest::test_map_of_strings_to_int): Fix
      	memory leak.
      
      From-SVN: r280015
      David Malcolm committed
    • libstdc++: Fix error handling in filesystem::remove_all (PR93201) · fff148b7
      When recursing into a directory, any errors that occur while removing a
      directory entry are ignored, because the subsequent increment of the
      directory iterator clears the error_code object.
      
      This fixes that bug by checking the result of each recursive operation
      before incrementing. This is a change in observable behaviour, because
      previously other directory entries would still be removed even if one
      (or more) couldn't be removed due to errors. Now the operation stops on
      the first error, which is what the code intended to do all along. The
      standard doesn't specify what happens in this case (because the order
      that the entries are processed is unspecified anyway).
      
      It also improves the error reporting so that the name of the file that
      could not be removed is included in the filesystem_error exception. This
      is done by introducing a new helper type for reporting errors with
      additional context and a new function that uses that type. Then the
      overload of std::filesystem::remove_all that throws an exception can use
      the new function to ensure any exception contains the additional
      information.
      
      For std::experimental::filesystem::remove_all just fix the bug where
      errors are ignored.
      
      	PR libstdc++/93201
      	* src/c++17/fs_ops.cc (do_remove_all): New function implementing more
      	detailed error reporting for remove_all. Check result of recursive
      	call before incrementing iterator.
      	(remove_all(const path&), remove_all(const path&, error_code&)): Use
      	do_remove_all.
      	* src/filesystem/ops.cc (remove_all(const path&, error_code&)): Check
      	result of recursive call before incrementing iterator.
      	* testsuite/27_io/filesystem/operations/remove_all.cc: Check errors
      	are reported correctly.
      	* testsuite/experimental/filesystem/operations/remove_all.cc: Likewise.
      
      From-SVN: r280014
      Jonathan Wakely committed
    • Add missing { dg-require-effective-target fpic } to aarch64 tests · face749a
      2020-01-08  Joel Brobecker  <brobecker@adacore.com>
                Olivier Hainque  <hainque@adacore.com>
      
      	testsuite/
      	* g++.target/aarch64/sve/tls_2.C: Add missing
      	{ dg-require-effective-target fpic } directive.
      	* gcc.target/aarch64/noplt_2.c: Likewise.
      	* gcc.target/aarch64/noplt_3.c: Likewise.
      	* gcc.target/aarch64/pic-constantpool1.c: Likewise.
      	* gcc.target/aarch64/pic-small.c: Likewise.
      	* gcc.target/aarch64/pic-symrefplus.c: Likewise.
      	* gcc.target/aarch64/pr66912.c: Likewise.
      	* gcc.target/aarch64/sve/tls_1.c: Likewise.
      	* gcc.target/aarch64/sve/tls_preserve_1.c: Likewise.
      	* gcc.target/aarch64/sve/tls_preserve_2.c: Likewise.
      	* gcc.target/aarch64/sve/tls_preserve_3.c: Likewise.
      	* gcc.target/aarch64/tlsie_tiny_1.c: Likewise.
      	* gcc.target/aarch64/tlsle12_1.c: Likewise.
      	* gcc.target/aarch64/tlsle12_tiny_1.c: Likewise.
      	* gcc.target/aarch64/tlsle24_1.c: Likewise.
      	* gcc.target/aarch64/tlsle24_tiny_1.c: Likewise.
      	* gcc.target/aarch64/tlsle32_1.c: Likewise.
      	* gcc.target/aarch64/tlsle_sizeadj_small_1.c: Likewise.
      	* gcc.target/aarch64/tlsle_sizeadj_tiny_1.c: Likewise.
      
      Co-Authored-By: Olivier Hainque <hainque@adacore.com>
      
      From-SVN: r280013
      Joel Brobecker committed
    • re PR target/93187 (ICE in extract_insn, at recog.c:2294) · b41383c8
      	PR target/93187
      	* config/i386/i386.md (*stack_protect_set_2_<mode> peephole2,
      	*stack_protect_set_3 peephole2): Also check that the second
      	insns source is general_operand.
      
      	* g++.dg/opt/pr93187.C: New test.
      
      From-SVN: r280012
      Jakub Jelinek committed
    • re PR target/93174 (ICE building glibc __sha512_process_block for i686) · 7ca803f1
      	PR target/93174
      	* config/i386/i386.md (addcarry<mode>_0): Use nonimmediate_operand
      	predicate for output operand instead of register_operand.
      	(addcarry<mode>, addcarry<mode>_1): Likewise.  Add alternative with
      	memory destination and non-memory operands[2].
      
      	* gcc.c-torture/compile/pr93174.c: New test.
      
      From-SVN: r280011
      Jakub Jelinek committed
    • relax aarch64 stack-clash tests depedence on alloca.h · 80d803ae
      2020-01-06  Olivier Hainque  <hainque@adacore.com>
      	Alexandre Oliva  <oliva@adacore.com>
      
      	* gcc.target/aarch64/stack-check-alloca.h: Remove
      	#include alloca.h. #define alloca __builtin_alloca
      	instead.
      	* gcc.target/aarch64/stack-check-alloca-1.c: Add
      	{ dg-require-effective-target alloca }.
      	* gcc.target/aarch64/stack-check-alloca-2.c: Likewise.
      	* gcc.target/aarch64/stack-check-alloca-3.c: Likewise.
      	* gcc.target/aarch64/stack-check-alloca-4.c: Likewise.
      	* gcc.target/aarch64/stack-check-alloca-5.c: Likewise.
      	* gcc.target/aarch64/stack-check-alloca-6.c: Likewise.
      	* gcc.target/aarch64/stack-check-alloca-7.c: Likewise.
      	* gcc.target/aarch64/stack-check-alloca-8.c: Likewise.
      	* gcc.target/aarch64/stack-check-alloca-9.c: Likewise.
      	* gcc.target/aarch64/stack-check-alloca-10.c: Likewise.
      
      Co-Authored-By: Alexandre Oliva <oliva@adacore.com>
      
      From-SVN: r280010
      Olivier Hainque committed
    • Use cgraph_node::dump_{asm_},name where possible. · 3629ff8a
      2020-01-08  Martin Liska  <mliska@suse.cz>
      
      	* cgraph.c (cgraph_node::dump): Use ::dump_name or
      	::dump_asm_name instead of (::name or ::asm_name).
      	* cgraphclones.c (symbol_table::materialize_all_clones): Likewise.
      	* cgraphunit.c (walk_polymorphic_call_targets): Likewise.
      	(analyze_functions): Likewise.
      	(expand_all_functions): Likewise.
      	* ipa-cp.c (ipcp_cloning_candidate_p): Likewise.
      	(propagate_bits_across_jump_function): Likewise.
      	(dump_profile_updates): Likewise.
      	(ipcp_store_bits_results): Likewise.
      	(ipcp_store_vr_results): Likewise.
      	* ipa-devirt.c (dump_targets): Likewise.
      	* ipa-fnsummary.c (analyze_function_body): Likewise.
      	* ipa-hsa.c (check_warn_node_versionable): Likewise.
      	(process_hsa_functions): Likewise.
      	* ipa-icf.c (sem_item_optimizer::merge_classes): Likewise.
      	(set_alias_uids): Likewise.
      	* ipa-inline-transform.c (save_inline_function_body): Likewise.
      	* ipa-inline.c (recursive_inlining): Likewise.
      	(inline_to_all_callers_1): Likewise.
      	(ipa_inline): Likewise.
      	* ipa-profile.c (ipa_propagate_frequency_1): Likewise.
      	(ipa_propagate_frequency): Likewise.
      	* ipa-prop.c (ipa_make_edge_direct_to_target): Likewise.
      	(remove_described_reference): Likewise.
      	* ipa-pure-const.c (worse_state): Likewise.
      	(check_retval_uses): Likewise.
      	(analyze_function): Likewise.
      	(propagate_pure_const): Likewise.
      	(propagate_nothrow): Likewise.
      	(dump_malloc_lattice): Likewise.
      	(propagate_malloc): Likewise.
      	(pass_local_pure_const::execute): Likewise.
      	* ipa-visibility.c (optimize_weakref): Likewise.
      	(function_and_variable_visibility): Likewise.
      	* ipa.c (symbol_table::remove_unreachable_nodes): Likewise.
      	(ipa_discover_variable_flags): Likewise.
      	* lto-streamer-out.c (output_function): Likewise.
      	(output_constructor): Likewise.
      	* tree-inline.c (copy_bb): Likewise.
      	* tree-ssa-structalias.c (ipa_pta_execute): Likewise.
      	* varpool.c (symbol_table::remove_unreferenced_decls): Likewise.
      2020-01-08  Martin Liska  <mliska@suse.cz>
      
      	* lto-partition.c (add_symbol_to_partition_1): Use ::dump_name or
      	::dump_asm_name instead of (::name or ::asm_name).
      	(lto_balanced_map): Likewise.
      	(promote_symbol): Likewise.
      	(rename_statics): Likewise.
      	* lto.c (lto_wpa_write_files): Likewise.
      2020-01-08  Martin Liska  <mliska@suse.cz>
      
      	* gcc.dg/ipa/ipa-icf-1.c: Update expected scanned output.
      	* gcc.dg/ipa/ipa-icf-10.c: Likewise.
      	* gcc.dg/ipa/ipa-icf-11.c: Likewise.
      	* gcc.dg/ipa/ipa-icf-12.c: Likewise.
      	* gcc.dg/ipa/ipa-icf-13.c: Likewise.
      	* gcc.dg/ipa/ipa-icf-16.c: Likewise.
      	* gcc.dg/ipa/ipa-icf-18.c: Likewise.
      	* gcc.dg/ipa/ipa-icf-2.c: Likewise.
      	* gcc.dg/ipa/ipa-icf-20.c: Likewise.
      	* gcc.dg/ipa/ipa-icf-21.c: Likewise.
      	* gcc.dg/ipa/ipa-icf-23.c: Likewise.
      	* gcc.dg/ipa/ipa-icf-25.c: Likewise.
      	* gcc.dg/ipa/ipa-icf-26.c: Likewise.
      	* gcc.dg/ipa/ipa-icf-27.c: Likewise.
      	* gcc.dg/ipa/ipa-icf-3.c: Likewise.
      	* gcc.dg/ipa/ipa-icf-35.c: Likewise.
      	* gcc.dg/ipa/ipa-icf-36.c: Likewise.
      	* gcc.dg/ipa/ipa-icf-37.c: Likewise.
      	* gcc.dg/ipa/ipa-icf-38.c: Likewise.
      	* gcc.dg/ipa/ipa-icf-5.c: Likewise.
      	* gcc.dg/ipa/ipa-icf-7.c: Likewise.
      	* gcc.dg/ipa/ipa-icf-8.c: Likewise.
      	* gcc.dg/ipa/ipa-icf-merge-1.c: Likewise.
      	* gcc.dg/ipa/pr64307.c: Likewise.
      	* gcc.dg/ipa/pr90555.c: Likewise.
      	* gcc.dg/ipa/propmalloc-1.c: Likewise.
      	* gcc.dg/ipa/propmalloc-2.c: Likewise.
      	* gcc.dg/ipa/propmalloc-3.c: Likewise.
      
      From-SVN: r280009
      Martin Liska committed
    • libgomp.texi: Fix typos, use https (actual change) · c1030b5c
      From-SVN: r280008
      Tobias Burnus committed
    • libgomp.texi: Fix typos, use https. · df2c0d36
      From-SVN: r280007
      Tobias Burnus committed
    • re PR tree-optimization/93199 (Compile time hog in sink_clobbers) · fb768529
      2020-01-08  Richard Biener  <rguenther@suse.de>
      
      	PR middle-end/93199
      	* tree-eh.c (sink_clobbers): Update virtual operands for
      	the first and last stmt only.  Add a dry-run capability.
      	(pass_lower_eh_dispatch::execute): Perform clobber sinking
      	after CFG manipulations and in RPO order to catch all
      	secondary opportunities reliably.
      
      From-SVN: r280006
      Richard Biener committed
    • re PR target/93182 ([avr] Add -nodevicespecs option.) · 949f0062
      	PR target/93182
      	* doc/invoke.texi (AVR Options) <-nodevicespecs>: Document.
      
      From-SVN: r280005
      Georg-Johann Lay committed
    • re PR other/92997 (gcc.dg/torture/ftrapv-1.c fails starting with r279523) · 0f3072b5
      2020-01-08  Richard Biener  <rguenther@suse.de>
      
      	PR testsuite/92997
      	* gcc.dg/torture/ftrapv-1.c (iaddv): Use noipa attribute.
      
      From-SVN: r280003
      Richard Biener committed
    • * gcc/doc/install.texi: Typo. · d672c0af
      From-SVN: r280002
      Georg-Johann Lay committed
    • re PR tree-optimization/93199 (Compile time hog in sink_clobbers) · f74c4b2c
      2019-01-08  Richard Biener  <rguenther@suse.de>
      
      	PR middle-end/93199
      	c/
      	* gimple-parser.c (c_parser_parse_gimple_body): Remove __PHI IFN
      	permanently.
      
      	* gimple-fold.c (rewrite_to_defined_overflow): Mark stmt modified.
      	* tree-ssa-loop-im.c (move_computations_worker): Properly adjust
      	virtual operand, also updating SSA use.
      	* gimple-loop-interchange.cc (loop_cand::undo_simple_reduction):
      	Update stmt after resetting virtual operand.
      	(tree_loop_interchange::move_code_to_inner_loop): Likewise.
      
      	* gimple-iterator.c (gsi_remove): When not removing the stmt
      	permanently do not delink immediate uses or mark the stmt modified.
      
      From-SVN: r280000
      Richard Biener committed
    • Replace node->name/node->order with node->dump_name. · d597b944
      2020-01-08  Martin Liska  <mliska@suse.cz>
      
      	* ipa-fnsummary.c (dump_ipa_call_summary): Use symtab_node::dump_name.
      	(ipa_call_context::estimate_size_and_time): Likewise.
      	(inline_analyze_function): Likewise.
      2020-01-08  Martin Liska  <mliska@suse.cz>
      
      	* lto-partition.c (lto_balanced_map): Use symtab_node::dump_name.
      
      From-SVN: r279999
      Martin Liska committed