1. 08 Oct, 2015 11 commits
  2. 07 Oct, 2015 24 commits
    • expr.c (store_expr_with_bounds): Handle aggregate moves from BLKmode. · ee3db47d
      
      	* expr.c (store_expr_with_bounds): Handle aggregate moves from
      	BLKmode.
      	* gimple-expr.c (useless_type_conversion_p): Do not use TYPE_CANONICAL
      	to define gimple type system; compare aggregates only by size.
      
      From-SVN: r228586
      Jan Hubicka committed
    • Re: [PATCH] Improve DOM's optimization of control statements · d44bd40e
      	* tree-ssa-dom.c (optimize_stmt): Don't set LOOPS_NEED_FIXUP here.
      	* tree-ssa-threadupdate.c (remove_ctrl_stmt_and_useless_edges): Do it
      	here instead.  Tighten test to avoid setting LOOPS_NEED_FIXUP
      	unnecessarily.
      
      @@ -1848,12 +1848,6 @@ optimize_stmt (basic_block bb, gimple_stmt_iterator si,
      
      From-SVN: r228585
      Jeff Law committed
    • gather bbs and conditions in a single walk through dominators · b0b5710c
      Clean up the function to build scop's basic blocks and the function
      that gathers the conditions under which a basic block is executed.  We remove
      one traversal of the dominator tree.
      
      This refactoring was triggered by the need of a vec<bb> of all the basic blocks
      in a region.  We will use that vector in a patch that removes the out-of-ssa
      translation of scalar dependences: we will iterate through the basic blocks of a
      region to record scalar dependences crossing bbs or going out of the region.
      
      The patch passes bootstrap and regtest on x86_64-linux.
      
      2015-10-06  Aditya Kumar  <aditya.k7@samsung.com>
                      Sebastian Pop  <s.pop@samsung.com>
      
                      * graphite-dependences.c (scop_get_dependences): Do not use SCOP_BBS.
                      * graphite-isl-ast-to-gimple.c (get_max_schedule_dimensions): Same.
                      (generate_isl_schedule): Same.
                      * graphite-optimize-isl.c (scop_get_domains): Same.
                      (apply_schedule_map_to_scop): Same.
                      * graphite-poly.c (print_iteration_domains): Same.
                      (remove_gbbs_in_scop): Same.
                      (new_scop): Same.
                      (free_scop): Same.
                      (print_scop): Same.
                      * graphite-poly.h (struct scop): Rename bbs to pbbs.
                      (SCOP_BBS): Remove.
                      * graphite-scop-detection.c (compare_bb_depths): Remove.
                      (graphite_sort_dominated_info): Remove.
                      (try_generate_gimple_bb): Move out of scop_detection.
                      (all_non_dominated_preds_marked_p): Remove.
                      (build_scop_bbs_1): Remove.
                      (build_scop_bbs): Remove.
                      (nb_pbbs_in_loops): Do not use SCOP_BBS.
                      (find_scop_parameters): Same.
                      (sese_dom_walker): Rename gather_bbs.
                      (before_dom_children): Call try_generate_gimple_bb and collect gbb
                      and pbb.
                      (build_scops): Call gather_bbs.
                      * graphite-sese-to-poly.c (build_scop_scattering): Do not use SCOP_BBS.
                      (add_conditions_to_constraints): Same.
                      (build_scop_iteration_domain): Same.
                      (build_scop_drs): Same.
                      (new_pbb_from_pbb): Same.
                      * sese.c (new_sese_info): Create bbs.
                      * sese.h (struct sese_info_t): Add bbs.
      
      Co-Authored-By: Sebastian Pop <s.pop@samsung.com>
      
      From-SVN: r228581
      Aditya Kumar committed
    • xcoff.h (ASM_PREFERRED_EH_DATA_FORMAT): Use 64-bit encoding in 64-bit mode. · b759335b
      * config/rs6000/xcoff.h (ASM_PREFERRED_EH_DATA_FORMAT): Use 64-bit
      encoding in 64-bit mode.
      
      From-SVN: r228579
      David Edelsohn committed
    • compiler: Don't make temporaries for constant operands. · 65f52d9a
          
          Fixes golang/go#12616.
          
          Reviewed-on: https://go-review.googlesource.com/14645
      
      From-SVN: r228578
      Ian Lance Taylor committed
    • re PR target/66697 (Feature request: -mstackrealign and force_align_arg_pointer for x86_64) · cba9c789
      	PR target/66697
      	* config/i386/i386.c (ix86_option_override_internal): Always use
      	8-byte minimum stack boundary in 64-bit mode.
      	(ix86_compute_frame_layout): Remove assert on INCOMING_STACK_BOUNDARY.
      	(ix86_emit_save_reg_using_mov): Support unaligned SSE store.
      	Add a REG_CFA_EXPRESSION note if needed.
      	(ix86_emit_restore_sse_regs_using_mov): Support unaligned SSE load.
      	(ix86_handle_force_align_arg_pointer_attribute): New.
      	(ix86_minimum_incoming_stack_boundary): Remove TARGET_64BIT check.
      	(ix86_attribute_table): Set ix86_force_align_arg_pointer_string
      	with ix86_handle_force_align_arg_pointer_attribute.
      	* config/i386/i386.h (MIN_STACK_BOUNDARY): Set to BITS_PER_WORD.
      
      testsuite/ChangeLog:
      
      	PR target/66697
      	* gcc.target/i386/20060512-1.c: Remove ia32 requirement.
      	(PUSH, POP): New defines.
      	(sse2_test): Use PUSH and POP to misalign runtime stack.
      	* gcc.target/i386/20060512-2.c: Remove ia32 requirement.
      
      From-SVN: r228577
      Uros Bizjak committed
    • re PR go/67874 (fd_unix.go does not build when there is fcntl64 and no fcntl syscall) · 0786e1fe
      	PR go/67874
          net, runtime: Call C library fcntl function rather than syscall.Syscall.
          
          Not all systems define a fcntl syscall; some only have fcntl64.
          
          Fixes GCC PR go/67874.
          
          Reviewed-on: https://go-review.googlesource.com/15497
      
      From-SVN: r228576
      Ian Lance Taylor committed
    • atomic-dg.exp (atomic_link_flags): Move flag setting to atomic_init. · 919e06d3
      	* testsuite/lib/atomic-dg.exp (atomic_link_flags): Move flag setting
      	to atomic_init. (atomic_init): Restrict flags usage.
      
      From-SVN: r228575
      James Norris committed
    • remove unused code · 91bf00a9
      2015-10-07  Aditya Kumar  <aditya.k7@samsung.com>
                      Sebastian Pop  <s.pop@samsung.com>
      
                      * graphite-scop-detection.c (parameter_index_in_region): Remove
                      use of SESE_ADD_PARAMS.
                      (find_scop_parameters): Same.
                      * sese.c (new_sese_info): Same.
                      * sese.h (struct sese_info_t): Remove add_params.
                      (SESE_ADD_PARAMS): Remove.
      
      Co-Authored-By: Sebastian Pop <s.pop@samsung.com>
      
      From-SVN: r228574
      Aditya Kumar committed
    • move graphite bookkeeping from sese to sese_info · bafcb153
      2015-10-06  Aditya Kumar  <aditya.k7@samsung.com>
                      Sebastian Pop  <s.pop@samsung.com>
      
                      * graphite-isl-ast-to-gimple.c (translate_isl_ast_to_gimple): Use
                      an sese_info_p.
                      (copy_def): Same.
                      (copy_internal_parameters): Same.
                      (translate_isl_ast_to_gimple): Use an sese_l.
                      (build_iv_mapping): Same.
                      * graphite-poly.c (new_sese): Rename new_sese_info.
                      (free_sese): Rename free_sese_info.
                      * graphite-poly.h (struct scop): Use an sese_info_p.
                      (scop_set_region): Same.
                      * graphite-scop-detection.c (struct sese_l): Moved...
                      (get_entry_bb): Moved...
                      (get_exit_bb): Moved...
                      (parameter_index_in_region_1): Use an sese_info_p.
                      (parameter_index_in_region): Same.
                      (scan_tree_for_params): Same.
                      (find_params_in_bb): Same.
                      (sese_dom_walker): Use an sese_l.
                      * graphite-sese-to-poly.c (remove_invariant_phi): Same.
                      (reduction_phi_p): Same.
                      (parameter_index_in_region_1): Use an sese_info_p.
                      (propagate_expr_outside_region): Use an sese_l.
                      * graphite.c: Replace uses of SCOP_REGION.
                      * sese.c (sese_record_loop): Use an sese_info_p.
                      (build_sese_loop_nests): Same.
                      (sese_build_liveouts_use): Same.
                      (sese_build_liveouts_bb): Same.
                      (sese_build_liveouts_bb): Same.
                      (sese_bad_liveouts_use): Same.
                      (sese_reset_debug_liveouts_bb): Same.
                      (sese_build_liveouts): Same.
                      (new_sese): Renamed new_sese_info.
                      (free_sese): Renamed free_sese_info.
                      (set_rename): Use an sese_info_p.
                      (graphite_copy_stmts_from_block): Same.
                      (copy_bb_and_scalar_dependences): Same.
                      (outermost_loop_in_sese_1): Use an sese_l.
                      (outermost_loop_in_sese): Same.
                      (if_region_set_false_region): Use an sese_info_p.
                      (move_sese_in_condition): Same.
                      (scalar_evolution_in_region): Use an sese_l.
                      * sese.h (struct sese_l): ... here.
                      (SESE_ENTRY): Remove.
                      (SESE_ENTRY_BB): Remove.
                      (SESE_EXIT): Remove.
                      (SESE_EXIT_BB): Remove.
                      (sese_contains_loop): Use an sese_info_p.
                      (sese_nb_params): Same.
                      (bb_in_sese_p): Use an sese_l.
                      (stmt_in_sese_p): Same.
                      (defined_in_sese_p): Same.
                      (loop_in_sese_p): Same.
                      (sese_loop_depth): Same.
                      (struct ifsese_s): Use an sese_info_p.
                      (gbb_loop_at_index): Use an sese_l.
                      (nb_common_loops): Same.
                      (scev_analyzable_p): Same.
      
      Co-Authored-By: Sebastian Pop <s.pop@samsung.com>
      
      From-SVN: r228572
      Aditya Kumar committed
    • re PR sanitizer/67867 (UBSan bootstrap fails with error: ‘otype’ may be used… · b850dd2f
      re PR sanitizer/67867 (UBSan bootstrap fails with error: ‘otype’ may be used uninitialized in this function [-Werror=maybe-uninitialized])
      
      	PR sanitizer/67867
      	* search.c (accessible_p): Initialize OTYPE to NULL_TREE.
      
      From-SVN: r228569
      Marek Polacek committed
    • Define x86 CALL_USED_REGISTERS_MASK · 1f3ccbc8
      Define x86 CALL_USED_REGISTERS_MASK used on x86 CALL_USED_REGISTERS.
      
      	* config/i386/i386.c (ix86_conditional_register_usage): Use
      	CALL_USED_REGISTERS_MASK.
      	* config/i386/i386.h (CALL_USED_REGISTERS_MASK): New macro.
      
      From-SVN: r228568
      H.J. Lu committed
    • Check $READELF_FOR_TARGET for readelf in configure · 32a18c8c
      Similar to as, ld, nm and objdump, gcc configure should check
      $READELF_FOR_TARGET for readelf.
      
      	PR bootstrap/67385
      	* configure.ac (gcc_cv_readelf): Check $READELF_FOR_TARGET.
      	* configure: Regenerated.
      
      From-SVN: r228567
      H.J. Lu committed
    • re PR fortran/65889 ([6 Regressions] [OOP] ICE with sizeof a polymorphic variable.) · b0ae33ba
      gcc/fortran/ChangeLog:
      
      2015-10-07  Andre Vehreschild  <vehre@gcc.gnu.org>
      
      	PR fortran/65889
      	* trans-intrinsic.c (gfc_conv_intrinsic_sizeof): Handle pointer to and
      	on stack class objects as sizeof parameter.
      
      gcc/testsuite/ChangeLog:
      
      2015-10-07  Andre Vehreschild  <vehre@gcc.gnu.org>
      
      	PR fortran/65889
      	* gfortran.dg/sizeof_5.f90: New test.
      
      From-SVN: r228566
      Andre Vehreschild committed
    • Merge ix86_maybe_switch_abi with ix86_set_current_function · 735e9641
      ix86_maybe_switch_abi is called to late during RTL expansion and we
      use the stale information from compilation of the previous function.
      aggregate_value_p uses call_used_regs.  aggregate_value_p is used by
      IPA and return value optimization, which are called before
      ix86_maybe_switch_abi is called.  This patch merges ix86_maybe_switch_abi
      with ix86_set_current_function.
      
      	PR target/67850
      	* config/i386/i386.c (ix86_maybe_switch_abi): Merged with ...
      	(ix86_set_current_function): This.
      	(TARGET_EXPAND_TO_RTL_HOOK): Removed.
      
      From-SVN: r228565
      H.J. Lu committed
    • Check in forgotten test for fortran/65766 · bbf3abfa
      From-SVN: r228564
      Louis Krupp committed
    • tree-vectorizer.h (stmt_vec_info_vec): Use vec<stmt_vec_info>. · 3161455c
      2015-10-07  Richard Biener  <rguenther@suse.de>
      
      	* tree-vectorizer.h (stmt_vec_info_vec): Use vec<stmt_vec_info>.
      	(vinfo_for_stmt): Adjust.
      	(set_vinfo_for_stmt): Likewise.
      	* tree-vectorizer.c (stmt_vec_info_vec): Likewise.
      	* tree-vect-stmts.c (free_stmt_vec_info_vec): Likewise.
      	* tree-vect-loop.c (new_loop_vec_info): Remove special-casing
      	of inner loop.
      	(vect_analyze_loop_1): Remove.
      	(vect_analyze_loop_form_1): Avoid building a loop_vec_info for
      	inner loop when vectorizing an outer loop by splitting out from ...
      	(vect_analyze_loop_form): ... here.
      
      From-SVN: r228563
      Richard Biener committed
    • Fix PR c/65345 for arm · baba8d7d
      
      
      
      2015-10-07  Ramana Radhakrishnan  <ramana.radhakrishnan@arm.com>
      
      	PR c/65345
      	* config/arm/arm-builtins.c (arm_atomic_assign_expand_fenv):
      	Use create_tmp_var_raw instead of create_tmp_var.
      
      From-SVN: r228562
      Ramana Radhakrishnan committed
    • Cache reals for 1/4, 1/6 and 1/9 · d01db77a
      We have a global 1/2 and a cached 1/3, but recalculate 1/4, 1/6 and 1/9
      each time we need them.  That seems a bit arbitrary and makes the folding
      code more noisy (especially once it's moved to match.pd).
      
      This patch caches the other three constants too.  Bootstrapped &
      regression-tested on x86_64-linux-gnu.
      
      gcc/
      	* real.h (dconst_quarter, dconst_sixth, dconst_ninth): New macros.
      	(dconst_quarter_ptr, dconst_sixth_ptr, dconst_ninth_ptr): Declare.
      	* real.c (CACHED_FRACTION): New helper macro.
      	(dconst_third_ptr): Use it.
      	(dconst_quarter_ptr, dconst_sixth_ptr, dconst_ninth_ptr): New.
      	* builtins.c (fold_builtin_sqrt): Use dconst_quarter and
      	dconst_sixth.
      	(fold_builtin_cbrt): Use dconst_sixth and dconst_ninth.
      
      From-SVN: r228561
      Richard Sandiford committed
    • cp-gimplify.c (genericize_if_stmt): Use protected_set_expr_location. · 5b5dce39
      	* cp-gimplify.c (genericize_if_stmt): Use protected_set_expr_location.
      	(genericize_cp_loop): Likewise.
      	* decl.c (cxx_maybe_build_cleanup): Likewise.
      	* parser.c (cp_parser_binary_expression): Likewise.
      	(cp_parser_omp_for_loop): Likewise.
      	(cp_parser_omp_construct): Likewise.
      	* semantics.c (finish_transaction_stmt): Likewise.
      	(build_transaction_expr): Likewise.
      
      From-SVN: r228560
      Marek Polacek committed
    • [PATCH][PR tree-optimization/67816] Fix jump threading when DOM removes… · 00852255
      [PATCH][PR tree-optimization/67816] Fix jump threading when DOM removes conditionals in jump threading path
      
      	PR tree-optimization/67816
      	* tree-ssa-threadupdate.h (remove_jump_threads_including): Renamed
      	from remove_jump_threads_starting_at.  Accept an edge rather than
      	a basic block.
      	* tree-ssa-threadupdate.c (removed_edges): New hash table.
      	(remove_jump_threads_including): Note edges that get removed from
      	the CFG for later pruning of jump threading paths including them.
      	(thread_through_all_blocks): Remove paths which include edges that
      	have been removed.
      	* tree-ssa-dom.c (optimize_stmt): Call remove_jump_threads_including
      	on each outgoing edges when optimizing away a control statement.
      
      	* gcc.c-torture/compile/pr67816.c: New test.
      
      From-SVN: r228559
      Jeff Law committed
    • reorg.c: use vec<rtx_insn *> instead of rtx_insn_list for the delay insn list · 165ccc54
      gcc/ChangeLog:
      
      2015-10-06  Trevor Saunders  <tbsaunde+gcc@tbsaunde.org>
      
      	* reorg.c (emit_delay_sequence): Store list of delay slot insns
      	in a vector instead of rtx_insn_list.
      	(add_to_delay_list): Likewise.
      	(delete_from_delay_slot): Likewise.
      	(optimize_skip): Likewise.
      	(redirect_with_delay_list_safe_p): Likewise.
      	(check_annul_list_true_false): Likewise.
      	(steal_delay_list_from_target): Likewise.
      	(steal_delay_list_from_fallthrough): Likewise.
      	(redundant_insn): Likewise.
      	(fill_simple_delay_slots): Likewise.
      	(fill_slots_from_thread): Likewise.
      	(fill_eager_delay_slots): Likewise.
      	(relax_delay_slots): Likewise.
      
      From-SVN: r228558
      Trevor Saunders committed
    • re PR c++/67810 (Non-expression recognized as fold expression) · 8237beb1
      	PR c++/67810
      	* parser.c (cp_parser_fold_expr_p): Remove.
      	(is_binary_op): New.
      	(cp_parser_fold_expression): Take LHS as parameter.
      	(cp_parser_primary_expression): Call it after parsing an expression.
      	(cp_parser_binary_expression, cp_parser_assignment_operator_opt)
      	(cp_parser_expression): Ignore an operator followed by '...'.
      	(is_binary_op): New.
      	* pt.c (tsubst_unary_left_fold, tsubst_binary_left_fold)
      	(tsubst_unary_right_fold, tsubst_binary_right_fold): Handle errors.
      
      From-SVN: r228556
      Jason Merrill committed
    • Daily bump. · 437d8c80
      From-SVN: r228555
      GCC Administrator committed
  3. 06 Oct, 2015 5 commits
    • [multiple changes] · 58864d1c
      2015-10-06  Louis Krupp <louis.krupp@zoho.com>
      	PR fortran/65766
      	* resolve.c (gfc_resolve_substring_charlen): For derived type,
      	use typespec of string component when resolving substring length.
      
      2015-10-06  Louis Krupp     <louis.krupp@zoho.com>
      
      	PR fortran/65766
      	* gfortran.dg/substr_alloc_string_comp_1.f90: New.
      
      From-SVN: r228551
      Louis Krupp committed
    • compiler: Record each import as a distinct alias. · c12df359
          
          This patch introduces the Package_alias class which is a
          finer representation of the different between a package and the
          aliases it is imported under.  Each alias keeps track of the location
          of its import statement and how many times that alias has been used.
          This allows the gofrontend to report when a specific import has not
          been used even if a symbol from the package has been used by another
          import.
          
          Fixes golang/go#12326.
          
          Reviewed-on: https://go-review.googlesource.com/14259
      
      From-SVN: r228550
      Ian Lance Taylor committed
    • nios2.c (nios2_symbol_ref_in_small_data_p): For -mgpopt=local, also exclude… · ce9f2dc5
      nios2.c (nios2_symbol_ref_in_small_data_p): For -mgpopt=local, also exclude unintialized common symbols.
      
      2015-10-06  Sandra Loosemore  <sandra@codesourcery.com>
      
      	gcc/
      	* config/nios2/nios2.c (nios2_symbol_ref_in_small_data_p):
      	For -mgpopt=local, also exclude unintialized common symbols.
      	* doc/invoke.texi (Nios II Options): Document the change.
      
      From-SVN: r228549
      Sandra Loosemore committed
    • iterators.md (vwcore): Add missing cases for V4HF/V8HF modes. · 64e9a944
      gcc/ChangeLog:
      
      2015-10-07  Kugan Vivekanandarajah  <kuganv@linaro.org>
      
      	* config/aarch64/iterators.md (vwcore): Add missing cases for
      	 V4HF/V8HF modes.
      
      gcc/testsuite/ChangeLog:
      
      2015-10-07  Kugan Vivekanandarajah  <kuganv@linaro.org>
      
      	* gcc.target/aarch64/get_lane_f16_1.c: New test.
      
      From-SVN: r228547
      Kugan Vivekanandarajah committed
    • move dr->alias_set to a helper structure · 09fefdad
      2015-10-06  Aditya Kumar  <aditya.k7@samsung.com>
                      Sebastian Pop  <s.pop@samsung.com>
      
                      * graphite-poly.c (new_scop): Initialize drs.
                      * graphite-poly.h (struct dr_info): New.
                      (struct scop): Add drs.
                      * graphite-sese-to-poly.c (pdr_add_alias_set): Use dr_info.
                      (pdr_add_memory_accesses): Same.
                      (build_poly_dr): Same.
                      (build_alias_set): Same.
                      (build_scop_drs): Same.
                      (build_pbb_drs): Remove.
                      * tree-data-ref.c (create_data_ref): Do not initialize alias_set.
                      * tree-data-ref.h (data_reference): Remove alias_set.
      
      Co-Authored-By: Sebastian Pop <s.pop@samsung.com>
      
      From-SVN: r228545
      Aditya Kumar committed