1. 15 Dec, 2015 17 commits
    • Add space between name and email in Changelog · 57e8ab24
      From-SVN: r231657
      Alessandro Fanfarillo committed
    • re PR c/68907 (bogus warning: right-hand operand of comma expression has no… · 2994fb91
      re PR c/68907 (bogus warning: right-hand operand of comma expression has no effect on an atomic_int preincrement)
      
      	PR c/68907
      	* c-typeck.c (build_atomic_assign): Set TREE_NO_WARNING on an
      	artificial decl.
      
      	* gcc.dg/pr68907.c: New test.
      
      From-SVN: r231656
      Marek Polacek committed
    • c-common.c (c_common_attribute_table): Handle "omp declare target link" attribute. · 4a38b02b
      gcc/c-family/
      	* c-common.c (c_common_attribute_table): Handle "omp declare target
      	link" attribute.
      gcc/
      	* cgraphunit.c (output_in_order): Do not assemble "omp declare target
      	link" variables in ACCEL_COMPILER.
      	* gimplify.c (gimplify_adjust_omp_clauses): Do not remove mapping of
      	"omp declare target link" variables.
      	* omp-low.c (scan_sharing_clauses): Do not remove mapping of "omp
      	declare target link" variables.
      	(add_decls_addresses_to_decl_constructor): For "omp declare target link"
      	variables output address of the artificial pointer instead of address of
      	the variable.  Set most significant bit of the size to mark them.
      	(pass_data_omp_target_link): New pass_data.
      	(pass_omp_target_link): New class.
      	(find_link_var_op): New static function.
      	(make_pass_omp_target_link): New function.
      	* passes.def: Add pass_omp_target_link.
      	* tree-pass.h (make_pass_omp_target_link): Declare.
      	* varpool.c (symbol_table::output_variables): Do not assemble "omp
      	declare target link" variables in ACCEL_COMPILER.
      gcc/lto/
      	* lto.c: Include stringpool.h and fold-const.h.
      	(offload_handle_link_vars): New static function.
      	(lto_main): Call offload_handle_link_vars.
      libgomp/
      	* libgomp.h (REFCOUNT_LINK): Define.
      	(struct splay_tree_key_s): Add link_key.
      	* target.c (gomp_map_vars): Treat REFCOUNT_LINK objects as not mapped.
      	Replace target address of the pointer with target address of newly
      	mapped object in the splay tree.  Set link pointer on target to the
      	device address of the mapped object.
      	(gomp_unmap_vars): Restore target address of the pointer in the splay
      	tree for REFCOUNT_LINK objects after unmapping.
      	(gomp_load_image_to_device): Set refcount to REFCOUNT_LINK for "omp
      	declare target link" objects.
      	(gomp_unload_image_from_device): Replace j with i.  Force unmap of all
      	"omp declare target link" objects, which were mapped for the image.
      	(gomp_exit_data): Restore target address of the pointer in the splay
      	tree for REFCOUNT_LINK objects after unmapping.
      	* testsuite/libgomp.c/target-link-1.c: New file.
      
      From-SVN: r231655
      Ilya Verbin committed
    • re PR middle-end/21273 (gensupport.c:collect_insn_data doesn't consider the… · b7e2dd6f
      re PR middle-end/21273 (gensupport.c:collect_insn_data doesn't consider the constraints of match_scratch)
      
      Fix PR21273
      
      	PR middle-end/21273
      	* gensupport.c (collect_insn_data): Look for number of alternatives
      	in MATCH_SCRATCH.
      
      From-SVN: r231654
      Bernd Schmidt committed
    • Remove vestigial traces of std::tr1::bind · 72030b28
      	* include/std/functional (is_placeholder, is_bind_expression): Update
      	comments.
      	(_Safe_tuple_element): Replace with _Safe_tuple_element_t alias
      	template.
      	(_Mu): Remove vestigial TR1 return types and update coments.
      
      From-SVN: r231653
      Jonathan Wakely committed
    • Fix cv-qualifiers in std::bind invocation · 66667312
      	PR libstdc++/68912
      	* include/std/functional (_Bind::operator()): Use lvalue functor to
      	deduce return type.
      	* testsuite/20_util/bind/68912.cc: New.
      
      From-SVN: r231652
      Jonathan Wakely committed
    • nvptx.h (HARD_REGNO_NREGS): Reformat. · 5c036f3f
      	* config/nvptx/nvptx.h (HARD_REGNO_NREGS): Reformat.
      	(CANNOT_CHANGE_MODE_CLASS): Always return true.
      	(HARD_REGNO_MODE_OK): Reformat.
      	* config/nvptx/nvptx.md (define_expand mov<mode>): No
      	RETURN_REGNUM handling here.
      	* config/nvptx/nvptx.c (nvptx_function_value): Set ret_reg_mode
      	here.
      	(write_one_arg): No QI or HI mode args.
      	(write_fn_proto_from_insn): No argument promotion here.
      	(nvptx_output_return_insn): No return promotion here.
      	(nvptx_output_mov_insn): No RETURN_REGNUM handling needed.
      	(nvptx_output_call_insn): No return promotion here.
      
      From-SVN: r231651
      Nathan Sidwell committed
    • Fix ICE for coarray Critical inside module procedure · 1fceb215
      From-SVN: r231649
      Alessandro Fanfarillo committed
    • [PR 68851] Do not collect thunks in collect_callers · 4a414de8
      2015-12-15  Martin Jambor  <mjambor@suse.cz>
      
      	PR ipa/68851
      	* cgraph.c (collect_callers_of_node_1): Do not collect thunks.
      	* cgraph.h (cgraph_node): Change comment of collect_callers.
      
      testsuite/
      	* g++.dg/ipa/pr68851.C: New test.
      
      From-SVN: r231648
      Martin Jambor committed
    • Add myself to MAINTAINERS · b15f0273
      From-SVN: r231647
      Alessandro Fanfarillo committed
    • re PR c++/63506 (GCC deduces wrong return type of operator*() inside template functions) · 293b1f44
      2015-12-15  Paolo Carlini  <paolo.carlini@oracle.com>
      
      	PR c++/63506
      	* g++.dg/cpp0x/pr63506-1.C: New.
      	* g++.dg/cpp0x/pr63506-2.C: Likewise.
      
      From-SVN: r231646
      Paolo Carlini committed
    • Skip block move tests for mcpu=gr5 on Visium · 2764999b
      testsuite/
              * gcc.target/visium/block_move.c: Skip for -mcpu=gr5.
      
      From-SVN: r231645
      Olivier Hainque committed
    • re PR debug/66688 (compare debug failure building Linux kernel on ppc64le) · 3be33b6e
      	PR tree-optimization/66688
      	* tree-cfgcleanup.c (cleanup_control_flow_bb): Handle
      	noreturn call followed only by debug stmts by removing
      	the debug stmts and handling it the same as if the noreturn
      	call is the last stmt.
      
      	* gcc.dg/pr66688.c: New test.
      
      From-SVN: r231644
      Jakub Jelinek committed
    • re PR libstdc++/68863 (Regular expressions: Backreferences don't work in negative lookahead) · 3ce38f68
      	PR libstdc++/68863
      	* include/bits/regex_executor.tcc (_Executor::_M_lookahead):
      	Copy the captured content for lookahead, so that the backreferences
      	inside can refer to them.
      	* testsuite/28_regex/algorithms/regex_match/ecma/char/68863.cc:
      	New testcase.
      
      From-SVN: r231641
      Tim Shen committed
    • Fix PR c++/21802 (two-stage name lookup fails for operators) · fcb9363e
      gcc/cp/ChangeLog:
      
      	PR c++/21802
      	PR c++/53223
      	* cp-tree.h (cp_tree_code_length): Declare.
      	(build_min_non_dep_op_overload): Declare.
      	* tree.c (cp_tree_code_length): Define.
      	(build_min_non_dep_op_overload): Define.
      	(build_win_non_dep_call_vec): Copy the KOENIG_LOOKUP_P flag.
      	* typeck.c (build_x_indirect_ref): Use
      	build_min_non_dep_op_overload when the given expression
      	has been resolved to an operator overload.
      	(build_x_binary_op): Likewise.
      	(build_x_array_ref): Likewise.
      	(build_x_unary_op): Likewise.
      	(build_x_compound_expr): Likewise.
      	(build_x_modify_expr): Likewise.
      	* decl2.c (grok_array_decl): Likewise.
      	* call.c (build_new_op_1): If during template processing we
      	chose an operator overload that is a hidden friend function, set
      	the call's KOENIG_LOOKUP_P flag to 1.
      
      gcc/testsuite/ChangeLog:
      
      	PR c++/21802
      	PR c++/53223
      	* g++.dg/cpp0x/pr53223.C: New test.
      	* g++.dg/lookup/pr21802.C: New test.
      	* g++.dg/lookup/two-stage4.C: Remove XFAIL.
      
      From-SVN: r231640
      Patrick Palka committed
    • PR libfortran/pr68867 · 8d3586e4
      2015-12-14  Jerry DeLisle  <jvdelisle@gcc.gnu.org>
      
      	PR libfortran/pr68867
      	* io/write.c (set_fnode_default): For kind=16, set the decimal precision
      	depending on the platform binary precision, 106 or 113.
      
      From-SVN: r231639
      Jerry DeLisle committed
    • Daily bump. · 060eb4c9
      From-SVN: r231638
      GCC Administrator committed
  2. 14 Dec, 2015 22 commits
    • ssa-fre-4.c: Remove mips*-*-* target. · 0c3fce93
      2015-12-14  Steve Ellcey  <sellcey@imgtec.com>
      
      	* gcc.dg/tree-ssa/ssa-fre-4.c: Remove mips*-*-* target.
      	* gcc.target/mips/ext-2.c: Update scan checks.
      
      From-SVN: r231635
      Steve Ellcey committed
    • mips.c (mips_promote_function_mode): New function. · db4aec84
      2015-12-14  Steve Ellcey  <sellcey@imgtec.com>
      
      	* config/mips/mips.c (mips_promote_function_mode): New function.
      	(TARGET_PROMOTE_FUNCTION_MODE): Define as above function.
      	(TARGET_PROMOTE_PROTOTYPES): Remove.
      
      From-SVN: r231634
      Steve Ellcey committed
    • re PR c++/68309 (ICE: Segmentation fault) · fa583f9e
      	PR c++/68309
      gcc/
      	* hash-table.h: Add copy constructor.
      	* hash-map.h: Add copy constructor.
      gcc/cp/
      	* pt.c (instantiate_decl): Copy local_specializations for nested
      	function.
      
      From-SVN: r231632
      Jason Merrill committed
    • re PR fortran/68850 (Coarray events: EVENT_QUERY not documented as intrinsic subroutine) · 1cb62d16
      2014-12-14  Tobias Burnus  <burnus@net-b.de>
      
              PR fortran/68850
              * gfortran.texi (Standards): Mention TS 18508.
              (Fortran 2003 and 2008 Status): Add section on TS 18508 status.
              * intrinsic.texi (EVENT_QUERY): Add.
      
      From-SVN: r231631
      Tobias Burnus committed
    • Dump default defs for arguments, static chain and decl-by-reference · 0482b001
      2015-12-14  Tom de Vries  <tom@codesourcery.com>
      
      	PR other/68882
      	* gimple-pretty-print.c (dump_ssaname_info_to_file): New function.
      	* gimple-pretty-print.h (dump_ssaname_info_to_file): Declare.
      	* tree-cfg.c (dump_default_def): New function.
      	(dump_function_to_file): Dump default defs for arguments, static chain,
      	and decl-by-reference.
      
      From-SVN: r231630
      Tom de Vries committed
    • nvptx.h (PARM_BOUNDARY): Set to 32. · 44eba92d
      	gcc/
      	* config/nvptx/nvptx.h (PARM_BOUNDARY): Set to 32.
      	* config/nvptx/nvptx.c (PASS_IN_REG_P, RETURN_IN_REG_P): Delete.
      	(pass_in_memory, promote_arg, promote_return): New.
      	(nvptx_function_arg_boundary): Delete.
      	(nvptx_function_value): Use promote_return.
      	(nvptx_pass_by_reference): Use pass_in_memory.
      	(nvptx_return_in_memory): Use pass_in_memory.
      	(nvptx_promote_function_mode): Use promote_arg.
      	(write_arg): Adjust arg splitting logic.
      	(write_return): Check and clear ret_reg_mode, if needed.
      	(write_fn_proto, nvptx_declare_function_name): Adust write_return
      	calls.
      	(TARGET_RUNCTION_ARG_BOUNDARY,
      	TARGET_FUNCTION_ARG_ROUND_BOUNDARY): Don't override.
      
      	gcc/testsuite/
      	* g++.dg/abi/nvptx-nrv1.C: New.
      	* g++.dg/abi/nvptx-ptrmem1.C: New.
      	* gcc.target/nvptx/abi-complex-arg.c: New.
      	* gcc.target/nvptx/abi-complex-ret.c: New.
      	* gcc.target/nvptx/abi-enum-arg.c: New.
      	* gcc.target/nvptx/abi-enum-ret.c: New.
      	* gcc.target/nvptx/abi-knr-arg.c: New.
      	* gcc.target/nvptx/abi-knr-ret.c: New.
      	* gcc.target/nvptx/abi-scalar-arg.c: New.
      	* gcc.target/nvptx/abi-scalar-ret.c: New.
      	* gcc.target/nvptx/abi-struct-arg.c: New.
      	* gcc.target/nvptx/abi-struct-ret.c: New.
      	* gcc.target/nvptx/abi-vararg-1.c: New.
      	* gcc.target/nvptx/abi-vararg-2.c: New.
      	* gcc.target/nvptx/abi-vect-arg.c: New.
      	* gcc.target/nvptx/abi-vect-ret.c: New.
      
      From-SVN: r231628
      Nathan Sidwell committed
    • re PR c/68833 (-Werror=format issues an error now) · 54d62f51
      	PR c/68833
      	* common.opt (Wmissing-noreturn): Add Warning option.
      	* opts-common.c (control_warning_option): If opt is
      	alias_target with alias_arg, set arg to it.
      
      	* c.opt (Wmissing-format-attribute, Wnormalized): Add Warning option.
      
      	* c-c++-common/pr68833-1.c: New test.
      	* c-c++-common/pr68833-2.c: New test.
      
      From-SVN: r231624
      Jakub Jelinek committed
    • libgomp.h (gomp_device_state): New enum. · d84ffc0a
      libgomp/
      	* libgomp.h (gomp_device_state): New enum.
      	(struct gomp_device_descr): Replace is_initialized with state.
      	(gomp_fini_device): Remove declaration.
      	* oacc-host.c (host_dispatch): Use state instead of is_initialized.
      	* oacc-init.c (acc_init_1): Use state instead of is_initialized.
      	(acc_shutdown_1): Likewise.  Inline gomp_fini_device.
      	(acc_set_device_type): Use state instead of is_initialized.
      	(acc_set_device_num): Likewise.
      	* target.c (resolve_device): Use state instead of is_initialized.
      	Do not initialize finalized device.
      	(gomp_map_vars): Do nothing if device is finalized.
      	(gomp_unmap_vars): Likewise.
      	(gomp_update): Likewise.
      	(GOMP_offload_register_ver): Use state instead of is_initialized.
      	(GOMP_offload_unregister_ver): Likewise.
      	(gomp_init_device): Likewise.
      	(gomp_unload_device): Likewise.
      	(gomp_fini_device): Remove.
      	(gomp_get_target_fn_addr): Do nothing if device is finalized.
      	(GOMP_target): Go to host fallback if device is finalized.
      	(GOMP_target_ext): Likewise.
      	(gomp_exit_data): Do nothing if device is finalized.
      	(gomp_target_task_fn): Go to host fallback if device is finalized.
      	(gomp_target_fini): New static function.
      	(gomp_target_init): Use state instead of is_initialized.
      	Call gomp_target_fini at exit.
      liboffloadmic/
      	* plugin/libgomp-plugin-intelmic.cpp (unregister_main_image): Remove.
      	(register_main_image): Do not call unregister_main_image at exit.
      	(GOMP_OFFLOAD_fini_device): Allow for OpenMP.  Unregister main image.
      
      From-SVN: r231623
      Ilya Verbin committed
    • rs6000: Fix a mistake in cstore_si_as_di (PR68865, PR68879) · 755cd5a9
      convert_move does not know how to zero-extend a constant integer to the
      target mode -- simply because it does not know the source mode.  As a
      result, 32-bit SImode with the high bit set would be effectively sign-
      extended instead of zero-extended.
      
      This patch fixes it.
      
      
      	PR target/68865
      	PR target/68879
      	* config/rs6000/rs6000.md (cstore_si_as_di): Force all operands
      	into registers.
      
      From-SVN: r231621
      Segher Boessenkool committed
    • re PR tree-optimization/68707 (testcase gcc.dg/vect/O3-pr36098.c vectorized… · 150cf347
      re PR tree-optimization/68707 (testcase gcc.dg/vect/O3-pr36098.c vectorized using VEC_PERM_EXPR rather than VEC_LOAD_LANES)
      
      2015-12-10  Richard Biener  <rguenther@suse.de>
      
      	PR tree-optimization/68707
      	PR tree-optimization/67323
      	* tree-vect-slp.c (vect_analyze_slp_instance): Drop SLP instances
      	if they can be vectorized using load/store-lane instructions.
      
      From-SVN: r231620
      Richard Biener committed
    • re PR middle-end/68852 (ICE in vect_is_simple_use (tree-vect-stmts.c:8750) using -O3) · 603cca93
      2015-12-14  Richard Biener  <rguenther@suse.de>
      
      	PR tree-optimization/68852
      	* tree-vectorizer.h (struct _slp_tree): Add def_type member.
      	(SLP_TREE_DEF_TYPE): New accessor.
      	* tree-vect-stmts.c (vect_is_simple_use): Remove BB vectorization
      	hack.
      	* tree-vect-slp.c (vect_create_new_slp_node): Initialize
      	SLP_TREE_DEF_TYPE.
      	(vect_build_slp_tree): When a node is to be built up from scalars
      	do not push a NULL as child but instead set its def_type to
      	vect_external_def.
      	(vect_analyze_slp_cost_1): Check for child def-type instead
      	of NULL.
      	(vect_detect_hybrid_slp_stmts): Likewise.
      	(vect_bb_slp_scalar_cost): Likewise.
      	(vect_get_slp_defs): Likewise.
      	(vect_slp_analyze_node_operations): Likewise.  Before
      	processing node push the children def-types to the underlying
      	stmts vinfo and restore it afterwards.
      	(vect_schedule_slp_instance): Likewise.
      	(vect_slp_analyze_bb_1): Do not mark stmts not in SLP instances
      	as not vectorizable.
      
      	* g++.dg/torture/pr68852.C: New testcase.
      
      From-SVN: r231619
      Richard Biener committed
    • re PR tree-optimization/68775 (spec2006 test case 465.tonto fails with the gcc… · 60f2b864
      re PR tree-optimization/68775 (spec2006 test case 465.tonto fails with the gcc 6.0 fortran compiler)
      
      2015-12-14  Richard Biener  <rguenther@suse.de>
      
      	PR tree-optimization/68775
      	* tree-vect-slp.c (vect_build_slp_tree): Make sure to apply
      	a operand swapping even if replacing the op with scalars.
      
      From-SVN: r231617
      Richard Biener committed
    • [combine] Don't create LSHIFTRT of zero bits in change_zero_ext · adb48173
      	* combine.c (change_zero_ext): Do not create a shift of zero length.
      
      From-SVN: r231613
      Kyrylo Tkachov committed
    • Bad date on the Changelog entry, boo hiss. · f5a8c224
      From-SVN: r231612
      Ville Voutilainen committed
    • Document the implementation of Logical Operator Type Traits. · 5d190d21
      	* doc/html/index.html: Regenerate.
      	* doc/html/manual/status.html: Likewise.
      	* doc/xml/manual/status_cxx2017.xml: Add P0013R1 to C++ 201z
      	and to Library Fundamentals 2 TS.
      
      From-SVN: r231611
      Ville Voutilainen committed
    • builtin-return-1.c: Correct effective-target test. · 6945a76e
      	* gcc.dg/builtin-return-1.c: Correct effective-target test.
      	* gcc.dg/stack-usage-2.c: Use effective-target test.
      
      From-SVN: r231610
      Alexander Monakov committed
    • [ARC] Use TARGET_NO_SPECULATION_IN_DELAY_SLOTS_P hook. · bf9e9dc5
      gcc/
      2015-12-14  Claudiu Zissulescu  <claziss@synopsys.com>
      
      	* config/arc/arc.c (TARGET_NO_SPECULATION_IN_DELAY_SLOTS_P):
      	Provide target hook.
      	(arc_no_speculation_in_delay_slots_p): New function.
      
      From-SVN: r231609
      Claudiu Zissulescu committed
    • [ARC] Refurbish emitting DWARF2 related information when expanding epilogue. · 67a96300
      gcc/
      2015-12-14  Claudiu Zissulescu  <claziss@synopsys.com>
      	    Andrew Burgess  <andrew.burgess@embecosm.com>
      
      	* config/arc/arc.c (frame_move): Set frame related flag.
      	(arc_save_restore): Emit epilogue related DWARF2 information.
      	(arc_expand_epilogue): Likewise.
      	* config/arc/arc.opt (mno-epilogue-cfi): Remove.
      	(mepilogue-cfi): Likewise.
      	* doc/invoke.texi: Remove -m[no]-epilogue-cfi documentation.
      
      Co-Authored-By: Andrew Burgess <andrew.burgess@embecosm.com>
      
      From-SVN: r231608
      Claudiu Zissulescu committed
    • [PR 66616] Check for thunks when adding extra constants to clones · 173b7355
      2015-12-14  Martin Jambor  <mjambor@suse.cz>
      
      	PR ipa/66616
      	* ipa-cp.c (propagate_constants_accross_call): Move thuk check...
      	(call_passes_through_thunk_p): ...here.
      	(find_more_scalar_values_for_callers_subset): Perform thunk checks
      	like propagate_constants_accross_call does.
      
      testsuite/
      	* g++.dg/ipa/pr66616.C: New test.
      
      From-SVN: r231607
      Martin Jambor committed
    • re PR rtl-optimization/68730 (wrong code at -O3 on x86_64-linux-gnu (in 32-bit mode)) · 63da5ff6
      	PR rtl-optimization/68730
      	* cfgrtl.c (cfg_layout_finalize): Free dominators.
      
      	* gcc.dg/pr68730.c: New test.
      
      From-SVN: r231606
      Jakub Jelinek committed
    • re PR testsuite/68629 (FAIL: c-c++-common/attr-simd-3.c) · 65a00f0e
      2015-12-14  Thomas Preud'homme  <thomas.preudhomme@arm.com>
      
          PR testsuite/68629
          * lib/target-supports.exp (check_effective_target_cilkplus): Also
          check that compiling with -fcilkplus does not give an error.
          * c-c++-common/attr-simd-3.c: Require cilkplus effective target.
      
      From-SVN: r231605
      Thomas Preud'homme committed
    • Daily bump. · 8edccfc6
      From-SVN: r231604
      GCC Administrator committed
  3. 13 Dec, 2015 1 commit
    • [PR67355] drop dummy zero from reverse VTA ops, fix infinite recursion · c779924e
      VTA's cselib expression hashing compares expressions with the same
      hash before adding them to the hash table.  When there is a collision
      involving a self-referencing expression, we could get infinite
      recursion, in spite of the cycle breakers already in place.  The
      problem is currently latent in the trunk, because by chance we don't
      get a collision.
      
      Such value cycles are often introduced by reverse_op; most often,
      they're indirect, and then value canonicalization takes care of the
      cycle, but if the reverse operation simplifies to the original value,
      we used to issue a (plus V (const_int 0)), because at some point
      adding a plain value V to a location list as a reverse_op equivalence
      caused other problems.
      
      This dummy zero, in turn, caused the value canonicalizer to not fully
      realize the equivalence, leading to more complex graphs and,
      occasionally, to infinite recursion when comparing such
      value-plus-zero expressions recursively.
      
      Simply using V solves the infinite recursion from the PR testcase,
      since the extra equivalence and the preexisting value canonicalization
      together prevent recursion while the unrecognized equivalence
      wouldn't, but it exposed another infinite recursion in
      memrefs_conflict_p: get_addr had a cycle breaker in place, to skip RTL
      referencing values introduced after the one we're examining, but it
      wouldn't break the cycle if the value itself appeared in the
      expression being examined.
      
      After removing the dummy zero above, this kind of cycle in the
      equivalence graph is no longer introduced by VTA itself, but dummy
      zeros are also present in generated code, such as in the 32-bit x86's
      pro_epilogue_adjust_stack_si_add epilogue insn generated as part of
      the builtin longjmp in _Unwind_RaiseException building libgcc's
      unwind-dw2.o.  So, break the recursion cycle for them too.
      
      
      for  gcc/ChangeLog
      
      	PR debug/67355
      	* var-tracking.c (reverse_op): Don't add dummy zero to reverse
      	ops that simplify back to the original value.
      	* alias.c (refs_newer_value_p): Cut off recursion for
      	expressions containing the original value.
      
      From-SVN: r231599
      Alexandre Oliva committed