1. 07 Dec, 2016 27 commits
  2. 06 Dec, 2016 13 commits
    • re PR tree-optimization/67955 (tree-dse does not use pointer info) · 8194dcdd
      	PR tree-optimization/67955
      	* tree-ssa-alias.c (same_addr_size_stores_p): New function.
      	(stmt_kills_ref_p): Use it.
      
      	PR tree-optimization/67955
      	* gcc.dg/tree-ssa/dse-points-to.c: New test.
      
      From-SVN: r243325
      Tom de Vries committed
    • Put back blank line · 6b8805cf
      From-SVN: r243324
      Eric Botcazou committed
    • re PR middle-end/78700 (gccgo testcases stack.go, recover.go, crypto/tls fails) · 78bcf3dc
      	PR middle-end/78700
      	* calls.c (expand_call): Move back call to prepare_call_address.
      
      From-SVN: r243322
      Eric Botcazou committed
    • compiler: pass lvalue/rvalue context to back end for var exprs · a5a56d88
          
          Add a new flag on the Var_expression class that indicates
          whether the var reference appears in an "lvalue" context
          (for example, on the LHS of an assignment stmt) or an
          "rvalue" context (for example, as an argument of a call).
          
          Add a traversal pass that visits assignment stmt LHS subtrees
          so as to mark things prior to backend gen. Select the right
          context value in other places where Backend::var_expression is
          called.
          
          Reviewed-on: https://go-review.googlesource.com/33990
      
      	* go-gcc.cc (Gcc_backend::var_expression): Add Varexpr_context
      	parameter.
      
      From-SVN: r243321
      Than McIntosh committed
    • re PR target/78658 (powerpc64le: ICE with -mcpu=power9 -Og) · dd5af1d6
      [gcc]
      2016-12-06  Michael Meissner  <meissner@linux.vnet.ibm.com>
      
      	PR target/78658
      	* config/rs6000/rs6000.md (zero_extendqi<mode>2): Use ^ instead of
      	?* constraints for the ISA 3.0 patterns, so the register allocator
      	is more likely to allocate QImode/HImode to vector registers for
      	conversion to floating point unless a reload is needed.
      	(zero_extendhi<mode>2): Likewise.
      	(float<QHI:mode><FP_ISA3:mode>2_internal): Properly deal with the
      	first alternative which is converting QImode/HImode to floating
      	point and the QImode/HImode value is in a vector register, and
      	does not allocate the second pseudo register.  Remove zero
      	extending into traditional floating point registers, since the
      	instruction used only works on traditional altivec registers.
      	(floatuns<QHI:mode><FP_ISA3:mode>2_internal): Likewise.
      
      [gcc/testsuite]
      2016-12-06  Michael Meissner  <meissner@linux.vnet.ibm.com>
      
      	PR target/78658
      	* gcc.target/powerpc/pr78658.c: New test.
      
      From-SVN: r243320
      Michael Meissner committed
    • print_rtx: implement support for reuse IDs (v2) · 00439aef
      gcc/ChangeLog:
      	* config/i386/i386.c: Include print-rtl.h.
      	(selftest::ix86_test_dumping_memory_blockage): New function.
      	(selftest::ix86_run_selftests): Call it.
      	* print-rtl-function.c (print_rtx_function): Create an
      	rtx_reuse_manager and use it.
      	* print-rtl.c: Include "rtl-iter.h".
      	(rtx_writer::rtx_writer): Add reuse_manager param.
      	(rtx_reuse_manager::rtx_reuse_manager): New ctor.
      	(uses_rtx_reuse_p): New function.
      	(rtx_reuse_manager::preprocess): New function.
      	(rtx_reuse_manager::has_reuse_id): New function.
      	(rtx_reuse_manager::seen_def_p): New function.
      	(rtx_reuse_manager::set_seen_def): New function.
      	(rtx_writer::print_rtx): If "in_rtx" has a reuse ID, print it as a
      	prefix the first time in_rtx is seen, and print reuse_rtx
      	subsequently.
      	(print_inline_rtx): Supply NULL for new reuse_manager param.
      	(debug_rtx): Likewise.
      	(print_rtl): Likewise.
      	(print_rtl_single): Likewise.
      	(rtx_writer::print_rtl_single_with_indent): Likewise.
      	* print-rtl.h: Include bitmap.h when building for host.
      	(rtx_writer::rtx_writer): Add reuse_manager param.
      	(rtx_writer::m_rtx_reuse_manager): New field.
      	(class rtx_reuse_manager): New class.
      	* rtl-tests.c (selftest::assert_rtl_dump_eq): Add reuse_manager
      	param and use it when constructing rtx_writer.
      	(selftest::test_dumping_rtx_reuse): New function.
      	(selftest::rtl_tests_c_tests): Call it.
      	* selftest-rtl.h (class rtx_reuse_manager): New forward decl.
      	(selftest::assert_rtl_dump_eq): Add reuse_manager param.
      	(ASSERT_RTL_DUMP_EQ): Supply NULL for reuse_manager param.
      	(ASSERT_RTL_DUMP_EQ_WITH_REUSE): New macro.
      
      From-SVN: r243317
      David Malcolm committed
    • lra-lives.c (process_bb_lives): Update biggest mode for implicitly used hard reg. · 9a38b8b9
      2016-12-06  Vladimir Makarov  <vmakarov@redhat.com>
      
      	target/77761
      	* lra-lives.c (process_bb_lives): Update biggest mode for
      	implicitly used hard reg.
      
      2016-12-06  Vladimir Makarov  <vmakarov@redhat.com>
      
      	target/77761
      	* testsuite/gcc.target/i386/pr77761.c: New.
      
      From-SVN: r243316
      Vladimir Makarov committed
    • predicates.md (general_gr_operand): New predicate. · cd3fe55a
      	* config/i386/predicates.md (general_gr_operand): New predicate.
      	* config/i386/i386.md (TImode and DImode push_operand splitter):
      	Use general_gr_operand.  Macroize using DWI mode macro.
      	(TImode and DImode nonimmediate_operand splitter): Use
      	nonimmediate_gr_operand and general_gr_operand.  Macroize using
      	DWI mode macro.
      	(TF/XF/DFmode push_operand splitter): Use general_gr_operand.
      	(TFmode nonimmediate_operand splitter): Use nonimmediate_gr_operand
      	and general_gr_operand.
      	(XFmode nonimmediate_operand splitter): Ditto.
      	(DFmode nonimmediate_operand splitter): Ditto.
      	* config/i386/mmx.md (MMXMODE nonimmediate_operand splitter): Ditto.
      
      From-SVN: r243315
      Uros Bizjak committed
    • Add #ifdef case for 16 bits in cow-stdexcept.cc · f68963c0
      Added #ifdef case for when void* is 16 bits so it compiles in AVR
      target.
      
      2016-12-06  Felipe Magno de Almeida  <felipe@expertisesolutions.com.br>
      
      	* src/c++11/cow-stdexcept.cc: Add special case for 16 bit pointers.
      
      From-SVN: r243310
      Felipe Magno de Almeida committed
    • Enable libstdc++ compilation on AVR targets · 6649ad7e
      Enable libstdc++ compilation in AVR targets with AVR-Libc. Most
      floating point math functions are already defined in AVR-Libc, so
      defines are in place to avoid multiple definition of these functions.
      
      2016-12-06  Felipe Magno de Almeida  <felipe@expertisesolutions.com.br>
      
      	* crossconfig.m4: Add avr target for cross-compilation.
      	* configure: Regenerate.
      
      From-SVN: r243309
      Felipe Magno de Almeida committed
    • re PR fortran/78659 ([F03] Spurious "requires DTIO" reported against namelist statement) · 34022d2b
      2016-12-06  Jerry DeLisle  <jvdelisle@gcc.gnu.org>
      
      	PR fortran/78659
      	* resolve.c (resolve_fl_namelist): Remove unneeded error.
      	PR fortran/78659
      	* gfortran.dg/alloc_comp_constraint_1.f90: Update test.
      	* gfortran.dg/alloc_comp_constraint_7.f90: New test.
      	* gfortran.dg/namelist_34.f90: Update test.
      	* gfortran.dg/namelist_63.f90: Update test.
      
      From-SVN: r243308
      Jerry DeLisle committed
    • [ARM][committed] Sort ARMv8 processors by alphabetic order · 0eada321
      	* config/arm/arm-cores.def (cortex-m23, cortex-m33): Move into
      	alphabetical order with respect to other ARMv8 processors.
      	* config/arm/arm-tables.opt: Regenerate.
      	* config/arm/arm-tune.md: Likewise.
      
      From-SVN: r243306
      Kyrylo Tkachov committed
    • Fix pretty-printer for std::variant · 449a4321
      	* python/libstdcxx/v6/printers.py (StdVariantPrinter): Update for new
      	data member name.
      	* testsuite/libstdc++-prettyprinters/cxx17.cc: Remove redundant test.
      
      From-SVN: r243304
      Jonathan Wakely committed