1. 25 Nov, 2016 24 commits
    • re PR fortran/60853 ([OOP] Failure to disambiguate generic with unlimited polymorphic) · f76c4d97
      2016-11-25  Janus Weil  <janus@gcc.gnu.org>
      
      	PR fortran/60853
      	* interface.c (gfc_compare_interfaces): Remove bad special case for
      	unlimited polymorphism. Refactor for loop.
      
      2016-11-25  Janus Weil  <janus@gcc.gnu.org>
      
      	PR fortran/60853
      	* gfortran.dg/typebound_assignment_8.f90: New test case.
      
      From-SVN: r242880
      Janus Weil committed
    • re PR rtl-optimization/78527 (ice on valid C code at -O3 in both 32-bit and… · 27d0862e
      re PR rtl-optimization/78527 (ice on valid C code at -O3 in both 32-bit and 64-bit modes on x86_64-linux-gnu (internal compiler error: in smallest_mode_for_size, at stor-layout.c:364))
      
      	PR rtl-optimization/78527
      	* combine.c (make_compound_operation_int): Ignore LSHIFTRT with
      	out of bounds shift count.
      
      	* gcc.c-torture/compile/pr78527.c: New test.
      
      From-SVN: r242879
      Jakub Jelinek committed
    • Fix documentation reference (PR web/71666) · be40f3cd
      	PR web/71666
      	* doc/invoke.texi (-fprofile-use): Fix reference to a section
      	where -fprofile-generate is documented.
      
      From-SVN: r242878
      Martin Liska committed
    • Don't use priority {cd}tors if not supported by a target (PR · 78681a7b
      	PR gcov-profile/78086
      	* g++.dg/gcov/pr16855.C: Clean up the test case.
      	* g++.dg/gcov/pr16855-priority.C: New test.
      	* coverage.c (build_init_ctor): Don't use priority {cd}tors if
      	not supported by a target.  Set priority to 100 if possible.
      	(build_gcov_exit_decl): Likewise.
      
      From-SVN: r242877
      Martin Liska committed
    • re PR ipa/78515 (ICE: in fold_binary_loc, at fold-const.c:8999 with -Os -mavx512bw) · a77af182
      2016-11-25  Richard Biener  <rguenther@suse.de>
      
      	PR ipa/78515
      	* ipa-prop.c (compute_complex_assign_jump_func): Properly identify
      	unary, binary and single RHSs.
      	* tree.def (BIT_INSERT_EXPR): Adjust tree code name.
      
      	* gcc.dg/torture/pr78515.c: New testcase.
      
      From-SVN: r242876
      Richard Biener committed
    • [multiple changes] · 3cae214f
      2016-11-25  Andre Vehreschild  <vehre@gcc.gnu.org>
      	Paul Thomas  <pault@gcc.gnu.org>
      
      	PR fortran/78293
      	* trans-expr.c (gfc_conv_procedure_call): Prepend deallocation
      	of alloctable components to post, rather than adding to
      	se->post.
      	* trans-stmt.c (gfc_trans_allocate): Move deallocation of expr3
      	allocatable components so that all expr3s are visited.
      
      2016-11-25  Paul Thomas  <pault@gcc.gnu.org>
      
      	PR fortran/78293
      	* gfortran.dg/allocatable_function_10.f90: New test.
      	* gfortran.dg/class_array_15.f03: Increase builtin_free count
      	from 11 to 12.
      
      From-SVN: r242875
      Paul Thomas committed
    • re PR middle-end/78507 (ICE: tree check: expected integer_type or enumeral_type… · ae22bc5d
      re PR middle-end/78507 (ICE: tree check: expected integer_type or enumeral_type or boolean_type or real_type or fixed_point_type, have pointer_type in int_fits_type_p, at tree.c:9153)
      
      	PR middle-end/78507
      	PR middle-end/78510
      	PR middle-end/78517
      	* match.pd ((cond (cmp (convert1? @1) @3) (convert2? @1) @2)): Use
      	cmp directly, rather than cmp_code.  Initialize code to ERROR_MARK
      	and set it to result code if transformation is valid.  Use code EQ
      	directly in last simplification case.
      
      	gcc/testsuite
      	PR middle-end/78507
      	PR middle-end/78510
      	PR middle-end/78517
      	* g++.dg/torture/pr78507.C: New test.
      	* gcc.dg/torture/pr78510.c: New test.
      	* gcc.dg/torture/pr78517.c: New test.
      
      From-SVN: r242874
      Bin Cheng committed
    • gimple-fold.c (fold_stmt_1): Check may_propagate_copy before valueizing return stmts. · 1af928db
      2016-11-25  Richard Biener  <rguenther@suse.de>
      
      	* gimple-fold.c (fold_stmt_1): Check may_propagate_copy
      	before valueizing return stmts.
      
      From-SVN: r242873
      Richard Biener committed
    • re PR tree-optimization/78343 (Loop is not eliminated) · 59ec925b
      2016-11-24  Richard Biener  <rguenther@suse.de>
      
      	PR tree-optimization/78343
      	* passes.def: Add CD-DCE pass after loop splitting.
      	* tree-ssa-dce.c (find_obviously_necessary_stmts): Move
      	SCEV init/finalize ...
      	(perform_tree_ssa_dce): ... here.  Deal with being
      	executed inside the loop pipeline in aggressive mode.
      
      	* gcc.dg/tree-ssa/sccp-2.c: New testcase.
      	* gcc.dg/autopar/uns-outer-6.c: Adjust.
      	* gcc.dg/tree-ssa/20030808-1.c: Likewise.
      	* gcc.dg/tree-ssa/20040305-1.c: Likewise.
      	* gcc.dg/vect/pr38529.c: Likewise.
      
      From-SVN: r242872
      Richard Biener committed
    • Remove conflict marker · 4741b062
      From-SVN: r242871
      Eric Botcazou committed
    • Improve comment for struct symbolic_number in bswap pass · d8cc3d06
      2016-11-25  Thomas Preud'homme  <thomas.preudhomme@arm.com>
      
          gcc/
          * tree-ssa-math-opts.c (struct symbolic_number): Improve comment.
      
      From-SVN: r242870
      Thomas Preud'homme committed
    • Fix PR77673: bswap loads passed end of object · 83624b60
      2016-11-25  Thomas Preud'homme  <thomas.preudhomme@arm.com>
      
          gcc/
          PR tree-optimization/77673
          * tree-ssa-math-opts.c (struct symbolic_number): Add new src field.
          (init_symbolic_number): Initialize src field from src parameter.
          (perform_symbolic_merge): Select most dominated statement as the
          source statement.  Set src field of resulting n structure from the
          input src with the lowest address.
          (find_bswap_or_nop): Rename source_stmt into ins_stmt.
          (bswap_replace): Rename src_stmt into ins_stmt.  Initially get source
          of load from src field rather than insertion statement.  Cancel
          optimization if statement analyzed is not dominated by the insertion
          statement.
          (pass_optimize_bswap::execute): Rename src_stmt to ins_stmt.  Compute
          dominance information.
      
          gcc/testsuite/
          PR tree-optimization/77673
          * gcc.dg/pr77673.c: New test.
      
      From-SVN: r242869
      Thomas Preud'homme committed
    • re PR ada/67205 (eliminate No_Implicit_Dynamic_Code restriction violations) · 605040b4
      	PR ada/67205
      	* config/mips/mips.c (TARGET_CUSTOM_FUNCTION_DESCRIPTORS): Define.
      
      From-SVN: r242868
      Eric Botcazou committed
    • [PR 70965] Schedule extra rebuild_cgraph_edges · 54e606f0
      2016-11-25  Martin Jambor  <mjambor@suse.cz>
      
      	PR tree-optimization/70965
      	* passes.def (pass_build_ssa_passes): Add pass_rebuild_cgraph_edges.
      
      gcc/testsuite/
      	* g++.dg/pr70965.C: New test.
      
      From-SVN: r242867
      Martin Jambor committed
    • [Patch i386] PR78509 - TARGET_C_EXCESS_PRECISION should not return · 2dbe91cf
       "unpredictable" for EXCESS_PRECISION_TYPE_STANDARD
      
      gcc/
      
      	PR target/78509
      	* config/i386/i386.c (i386_excess_precision): Do not return
      	FLT_EVAL_METHOD_UNPREDICTABLE when "type" is
      	EXCESS_PRECISION_TYPE_STANDARD.
      	* target.def (excess_precision): Document that targets should
      	not return FLT_EVAL_METHOD_UNPREDICTABLE when "type" is
      	EXCESS_PRECISION_TYPE_STANDARD or EXCESS_PRECISION_TYPE_FAST.
      	Fix typo in first sentence.
      	* doc/tm.texi: Regenerate.
      
      From-SVN: r242866
      James Greenhalgh committed
    • re PR tree-optimization/78396 (gcc.dg/vect/bb-slp-cond-1.c FAILs after fix for PR77848) · 5bcfb22c
      2016-11-25  Richard Biener  <rguenther@suse.de>
      
      	PR tree-optimization/78396
      	* tree-vectorizer.c (vectorize_loops): When the if-converted
      	body contains masked loads or stores do not attempt to
      	basic-block-vectorize it.
      
      From-SVN: r242865
      Richard Biener committed
    • re PR gcov-profile/78467 (gcc.dg/tree-prof/comp-goto-1.c FAILs) · 758dcf83
      	PR gcov-profile/78467
      	* gcc.dg/tree-prof/comp-goto-1.c (insn_t): Change offset to
      	signed int.
      
      Co-Authored-By: Andreas Schwab <schwab@linux-m68k.org>
      
      From-SVN: r242864
      Jakub Jelinek committed
    • Tweak LRA handling of shared spill slots · 83d0488b
      The previous code processed the users of a stack slot in order of
      decreasing size and allocated the slot based on the first user.
      This seems a bit dangerous, since the ordering is based on the
      mode of the biggest reference while the allocation is based also
      on the size of the register itself (which I think could be larger).
      
      That scheme doesn't scale well to polynomial sizes, since there's
      no guarantee that the order of the sizes is known at compile time.
      This patch instead records an upper bound on the size required
      by all users of a slot.  It also records the maximum alignment
      requirement.
      
      gcc/
      2016-11-15  Richard Sandiford  <richard.sandiford@arm.com>
      	    Alan Hayward  <alan.hayward@arm.com>
      	    David Sherwood  <david.sherwood@arm.com>
      
      	* function.h (spill_slot_alignment): Declare.
      	* function.c (spill_slot_alignment): New function.
      	* lra-spills.c (slot): Add align and size fields.
      	(assign_mem_slot): Use them in the call to assign_stack_local.
      	(add_pseudo_to_slot): Update the fields.
      	(assign_stack_slot_num_and_sort_pseudos): Initialise the fields.
      
      Co-Authored-By: Alan Hayward <alan.hayward@arm.com>
      Co-Authored-By: David Sherwood <david.sherwood@arm.com>
      
      From-SVN: r242863
      Richard Sandiford committed
    • Set mode of decimal floats before calling layout_type · 664e6968
      Previously decimal floating-point types were created and laid
      out as binary floating-point types, then the caller changed
      the mode to a decimal mode later.  The problem with that
      approach is that not all targets support an equivalent binary
      floating-point mode.  When they didn't, we would give the
      type BLKmode and lay it out as a zero-sized type.
      
      This probably had no effect in practice.  If a target doesn't
      support a binary mode then it's unlikely to support the decimal
      equivalent either.  However, with the stricter mode checking
      added by later patches, we would assert if a scalar floating-
      point type didn't have a scalar floating-point mode.
      
      gcc/
      2016-11-16  Richard Sandiford  <richard.sandiford@arm.com>
      	    Alan Hayward  <alan.hayward@arm.com>
      	    David Sherwood  <david.sherwood@arm.com>
      
      	* stor-layout.c (layout_type): Allow the caller to set the mode of
      	a float type.  Only choose one here if the mode is still VOIDmode.
      	* tree.c (build_common_tree_nodes): Set the type mode of decimal
      	floats before calling layout_type.
      	* config/rs6000/rs6000.c (rs6000_init_builtins): Likewise.
      
      Co-Authored-By: Alan Hayward <alan.hayward@arm.com>
      Co-Authored-By: David Sherwood <david.sherwood@arm.com>
      
      From-SVN: r242862
      Richard Sandiford committed
    • Add run tests for recent sibcall patches · 84db1406
      gcc/testsuite/
      	* gcc.dg/tree-ssa/tailcall-7-run.c: New test.
      	* gcc.dg/tree-ssa/tailcall-8-run.c: Likewise.
      
      From-SVN: r242861
      Richard Sandiford committed
    • Tighten check for whether sibcall references local variables · 2c28c3e4
      This loop:
      
            /* Make sure the tail invocation of this function does not refer
               to local variables.  */
            FOR_EACH_LOCAL_DECL (cfun, idx, var)
              {
                if (TREE_CODE (var) != PARM_DECL
                    && auto_var_in_fn_p (var, cfun->decl)
                    && (ref_maybe_used_by_stmt_p (call, var)
                        || call_may_clobber_ref_p (call, var)))
                  return;
              }
      
      triggered even for local variables that are passed by value.
      This meant that we didn't allow local aggregates to be passed
      to a sibling call but did (for example) allow global aggregates
      to be passed.
      
      I think the loop is really checking for indirect references,
      so should be able to skip any variables that never have their
      address taken.
      
      gcc/
      	* tree-tailcall.c (find_tail_calls): Allow calls to reference
      	local variables if all references are known to be direct.
      
      gcc/testsuite/
      	* gcc.dg/tree-ssa/tailcall-8.c: New test.
      
      From-SVN: r242860
      Richard Sandiford committed
    • Fix bogus pr64277.c failure for avr · 4ae35e69
      The smaller int size for the avr target breaks the test's
      expectation on the number of iterations. The failure goes
      away if 32 bit ints are used in place of a plain int.
      
      Fix by conditionally typedef int32_t to __INT32_TYPE__ for targets
      with int size < 4,  and then use int32_t everywhere.
      
      gcc/testsuite
      016-11-25  Senthil Kumar Selvaraj  <senthil_kumar.selvaraj@atmel.com>
      
      	* gcc.dg/pr64277.c: Use __INT32_TYPE__ for targets
      	with sizeof(int) < 4.
      
      From-SVN: r242859
      Senthil Kumar Selvaraj committed
    • re PR middle-end/78501 (SEGV in vrp_val_max) · 2131e489
      2016-11-25  Jakub Jelinek  <jakub@redhat.com>
      	    Prathamesh Kulkarni  <prathamesh.kulkarni@linaro.org>
      
      	PR middle-end/78501
      	* tree-vrp.c (extract_range_basic): Check for ptrdiff_type_node to be
      	non null and it's precision matches precision of lhs's type.
      
      Co-Authored-By: Prathamesh Kulkarni <prathamesh.kulkarni@linaro.org>
      
      From-SVN: r242858
      Jakub Jelinek committed
    • Daily bump. · 6d52e466
      From-SVN: r242857
      GCC Administrator committed
  2. 24 Nov, 2016 16 commits