1. 02 Jun, 2017 25 commits
    • Fix segfault in free_growth_caches (PR jit/80954) · 0cbae4a7
      gcc/ChangeLog:
      	PR jit/80954
      	* ipa-inline-analysis.c (free_growth_caches): Set
      	edge_removal_hook_holder to NULL after removing it.
      
      From-SVN: r248841
      David Malcolm committed
    • Add ChangeLog entry for revision 248838 · 38a75ccc
      From-SVN: r248839
      Olivier Hainque committed
    • vxlib.c (__gthread_once): Add missing value to nested return statement. · ee834d3b
      2017-06-02  Olivier Hainque  <hainque@adacore.com>
      
      	* config/vxlib.c (__gthread_once): Add missing value to
      	nested return statement.
      
      From-SVN: r248838
      Olivier Hainque committed
    • vx_crtbegin_auto.c: New file. · f8763042
      2017-06-02  Olivier Hainque  <hainque@adacore.com>
      
      	* vx_crtbegin_auto.c: New file.
      	* vx_crtbegin.c: New file.
      	* vx_crtbegin.inc: New file.
      	* vx_crtend.c: New file.
      
      From-SVN: r248837
      Olivier Hainque committed
    • [PATCH][AArch64] Allow CMP+SHIFT when comparing with zero · ffa8a921
      gcc/
      
      	* config/aarch64/aarch64.c (aarch64_select_cc_mode): Return CC_SWP for
      	comparision with zero.
      
      gcc/testsuite/
      
      	* gcc.target/aarch64/cmp_shifted_reg_1.c: New.
      
      From-SVN: r248836
      Sudakshina Das committed
    • [AArch64] Add HF vector modes to lane-to-lane INS pattern · b160939b
              * config/aarch64/aarch64-simd.md (*aarch64_simd_vec_copy_lane<mode>):
              Use VALL_F16 iterator rather than VALL.
      
              * gcc.target/aarch64/hfmode_ins_1.c: New test.
      
      From-SVN: r248835
      Kyrylo Tkachov committed
    • rs6000.c (rs6000_gimple_fold_builtin): Add handling for early expansion of… · d65d1bd9
      rs6000.c (rs6000_gimple_fold_builtin): Add handling for early expansion of vec_min and vec_max builtins.
      
      [gcc]
      
      2017-06-02  Will Schmidt  <will_schmidt@vnet.ibm.com>
      	* config/rs6000/rs6000.c (rs6000_gimple_fold_builtin): Add handling
      	for early expansion of vec_min and vec_max builtins.
      	(builtin_function_type): Add min/max unsigned variants to those
      	identified as having unsigned arguments.
      
      [gcc/testsuite]
      
      2017-06-02  Will Schmidt  <will_schmidt@vnet.ibm.com>
      
      	*  testsuite/gcc.target/powerpc/fold-vec-minmax-char.c: New.
      	*  testsuite/gcc.target/powerpc/fold-vec-minmax-floatdouble.c: New.
      	*  testsuite/gcc.target/powerpc/fold-vec-minmax-int.c: New.
      	*  testsuite/gcc.target/powerpc/fold-vec-minmax-longlong.c: New.
      	*  testsuite/gcc.target/powerpc/fold-vec-minmax-short.c: New.
      
      From-SVN: r248834
      Will Schmidt committed
    • vx-common.h (DWARF_UNWIND_INFO): Switch #define to 1. · a9945ae2
      2017-06-02  Olivier Hainque  <hainque@adacore.com>
      
      	* config/vx-common.h (DWARF_UNWIND_INFO): Switch #define to 1.
      
      From-SVN: r248833
      Olivier Hainque committed
    • [AArch64] Emit tighter strong atomic compare-exchange loop when comparing against zero · 17f47f86
      	* config/aarch64/aarch64.c (aarch64_split_compare_and_swap):
      	Emit CBNZ inside loop when doing a strong exchange and comparing
      	against zero.  Generate the CC flags after the loop.
      
      	* gcc.target/aarch64/atomic_cmp_exchange_zero_strong_1.c: New test.
      
      From-SVN: r248832
      Kyrylo Tkachov committed
    • dwarf2out.c (DWARF_INITIAL_LENGTH_SIZE_STR): New. · e3bd1c68
              * dwarf2out.c (DWARF_INITIAL_LENGTH_SIZE_STR): New.
              (dl_section_ref): New.
              (dwarf2out_finish): Copy debug_line_section_label to dl_section_ref.
              On AIX, append an expression to subtract the size of the
              section length to dl_section_ref.
      
      From-SVN: r248831
      David Edelsohn committed
    • rs6000.c (rs6000_gimple_fold_builtin): Add handling for early expansion of… · ab82e126
      rs6000.c (rs6000_gimple_fold_builtin): Add handling for early expansion of vector absolute builtins.
      
      [gcc]
      
      2017-05-31  Will Schmidt  <will_schmidt@vnet.ibm.com>
      
      	* config/rs6000/rs6000.c (rs6000_gimple_fold_builtin): Add handling
      	for early expansion of vector absolute builtins.
      
      [gcc/testsuite]
      
      2017-05-31  Will Schmidt  <will_schmidt@vnet.ibm.com>
      
      	* gcc.target/powerpc/fold-vec-abs-char.c: New.
      	* gcc.target/powerpc/fold-vec-abs-floatdouble.c: New.
      	* gcc.target/powerpc/fold-vec-abs-int.c: New.
      	* gcc.target/powerpc/fold-vec-abs-longlong.c: New.
      	* gcc.target/powerpc/fold-vec-abs-short.c: New.
      	* gcc.target/powerpc/fold-vec-abs-char-fwrapv.c: New.
      	* gcc.target/powerpc/fold-vec-abs-int-fwrapv.c: New.
      	* gcc.target/powerpc/fold-vec-abs-longlong-fwrapv.c: New.
      	* gcc.target/powerpc/fold-vec-abs-short-fwrapv.c: New.
      
      From-SVN: r248830
      Will Schmidt committed
    • Remove lang_type_ptrmem. · fb3a2657
      Changlogs:
      	cp/
      	Remove lang_type_ptrmem.
      	* cp-tree.h (lang_type_header): Remove is_lang_type_class. Move
      	into ...
      	(lang_type_class): ... this.  Reorder bitfields.  Rename to ...
      	(lang_type): ... this.  Delete old definition.
      	(lang_type_ptrmem): Delete.
      	(LANG_TYPE_CLASS_CHECK): Simply get TYPE_LANG_SPECIFIC.  Adjust
      	uses.
      	(LANG_TYPE_PTRMEM_CHECK): Delete.
      	(TYPE_GET_PTRMEMFUNC_TYPE, TYPE_SET_PTRMEMFUNC_TYPE): Delete.
      	(TYPE_PTRMEMFUNC_TYPE): New.  Use TYPE_LANG_SLOT_1.
      	* decl.c (build_ptrmemfunc_type): Adjust.
      	* lex.c (copy_lang_type): Remove lang_type_ptrmem handling.
      	(maybe_add_lang_type_raw): Don't set u.c.h.is_lang_type_class.
      
      	objcp/
      	* objcp-decl.h (SIZEOF_OBJC_TYPE_LANG_SPECIFIC): Use lang_type.
      	(ALLOC_OBJC_TYPE_LANG_SPECIFIC): Use it.  Don't set
      	u.c.h.is_lang_type_class.
      
      From-SVN: r248827
      Nathan Sidwell committed
    • Remove lang_type_ptrmem. · 030cfa22
      	cp/
      	Remove lang_type_ptrmem.
      	* cp-tree.h (lang_type_header): Remove is_lang_type_class. Move
      	into ...
      	(lang_type_class): ... this.  Reorder bitfields.  Rename to ...
      	(lang_type): ... this.  Delete old definition.
      	(lang_type_ptrmem): Delete.
      	(LANG_TYPE_CLASS_CHECK): Simply get TYPE_LANG_SPECIFIC.  Adjust
      	uses.
      	(LANG_TYPE_PTRMEM_CHECK): Delete.
      	(TYPE_GET_PTRMEMFUNC_TYPE, TYPE_SET_PTRMEMFUNC_TYPE): Delete.
      	(TYPE_PTRMEMFUNC_TYPE): New.  Use TYPE_LANG_SLOT_1.
      	* decl.c (build_ptrmemfunc_type): Adjust.
      	* lex.c (copy_lang_type): Remove lang_type_ptrmem handling.
      	(maybe_add_lang_type_raw): Don't set u.c.h.is_lang_type_class.
      
      	objcp/
      	* objcp-decl.h (SIZEOF_OBJC_TYPE_LANG_SPECIFIC): Use lang_type.
      	(ALLOC_OBJC_TYPE_LANG_SPECIFIC): Use it.  Don't set
      	u.c.h.is_lang_type_class.
      
      From-SVN: r248826
      Nathan Sidwell committed
    • tree-vect-slp.c (vect_detect_hybrid_slp_2): Match up what we consider a relevant… · 9186a9d3
      tree-vect-slp.c (vect_detect_hybrid_slp_2): Match up what we consider a relevant use stmt with vect_detect_hybrid_slp_stmts.
      
      2017-06-02  Richard Biener  <rguenther@suse.de>
      
      	* tree-vect-slp.c (vect_detect_hybrid_slp_2): Match up
      	what we consider a relevant use stmt with vect_detect_hybrid_slp_stmts.
      
      From-SVN: r248825
      Richard Biener committed
    • re PR tree-optimization/80948 (test case gcc.dg/torture/pr68017.c fails with ICE… · bd53b257
      re PR tree-optimization/80948 (test case gcc.dg/torture/pr68017.c fails with ICE starting with r248771)
      
      2017-06-02  Richard Biener  <rguenther@suse.de>
      
      	PR tree-optimization/80948
      	* tree-tailcall.c (find_tail_calls): Track stmts to move in
      	stmt order as well.
      
      From-SVN: r248824
      Richard Biener committed
    • Remove libsupc++ makefile targets setting -std=gnu++11 or -std=gnu++14 · ef3985db
      	* libsupc++/Makefile.am: Remove custom targets for files that need to
      	be compiled as C++11 or C++14.
      	* libsupc++/Makefile.in: Regenerate.
      	* libsupc++/del_ops.cc: Use pragma to disable -Wsized-deallocation
      	warnings.
      	* libsupc++/del_opvs.cc: Likewise.
      
      From-SVN: r248823
      Jonathan Wakely committed
    • name-lookup.h (cp_binding_level): Lose namespaces field. · c957e9c0
      	* name-lookup.h (cp_binding_level): Lose namespaces field.
      	* name-lookup.c (add_decl_to_level): Chain namespaces on the names
      	list.
      	(suggest_alternatives_for): Adjust for namespace list.  Do
      	breadth-first search.
      	* decl2.c (collect_source_refs): Namespaces are on the regulr
      	list.
      	(collect_ada_namespace): Likewise.
      
      	* g++.dg/pr45330.C: Adjust.  Check breadth-firstness.
      
      From-SVN: r248821
      Nathan Sidwell committed
    • tree-vect-loop.c (vect_analyze_loop_operations): Not relevant PHIs are ok. · 643a9684
      2017-06-02  Richard Biener  <rguenther@suse.de>
      
      	* tree-vect-loop.c (vect_analyze_loop_operations): Not relevant
      	PHIs are ok.
      	* tree-vect-stmts.c (process_use): Do not mark backedge defs
      	for inductions as relevant.
      
      From-SVN: r248820
      Richard Biener committed
    • tree-vect-loop.c (get_initial_def_for_induction): Inline into ... · e7754973
      2017-06-02  Richard Biener  <rguenther@suse.de>
      
      	* tree-vect-loop.c (get_initial_def_for_induction): Inline into ...
      	(vectorizable_induction): ... this.  Remove dead code.
      
      From-SVN: r248819
      Richard Biener committed
    • * builtins. (expand_builtin_alloca): Remove second parameter and · b7e52782
      	infer its value from the first parameter instead.
      	(expand_builtin) <BUILT_IN_ALLOCA>: Adjust call to above.
      
      From-SVN: r248818
      Eric Botcazou committed
    • re PR libstdc++/80721 (Sorting/Merging of free EH-emergency buffer may wrong or uncomplete) · 1c26adb7
      2017-06-02  Richard Biener  <rguenther@suse.de>
      	Markus Eisenmann  <meisenmann.lba@fh-salzburg.ac.at>
      
      	PR libstdc++/80721
      	* libsupc++/eh_alloc.cc (pool::free): Keep list properly
      	sorted and add missing freelist item merging cases.
      
      Co-Authored-By: Markus Eisenmann <meisenmann.lba@fh-salzburg.ac.at>
      
      From-SVN: r248816
      Richard Biener committed
    • re PR rtl-optimization/80903 (ICE: internal consistency failure (error: invalid… · 74b4885d
      re PR rtl-optimization/80903 (ICE: internal consistency failure (error: invalid rtl sharing found in the insn))
      
      	PR rtl-optimization/80903
      	* loop-doloop.c (add_test): Unshare sequence.
      
      	* gcc.dg/pr80903.c: New test.
      
      From-SVN: r248815
      Jakub Jelinek committed
    • re PR fortran/80918 (Assumed size whole array rejected in depend clause) · aad16012
      	PR fortran/80918
      	* openmp.c (resolve_omp_clauses): Fix a typo.
      
      	* gfortran.dg/gomp/pr80918.f90: New test.
      
      From-SVN: r248812
      Jakub Jelinek committed
    • invoke.texi: Document the -Wsizeof-pointer-div warning. · 40ffd95f
      gcc:
      2017-06-02  Bernd Edlinger  <bernd.edlinger@hotmail.de>
      
              * doc/invoke.texi: Document the -Wsizeof-pointer-div warning.
      
      gcc/c-family:
      2017-06-02  Bernd Edlinger  <bernd.edlinger@hotmail.de>
      
              * c.opt (Wsizeof-pointer-div): New warning option.
      
      gcc/c:
      2017-06-02  Bernd Edlinger  <bernd.edlinger@hotmail.de>
      
              * c-parser.c (c_parser_binary_expression): Implement the
              -Wsizeof_pointer_div warning.
              (c_parser_postfix_expression): Allow SIZEOF_EXPR as expr.original_code
              from a parenthesized expression.
              (c_parser_expr_list): Use c_last_sizeof_loc.
              * c-tree.h (c_last_sizeof_loc): New external.
              * c-typeck.c (c_last_sizeof_loc): New variable.
              (c_expr_sizeof_expr, c_expr_sizeof_type): Assign c_last_sizeof_loc.
      
      gcc/cp:
      2017-06-02  Bernd Edlinger  <bernd.edlinger@hotmail.de>
      
              * typeck.c (cp_build_binary_op): Implement the -Wsizeof_pointer_div
              warning.
      
      gcc/testsuite:
      2017-06-02  Bernd Edlinger  <bernd.edlinger@hotmail.de>
      
              * c-c++-common/Wsizeof-pointer-div.c: New test. 
              * gcc.dg/Wsizeof-pointer-memaccess1.c: Add test cases with parens.
              * gcc.dg/torture/Wsizeof-pointer-memaccess1.c: Likewise.
              * gcc.target/i386/sse-init-v4hi-1.c: Fix test case.
              * gcc.target/i386/sse-init-v4sf-1.c: Likewise.
              * gcc.target/i386/sse-set-ps-1.c: Likewise.
              * gcc.target/i386/sse2-init-v16qi-1.c: Likewise.
              * gcc.target/i386/sse2-init-v2di-1.c: Likewise.
              * gcc.target/i386/sse2-init-v4si-1.c: Likewise.
              * gcc.target/i386/sse2-init-v8hi-1.c: Likewise.
              * gcc.target/i386/sse2-set-epi32-1.c: Likewise.
              * gcc.target/i386/sse2-set-epi64x-1.c: Likewise.
              * gcc.target/i386/sse4_1-init-v16qi-1.c: Likewise.
              * gcc.target/i386/sse4_1-init-v2di-1.c: Likewise.
              * gcc.target/i386/sse4_1-init-v4sf-1.c: Likewise.
              * gcc.target/i386/sse4_1-init-v4si-1.c: Likewise.
              * gcc.target/i386/sse4_1-set-epi32-1.c: Likewise.
              * gcc.target/i386/sse4_1-set-epi64x-1.c: Likewise.
              * gcc.target/i386/sse4_1-set-ps-1.c: Likewise.
              * libgomp.c/pr39591-2.c: Likewise.
              * libgomp.c/pr39591-3.c: Likewise.
      
      From-SVN: r248811
      Bernd Edlinger committed
    • Daily bump. · 616dbacb
      From-SVN: r248810
      GCC Administrator committed
  2. 01 Jun, 2017 15 commits
    • fold-vec-logical-ors-longlong.c: Update the target to power8-vector. · 052754ea
      
      [gcc/testsuite]
      
      2017-05-26  Will Schmidt  <will_schmidt@vnet.ibm.com>
      
      	* gcc.target/powerpc/fold-vec-logical-ors-longlong.c:
      	Update the target to power8-vector.
      
      From-SVN: r248805
      Will Schmidt committed
    • * es.po: Update. · d80d5239
      From-SVN: r248802
      Joseph Myers committed
    • testsuite: ensure GCC_COLORS is unset · aa63913f
      gcc/testsuite/ChangeLog:
      	* lib/gcc-dg.exp: Ensure GCC_COLORS is unset.
      
      From-SVN: r248800
      David Malcolm committed
    • i386.c (x86_64_ms_sysv_extra_clobbered_registers): Make static. · 77560086
      2017-06-01  Bernd Edlinger  <bernd.edlinger@hotmail.de>
      
              * config/i386/i386.c (x86_64_ms_sysv_extra_clobbered_registers): Make
              static.
              (xlogue_layout::get_stack_space_used, xlogue_layout::s_instances,
              xlogue_layout::get_instance, logue_layout::xlogue_layout,
              sp_valid_at, fp_valid_at, choose_basereg): Formatting.
              (xlogue_layout::get_stub_rtx): Make static.
              (xlogue_layout::get_stub_name): Avoid const-cast, make static.
              (xlogue_layout::compute_stub_managed_regs): Rename to...
              (xlogue_layout::count_stub_managed_regs): ...this.
              (xlogue_layout::is_stub_managed_reg): New function.
              (xlogue_layout::m_stub_names): Rename to...
              (xlogue_layout::s_stub_names): ...this, make static.
              (xlogue_layout::STUB_INDEX_OFFSET, xlogue_layout::MIN_REGS,
              xlogue_layout::MAX_REGS, xlogue_layout::MAX_EXTRA_REGS,
              xlogue_layout::VARIANT_COUNT, xlogue_layout::STUB_NAME_MAX_LEN,
              xlogue_layout::s_stub_names): Instantiate statics.
              (stub_managed_regs): Remove.
              (ix86_save_reg): Use xlogue_layout::compute_stub_managed_regs.
              (disable_call_ms2sysv_xlogues): Rename to...
              (warn_once_call_ms2sysv_xlogues): ...this, and warn only once.
              (ix86_initial_elimination_offset, ix86_expand_call): Fix call_ms2sysv
              warning logic.
              (ix86_static_chain): Make sure that ix86_static_chain_on_stack can't
              change after reload_completed.
              (ix86_can_use_return_insn_p): Use the ix86_frame data structure
              directly.
              (ix86_expand_prologue): Likewise.
              (ix86_expand_epilogue): Likewise.
              (ix86_expand_split_stack_prologue): Likewise.
              (ix86_compute_frame_layout): Remove frame parameter ...
              (TARGET_COMPUTE_FRAME_LAYOUT): ... and export it as a target hook.
              (ix86_finalize_stack_realign_flags): Call ix86_compute_frame_layout
              only if necessary.
              (ix86_init_machine_status): Don't set use_fast_prologue_epilogue_nregs.
              (ix86_frame): Move from here ...
              * config/i386/i386.h (ix86_frame): ... to here.
              (machine_function): Remove use_fast_prologue_epilogue_nregs, cache the
              complete ix86_frame data structure instead.  Remove some_ld_name.
      
      From-SVN: r248798
      Bernd Edlinger committed
    • DWARF: add DW_AT_location for global decls with DECL_VALUE_EXPR · 2ded3754
      In GNAT, we materialize renamings that cannot be described in standard
      DWARF as synthetic variables that describe how to fetch the renamed
      object.  Look for "___XR" in gcc/ada/exp_dbug.ads for more details about
      this convention.
      
      In order to have a location for these variables in the debug info (GDB
      requires it not to discard the variable) but also to avoid allocating
      runtime space for them, we make these variable hold a DECL_VALUE_EXPR
      tree.  However, since GCC 7, the DWARF back-end no longer generates a
      DW_AT_location attribute for those.  This patch is an attempt to restore
      this attribute.
      
      gcc/
      
      	* dwarf2out.c (dwarf2out_late_global_decl): Add locations for
      	symbols that hold a DECL_VALUE_EXPR.
      
      gcc/testsuite/
      
      	* debug12.adb, debug12.ads: New testcase.
      
      From-SVN: r248792
      Pierre-Marie de Rodat committed
    • Fix cross compilation to Solaris · e34fd4dc
      	(GLIBCXX_CROSSCONFIG): Handle *-solaris* like *-linux* etc.
      	Remove *-solaris* section.
      	* configure: Regenerate.
      
      From-SVN: r248791
      Rainer Orth committed
    • [PR 80898] Propagate grp_write from disqualified SRA candidates · c8638450
      2017-06-01  Martin Jambor  <mjambor@suse.cz>
      
      	PR tree-optimization/80898
      	* tree-sra.c (process_subtree_disqualification): Removed.
      	(disqualify_candidate): Do not acll
      	process_subtree_disqualification.
      	(subtree_mark_written_and_enqueue): New function.
      	(propagate_all_subaccesses): Set grp_write of LHS subtree if the
      	RHS has been disqualified and re-queue LHS if necessary.  Apart
      	from that, ignore disqualified RHS.
      
      testsuite/
      	* gcc.dg/tree-ssa/pr80898.c: New test.
      	* gcc.dg/tree-ssa/pr80898-2.c: Likewise.
      
      From-SVN: r248790
      Martin Jambor committed
    • S/390: Don't fetch the return address early with ooo · 4ba66aee
      We used to load the return address slot some time in advance.  This
      helped on older machines to resolve the data dependencies in time.
      However, it is pointless on out of order CPUs.  Disabled with that
      patch.
      
      gcc/ChangeLog:
      
      2017-06-01  Andreas Krebbel  <krebbel@linux.vnet.ibm.com>
      
      	* config/s390/s390.c (s390_emit_epilogue): Disable early return
      	address fetch for z10 or later.
      
      From-SVN: r248789
      Andreas Krebbel committed
    • re PR c++/80812 (ICE: in build_value_init_noctor, at cp/init.c:483) · e257141f
      PR c++/80812
      
      cp/
      
      PR c++/80812
      * method.c (constructible_expr): Strip array types before calling
      build_value_init.
      
      libstdc++/
      
      PR c++/80812
      * testsuite/20_util/is_constructible/80812.cc: New.
      
      From-SVN: r248788
      Ville Voutilainen committed
    • re PR ada/80921 (cross compiling fails to build Ada shared libraries) · 2d16708f
      	PR ada/80921
      	* configure.ac (default_gnatlib_target): Remove bogus condition.
      	(have_getipinfo): Tweak.
      	* configure: Regenerate.
      
      From-SVN: r248785
      Eric Botcazou committed
    • re PR c++/80896 ([[nodiscard]] is ignored for functions returning references) · ac853c90
      /cp
      2017-06-01  Paolo Carlini  <paolo.carlini@oracle.com>
      
      	PR c++/80896
      	* cvt.c (convert_to_void): Possibly call maybe_warn_nodiscard
      	for case INDIRECT_REF too in the main switch.
      
      /testsuite
      2017-06-01  Paolo Carlini  <paolo.carlini@oracle.com>
      
      	PR c++/80896
      	* g++.dg/cpp1z/nodiscard5.C: New.
      
      From-SVN: r248784
      Paolo Carlini committed
    • [ARC] Fix tst_movb pattern. · 7841f13c
      The tst_movb pattern is missing guarding when spitting.
      
      gcc/
      2017-06-01  Claudiu Zissulescu  <claziss@synopsys.com>
      
      	* config/arc/arc.md (tst_movb): Add guard when splitting.
      
      testsuite/
      2017-06-01  Claudiu Zissulescu  <claziss@synopsys.com>
      
      	* gcc.target/arc/pr9001195952.c: New test.
      
      From-SVN: r248783
      Claudiu Zissulescu committed
    • [ARC] Test against frame_pointer_needed in arc_can_eliminate. · 19dc4752
      arc_can_eliminate is using arc_frmae_pointer_required() which is wrong
      as the frame_pointer_needed can be set on different conditions. Fix it
      by calling arc_frame_pointer_needed().
      
      gcc/
      2017-06-01  Claudiu Zissulescu  <claziss@synopsys.com>
      
      	* config/arc/arc.c (arc_can_eliminate): Test against
      	arc_frame_pointer_needed.
      
      From-SVN: r248782
      Claudiu Zissulescu committed
    • [ARC] Prevent moving stores to the frame before the stack adjustment. · 2daad50b
      If the stack pointer is needed, emit a special barrier that will prevent
      the scheduler from moving stores to the frame before the stack adjustment.
      
      For example:
      
      [snip]
      	mov_s	fp,sp 	; frame pointer is set here
      [snip]
      	st	r1,[fp,-24]	; frame pointer is used here
      [snip]
      	sub_s	sp,sp,0x20	; stack pointer adjusted
      
      So we can easily see that any interrupt between the `st` and `sub`
      instruction will lead to faulty code as the interrupt routine will use
      a faulty sp register, and, potentially, overwriting the value stored
      by 'st' instruction. Thus, adding a scheduler barrier will force the
      compiler to emit the `sub` instruction before the store one.
      
      2017-06-01  Claudiu Zissulescu  <claziss@synopsys.com>
      
      	* config/arc/arc.c (arc_expand_prologue): Emit a special barrier
      	to prevent store reordering.
      	* config/arc/arc.md (UNSPEC_ARC_STKTIE): Define.
      	(type): Add block type.
      	(stack_tie): Define special instruction to be used in
      	expand_prologue.
      
      From-SVN: r248781
      Claudiu Zissulescu committed
    • [ARC] Update (non)commutative_binary_comparison patterns. · 6f70ebc3
      gcc/
      2017-06-01  Claudiu Zissulescu  <claziss@synopsys.com>
      
      	* config/arc/arc.md (commutative_binary_comparison): Remove 'I'
      	constraint. It is not valid for the pattern.
      	(noncommutative_binary_comparison): Likewise.
      
      From-SVN: r248780
      Claudiu Zissulescu committed