1. 06 Oct, 2015 34 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
    • remove unused struct base_alias_pair · 790befae
      2015-10-06  Aditya Kumar  <aditya.k7@samsung.com>
                      Sebastian Pop  <s.pop@samsung.com>
      
                      * graphite-poly.c (free_data_refs_aux): Remove.
                      (free_gimple_poly_bb): Do not call free_data_refs_aux.
                      * graphite-poly.h (struct base_alias_pair): Remove.
                      * graphite-sese-to-poly.c (pdr_add_alias_set): Remove all uses of
                      base_alias_pair and dr->aux.
                      (build_alias_set): Same.
                      * tree-data-ref.c (create_data_ref): Initialize alias_set.
                      * tree-data-ref.h (data_reference): Add alias_set.
      
      Co-Authored-By: Sebastian Pop <s.pop@samsung.com>
      
      From-SVN: r228544
      Aditya Kumar committed
    • remove dead code in computation of alias sets · 4fd0b176
      2015-10-06  Aditya Kumar  <aditya.k7@samsung.com>
                      Sebastian Pop  <s.pop@samsung.com>
      
                      * graphite-poly.c (new_poly_dr): Remove dr_base_object_set.
                      Do not set PDR_BASE_OBJECT_SET.
                      * graphite-poly.h (poly_dr): Same.
                      (PDR_BASE_OBJECT_SET): Remove.
                      (new_poly_dr): Update decl.
                      * graphite-sese-to-poly.c (build_poly_dr): Update call to
                      new_poly_dr.
                      (write_alias_graph_to_ascii_dimacs): Remove.
                      (write_alias_graph_to_ascii_dot): Remove.
                      (write_alias_graph_to_ascii_ecc): Remove.
                      (dr_same_base_object_p): Remove.
                      (build_alias_set_optimal_p): Rename build_alias_set.  Remove dead
                      code.
                      (build_base_obj_set_for_drs): Remove.
                      (dump_alias_graphs): Remove.
                      (build_scop_drs): Remove dead code.
      
      Co-Authored-By: Sebastian Pop <s.pop@samsung.com>
      
      From-SVN: r228543
      Aditya Kumar committed
    • c-parser.c (c_parser_statement_after_labels): Use protected_set_expr_location. · 21ba0cea
      	* c-parser.c (c_parser_statement_after_labels): Use
      	protected_set_expr_location.
      	(c_parser_omp_clause_num_gangs): Likewise.
      	(c_parser_omp_clause_num_threads): Likewise.
      	(c_parser_omp_clause_num_workers): Likewise.
      	(c_parser_omp_clause_vector_length): Likewise.
      	(c_parser_omp_clause_num_teams): Likewise.
      	(c_parser_omp_clause_thread_limit): Likewise.
      	* c-typeck.c (build_c_cast): Likewise.
      	(c_cast_expr): Likewise.
      
      From-SVN: r228541
      Marek Polacek committed
    • re PR c++/67863 (-Wtautological-compare warns when it shouldn't) · 46836b0e
      	PR c++/67863
      	* call.c (build_conditional_expr_1): Build the COND_EXPR with
      	a location.
      
      	* c-c++-common/Wtautological-compare-4.c: New test.
      
      From-SVN: r228540
      Marek Polacek committed
    • Remove duplicate target line. · 1f27e054
      From-SVN: r228539
      Michael Meissner committed
    • re PR target/67808 (LRA ICEs on simple double to long double conversion test case) · bd4b39f2
      [gcc]
      2015-10-05  Michael Meissner  <meissner@linux.vnet.ibm.com>
      	    Peter Bergner  <bergner@vnet.ibm.com>
      
      	PR target/67808
      	* config/rs6000/rs6000.md (extenddftf2): In the expander, only
      	allow registers, but provide insns for the combiner to create for
      	loads from memory. Separate VSX code from non-VSX code. For
      	non-VSX code, combine extenddftf2_fprs into extenddftf2 and rename
      	externaldftf2_internal to externaldftf2_fprs. Reorder constraints
      	so that registers come before memory operations. Drop support from
      	converting DFmode to TFmode, if the DFmode value is in a GPR
      	register.
      	(extenddftf2_fprs): Likewise.
      	(extenddftf2_internal): Likewise.
      	(extenddftf2_vsx): Likewise.
      	(extendsftf2): In the expander, only allow registers, but provide
      	insns for the combiner to create for stores and loads.
      
      [gcc/testsuite]
      2015-10-05  Michael Meissner  <meissner@linux.vnet.ibm.com>
      	    Peter Bergner <bergner@vnet.ibm.com>
      
      	PR target/67808
      	* gcc.target/powerpc/pr67808.c: New test.
      
      
      Co-Authored-By: Peter Bergner <bergner@vnet.ibm.com>
      
      From-SVN: r228538
      Michael Meissner committed
    • Remove ATTRIBUTE_UNUSED from `decl' parameter of default_elf_asm_named_section · 184a8d6f
      The decl parameter in default_elf_asm_named_section is actually used.
      Applied as obvious after an arm-none-eabi build.
      
      Ramana
      
      
      2015-10-06 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com>
      
      	* varasm.c (default_elf_asm_named_section): Remove ATTRIBUTE_UNUSED
      	from the decl parameter.
      
      From-SVN: r228537
      Ramana Radhakrishnan committed
    • re PR middle-end/67861 (coreutils' wc.c:write_counts is miscompiled since commit… · 242a37f1
      re PR middle-end/67861 (coreutils' wc.c:write_counts is miscompiled since commit 7e3a76de7c496449b187c2688d958631cf21a944)
      
      	PR 67861
      	* gimple-fold.c (gimple_fold_builtin): Add break after
      	BUILT_IN_PRINTF_CHK, BUILT_IN_VPRINTF_CHK folding.
      
      From-SVN: r228536
      Nathan Sidwell committed
    • Rename scop->ctx to isl_context · cbe7b229
      	* graphite-optimize-isl.c (optimize_isl): Rename scop->ctx
      	to scop->isl_context.
      
      From-SVN: r228535
      H.J. Lu committed
    • arm.c (arm_emit_probe_stack_range): Adjust comment. · fabc9e22
      	* config/arm/arm.c (arm_emit_probe_stack_range): Adjust comment.
      	(output_probe_stack_range): Rotate the loop and simplify.
      	(thumb1_expand_prologue): Tweak sorry message.
      	* config/arm/arm.md (probe_stack): Use bare string.
      
      From-SVN: r228534
      Eric Botcazou committed
    • * config.gcc (lm32-elf): Add newlib-stdint.h to tm_file. · 7c9bb341
      From-SVN: r228533
      Nick Clifton committed
    • gcc * config/msp430/msp430.c (ATTR_NOINIT): New constant. · 90bc4878
      	(ATTR_PERSIST): New constant.
      	(msp430_data_attr): New function - verifies an attribute that only
      	applies to variables.
      	(msp430_attributes): Add noinit and persistent attributes.
      	(noinit_section): New variable.
      	(presis_section): New variable.
      	(TARGET_ASM_INIT_SECTIONS): Define.
      	(msp430_init_sections): New function - initialises the noinit and
      	persist section variables.
      	(msp430_select_section): Add support for noinit and persist
      	attributes.
      	(msp430_section_type_flags): Likewise.
      	* doc/extend.texi:  Document the reent, critical, wakeup, noinit
      	and persistent attributes.
      
      tests	* gcc.target/msp430: New directory.
      	* gcc.target/msp430/msp430.exp: New file.  Runs MSP430 specific
      	tests.
      	* gcc.target/msp430/data-attributes.c: New file.  Checks the
      	noinit and persistent data attributes.
      
      From-SVN: r228531
      Nick Clifton committed
    • remove dead code used by the old cloog scheduler · eaec70cd
      2015-10-05  Aditya Kumar  <aditya.k7@samsung.com>
                      Sebastian Pop  <s.pop@samsung.com>
      
                      * graphite-dependences.c (scop_get_transformed_schedule): Remove.
                      (no_violations): Remove.
                      (subtract_commutative_associative_deps): Remove.
                      (compute_deps): Do not call subtract_commutative_associative_deps.
                      (transform_is_safe): Remove.
                      (graphite_legal_transform): Remove.
                      * graphite-poly.h (graphite_legal_transform): Remove.
      
      Co-Authored-By: Sebastian Pop <s.pop@samsung.com>
      
      From-SVN: r228530
      Aditya Kumar committed
    • Early exit to avoid redundant computations · 216cc294
      Analyze only those bbs which are outside the region for uses which might be
      defined inside the region. This is intended to improve the compile time. This
      algorithm may be further improved by only looking at the successors of region as
      these regions are sese. Added FIXMEs to make this improvement in future.
      
      Passes regtest and bootstrap on x86_64.
      
      gcc/ChangeLog:
      
      2015-10-05  Aditya Kumar  <hiraditya@msn.com>
      
              * graphite-sese-to-poly.c (build_loop_iteration_domains): Only loops
              which are in this region are passed so gcc_assert and remove redundant
              computation.
              * sese.c (sese_build_liveouts): Pass only those bbs which are not in region.
              (sese_bad_liveouts_use): Only BBs which are not in region are passed so
              gcc_assert on that and remove unnecessary computation.
              (sese_build_liveouts_use): Same.
      
      From-SVN: r228529
      Aditya Kumar committed
    • Move declarations, assign types, renaming. · 8e4dc590
      1. Move declarations near the assignment/usage.
      2. Assign type to members which were void*.
      3. Rename scop->context to scop::param_context, and scop::ctx to
      scop::isl_context
      
      No functional changes intended. Passes regtest and bootstrap.
      
      gcc/ChangeLog:
      
      2015-10-05  Aditya Kumar  <aditya.k7@samsung.com>
      
              * graphite-dependences.c (scop_get_reads): Renamed scop->context to scop->param_context.
              (scop_get_must_writes): Same.
              (scop_get_may_writes): Same.
              (scop_get_original_schedule): Same.
              (scop_get_transformed_schedule): Same.
              (subtract_commutative_associative_deps): Same.
              * graphite-isl-ast-to-gimple.c (add_parameters_to_ivs_params): Same.
              (generate_isl_context): Same.
              (generate_isl_schedule): Same.
              (scop_to_isl_ast): Same.
              (graphite_regenerate_ast_isl): Same.
              * graphite-optimize-isl.c (scop_get_domains): Same.
              (optimize_isl): Renamed scop->context to scop->param_context.
              * graphite-poly.c (new_poly_bb): Change the type of argument to gimple_poly_bb_p.
              (new_scop): Renamed scop->context to scop->param_context.
              (free_scop): Same.
              (print_scop_context): Same.
              * graphite-poly.h (new_poly_dr): Change the type of argument from void* to data_reference_p.
              (struct poly_bb): Change the type of black_box to gimple_poly_bb_p.
              (new_poly_bb): Change the type of argument from void* to gimple_poly_bb_p.
              (pbb_set_black_box): Same.
              (struct scop): Rename context to param_context, ctx to isl_context.
              * graphite-scop-detection.c (scop_detection::build_scop_bbs_1): Move declarations closer to assignment.
              (find_params_in_bb): Same.
              (find_scop_parameters): Same.
              * graphite-sese-to-poly.c (unsigned ssa_name_version_typesize): Global to be used for statement IDs.
              (isl_id_for_pbb): Use ssa_name_version_typesize.
              (simple_copy_phi_p): Move declarations closer to assignment.
              (build_pbb_scattering_polyhedrons): Same.
              (build_scop_scattering): Same.
              (isl_id_for_ssa_name): Same.
              (extract_affine_name): Same.
              (extract_affine_int): Same.
              (extract_affine): Same.
              (set_scop_parameter_dim): Use renamed member.
              (build_loop_iteration_domains): Same.
              (add_param_constraints): Same.
              (build_scop_iteration_domain): Same.
              (pdr_add_data_dimensions): Same.
              (build_poly_dr): Same.
              (build_scop_drs): Move declarations closer to assignment.
              (analyze_drs_in_stmts): Same.
              (insert_out_of_ssa_copy): Same.
              (insert_out_of_ssa_copy_on_edge): Same.
              (propagate_expr_outside_region): Same.
              (rewrite_phi_out_of_ssa): Same.
              (rewrite_degenerate_phi): Same.
              (rewrite_reductions_out_of_ssa): Same.
              (rewrite_cross_bb_scalar_dependence): Same.
              (handle_scalar_deps_crossing_scop_limits): Same.
              (rewrite_cross_bb_scalar_deps): Same.
              * graphite.c (graphite_transform_loops): Use renamed member.
      
      From-SVN: r228528
      Aditya Kumar committed
    • re PR c/65345 (ICE with _Generic selection on _Atomic int) · 07119921
      	PR c/65345
      	* config/alpha/alpha.c (alpha_atomic_assign_expand_fenv): Use
      	create_tmp_var_raw instead of create_tmp_var.
      
      From-SVN: r228527
      Uros Bizjak committed
    • Fix PR c/65345 for AArch64 · 09ba9ef7
      
      
      2015-10-06  Ramana Radhakrishnan  <ramana.radhakrishnan@arm.com>
      
      	PR c/65345
      	* config/aarch64/aarch64-builtins.c (aarch64_atomic_assign_expand_fenv):
      	Use create_tmp_var_raw instead of create_tmp_var.
      
      From-SVN: r228526
      Ramana Radhakrishnan committed
    • AVX-512. Avoid upper-bank registers when splitting vec_extract_lo instruction. · 2d83470f
      gcc/
      	PR target/67849
      	* config/i386/sse.md (define_split vec_select/V8FI): Restrict
      	split for upper-bank registers when target does not support
      	AVX512VL.
      	(define_insn "vec_extract_lo_<mode><mask_name>"): Restrict
      	split when target does not support AVX512VL.
      
      From-SVN: r228525
      Alexander Fomin committed
    • re PR c/65345 (ICE with _Generic selection on _Atomic int) · 2d546fb7
              PR c/65345
              * config/rs6000/rs6000.c (rs6000_atomic_assign_expand_fenv):
              Adjust to use create_tmp_var_raw instead of create_tmp_var.
      
      From-SVN: r228524
      David Edelsohn committed
    • builtin_target.c: Fix AVX-512VBMI detection. · bdef5442
      gcc/testsuite/
              * gcc.target/i386/builtin_target.c: Fix AVX-512VBMI detection.
      
      From-SVN: r228523
      Kirill Yukhin committed
    • rl78.c (rl78_rtx_costs): Improve cost estimates for multiplication. · 2ef98fb9
      	* config/rl78/rl78.c (rl78_rtx_costs): Improve cost estimates for
      	multiplication.
      
      From-SVN: r228521
      Nick Clifton committed
    • AMD znver1 enablement. · 9ce29eb0
      2015-10-06  Venkataramanan Kumar  <Venkataramanan.kumar@amd.com>
      	
      	AMD znver1 enablement. 
      	* config.gcc (i[34567]86-*-linux* | ...): Add znver1.
      	(case ${target}): Add znver1.
      	* config/i386/cpuid.h(bit_CLZERO):  Define.
      	* config/i386/driver-i386.c: (host_detect_local_cpu): Let
      	-march=native recognize znver1 processors. 
      	* config/i386/i386-c.c (ix86_target_macros_internal): Add
      	znver1, clzero def_and_undef. 
      	* config/i386/i386.c (struct processor_costs znver1_cost): New.
      	(m_znver1): New definition.
      	(m_AMD_MULTIPLE): Includes m_znver1.
      	(processor_target_table): Add znver1 entry.
      	(ix86_target_string) : Add clzero entry.
      	(static const char *const cpu_names): Add znver1 entry.
      	(ix86_option_override_internal): Add znver1 instruction sets.
      	(PTA_CLZERO) :  New definition.
      	(ix86_option_override_internal): Handle new clzerooption.
      	(ix86_issue_rate): Add znver1.
      	(ix86_adjust_cost): Add znver1.                
      	(ia32_multipass_dfa_lookahead): Add znver1.
      	(has_dispatch): Add znver1.       
      	* config/i386/i386.h (TARGET_znver1): New definition. 
      	(TARGET_CLZERO): Define.
      	(TARGET_CLZERO_P): Define.
      	(struct ix86_size_cost): Add TARGET_ZNVER1.
      	(enum processor_type): Add PROCESSOR_znver1.
      	* config/i386/i386.md (define_attr "cpu"): Add znver1.
      	(set_attr znver1_decode): New definitions for znver1.
      	* config/i386/i386.opt (flag_dispatch_scheduler): Add znver1.
      	(mclzero): New.
      	* config/i386/mmx.md (set_attr znver1_decode): New definitions
      	for znver1.
      	* config/i386/sse.md (set_attr znver1_decode): Likewise.
      	* config/i386/x86-tune.def:  Add znver1 tunings.
      	* config/i386/znver1.md: Introduce znver1 cpu and include new md file.
      	* gcc/doc/invoke.texi: Add details about znver1
      
      From-SVN: r228520
      Venkataramanan Kumar committed
    • re PR tree-optimization/67859 (ICE on valid code at -O2 and -O3 on x86_64-linux-gnu) · 0580f6a1
      2015-10-06  Richard Biener  <rguenther@suse.de>
      
      	PR tree-optimization/67859
      	* tree-ssa-pre.c (create_expression_by_pieces): Properly
      	discard not inserted stmts.
      
      	* gcc.dg/torture/pr67859.c: New testcase.
      
      From-SVN: r228519
      Richard Biener committed
    • Update template instantiation documentation · badfb2fb
      	* doc/extend.texi (Template Instantiation): Reorder options and
      	de-emphasize -frepo.
      	* doc/invoke.texi (C++ Dialect Options): Use -fstrict-enums in
      	example instead of -frepo.
      
      From-SVN: r228518
      Jonathan Wakely committed
    • re PR c/65345 (ICE with _Generic selection on _Atomic int) · 68ea7618
      	PR c/65345
      	* config/sparc/sparc.c (sparc_atomic_assign_expand_fenv): Adjust to
      	use create_tmp_var_raw rather than create_tmp_var.
      
      From-SVN: r228516
      Eric Botcazou committed
    • builtin_target.c: Fix AVX-512VBMI detection. · 4a2fc4d4
      gcc/testsuite/
      	* gcc.target/i386/builtin_target.c: Fix AVX-512VBMI detection.
      
      From-SVN: r228515
      Kirill Yukhin committed
    • tree-vectorizer.h (vec_info): New base class for... · 310213d4
      2015-10-06  Richard Biener  <rguenther@suse.de>
      
      	* tree-vectorizer.h (vec_info): New base class for...
      	(_loop_vec_info): ... this and ...
      	(_bb_vec_info): ... this.
      	(vect_is_simple_use, vect_is_simple_use_1, new_stmt_vec_info,
      	vect_analyze_data_refs_alignment, vect_verify_datarefs_alignment,
      	vect_analyze_data_ref_accesses, vect_analyze_data_refs,
      	vect_schedule_slp, vect_analyze_slp, vect_pattern_recog,
      	vect_destroy_datarefs): Adjust interface to take a vec_info *
      	rather than both a loop_vec_info and a bb_vec_info argument.
      	* tree-vect-data-refs.c (vect_compute_data_refs_alignment,
      	vect_verify_datarefs_alignment, vect_enhance_data_refs_alignment,
      	vect_analyze_data_refs_alignment, vect_analyze_data_ref_accesses,
      	vect_analyze_data_refs, vect_create_data_ref_ptr): Adjust
      	accordingly.
      	* tree-vect-loop.c (new_loop_vec_info): Initialize base class.
      	(destroy_loop_vec_info, vect_analyze_loop_2,
      	vect_is_simple_reduction_1, get_initial_def_for_induction,
      	vect_create_epilog_for_reduction, vectorizable_reduction,
      	vectorizable_live_operation, vect_transform_loop): Adjust.
      	* tree-vect-patterns.c (type_conversion_p,
      	vect_recog_widen_mult_pattern, vect_recog_widen_shift_pattern,
      	vect_recog_rotate_pattern, vect_recog_vector_vector_shift_pattern,
      	vect_recog_divmod_pattern, vect_recog_mixed_size_cond_pattern,
      	check_bool_pattern, vect_recog_bool_pattern,
      	vect_mark_pattern_stmts, vect_pattern_recog): Likewise.
      	* tree-vect-slp.c (vect_get_and_check_slp_defs,
      	vect_build_slp_tree_1, vect_build_slp_tree, vect_analyze_slp_cost_1,
      	vect_analyze_slp_instance, vect_analyze_slp, destroy_bb_vec_info,
      	vect_slp_analyze_bb_1, vect_schedule_slp): Likewise.
      	(new_bb_vec_info): Initialize base classs.
      	* tree-vect-stmts.c (record_stmt_cost, process_use,
      	vect_get_vec_def_for_operand, vect_finish_stmt_generation,
      	vectorizable_mask_load_store, vectorizable_call,
      	vectorizable_simd_clone_call, vectorizable_conversion,
      	vectorizable_assignment, vectorizable_shift,
      	vectorizable_operation, vectorizable_store,
      	vectorizable_load, vect_is_simple_cond, vectorizable_condition,
      	new_stmt_vec_info, vect_is_simple_use, vect_is_simple_use_1): Likewise.
      	* tree-vectorizer.c (vect_destroy_datarefs): Likewise.
      
      From-SVN: r228514
      Richard Biener committed
    • builtin_target.c: Add check for AES and PCLMUL. · 5097195f
      gcc/testsuite/
      	* gcc.target/i386/builtin_target.c: Add check for AES and PCLMUL.
      
      From-SVN: r228513
      Kirill Yukhin committed
    • Daily bump. · 5d51afce
      From-SVN: r228510
      GCC Administrator committed
  2. 05 Oct, 2015 6 commits