1. 09 Sep, 2008 1 commit
  2. 06 Sep, 2008 2 commits
    • 2008-xx-xx Richard Sandiford <rdsandiford@goolemail.com> Peter Fuerst <post@pfrst.de> · 4d210b07
      gcc/
      2008-xx-xx  Richard Sandiford  <rdsandiford@goolemail.com>
      	    Peter Fuerst  <post@pfrst.de>
      
      	* doc/invoke.texi: Document -mr10k-cache-barrier=.
      	* doc/extend.texi: Document __builtin_mips_cache.
      	* config/mips/mips-ftypes.def: Add a (VOID, SI, CVPOINTER) entry.
      	* config/mips/mips.opt (mr10k-cache-barrier=): New option.
      	* config/mips/mips.h (TARGET_CPU_CPP_BUILTINS): Define
      	__GCC_HAVE_BUILTIN_MIPS_CACHE.
      	(TARGET_CACHE_BUILTIN, ISA_HAS_CACHE): New macros.
      	* config/mips/mips.c (mips_r10k_cache_barrier_setting): New enum.
      	(set_push_mips_isas): New variable.
      	(mips_r10k_cache_barrier): New variable.
      	(cache): New availability predicate.
      	(mips_builtins): Add an entry for __builtin_mips_cache.
      	(mips_build_cvpointer_type): New function.
      	(MIPS_ATYPE_CVPOINTER): New macro.
      	(mips_prepare_builtin_arg): Only use the insn's mode if the rtx's
      	mode is VOIDmode.
      	(r10k_simplified_address_p, r10k_simplify_address)
      	(r10k_uncached_address_p, r10k_safe_address_p)
      	(r10k_needs_protection_p_1, r10k_needs_protection_p_store)
      	(r10k_needs_protection_p_call, r10k_needs_protection_p)
      	(r10k_insert_cache_barriers): New functions.
      	(mips_reorg_process_insns): Delete cache barriers after a
      	branch-likely instruction.
      	(mips_reorg): Call r10k_insert_cache_barriers.
      	(mips_handle_option): Handle OPT_mr10k_cache_barrier_.
      	* config/mips/mips.md (UNSPEC_MIPS_CACHE): New constant.
      	(UNSPEC_R10K_CACHE_BARRIER): Likewise.
      	(mips_cache, r10k_cache_barrier): New define_insns.
      
      gcc/testsuite/
      	* gcc.target/mips/mips.exp (dg-mips-options): Make
      	-mr10k-cache-barrier=* imply -mips3 or above.
      	* gcc.target/mips/cache-1.c: New test.
      	* gcc.target/mips/r10k-cache-barrier-1.c: Likewise.
      	* gcc.target/mips/r10k-cache-barrier-2.c: Likewise.
      	* gcc.target/mips/r10k-cache-barrier-3.c: Likewise.
      	* gcc.target/mips/r10k-cache-barrier-4.c: Likewise.
      	* gcc.target/mips/r10k-cache-barrier-5.c: Likewise.
      	* gcc.target/mips/r10k-cache-barrier-6.c: Likewise.
      	* gcc.target/mips/r10k-cache-barrier-7.c: Likewise.
      	* gcc.target/mips/r10k-cache-barrier-8.c: Likewise.
      	* gcc.target/mips/r10k-cache-barrier-9.c: Likewise.
      	* gcc.target/mips/r10k-cache-barrier-10.c: Likewise.
      	* gcc.target/mips/r10k-cache-barrier-11.c: Likewise.
      	* gcc.target/mips/r10k-cache-barrier-12.c: Likewise.
      	* gcc.target/mips/r10k-cache-barrier-13.c: Likewise.
      	* gcc.target/mips/r10k-cache-barrier-14.c: Likewise.
      	* gcc.target/mips/r10k-cache-barrier-15.c: Likewise.
      
      From-SVN: r140055
      Richard Sandiford committed
    • tm.texi (IRA_COVER_CLASSES): Fix a typo. · af9253a1
      2008-09-05  Vladimir Makarov  <vmakarov@redhat.com>
      
      	* doc/tm.texi (IRA_COVER_CLASSES): Fix a typo.
      
      From-SVN: r140053
      Vladimir Makarov committed
  3. 05 Sep, 2008 2 commits
    • Improved branch hints, safe hints, and scheduling. · 9dcc2e87
      	* haifa-sched.c (sched_emit_insn) : Define.
      	* sched-int.h (sched_emit_insn) : Add prototype.
      	* doc/invoke.texi (-mdual-nops, -mhint-max-nops,
      	-mhint-max-distance -msafe-hints) : Document.
      	* config/spu/spu.c (spu_flag_var_tracking): New.
      	(TARGET_SCHED_INIT_GLOBAL, TARGET_SCHED_INIT,
      	TARGET_SCHED_REORDER, TARGET_SCHED_REORDER2,
      	TARGET_ASM_FILE_START): Define.
      	(TARGET_SCHED_ADJUST_PRIORITY): Remove.
      	(STOP_HINT_P, HINTED_P, SCHED_ON_EVEN_P): Define.
      	(spu_emit_branch_hint): Add blocks argument.
      	(insert_branch_hints, insert_nops): Remove.
      	(pad_bb, insert_hbrp_for_ilb_runout, insert_hbrp, in_spu_reorg,
      	uses_ls_unit, spu_sched_init_global, spu_sched_init,
      	spu_sched_reorder, asm_file_start): New functions.
      	(clock_var, spu_sched_length, pipe0_clock,
      	pipe1_clock, prev_clock_var, prev_priority,
      	spu_ls_first, prev_ls_clock): New static variables.
      	* config/spu/spu.h (TARGET_DEFAULT): Add MASK_SAFE_HINTS.
      	* config/spu.md (iprefetch): Add operand, make it clobber MEM.
      	(nopn_nv): Add a non-volatile version of nop.
      	* config/spu/spu.opt (-mdual-nops, -mhint-max-nops,
      	-mhint-max-distance, -msafe-hints): New options.
      
      From-SVN: r140047
      Trevor Smigiel committed
    • install.texi (--enable-reduced-reflection): Document new option. · c07cd2c7
      2008-09-05  David Daney  <ddaney@avtrex.com>
      
      	* doc/install.texi (--enable-reduced-reflection): Document new option.
      
      
      2008-09-05  David Daney  <ddaney@avtrex.com>
      
      	* configure.ac (reduced-reflection): New AC_ARG_ENABLE.
      	(build_libgcj_reduced_reflection): New variable.
      	(BUILD_LIBGCJ_REDUCED_REFLECTION): New AM_CONDITIONAL.
      	* Makefile.am (LIBGCJ_REDUCED_REFLECTION_FLAGS): New variable.
      	(%.lo: %.list): Add LIBGCJ_REDUCED_REFLECTION_FLAGS to compile
      	command.
      	(java/util/concurrent.lo, java/util/concurrent/atomic.lo,
      	java/util/concurrent/locks.lo): Override
      	LIBGCJ_REDUCED_REFLECTION_FLAGS.
      	* Makefile.in, include/Makefile.in, testsuite/Makefile.in,
      	gcj/Makefile.in, configure: Regenerate.
      
      From-SVN: r140038
      David Daney committed
  4. 04 Sep, 2008 1 commit
    • ira-conflicts.c (process_regs_for_copy): Check insn to check that the cost is… · 4cda38d5
      ira-conflicts.c (process_regs_for_copy): Check insn to check that the cost is already taken into account in ira-costs.c
      
      2008-09-04  Vladimir Makarov  <vmakarov@redhat.com>
      
      	* ira-conflicts.c (process_regs_for_copy): Check insn to check
      	that the cost is already taken into account in ira-costs.c
      
      	* ira-int.h (ira_debug_copy, ira_debug_copies): New.
      
      	* ira-build.c (print_copy, print_copies, ira_debug_copy,
      	ira_debug_copies): New.
      	(ira_bulid): Call print_copies.
      	
      	* doc/tm.texi (IRA_COVER_CLASSES): Fix the description.
      
      From-SVN: r140014
      Vladimir Makarov committed
  5. 03 Sep, 2008 1 commit
    • Add picoChip port. · 358da97e
      2008-09-03  Hari Sandanagobalane  <hariharan@picochip.com>
      
      	Add picoChip port.
      	* MAINTAINERS: Add picoChip maintainers.
      	libgcc/
      	* config.host: Add picochip-*-*.
      	gcc/
      	* doc/extend.texi: Document picoChip builtin functions.
      	* doc/invoke.texi: Document picoChip options.
      	* doc/contrib.texi: Add picoChip contribution.
      	* doc/md.texi: Document picoChip constraints.
      	* config.gcc: Add picochip-*-*.
      	* config/picochip/: Add new port.
      
      From-SVN: r139932
      Hari Sandanagobalane committed
  6. 02 Sep, 2008 2 commits
    • backport: configure: Regenerate. · f8bf9252
      2008-09-02  Sebastian Pop  <sebastian.pop@amd.com>
      	    Tobias Grosser  <grosser@fim.uni-passau.de>
      	    Jan Sjodin  <jan.sjodin@amd.com>
      	    Harsha Jagasia  <harsha.jagasia@amd.com>
      	    Dwarakanath Rajagopal  <dwarak.rajagopal@amd.com>
      	    Konrad Trifunovic  <konrad.trifunovic@inria.fr>
      	    Adrien Eliche  <aeliche@isty.uvsq.fr>
      
      	Merge from graphite branch.
      	* configure: Regenerate.
      	* Makefile.in: Regenerate.
      	* configure.ac (host_libs): Add ppl and cloog.
      	Add checks for PPL and CLooG.
      	* Makefile.def (ppl, cloog): Added modules and dependences.
      	* Makefile.tpl (PPLLIBS, PPLINC, CLOOGLIBS, CLOOGINC): New.
      	(HOST_PPLLIBS, HOST_PPLINC, HOST_CLOOGLIBS, HOST_CLOOGINC): New.
      
      gcc/
      	* graphite.c: New.
      	* graphite.h: New.
      	* tree-loop-linear.c (perfect_loop_nest_depth): Export.
      	* doc/invoke.texi (-floop-block, -floop-interchange,
      	-floop-strip-mine): Document new flags.
      	* tree-into-ssa.c (gimple_vec): Moved...
      	* tree-loop-distribution.c (rdg_component): Moved...
      	* cfgloopmanip.c: Include tree-flow.h.
      	(update_dominators_in_loop): New.
      	(create_empty_if_region_on_edge): New.
      	(create_empty_loop_on_edge): New.
      	(loopify): Use update_dominators_in_loop.
      	* tree-pass.h (pass_graphite_transforms): Declared.
      	* configure: Regenerate.
      	* tree-phinodes.c (make_phi_node): Export.
      	(add_phi_node_to_bb): New, split from create_phi_node.
      	* tree-chrec.c (for_each_scev_op): New.
      	* tree-chrec.h (for_each_scev_op): Declared.
      	* tree-ssa-loop-ivopts.c (get_phi_with_result): New.
      	(remove_statement): Call get_phi_with_result.
      	* config.in (HAVE_cloog): Undef.
      	* gdbinit.in (pgg): New.
      	* timevar.def (TV_GRAPHITE_TRANSFORMS): New.
      	* tree-ssa-loop.c (graphite_transforms): New.
      	(gate_graphite_transforms): New.
      	(pass_graphite_transforms): New.
      	* configure.ac (PPLLIBS, PPLINC, CLOOGLIBS, CLOOGINC,
      	HAVE_cloog): Defined.
      	* tree-vectorizer.c (rename_variables_in_bb): Export.
      	* tree-data-ref.c (dr_may_alias_p): Export.
      	(stmt_simple_memref_p): New.
      	(find_data_references_in_stmt): Export.
      	(find_data_references_in_loop): Export.
      	(create_rdg_edge_for_ddr): Initialize RDGE_RELATION.
      	(create_rdg_edges_for_scalar): Initialize RDGE_RELATION.
      	(create_rdg_vertices): Export.
      	(build_empty_rdg): New.
      	(build_rdg): Call build_empty_rdg.  Free dependence_relations.
      	* tree-data-ref.h (rdg_component): ... here.
      	(scop_p): New.
      	(struct data_reference): Add a field scop.
      	(DR_SCOP): New.
      	(find_data_references_in_loop): Declared.
      	(find_data_references_in_stmt): Declared.
      	(create_rdg_vertices): Declared.
      	(dr_may_alias_p): Declared.
      	(stmt_simple_memref_p): Declared.
      	(struct rdg_edge): Add a field ddr_p relation.
      	(build_empty_rdg): Declared.
      	* lambda.h (lambda_matrix): Declare a VEC of.
      	(find_induction_var_from_exit_cond): Declared.
      	(lambda_vector_compare): New.
      	* common.opt (fgraphite, floop-strip-mine,
      	floop-interchange, floop-block): New flags.
      	* lambda-code.c (find_induction_var_from_exit_cond): Export.
      	* cfgloop.c (is_loop_exit): New.
      	* cfgloop.h (is_loop_exit): Declared.
      	(create_empty_if_region_on_edge): Declared.
      	(create_empty_loop_on_edge): Declared.
      	* tree-flow.h (add_phi_node_to_bb): Declared.
      	(make_phi_node): Declared.
      	(rename_variables_in_bb): Declared.
      	(perfect_loop_nest_depth): Declared.
      	(graphite_transform_loops): Declared.
      	* Makefile.in (cfgloopmanip.o): Depend on TREE_FLOW_H.
      	(graphite.o-warn): Add -Wno-error.
      	(PPLLIBS, PPLINC, CLOOGLIBS, CLOOGINC): Declared.
      	(LIBS): Add GMPLIBS, CLOOGLIBS, PPLLIBS.
      	(INCLUDES): Add PPLINC, CLOOGINC.
      	(OBJS-common): Add graphite.o.
      	(graphite.o): Add rule.
      	* gimple.h (gimple_vec): ... here.
      	* tree-cfg.c (print_loops): Start printing at ENTRY_BLOCK_PTR.
      	* passes.c (init_optimization_passes): Schedule 
      	pass_graphite_transforms.
      
      testsuite/
      
      	* gcc.dg/graphite/scop-{0,1,2,3,4,5,6,7,8,9,
      	10,11,12,13,14,15,16,17,18}.c: New.
      	* gcc.dg/graphite/graphite.exp: New.
      	* gcc.dg/graphite/scop-matmult.c: New.
      	* gcc.dg/graphite/block-0.c: New.
      	* lib/target-supports.exp (check_effective_target_fgraphite): New.
      	* gfortran.dg/graphite/block-1.f90: New.
      	* gfortran.dg/graphite/scop-{1,2}.f: New.
      	* gfortran.dg/graphite/block-{1,3,4}.f90: New.
      	* gfortran.dg/graphite/graphite.exp: New.
      
      
      Co-Authored-By: Adrien Eliche <aeliche@isty.uvsq.fr>
      Co-Authored-By: Dwarakanath Rajagopal <dwarak.rajagopal@amd.com>
      Co-Authored-By: Harsha Jagasia <harsha.jagasia@amd.com>
      Co-Authored-By: Jan Sjodin <jan.sjodin@amd.com>
      Co-Authored-By: Konrad Trifunovic <konrad.trifunovic@inria.fr>
      Co-Authored-By: Tobias Grosser <grosser@fim.uni-passau.de>
      
      From-SVN: r139893
      Sebastian Pop committed
    • invoke.texi: Document -mword-relocations. · 571191af
      2008-09-01  Paul Brook  <paul@codesourcery.com>
      
      	* doc/invoke.texi: Document -mword-relocations.
      	* config/arm/uclinux-elf.h (TARGET_DEFAULT_WORD_RELOCATIONS): Define.
      	* config/arm/symbian.h (TARGET_DEFAULT_WORD_RELOCATIONS): Define.
      	* config/arm/vxworks.h (TARGET_DEFAULT_WORD_RELOCATIONS): Define.
      	* config/arm/arm.c (arm_split_constant): Use arm_emit_movpair.
      	(arm_rtx_costs_1, arm_size_rtx_costs): Handle HIGH and LO_SUM.
      	(arm_emit_movpair): New function.
      	(arm_print_operand <c>): Handle sybolic addresses.
      	* config/arm/arm.h (TARGET_USE_MOVT): Define.
      	(TARGET_DEFAULT_WORD_RELOCATIONS): Define.
      	* config/arm/arm-protos.h (arm_emit_movpair): Add prototype.
      	* config/arm/arm.opt: Add -mword-relocations.
      	* config/arm/arm.md (movsi): Use arm_emit_movpair.
      	(arm_movt, arm_movw): New.
      
      From-SVN: r139881
      Paul Brook committed
  7. 01 Sep, 2008 1 commit
    • sel-sched.h, [...]: New files. · e855c69d
      2008-08-31  Andrey Belevantsev  <abel@ispras.ru>
              Dmitry Melnik  <dm@ispras.ru>
              Dmitry Zhurikhin  <zhur@ispras.ru>
              Alexander Monakov  <amonakov@ispras.ru>
              Maxim Kuvyrkov  <maxim@codesourcery.com>
      
      	* sel-sched.h, sel-sched-dump.h, sel-sched-ir.h, sel-sched.c,
      	sel-sched-dump.c, sel-sched-ir.c: New files.
      	* Makefile.in (OBJS-common): Add selective scheduling object
      	files.
      	(sel-sched.o, sel-sched-dump.o, sel-sched-ir.o): New entries.
      	(SEL_SCHED_IR_H, SEL_SCHED_DUMP_H): New entries.
      	(sched-vis.o): Add dependency on $(INSN_ATTR_H).
      	* cfghooks.h (get_cfg_hooks, set_cfg_hooks): New prototypes.
      	* cfghooks.c (get_cfg_hooks, set_cfg_hooks): New functions.
      	(make_forwarder_block): Update loop latch if we have redirected
      	the loop latch edge.
      	* cfgloop.c (get_loop_body_in_custom_order): New function.
      	* cfgloop.h (LOOPS_HAVE_FALLTHRU_PREHEADERS): New enum field.
      	(CP_FALLTHRU_PREHEADERS): Likewise.
      	(get_loop_body_in_custom_order): Declare.
      	* cfgloopmanip.c (has_preds_from_loop): New.
      	(create_preheader): Honor CP_FALLTHRU_PREHEADERS.
      	Assert that the preheader edge will be fall thru when it is set.
      	* common.opt (fsel-sched-bookkeeping, fsel-sched-pipelining,
      	fsel-sched-pipelining-outer-loops, fsel-sched-renaming,
      	fsel-sched-substitution, fselective-scheduling): New flags.
          	* cse.c (hash_rtx_cb): New.
      	(hash_rtx): Use it.
      	* dbgcnt.def (sel_sched_cnt, sel_sched_region_cnt,
      	sel_sched_insn_cnt): New counters. 
      	* final.c (compute_alignments): Export.  Free dominance info after loop_optimizer_finalize.
      	* genattr.c (main): Output maximal_insn_latency prototype.
      	* genautomata.c (output_default_latencies): New. Factor its code from ...
      	(output_internal_insn_latency_func): ... here.
      	(output_internal_maximal_insn_latency_func): New.
      	(output_maximal_insn_latency_func): New.
      	* hard-reg-set.h (UHOST_BITS_PER_WIDE_INT): Define unconditionally.
      	(struct hard_reg_set_iterator): New.
      	(hard_reg_set_iter_init, hard_reg_set_iter_set,
      	hard_reg_set_iter_next): New functions.
      	(EXECUTE_IF_SET_IN_HARD_REG_SET): New macro.
      	* lists.c (remove_free_INSN_LIST_node,
      	remove_free_EXPR_LIST_node): New functions.
      	* loop-init.c (loop_optimizer_init): When LOOPS_HAVE_FALLTHRU_PREHEADERS,
      	set CP_FALLTHRU_PREHEADERS when calling create_preheaders.
      	(loop_optimizer_finalize): Do not verify flow info after reload.
      	* recog.c (validate_replace_rtx_1): New parameter simplify.
      	Default it to true.  Update all uses.  Factor out simplifying
      	code to ...
      	(simplify_while_replacing): ... this new function.
      	(validate_replace_rtx_part,
      	validate_replace_rtx_part_nosimplify): New.
      	* recog.h (validate_replace_rtx_part,
      	validate_replace_rtx_part_nosimplify): Declare.
      	* rtl.c (rtx_equal_p_cb): New.
      	(rtx_equal_p): Use it.
      	* rtl.h (rtx_equal_p_cb, hash_rtx_cb): Declare.
      	(remove_free_INSN_LIST_NODE, remove_free_EXPR_LIST_node,
      	debug_bb_n_slim, debug_bb_slim,    print_rtl_slim): Likewise.
      	* vecprim.h: Add a vector type for unsigned int. 
      	* haifa-sched.c: Include vecprim.h and cfgloop.h.
      	(issue_rate, sched_verbose_param, note_list, dfa_state_size,
      	ready_try, cycle_issued_insns, spec_info): Make global.
      	(readyp): Initialize.
      	(dfa_lookahead): New global variable.
      	(old_max_uid, old_last_basic_block): Remove.
      	(h_i_d): Make it a vector.
      	(INSN_TICK, INTER_TICK, QUEUE_INDEX, INSN_COST): Make them work
      	through HID macro.
      	(after_recovery, adding_bb_to_current_region_p):
      	New variables to handle correct insertion of the recovery code.
      	(struct ready_list): Move declaration to sched-int.h.
      	(rgn_n_insns): Removed.
      	(rtx_vec_t): Move to sched-int.h.
      	(find_insn_reg_weight): Remove.
      	(find_insn_reg_weight1): Rename to find_insn_reg_weight.
      	(haifa_init_h_i_d, haifa_finish_h_i_d):
      	New functions to initialize / finalize haifa instruction data.
      	(extend_h_i_d, init_h_i_d): Rewrite.
      	(unlink_other_notes): Move logic to add_to_note_list.  Handle
      	selective scheduler.
      	(ready_lastpos, ready_element, ready_sort, reemit_notes,
      	find_fallthru_edge): Make global, remove static prototypes.
      	(max_issue): Make global.  Add privileged_n and state parameters.  Use
      	them.  
      	(extend_global, extend_all): Removed.
      	(init_before_recovery): Add new param.  Fix the handling of the case
      	when we insert a recovery code before the EXIT which has a predecessor
      	with a fallthrough edge to it.
      	(create_recovery_block): Make global.  Rename to
      	sched_create_recovery_block.  Update.
      	(change_pattern): Rename to sched_change_pattern.  Make global.
      	(speculate_insn): Rename to sched_speculate_insn.  Make global.
      	Split haifa-specific functionality into ...
      	(haifa_change_pattern): New static function.
      	(sched_extend_bb): New static function.
      	(sched_init_bbs): New function.
      	(current_sched_info): Change type to struct haifa_sched_info.
      	(insn_cost): Adjust for selective scheduling.
      	(dep_cost_1): New function.  Move logic from ...
      	(dep_cost): ... here.
      	(dep_cost): Use dep_cost_1.
      	(contributes_to_priority_p): Use sched_deps_info instead of
      	current_sched_info.
      	(priority): Adjust to work with selective scheduling.  Process the
      	corner case when all dependencies don't contribute to priority.
      	(rank_for_schedule): Use ds_weak instead of dep_weak.
      	(advance_state): New function.  Move logic from ...
      	(advance_one_cycle): ... here.
      	(add_to_note_list, concat_note_lists): New functions.
      	(rm_other_notes): Make static.  Adjust for selective scheduling.
      	(remove_notes, restore_other_notes): New functions.
      	(move_insn): Add two arguments.  Update assert.  Don't call
      	reemit_notes.
      	(choose_ready): Remove lookahead variable, use dfa_lookahead.
      	Remove more_issue, max_points.  Move the code to initialize
      	max_lookahead_tries to max_issue.
      	(schedule_block): Remove rgn_n_insns1 parameter.  Don't allocate
      	ready.  Adjust use of move_insn.  Call restore_other_notes.
      	(luid): Remove.
      	(sched_init, sched_finish): Move Haifa-specific initialization/
      	finalization to ...
      	(haifa_sched_init, haifa_sched_finish): ... respectively.
      	New functions.
      	(setup_sched_dump): New function.
      	(haifa_init_only_bb): New static function.
      	(haifa_speculate_insn): New static function.
      	(try_ready): Use haifa_* instead of speculate_insn and
      	change_pattern.
      	(extend_ready, extend_all): Remove.
      	(sched_extend_ready_list, sched_finish_ready_list): New functions.
      	(create_check_block_twin, add_to_speculative_block): Use
      	haifa_insns_init instead of extend_global.  Update to use new
      	initialization functions.  Change parameter.  Factor out code from
      	create_check_block_twin to ...
      	(sched_create_recovery_edges) ... this new function.
      	(add_block): Remove.
      	(sched_scan_info): New.
      	(extend_bb): Use sched_scan_info.
      	(init_bb, extend_insn, init_insn, init_insns_in_bb, sched_scan): New
      	static functions for walking through scheduling region.
      	(sched_luids): New vector variable to replace uid_to_luid.
      	(luids_extend_insn): New function.
      	(sched_max_luid): New variable.
      	(luids_init_insn): New function.
      	(sched_init_luids, sched_finish_luids): New functions.
      	(insn_luid): New debug function.
      	(sched_extend_target): New function.
      	(haifa_init_insn): New static function.
      	(sched_init_only_bb): New hook.
      	(sched_split_block): New hook.
      	(sched_split_block_1): New function.
      	(sched_create_empty_bb): New hook.
      	(sched_create_empty_bb_1): New function.	
      	(common_sched_info, ready): New global variables.
      	(current_sched_info_var): Remove.
      	(move_block_after_check): Use common_sched_info.		
      	(haifa_luid_for_non_insn): New static function.	
      	(init_before_recovery): Use haifa_init_only_bb instead of
      	add_block.
      	(increase_insn_priority): New.
      	* modulo-sched.c: (issue_rate): Remove static declaration.
      	(sms_sched_info): Change type to haifa_sched_info.
      	(sms_sched_deps_info, sms_common_sched_info): New variables.
      	(setup_sched_infos): New.
      	(sms_schedule): Initialize them.  Call haifa_sched_init/finish.
      	Do not call regstat_free_calls_crossed.
      	(sms_print_insn): Use const_rtx.
      	* params.def (PARAM_MAX_PIPELINE_REGION_BLOCKS,
      	PARAM_MAX_PIPELINE_REGION_INSNS, PARAM_SELSCHED_MAX_LOOKAHEAD,
      	PARAM_SELSCHED_MAX_SCHED_TIMES, PARAM_SELSCHED_INSNS_TO_RENAME,
      	PARAM_SCHED_MEM_TRUE_DEP_COST): New.
      	* sched-deps.c (sched_deps_info): New.  Update all relevant uses of
      	current_sched_info to use it.
      	(enum reg_pending_barrier_mode): Move to sched-int.h.
      	(h_d_i_d): New variable. Initialize to NULL.
      	({true, output, anti, spec, forward}_dependency_cache): Initialize
      	to NULL.
      	(estimate_dep_weak): Remove static declaration.
      	(sched_has_condition_p): New function.  Adjust users of
      	sched_get_condition to use it instead.
      	(conditions_mutex_p): Add arguments indicating which conditions are
      	reversed.  Use them.
      	(sched_get_condition_with_rev): Rename from sched_get_condition.  Add
      	argument to indicate whether returned condition is reversed.  Do not
      	generate new rtx when condition should be reversed; indicate it by
      	setting new argument instead.
      	(add_dependence_list_and_free): Add deps parameter.
      	Update all users.  Do not free dependence list when
      	deps context is readonly.
      	(add_insn_mem_dependence, flush_pending_lists): Adjust for readonly
      	contexts.
      	(remove_from_dependence_list, remove_from_both_dependence_lists): New.
      	(remove_from_deps): New. Use the above functions.	
      	(cur_insn, can_start_lhs_rhs_p): New static variables.
      	(add_or_update_back_dep_1): Initialize present_dep_type.
      	(haifa_start_insn, haifa_finish_insn, haifa_note_reg_set,
      	haifa_note_reg_clobber, haifa_note_reg_use, haifa_note_mem_dep,
      	haifa_note_dep): New functions implementing dependence hooks for
      	the Haifa scheduler.
      	(note_reg_use, note_reg_set, note_reg_clobber, note_mem_dep,
      	note_dep): New functions.
      	(ds_to_dt, extend_deps_reg_info, maybe_extend_reg_info_p): New
      	functions.
      	(init_deps): Initialize last_reg_pending_barrier and deps->readonly.
      	(free_deps): Initialize deps->reg_last.
      	(sched_analyze_reg, sched_analyze_1, sched_analyze_2,
      	sched_analyze_insn): Update to use dependency hooks infrastructure
      	and readonly contexts.
      	(deps_analyze_insn): New function.  Move part of logic from ...
      	(sched_analyze): ... here.  Also move some logic to ...
      	(deps_start_bb): ... here.  New function.
      	(add_forw_dep, delete_forw_dep): Guard use of INSN_DEP_COUNT with
      	sel_sched_p.
      	(sched_deps_init): New function.  Move code from ...
      	(init_dependency_caches): ... here.  Remove.
      	(init_deps_data_vector): New.
      	(sched_deps_finish): New function.  Move code from ...
      	(free_dependency_caches): ... here.  Remove.
      	(init_deps_global, finish_deps_global): Adjust for use with
      	selective scheduling.
      	(get_dep_weak): Move logic to ...
      	(get_dep_weak_1): New function.
      	(ds_merge): Move logic to ...
      	(ds_merge_1): New static function.
      	(ds_full_merge, ds_max_merge, ds_get_speculation_types): New functions.
      	(ds_get_max_dep_weak): New function.
      	* sched-ebb.c (sched_n_insns): Rename to sched_rgn_n_insns.
      	(n_insns): Rename to rgn_n_insns.
      	(debug_ebb_dependencies): New function.
      	(init_ready_list): Use it.
      	(begin_schedule_ready): Use sched_init_only_bb.
      	(ebb_print_insn): Indicate when an insn starts a new cycle.
      	(contributes_to_priority, compute_jump_reg_dependencies,
      	add_remove_insn, fix_recovery_cfg): Add ebb_ prefix to function names.
      	(add_block1): Remove to ebb_add_block.
      	(ebb_sched_deps_info, ebb_common_sched_info): New variables.
      	(schedule_ebb): Initialize them.  Use remove_notes instead of
      	rm_other_notes.  Use haifa_local_init/finish.
      	(schedule_ebbs): Use haifa_sched_init/finish.
      	* sched-int.h: Include vecprim.h, remove rtl.h.
      	(struct ready_list): Delete declaration.
      	(sched_verbose_param, enum sched_pass_id_t,
      	bb_vec_t, insn_vec_t, rtx_vec_t): New.
      	(struct sched_scan_info_def): New structure.
      	(sched_scan_info, sched_scan, sched_init_bbs,
      	sched_init_luids, sched_finish_luids, sched_extend_target,
      	haifa_init_h_i_d, haifa_finish_h_i_d): Declare.
      	(struct common_sched_info_def): New.
      	(common_sched_info, haifa_common_sched_info,
      	sched_emulate_haifa_p): Declare.
      	(sel_sched_p): New.
      	(sched_luids): Declare.
      	(INSN_LUID, LUID_BY_UID, SET_INSN_LUID): Declare.
      	(sched_max_luid, insn_luid): Declare.
      	(note_list, remove_notes, restore_other_notes, bb_note): Declare.
      	(sched_insns_init, sched_insns_finish, xrecalloc, reemit_notes,
      	print_insn, print_pattern, print_value, haifa_classify_insn,
      	sel_find_rgns, sel_mark_hard_insn, dfa_state_size, advance_state,
      	setup_sched_dump, sched_init, sched_finish,
      	sel_insn_is_speculation_check): Export.
      	(struct ready_list): Move from haifa-sched.c.
      	(ready_try, ready, max_issue): Export.
      	(ebb_compute_jump_reg_dependencies, find_fallthru_edge,
      	sched_init_only_bb, sched_split_block, sched_split_block_1,
      	sched_create_empty_bb, sched_create_empty_bb_1,
      	sched_create_recovery_block, sched_create_recovery_edges): Export.
      	(enum reg_pending_barrier_mode): Export.
      	(struct deps): New fields `last_reg_pending_barrier' and `readonly'.
      	(deps_t): New.
      	(struct sched_info): Rename to haifa_sched_info.  Use const_rtx for
      	print_insn field.  Move add_block and fix_recovery_cfg to
      	common_sched_info_def.  Move compute_jump_reg_dependencies, use_cselib  ...
      	(struct sched_deps_info_def): ... this new structure.
      	(sched_deps_info): Declare.
      	(struct spec_info_def): Remove weakness_cutoff, add
      	data_weakness_cutoff and control_weakness_cutoff.
      	(spec_info): Declare.
      	(struct _haifa_deps_insn_data): Split from haifa_insn_data.  Add
      	dep_count field.
      	(struct haifa_insn_data): Rename to struct _haifa_insn_data.
      	(haifa_insn_data_def, haifa_insn_data_t): New typedefs.
      	(current_sched_info): Change type to struct haifa_sched_info.
      	(haifa_deps_insn_data_def, haifa_deps_insn_data_t): New typedefs.
      	(h_d_i_d): New variable.
      	(HDID): New accessor macro.
      	(h_i_d): Change type to VEC (haifa_insn_data_def, heap) *.
      	(HID): New accessor macro.  Rewrite h_i_d accessor macros through HID
      	and HDID.
      	(IS_SPECULATION_CHECK_P): Update for selective scheduler.
      	(enum SCHED_FLAGS): Update for selective scheduler.
      	(enum SPEC_SCHED_FLAGS): New flag SEL_SCHED_SPEC_DONT_CHECK_CONTROL.
      	(init_dependency_caches, free_dependency_caches): Delete declarations.
      	(deps_analyze_insn, remove_from_deps, get_dep_weak_1,
      	estimate_dep_weak, ds_full_merge, ds_max_merge, ds_weak,
      	ds_get_speculation_types, ds_get_max_dep_weak, sched_deps_init,
      	sched_deps_finish, haifa_note_reg_set, haifa_note_reg_use,
      	haifa_note_reg_clobber, maybe_extend_reg_info_p, deps_start_bb,
      	ds_to_dt): Export.
      	(rm_other_notes): Delete declaration.
      	(schedule_block): Remove one argument.
      	(cycle_issued_insns, issue_rate, dfa_lookahead, ready_sort,
      	ready_element, ready_lastpos, sched_extend_ready_list,
      	sched_finish_ready_list, sched_change_pattern, sched_speculate_insn,
      	concat_note_lists): Export.
      	(struct region): Move from sched-rgn.h.
      	(nr_regions, rgn_table, rgn_bb_table, block_to_bb, containing_rgn,
      	RGN_NR_BLOCKS, RGN_BLOCKS, RGN_DONT_CALC_DEPS, RGN_HAS_REAL_EBB,
      	BLOCK_TO_BB, CONTAINING_RGN): Export.
      	(ebb_head, BB_TO_BLOCK, EBB_FIRST_BB, EBB_LAST_BB, INSN_BB): Likewise.
      	(current_nr_blocks, current_blocks, target_bb): Likewise.
      	(dep_cost_1, sched_is_disabled_for_current_region_p, sched_rgn_init,
      	sched_rgn_finish, rgn_setup_region, sched_rgn_compute_dependencies,
      	sched_rgn_local_init, extend_regions,
      	rgn_make_new_region_out_of_new_block, compute_priorities,
      	debug_rgn_dependencies, free_rgn_deps, contributes_to_priority,
      	extend_rgns, deps_join rgn_setup_common_sched_info,
      	rgn_setup_sched_infos, debug_regions, debug_region, dump_region_dot,
      	dump_region_dot_file, haifa_sched_init, haifa_sched_finish): Export.
      	(get_rgn_sched_max_insns_priority, sel_add_to_insn_priority, 
      	increase_insn_priority): Likewise.
      	* sched-rgn.c: Include sel-sched.h.
      	(ref_counts): New static variable.  Use it ...
      	(INSN_REF_COUNT): ... here.  Rewrite and move closer to uses.
      	(FED_BY_SPEC_LOAD, IS_LOAD_INSN): Rewrite to use HID accessor macro.
      	(sched_is_disabled_for_current_region_p): Delete static declaration.
      	(struct region): Move to sched-int.h.
      	(nr_regions, rgn_table, rgn_bb_table, block_to_bb, containing_rgn,
      	ebb_head): Define and initialize.
      	(RGN_NR_BLOCKS, RGN_BLOCKS, RGN_DONT_CALC_DEPS, RGN_HAS_REAL_EBB,
      	BLOCK_TO_BB, CONTAINING_RGN, debug_regions, extend_regions,
      	BB_TO_BLOCK, EBB_FIRST_BB, EBB_LAST_BB): Move to
      	sched-int.h.
      	(find_single_block_region): Add new argument to indicate that EBB
      	regions should be constructed.
      	(debug_live): Delete declaration.
      	(current_nr_blocks, current_blocks, target_bb): Remove static qualifiers.
      	(compute_dom_prob_ps, check_live, update_live, set_spec_fed): Delete
      	declaration.
      	(init_regions): Delete declaration.
      	(debug_region, bb_in_region_p, dump_region_dot_file, dump_region_dot,
      	rgn_estimate_number_of_insns): New.
      	(too_large): Use estimate_number_of_insns.
      	(haifa_find_rgns): New. Move the code from ...
      	(find_rgns): ... here.  Call either sel_find_rgns or haifa_find_rgns.
      	(free_trg_info): New.
      	(compute_trg_info): Allocate candidate tables here instead of ...
      	(init_ready_list): ... here.
      	(rgn_print_insn): Use const_rtx.
      	(contributes_to_priority, extend_regions): Delete static declaration.
      	(add_remove_insn, fix_recovery_cfg): Add rgn_ to function names.
      	(add_block1): Rename to rgn_add_block.
      	(debug_rgn_dependencies): Delete static qualifier.
      	(new_ready): Use sched_deps_info.  Simplify.
      	(rgn_common_sched_info, rgn_const_sched_deps_info,
      	rgn_const_sel_sched_deps_info, rgn_sched_deps_info, rgn_sched_info): New.
      	(region_sched_info): Rename to rgn_const_sched_info.
      	(deps_join): New, extracted from ...
      	(propagate_deps): ... here.
      	(compute_block_dependences, debug_dependencies): Update for selective
      	scheduling.
      	(free_rgn_deps, compute_priorities): New functions.
      	(sched_rgn_init, sched_rgn_finish, rgn_setup_region,
      	sched_rgn_compute_dependencies): New functions.
      	(schedule_region): Use them.
      	(sched_rgn_local_init, sched_rgn_local_free, sched_rgn_local_finish,
      	rgn_setup_common_sched_info, rgn_setup_sched_infos):
      	New functions.
      	(schedule_insns): Call new functions that were split out.
      	(rgn_make_new_region_out_of_new_block): New.
      	(get_rgn_sched_max_insns_priority): New.
      	(rest_of_handle_sched, rest_of_handle_sched2): Call selective
      	scheduling when appropriate.
      	* sched-vis.c: Include insn-attr.h.
      	(print_value, print_pattern): Make global.
      	(print_rtl_slim, debug_bb_slim, debug_bb_n_slim): New functions.
      	* target-def.h (TARGET_SCHED_ADJUST_COST_2,
      	TARGET_SCHED_ALLOC_SCHED_CONTEXT, TARGET_SCHED_INIT_SCHED_CONTEXT,
      	TARGET_SCHED_SET_SCHED_CONTEXT, TARGET_SCHED_CLEAR_SCHED_CONTEXT,
      	TARGET_SCHED_FREE_SCHED_CONTEXT, TARGET_SCHED_GET_INSN_CHECKED_DS,
      	TARGET_SCHED_GET_INSN_SPEC_DS, TARGET_SCHED_SKIP_RTX_P): New target
      	hooks.  Initialize them to 0.
      	(TARGET_SCHED_GEN_CHECK): Rename to TARGET_SCHED_GEN_SPEC_CHECK.
      	* target.h (struct gcc_target): Add them.  Rename gen_check field to
      	gen_spec_check.
      	* flags.h (sel_sched_switch_set): Declare.
      	* opts.c (sel_sched_switch_set): New variable.
      	(decode_options): Unset flag_sel_sched_pipelining_outer_loops if
      	pipelining is disabled from command line.
      	(common_handle_option): Record whether selective scheduling is
      	requested from command line.
      	* doc/invoke.texi: Document new flags and parameters.
      	* doc/tm.texi: Document new target hooks.
      	* config/ia64/ia64.c (TARGET_SCHED_GEN_SPEC_CHECK): Define to ia64_gen_check.
      	(dfa_state_size): Do not declare locally.
      	* config/ia64/ia64.opt (msched-ar-data-spec): Default to 0.
      	* config/rs6000/rs6000.c (rs6000_init_sched_context,
      	rs6000_alloc_sched_context, rs6000_set_sched_context,
      	rs6000_free_sched_context): New functions.
      	(struct _rs6000_sched_context): New.
      	(rs6000_sched_reorder2): Do not modify INSN_PRIORITY for selective
      	scheduling.
      	(rs6000_sched_finish): Do not run for selective scheduling. 
      
      Co-Authored-By: Alexander Monakov <amonakov@ispras.ru>
      Co-Authored-By: Dmitry Melnik <dm@ispras.ru>
      Co-Authored-By: Dmitry Zhurikhin <zhur@ispras.ru>
      Co-Authored-By: Maxim Kuvyrkov <maxim@codesourcery.com>
      
      From-SVN: r139854
      Andrey Belevantsev committed
  8. 30 Aug, 2008 2 commits
    • Change attribute((option(...))) to attribute((target(...))); Do not allocate… · 5779e713
      Change attribute((option(...))) to attribute((target(...))); Do not allocate tree nodes on x86 for builtins until we generate code for the ISA; Delete hot/cold functions changing optimization; Make C++ support target specific functions; Add #pragma GCC {push_options,pop_options,reset_options} instead of #pragma GCC {target,optimize} {push,reset,pop}
      
      From-SVN: r139812
      Michael Meissner committed
    • optabs.c (expand_abs_nojump): Update BRANCH_COST call. · 3a4fd356
      	* optabs.c (expand_abs_nojump): Update BRANCH_COST call.
      	* fold-cost.c (LOGICAL_OP_NON_SHORT_CIRCUIT, fold_truthop): Likewise.
      	* dojump.c (do_jump): Likewise.
      	* ifcvt.c (MAX_CONDITIONAL_EXECUTE): Likewise.
      	(note-if_info): Add BRANCH_COST.
      	(noce_try_store_flag_constants, noce_try_addcc, noce_try_store_flag_mask,
      	noce_try_cmove_arith, noce_try_cmove_arith, noce_try_cmove_arith,
      	noce_find_if_block, find_if_case_1, find_if_case_2): Use compuated
      	branch cost.
      	* expr.h (BRANCH_COST): Update default.
      	* predict.c (predictable_edge_p): New function.
      	* expmed.c (expand_smod_pow2, expand_sdiv_pow2, emit_store_flag):
      	Update BRANCH_COST call.
      	* basic-block.h (predictable_edge_p): Declare.
      	* config/alpha/alpha.h (BRANCH_COST): Update.
      	* config/frv/frv.h (BRANCH_COST): Update.
      	* config/s390/s390.h (BRANCH_COST): Update.
      	* config/spu/spu.h (BRANCH_COST): Update.
      	* config/sparc/sparc.h (BRANCH_COST): Update.
      	* config/m32r/m32r.h (BRANCH_COST): Update.
      	* config/i386/i386.h (BRANCH_COST): Update.
      	* config/i386/i386.c (ix86_expand_int_movcc): Update use of BRANCH_COST.
      	* config/sh/sh.h (BRANCH_COST): Update.
      	* config/pdp11/pdp11.h (BRANCH_COST): Update.
      	* config/avr/avr.h (BRANCH_COST): Update.
      	* config/crx/crx.h (BRANCH_COST): Update.
      	* config/xtensa/xtensa.h (BRANCH_COST): Update.
      	* config/stormy16/stormy16.h (BRANCH_COST): Update.
      	* config/m68hc11/m68hc11.h (BRANCH_COST): Update.
      	* config/iq2000/iq2000.h (BRANCH_COST): Update.
      	* config/ia64/ia64.h (BRANCH_COST): Update.
      	* config/rs6000/rs6000.h (BRANCH_COST): Update.
      	* config/arc/arc.h (BRANCH_COST): Update.
      	* config/score/score.h (BRANCH_COST): Update.
      	* config/arm/arm.h (BRANCH_COST): Update.
      	* config/pa/pa.h (BRANCH_COST): Update.
      	* config/mips/mips.h (BRANCH_COST): Update.
      	* config/vax/vax.h (BRANCH_COST): Update.
      	* config/h8300/h8300.h (BRANCH_COST): Update.
      	* params.def (PARAM_PREDICTABLE_BRANCH_OUTCOME): New.
      	* doc/invoke.texi (predictable-branch-cost-outcome): Document.
      	* doc/tm.texi (BRANCH_COST): Update.
      
      From-SVN: r139804
      Jan Hubicka committed
  9. 29 Aug, 2008 2 commits
    • common.opt (ftree-store-ccp): Mark as preserved for backward compatibility. · dce2b2f6
      2008-08-29  Richard Guenther  <rguenther@suse.de>
      
      	* common.opt (ftree-store-ccp): Mark as preserved for
      	backward compatibility.
      	* doc/invoke.texi (-ftree-store-ccp): Remove documentation.
      	* tree-pass.h (pass_store_ccp): Remove.
      	* tree-ssa-propagate.h (struct prop_value_d): Remove mem_ref field.
      	(first_vdef): Remove declaration.
      	(get_value_loaded_by): Likewise.
      	* tree-ssa-ccp.c (do_store_ccp): Remove.
      	(get_default_value): Simplify as do_store_ccp is always false
      	now.  Do not initialize mem_ref.
      	(set_value_varying): Likewise.
      	(canonicalize_float_value): Likewise.
      	(set_lattice_value): Likewise.
      	(likely_value): Likewise.
      	(surely_varying_stmt_p): Likewise.
      	(ccp_initialize): Likewise.
      	(ccp_lattice_meet): Likewise.
      	(ccp_visit_phi_node): Likewise.
      	(ccp_fold): Likewise.
      	(evaluate_stmt): Likewise.
      	(visit_assignment): Likewise.
      	(ccp_visit_stmt): Likewise.
      	(execute_ssa_ccp): Fold into ...
      	(do_ssa_ccp): ... this.
      	(do_ssa_store_ccp): Remove.
      	(gate_store_ccp): Likewise.
      	(pass_store_ccp): Likewise.
      	* tree-ssa-copy.c (copy_prop_visit_phi_node): Do not
      	initialize mem_ref.
      	* tree-ssa-propagate.c (first_vdef): Remove.
      	(get_value_loaded_by): Likewise.
      	(replace_vuses_in): Likewise.
      	(substitute_and_fold): Do not call replace_vuses_in.
      	* opts.c (decode_options): Do not set flag_tree_store_ccp.
      
      From-SVN: r139764
      Richard Guenther committed
    • invoke.texi (-fipa-cp): Enabled by default at -O2/-Os/-O3 · fcbe056b
      	* doc/invoke.texi (-fipa-cp): Enabled by default at -O2/-Os/-O3
      	(-fipa-cp-clone): Enabled by default at -O3.
      	* opts.c (decode_options): Enable ipa-cp at -O2, ipa-cp-clone at -O3;
      	make ipa-cp-clone to imply ipa-cp; disable cloning at -Os.
      
      From-SVN: r139762
      Jan Hubicka committed
  10. 28 Aug, 2008 1 commit
  11. 26 Aug, 2008 1 commit
    • [multiple changes] · 058e97ec
      2008-08-26  Vladimir Makarov  <vmakarov@redhat.com>
      
      	* ira-build.c, ira-color.c, ira-costs.c, ira.h, ira-lives.c,
      	ira.c, ira-conflicts.c, ira-emit.c, ira-int.h: New files.
      
      	* doc/passes.texi: Describe IRA.
      
      	* doc/tm.texi (IRA_COVER_CLASSES,
      	IRA_HARD_REGNO_ADD_COST_MULTIPLIER): Describe the new macros.
      
      	* doc/invoke.texi (ira-max-loops-num): Describe the new parameter.
      	(-fira, -fira-algorithm, -fira-coalesce, -fno-ira-move-spills,
      	-fira-propagate-cost, -fno-ira-share-save-slots,
      	-fno-ira-share-spill-slots, -fira-verbose): Describe new options.
      
      	* flags.h (ira_algorithm): New enumeration.
      	(flag_ira_algorithm, flag_ira_verbose): New external variable
      	declarations.
      
      	* postreload.c (gate_handle_postreload): Don't do post reload
      	optimizations unless the reload is completed.
      
      	* reload.c (push_reload, find_dummy_reload): Use DF_LR_OUT for
      	IRA.
      
      	* tree-pass.h (pass_ira): New external variable declaration.
      
      	* reload.h: Add 2008 to the Copyright.
          
      	* cfgloopanal.c: Include params.h.
      	(estimate_reg_pressure_cost): Decrease cost for IRA optimization
      	mode.
          
      	* params.h (IRA_MAX_LOOPS_NUM): New macro.
      
      	* toplev.c (ira.h): New include.
      	(flag_ira_algorithm, flag_ira_verbose): New external variables.
      	(backend_init_target): Call ira_init.
      	(backend_init): Call ira_init_once.
      	(finalize): Call finish_ira_once.
      
      	* toplev.h (flag_ira, flag_ira_coalesce, flag_ira_move_spills,
      	flag_ira_share_save_slots, flag_ira_share_spill_slots): New
      	external variables.
      
      	* regs.h (contains_reg_of_mode, move_cost, may_move_in_cost,
      	may_move_out_cost): New external variable declarations.
      	(move_table): New typedef.
          
      	* caller-save.c: Include headers output.h and ira.h.
      	(no_caller_save_reg_set): New global variable.
      	(save_slots_num, save_slots): New variables.
      	(reg_save_code, reg_restore_code, add_stored_regs): Add
      	prototypes.
      	(init_caller_save): Set up no_caller_save_reg_set.
      	(init_save_areas): Reset save_slots_num.
      	(saved_hard_reg): New structure.
      	(hard_reg_map, saved_regs_num, all_saved_regs): New variables.
      	(initiate_saved_hard_regs, new_saved_hard_reg,
      	finish_saved_hard_regs, saved_hard_reg_compare_func): New
      	functions.
      	(setup_save_areas): Add code for sharing stack slots.
      	(all_blocks): New variable.
      	(save_call_clobbered_regs): Process pseudo-register too.
      	(mark_set_regs): Process pseudo-register too.
      	(insert_one_insn): Put the insn after bb note in a empty basic
      	block.  Add insn check.
          
      	* global.c (eliminable_regset): Make it external.
      	(mark_elimination): Use DF_LR_IN for IRA.
      	(pseudo_for_reload_consideration_p): New.
      	(build_insn_chain): Make it external.  Don't ignore spilled
      	pseudos for IRA.  Use pseudo_for_reload_consideration_p.
      	(gate_handle_global_alloc): New function.
      	(pass_global_alloc): Add the gate function.
      
      	* opts.c (decode_options): Set up flag_ira.  Print the warning for
      	-fira.
      	(common_handle_option): Process -fira-algorithm and -fira-verbose.
      
      	* timevar.def (TV_IRA, TV_RELOAD): New passes.
      
      	* regmove.c (regmove_optimize): Don't do replacement of output for
      	IRA.
      
      	* hard-reg-set.h (no_caller_save_reg_set, reg_class_subclasses):
      	New external variable declarations.
      
      	* local-alloc.c (update_equiv_regs): Make it external.  Return
      	true if jump label rebuilding should be done.  Rescan new_insn for
      	notes.
      	(gate_handle_local_alloc): New function.
      	(pass_local_alloc): Add the gate function.
      
      	* alias.c (value_addr_p, stack_addr_p): New functions.
      	(nonoverlapping_memrefs_p): Use them for IRA.
      
      	* common.opt (fira, fira-algorithm, fira-coalesce,
      	fira-move-spills, fira-share-save-slots, fira-share-spill-slots,
      	fira-verbose): New options.
      
      	* regclass.c (reg_class_subclasses, contains_reg_of_mode,
      	move_cost, may_move_in_cost, may_move_out_cost): Make the
      	variables external.
      	(move_table): Remove typedef.
      	(init_move_cost): Make it external.
      	(allocate_reg_info, resize_reg_info, setup_reg_classes): New
      	functions.
      
      	* rtl.h (init_move_cost, allocate_reg_info, resize_reg_info,
      	setup_reg_classes): New function prototypes.
      	(eliminable_regset): New external variable declaration.
      	(build_insn_chain, update_equiv_regs): New function prototypes.
          
      	* Makefile.in (IRA_INT_H): New definition.
      	(OBJS-common): Add ira.o, ira-build.o, ira-costs.o,
      	ira-conflicts.o, ira-color.o, ira-emit.o, and ira-lives.o.
      	(reload1.o, toplev.o): Add dependence on ira.h.
      	(cfgloopanal.o): Add PARAMS_H.
      	(caller-save.o): Add dependence on output.h and ira.h.
      	(ira.o, ira-build.o, ira-costs.o, ira-conflicts.o, ira-color.o,
      	ira-emit.o, ira-lives.o): New entries.
      
      	* passes.c (pass_ira): New pass.
      
      	* params.def (PARAM_IRA_MAX_LOOPS_NUM): New parameter.
      
      	* reload1.c (ira.h): Include the header.
      	(changed_allocation_pseudos): New bitmap.
      	(init_reload): Initiate the bitmap.
      	(compute_use_by_pseudos): Permits spilled registers in FROM.
      	(temp_pseudo_reg_arr): New variable.
      	(reload): Allocate and free temp_pseudo_reg_arr.  Sort pseudos for
      	IRA.  Call alter_reg with the additional parameter.  Don't clear
      	spilled_pseudos for IRA.  Restore original insn chain for IRA.
      	Clear changed_allocation_pseudos at the end of reload.
      	(calculate_needs_all_insns): Call IRA's mark_memory_move_deletion.
      	(hard_regno_to_pseudo_regno): New variable.
      	(count_pseudo): Check spilled pseudos.  Set up
      	hard_regno_to_pseudo_regno.
      	(count_spilled_pseudo): Check spilled pseudos. Update
      	hard_regno_to_pseudo_regno.
      	(find_reg): Use better_spill_reload_regno_p.  Check
      	hard_regno_to_pseudo_regno.
      	(alter_reg): Set up spilled_pseudos.  Add a new parameter.  Add
      	code for IRA.
      	(eliminate_regs_1): Use additional parameter for alter_reg.
      	(finish_spills): Set up pseudo_previous_regs only for spilled
      	pseudos.  Call reassign_pseudos once for all spilled pseudos, pass
      	more arguments.  Don't clear live_throughout and dead_or_set for
      	spilled pseudos.  Use additional parameter for alter_reg.  Call
      	mark_allocation_change.  Set up changed_allocation_pseudos.
      	Remove sanity check.
      	(emit_input_reload_insns, delete_output_reload): Use additional
      	parameter for alter_reg.  Call mark_allocation_change.
      	(substitute, gen_reload_chain_without_interm_reg_p): New
      	functions.
      	(reloads_conflict): Use gen_reload_chain_without_interm_reg_p.
          
      	* testsuite/gcc.dg/20080410-1.c: New file.
      	
      	* config/s390/s390.h (IRA_COVER_CLASSES,
      	IRA_HARD_REGNO_ADD_COST_MULTIPLIER): Define.
      
      	* config/sparc/sparc.h (IRA_COVER_CLASSES): New macro.
      
      	* config/i386/i386.h (IRA_COVER_CLASSES): Ditto.
      
      	* config/ia64/ia64.h (IRA_COVER_CLASSES): Ditto.
      
      	* config/rs6000/rs6000.h (IRA_COVER_CLASSES): Ditto.
      
      	* config/arm/arm.h (IRA_COVER_CLASSES): Ditto.
          
      	* config/alpha/alpha.h (IRA_COVER_CLASSES): Ditto.
          
      	2008-08-24  Jeff Law  <law@redhat.com>
      	* ira.c (setup_reg_class_intersect_union): Prefer smallest class
      	when ignoring unavailable registers.
      
      	2008-08-24  Jeff Law  <law@redhat.com>
      	* ira-color.c (coalesced_pseudo_reg_slot_compare): Check
      	FRAME_GROWS_DOWNWARD and STACK_GROWS_DOWNWARD.
      	* ira.c (setup_eliminable_regset): Check stack_realign_needed.
      	* config/mn10300/mn10300.h (IRA_COVER_CLASSES): New macro.
      
      	2008-06-03 Steve Chamberlain <steve.chamberlain@gmail.com>
      	* ira-build.c (allocno_range_compare_func): Stabilize sort.
      
      	2008-05-29 Andy Hutchinson <hutchinsonandy@aim.com>
      	* config/avr/avr.h (IRA_COVER_CLASSES): New macro.
      	* reload1.c (find_reg): Process registers in register allocation order.
      
      	2008-05-10 Richard Sandiford <rsandifo@nildram.co.uk>
      	* toplev.c (backend_init_target): Move ira_init call from
      	here...
      	(lang_dependent_init_target): ...to here.
      
      	2008-05-10 Richard Sandiford <rsandifo@nildram.co.uk>
      	* ira.c (setup_class_subset_and_memory_move_costs): Don't
      	calculate memory move costs for NO_REGS.
      
      	2008-05-05 Kaz Kojima <kkojima@gcc.gnu.org>
      	* ira-color.c (ira_fast_allocation): Use no_stack_reg_p only if
      	STACK_REGS is defined.
      
      	2008-04-08 Andrew Pinski <andrew_pinski@playstation.sony.com>
      	* config/spu/spu.h (IRA_COVER_CLASSES): New macro.
      
      	2008-04-04 Bernd Schmidt <bernd.schmidt@analog.com>
      	* config/bfin/bfin.h (IRA_COVER_CLASSES): New macro.
      
      	2008-04-04 Kaz Kojima <kkojima@gcc.gnu.org>
      	* config/sh/sh.h (IRA_COVER_CLASSES): Define.
      	* config/sh/sh.md (movsicc_true+3): Check if emit returns a
      	barrier.
      
      From-SVN: r139590
      Vladimir Makarov committed
  12. 25 Aug, 2008 1 commit
    • config.gcc (mips64*-*-linux*): Handle mips64octeon*-*-linux*. · d97e6aca
      	* config.gcc (mips64*-*-linux*): Handle mips64octeon*-*-linux*.
      	* config/mips/mips.h (enum processor_type): Add PROCESSOR_OCTEON.
      	(TARGET_OCTEON): New macro.
      	(TARGET_CPU_CPP_BUILTINS): Define __OCTEON__ for Octeon.
      	(MIPS_ISA_LEVEL_SPEC, MIPS_ARCH_FLOAT_SPEC): Handle -march=octeon.
      	(ISA_HAS_POP): New macro.
      	* config/mips/driver-native.c (host_detect_local_cpu): Handle
      	Octeon.
      	* config/mips/mips.c (mips_cpu_info_table, mips_rtx_cost_data):
      	Handle Octeon.
      	* config/mips/mips.md (cpu): Add octeon.
      	(type): Add pop attribute value.
      	(popcount<mode>2): New pattern.
      	* doc/invoke.texi (-march=@var{arch}): Add octeon.
      testsuite/
      	* gcc.target/mips/octeon-pop-1.c: New test.
      
      From-SVN: r139554
      Adam Nemet committed
  13. 24 Aug, 2008 1 commit
    • invoke.texi (-fipa-cp-clone): New option. · 5e45130d
      	* doc/invoke.texi (-fipa-cp-clone): New option.
      	(-fipa-cp): Update docs.
      	(--param ipcp-unit-growth):New.
      	* ipa-cp.c: Include fibheap.h, params.h
      	(ipcp_initialize_node_lattices): When not cloning, all externally
      	visible functions are bottom.
      	(ipcp_need_redirect_p): Accept clones.
      	(ipcp_insert_stage): Use cost driven heuristics.
      	(max_count, dead_nodes): New static vars.
      	(ipcp_need_original_clone_p, ipcp_estimate_cloning_cost,
      	ipcp_const_param_count): New functions.
      	* common.opt (ipa-cp-clone): New command line option.
      	* params.def (ipcp-unit-growth): New.
      
      	* gcc.dg/ipa/ipacost-1.c: New testcase.
      	* gcc.dg/ipa/ipacost-2.c: New testcase.
      	* gcc.dg/ipa/ipa-7.c: Update template.
      
      From-SVN: r139543
      Jan Hubicka committed
  14. 23 Aug, 2008 1 commit
  15. 18 Aug, 2008 1 commit
    • cgraph.c (cgraph_edge): Handle inconsistent counts when setting count_scale. · 52c76998
      2008-08-18  Paul Yuan  <yingbo.com@gmail.com>
      	    Vinodha Ramasamy  <vinodha@google.com>
      
      	* cgraph.c (cgraph_edge): Handle inconsistent counts when setting
      	count_scale.
      	* value-prof.c (check_counter): Fix the counter if
      	flag_profile_correction is true.
      	(tree_divmod_fixed_value_transform, tree_mod_pow2_value_transform,
      	tree_mod_subtract_transform):
      	Follow check_counter parameter change.
      	* common.opt (fprofile-correction): New option.
      	* mcf.c: New file.
      	* profile.c (edge_info, EDGE_INFO): Moved to new file profile.h.
      	(sum_edge_counts, is_edge_inconsistent, correct_negative_edge_counts,
      	is_inconsistent, set_bb_counts, read_profile_edge_counts): New
      	functions.
      	(compute_branch_probabilities): Refactored. Invokes mcf_smooth_cfg if
      	flag_profile_correction is set.
      
      
      Co-Authored-By: Vinodha Ramasamy <vinodha@google.com>
      
      From-SVN: r139208
      Paul Yuan committed
  16. 17 Aug, 2008 2 commits
    • extend.texi (Function Attributes): Fix typo in description if hot function attribute. · 0859c412
      * doc/extend.texi (Function Attributes): Fix typo in description
        if hot function attribute.
      
      From-SVN: r139179
      Nick Clifton committed
    • install.texi (--with-mips-plt): Document. · e21d5757
      gcc/
      2008-08-17  Daniel Jacobowitz  <dan@codesourcery.com>
      	    Richard Sandiford  <rdsandiford@googlemail.com>
      
      	* doc/install.texi (--with-mips-plt): Document.
      	* doc/invoke.texi (-mplt, -mno-plt): Document.
      	* config.gcc (mips*-*-*): Add mips-plt to supported_defaults
      	and handle ${with_mips_plt}.
      	* config/mips/mips.opt (mplt): New option.
      	* config/mips/mips.h (TARGET_ABICALLS_PIC0): New macro.
      	(TARGET_ABICALLS_PIC2): Likewise.
      	(TARGET_GPWORD): Return false for TARGET_ABSOLUTE_ABICALLS.
      	(OPTION_DEFAULT_SPECS): Add a mips-plt entry.
      	(ASM_SPEC): Use !mabi=* instead of !mabi*.
      	(MIPS_CALL): Use TARGET_ABICALLS_PIC2 instead of TARGET_ABICALLS
      	to decide whether to output ".option picX" directives.
      	* config/mips/linux.h (SUBTARGET_ASM_SPEC): Remove -mabi=64 handling.
      	Pass -call_nonpic rather than -KPIC for -mplt.
      	(BASE_DRIVER_SELF_SPECS): Remove -mplt if -mno-shared is not present
      	on the command line.  Also remove it when -mabi=64 is used without
      	-msym32.
      	* config/mips/linux64.h (SUBTARGET_ASM_SPEC): Delete.
      	* config/mips/mips.c (mips_use_pic_fn_addr_reg_p): Handle
      	TARGET_ABICALLS_PIC0.
      	(mips_classify_symbol): Use TARGET_ABICALLS_PIC2 instead of
      	TARGET_ABICALLS.
      	(mips16_build_function_stub): Only output ".option pic" directives
      	and PIC stubs if TARGET_ABICALLS_PIC2.  Call through $25 instead of $1.
      	(mips16_build_call_stub): Fix comment and remove redundant
      	".set at"/"set .noat" directives.
      	(mips_function_rodata_section): Use the default behaviour for
      	TARGET_ABSOLUTE_ABICALLS.
      	(mips_file_start): Emit ".option pic0" for TARGET_ABICALLS_PIC0.
      	(mips_global_pointer): Handle TARGET_ABICALLS_PIC0.
      	(mips_restore_gp): Do nothing if the current function doesn't use
      	a global pointer.
      	(mips_expand_prologue): Only save $gp if the current function uses it.
      	Use a normal move for TARGET_ABICALLS_PIC0.
      	(mips_override_options): Only set flag_pic if TARGET_ABICALLS_PIC2.
      
      Co-Authored-By: Richard Sandiford <rdsandiford@googlemail.com>
      
      From-SVN: r139170
      Daniel Jacobowitz committed
  17. 16 Aug, 2008 1 commit
    • re PR middle-end/20548 (ACATS c52103x c52104x c52104y segfault) · b38f3813
      	PR ada/20548
      	* common.opt (-fstack-check): Do not declare the variable here.
      	(-fstack-check=): New option variant.
      	* doc/invoke.texi (Code Gen Options): Document it.
      	* expr.h (STACK_OLD_CHECK_PROTECT): New macro.
      	(STACK_CHECK_PROTECT): Bump to 3 pages if DWARF-2 EH is used.
      	(STACK_CHECK_STATIC_BUILTIN): New macro.
      	* doc/tm.texi (Stack Checking): Document STACK_CHECK_STATIC_BUILTIN.
      	* opts.c: Include expr.h.
      	(common_handle_option) <OPT_fold_stack_check_>: New case.
      	<OPT_fstack_check>: Likewise.
      	* calls.c (initialize_argument_information): Use TYPE_SIZE_UNIT
      	consistently in the test for variable-sized types.  Adjust for
      	new behaviour of flag_stack_check.
      	* explow.c: Include except.h.
      	(allocate_dynamic_stack_space): Do not take into account
      	STACK_CHECK_MAX_FRAME_SIZE for static builtin stack checking.
      	* function.c (gimplify_parameters): Use DECL_SIZE_UNIT in the test
      	for variable-sized parameters.  Treat all parameters whose size is
      	greater than STACK_CHECK_MAX_VAR_SIZE as variable-sized if generic
      	stack checking is enabled.
      	* gimplify.c (gimplify_decl_expr): Treat non-static objects whose
      	size is greater than STACK_CHECK_MAX_VAR_SIZE as variable-sized
      	if generic stack checking is enabled.
      	(expand_function_end): Adjust for new behaviour of flag_stack_check.
      	* reload1.c (reload): Likewise.
      	* stmt.c (expand_decl): Assert that all automatic variables have
      	fixed size at this point and remove dead code.
      	* flags.h (stack_check_type): New enumeration type.
      	(flag_stack_check): Declare.
      	* toplev.c (flag_stack_check): New global variable.
      	* Makefile.in (opts.o): Add dependency on EXPR_H.
      	(explow.o): Add dependency on except.h.
      ada/
      	* gcc-interface/decl.c (gnat_to_gnu_entity): Use DECL_SIZE_UNIT in the
      	setjmp test consistently.  Adjust for new behaviour of flag_stack_check.
      	* gcc-interface/utils2.c (build_call_alloc_dealloc): Remove redundant
      	test of flag_stack_check.  Adjust for new behaviour of flag_stack_check.
      
      From-SVN: r139159
      Eric Botcazou committed
  18. 13 Aug, 2008 1 commit
    • re PR c/30551 (-pedantic does not include -Wmain, but -pedantic-errors does make… · 4003301d
      re PR c/30551 (-pedantic does not include -Wmain, but -pedantic-errors does make -Wmain cause error messages)
      
      2008-08-13  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
      
      	PR 30551
      	* doc/invoke.texi (Wmain): Update.
      	* c-decl.c (start_decl): warn_main is only 0 or 1.
      	(start_function): Likewise. Fix formatting.
      	(finish_function): Delete redundant warning.
      	* c.opt (Wmain): Add Var(warn_main) and Init(-1).
      	* c-opts (c_common_handle_option): -Wall only has effect if
      	warn_main is uninitialized. OPT_Wmain is automatically
      	handled. -pedantic also enables Wmain.
      	(c_common_post_options): Handle all logic for Wmain here.
      	* c-common.c (warn_main): Delete.
      	(check_main_parameter_types): Make pedwarns conditional on
      	OPT_Wmain.
      	* c-common.h (warn_main): Delete.
      cp/	
      	* decl.c (grokfndecl): Call check_main_parameters_type only if
      	-Wmain.
      testsuite/
      	* gcc.dg/pr30551.c: New.
      	* gcc.dg/pr30551-2.c: New.
      	* gcc.dg/pr30551-3.c: New.
      	* gcc.dg/pr30551-4.c: New.
      	* gcc.dg/pr30551-5.c: New.
      	* gcc.dg/pr30551-6.c: New.
      	* gcc.dg/tree-ssa/reassoc-3.c: Don't compile with -pedantic-errors.
      	* g++.dg/warn/pr30551.C: New.
      	* g++.dg/warn/pr30551-2.C: New.
      
      From-SVN: r139063
      Manuel López-Ibáñez committed
  19. 12 Aug, 2008 5 commits
    • * doc/invoke.texi: Revert unintended checkin. · e1765251
      From-SVN: r139038
      Janis Johnson committed
    • re PR testsuite/36087 (test failures between revs. 134696 and 134717) · becdc486
      	PR testsuite/36087
      	* gcc.dg/var-expand3.c: Fix name of dump file.
      
      From-SVN: r139037
      Janis Johnson committed
    • defaults.h (TARGET_FLOAT_FORMAT): Remove. · b8972354
      ChangeLog:
      
      	* defaults.h (TARGET_FLOAT_FORMAT): Remove.
      	(UNKNOWN_FLOAT_FORMAT, IEEE_FLOAT_FORMAT, VAX_FLOAT_FORMAT): Remove.
      
      	* config/alpha/alpha.h (TARGET_FLOAT_FORMAT): Remove.
      	* config/iq2000/iq2000.h (TARGET_FLOAT_FORMAT): Remove.
      	* config/pdp11/pdp11.h (TARGET_FLOAT_FORMAT): Remove.
      	* config/score/score.h (TARGET_FLOAT_FORMAT): Remove.
      	* config/vax/vax.h (TARGET_FLOAT_FORMAT): Remove.
      
      	* doc/tm.texi (Storage Layout): Remove documentation for
      	TARGET_FLOAT_FORMAT.
      
      	* simplify-rtx.c (simplify_binary_operation_1): Replace
      	TARGET_FLOAT_FORMAT check by appropriate HONOR_... checks.
      
      java/ChangeLog:
      
      	* typeck.c (convert): Do not check for TARGET_FLOAT_FORMAT.
      
      From-SVN: r139017
      Ulrich Weigand committed
    • real.h (struct real_format): New member has_sign_dependent_rounding. · 4099e2c2
      	* real.h (struct real_format): New member has_sign_dependent_rounding.
      	* real.c (ieee_single_format, mips_single_format, motorola_single_format,
      	spu_single_format, ieee_double_format, mips_double_format,
      	motorola_double_format, ieee_extended_motorola_format,
      	ieee_extended_intel_96_format, ieee_extended_intel_128_format,
      	ieee_extended_intel_96_round_53_format, ibm_extended_format,
      	mips_extended_format, ieee_quad_format, mips_quad_format,
      	vax_f_format, vax_d_format, vax_g_format): Initialize it.
      	* config/pdp11/pdp11.c (pdp11_f_format, pdp11_d_format): Likewise.
      
      	* defaults.h (MODE_HAS_NANS, MODE_HAS_INFINITIES,
      	MODE_HAS_SIGNED_ZEROS, MODE_HAS_SIGN_DEPENDENT_ROUNDING): Remove.
      	* config/spu/spu.h (MODE_HAS_NANS, MODE_HAS_INFINITIES,
      	MODE_HAS_SIGN_DEPENDENT_ROUNDING): Remove.
      	(ROUND_TOWARDS_ZERO): Likewise.
      
      	* real.h (REAL_MODE_FORMAT): Protect MODE against macro expansion.
      	(FLOAT_MODE_FORMAT): New macro.
      	(REAL_MODE_FORMAT_COMPOSITE_P): Remove, replace by ...
      	(MODE_COMPOSITE_P): ... this new macro.
      	(MODE_HAS_NANS, MODE_HAS_INFINITIES, MODE_HAS_SIGNED_ZEROS,
      	MODE_HAS_SIGN_DEPENDENT_ROUNDING): New macros.
      	* machmode.h (GET_MODE_INNER): Cast result to enum machine_mode.
      
      	* flags.h: Include "real.h".
      
      	* fold-const.c (const_binop): Use MODE_COMPOSITE_P instead of
      	REAL_MODE_FORMAT_COMPOSITE_P.
      	* simplify-rtx.c (simplify_const_binary_operation): Likewise.
      
      	* doc/tm.texi (Storage Layout): Remove documentation of
      	MODE_HAS_NANS, MODE_HAS_INFINITIES, MODE_HAS_SIGNED_ZEROS,
      	MODE_HAS_SIGN_DEPENDENT_ROUNDING.  Update documentation of
      	ROUND_TOWARDS_ZERO and LARGEST_EXPONENT_IS_NORMAL to clarify
      	they only apply to libgcc2.a.
      
      From-SVN: r139016
      Ulrich Weigand committed
  20. 10 Aug, 2008 1 commit
  21. 08 Aug, 2008 2 commits
    • re PR middle-end/7651 (Define -Wextra strictly in terms of other warning flags) · c73d5dd9
      2008-08-09  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
      
      	PR 7651
      	* doc/invoke.texi (-Wextra): Move warning from here...
      	(-Wuninitialized): ... to here.
      cp/
      	* class.c (check_bases_and_members): Warn with -Wuninitialized
      	instead of -Wextra.
      testsuite/
      	* g++.dg/warn/Wuninitializable-member.C: New.
      	* g++.dg/warn/Wuninitializable-member-no.C: New.
      
      From-SVN: r138892
      Manuel López-Ibáñez committed
    • invoke.texi: Add cpu_type power7. · d40c9e33
      2008-08-08  Peter Bergner  <bergner@vnet.ibm.com>
      
              * doc/invoke.texi: Add cpu_type power7.
              * config.in (HAVE_AS_VSX): New.
              * config.gcc: Add cpu_type power7.
              * configure.ac (HAVE_AS_VSX): Check for assembler support of the
              VSX instructions.
              * configure: Regenerate.
              * config/rs6000/rs6000.c (rs6000_override_options): Alias power7 to
              power5.
              * config/rs6000/rs6000.h (ASM_CPU_POWER7_SPEC): Define.
              (ASM_CPU_SPEC): Pass %(asm_cpu_power7) for -mcpu=power7.
              (EXTRA_SPECS): Add asm_cpu_power7 spec string.
      
      From-SVN: r138887
      Peter Bergner committed
  22. 07 Aug, 2008 1 commit
    • re PR target/36992 (Very stange code for _mm_move_epi64) · b53b23dc
      gcc/
      
      2008-08-07  H.J. Lu  <hongjiu.lu@intel.com>
      
      	PR target/36992
      	* config/i386/emmintrin.h (_mm_move_epi64): Use
      	__builtin_ia32_movq128.
      
      	* config/i386/i386.c (ix86_builtins): Add IX86_BUILTIN_MOVQ128.
      	(bdesc_args): Add IX86_BUILTIN_MOVQ128.
      
      	* config/i386/sse.md (sse2_movq128): New.
      
      	* doc/extend.texi: Document __builtin_ia32_movq128.
      
      gcc/testsuite/
      
      2008-08-07  H.J. Lu  <hongjiu.lu@intel.com>
      
      	PR target/36992
      	* gcc.target/i386/pr36992-1.c: Scan movq.
      	* gcc.target/i386/pr36992-2.c: Use "-O2 -msse4" instead of
      	"-O0 -msse2".  Scan movq.
      
      From-SVN: r138839
      H.J. Lu committed
  23. 06 Aug, 2008 1 commit
    • config.gcc: Match more processor names for Xtensa. · 6d656178
      2008-08-06  Marc Gauthier  <marc@tensilica.com>
      	* config.gcc: Match more processor names for Xtensa.
      	* configure.ac: Likewise.
      	* doc/install.texi (Specific): Likewise.
      	* configure: Regenerate.
      testsuite/
      	* lib/target-supports.exp (check_profiling_available): Match more
      	processor names for Xtensa.
      	* g++.old-deja/g++.jason/thunk3.C: Likewise.
      	* gcc.dg/intmax_t-1.c: Likewise.
      	* gcc.dg/sibcall-3.c: Likewise.
      	* gcc.dg/sibcall-4.c: Likewise.
      	* gcc.c-torture/compile/20001226-1.c: Likewise.
      
      From-SVN: r138810
      Marc Gauthier committed
  24. 05 Aug, 2008 2 commits
    • Makefile.in (c-cppbuiltin.o): Depend on debug.h. · d4ea4622
              * Makefile.in (c-cppbuiltin.o): Depend on debug.h.
              * c-cppbuiltin.c (c_cpp_builtins): Define __GCC_HAVE_DWARF2_CFI_ASM.
              * doc/cpp.texi (__GCC_HAVE_DWARF2_CFI_ASM): Document it.
              * common.opt (fdwarf2-cfi-asm): New.
              * configure.ac (HAVE_GAS_CFI_DIRECTIVE): New.
              * config.in, configure: Rebuild.
              * dwarf2asm.c (dw2_asm_output_data_raw): New.
              (dw2_asm_output_data_uleb128_raw, dw2_asm_output_data_sleb128_raw): New.
              (dw2_force_const_mem): Externalize.
              * dwarf2asm.h: Update.
              * dwarf2out.c (dwarf2out_cfi_label): If flag_dwarf2_cfi_asm, don't
              generate a real label.
              (output_cfi_directive): New.
              (add_fde_cfi): If flag_dwarf2_cfi_asm, use it.
              (output_call_frame_info): Do nothing if flag_dwarf2_cfi_asm.
              (dwarf2out_begin_prologue): Emit .cfi_startproc, .cfi_personality,
              and .cfi_lsda.
              (dwarf2out_end_epilogue): Emit .cfi_endproc.
              (output_loc_operands_raw, output_loc_sequence_raw): New.
              (output_cfa_loc_raw): New.
      
      From-SVN: r138733
      Richard Henderson committed
    • invoke.texi: Document new ARM -mfpu= and -mcpu= options. · 302c3d8e
      2008-08-05  Paul Brook  <paul@codesourcery.com>
      
      	gcc/
      	* doc/invoke.texi: Document new ARM -mfpu= and -mcpu= options.
      	* config/arm/arm.c (all_fpus): Add vfpv3 and vfpv3-d16.
      	(fp_model_for_fpu): Add entry for FPUTYPE_VFP3D16.
      	(arm_file_start): Add FPUTYPE_VFP3D16.  Rename vfp3 to vfpv3.
      	* config/arm/arm.h (TARGET_VFPD32): Define.
      	(TARGET_VFP3): Use TARGET_VFPD32.
      	(fputype): Add FPUTYPE_VFP3D16.
      	(LAST_VFP_REGNUM): Use TARGET_VFPD32.
      	* config/arm/constraints.md ("w"): Use TARGET_VFPD32.
      	* config/arm/arm-cores.def: Add cortex-r4f.
      	* config/arm/arm-tune.md: Regenerate.
      
      From-SVN: r138718
      Paul Brook committed
  25. 01 Aug, 2008 2 commits
    • tree-pass.h: Added comment about not dumping passes with name starting with star in struct... · 8e352cd3
      2008-08-01  Basile Starynkevitch  <basile@starynkevitch>
      	* gcc/tree-pass.h: Added comment about not dumping passes with name
      	starting with star in struct opt_pass.
      	* gcc/passes.c (register_dump_files_1): Don't do dump for a pass with
      	name starting with star.
      	* gcc/doc/passes.texi (Pass manager): Mention pass names and special
      	meaning of star prefix to avoid dump.
      
      From-SVN: r138450
      Basile Starynkevitch committed
    • config.gcc (mipsisa64*-*-linux*): New configuration. · f2d6ca50
      	* config.gcc (mipsisa64*-*-linux*): New configuration.  Set ISA
      	to MIPS64r2 for mipsisa64r2*.
      	* config/mips/mips.h (GENERATE_MIPS16E): Update comment.
      	(ISA_MIPS64R2): New macro.
      	(TARGET_CPU_CPP_BUILTINS, MULTILIB_ISA_DEFAULT): Handle it.
      	(ISA_HAS_64BIT_REGS, ISA_HAS_MUL3, ISA_HAS_FP_CONDMOVE,
      	ISA_HAS_8CC, ISA_HAS_FP4, ISA_HAS_PAIRED_SINGLE,
      	ISA_HAS_MADD_MSUB, ISA_HAS_NMADD4_NMSUB4, ISA_HAS_CLZ_CLO,
      	ISA_HAS_ROR, ISA_HAS_PREFETCH, ISA_HAS_PREFETCHX, ISA_HAS_SEB_SEH,
      	ISA_HAS_EXT_INS, ISA_HAS_MXHC1, ISA_HAS_HILO_INTERLOCKS,
      	ISA_HAS_SYNCI, MIN_FPRS_PER_FMT): Return true for ISA_MIPS64R2.
      	(MIPS_ISA_LEVEL_SPEC, ASM_SPEC, LINK_SPEC): Handle -mips64r2.
      	(TARGET_LOONGSON_2E, TARGET_LOONGSON_2F, TARGET_LOONGSON_2EF):
      	Move up to keep list alphabetically sorted.
      	(TUNE_20KC, TUNE_24K, TUNE_74K, TUNE_LOONGSON_2EF): Likewise.
      	* config/mips/mips.c (mips_cpu_info_table): Add default MIPS64r2
      	processor.
      	* doc/invoke.texi (MIPS Options): Add -mips64r2.
      	(-march=@var{arch}): Add mips64r2.
      
      testsuite/
      
      	* gcc.target/mips/ext-1.c: New test.
      
      From-SVN: r138448
      Adam Nemet committed
  26. 31 Jul, 2008 1 commit
    • passes.c (init_optimization_passes): Always call pass_early_warn_uninitialized. · 2dc74010
      2008-07-31  Richard Guenther  <rguenther@suse.de>
      
      	* passes.c (init_optimization_passes): Always call
      	pass_early_warn_uninitialized.
      	* opts.c (decode_options): Do not warn about -Wuninitialized
      	at -O0.
      	* doc/invoke.texi (-Wuninitialized): Correct for enabling at -O0.
      	* doc/passes.texi (Warn for uninitialized variables): Adjust.
      
      	* gcc.dg/uninit-1-O0.c: New testcase.
      	* gcc.dg/uninit-2-O0.c: Likewise.
      	* gcc.dg/uninit-3-O0.c: Likewise.
      	* gcc.dg/uninit-4-O0.c: Likewise.
      	* gcc.dg/uninit-5-O0.c: Likewise.
      	* gcc.dg/uninit-6-O0.c: Likewise.
      	* gcc.dg/uninit-8-O0.c: Likewise.
      	* gcc.dg/uninit-9-O0.c: Likewise.
      	* gcc.dg/uninit-A-O0.c: Likewise.
      	* gcc.dg/uninit-B-O0.c: Likewise.
      	* gcc.dg/uninit-C-O0.c: Likewise.
      	* gcc.dg/uninit-D-O0.c: Likewise.
      	* gcc.dg/uninit-E-O0.c: Likewise.
      	* gcc.dg/uninit-F-O0.c: Likewise.
      	* gcc.dg/uninit-G-O0.c: Likewise.
      	* gcc.dg/uninit-H-O0.c: Likewise.
      	* gcc.dg/uninit-I-O0.c: Likewise.
      	* gcc.dg/uninit-10-O0.c: Likewise.
      	* gcc.dg/uninit-11-O0.c: Likewise.
      	* gcc.dg/uninit-12-O0.c: Likewise.
      	* gcc.dg/uninit-13-O0.c: Likewise.
      	* gcc.dg/uninit-14-O0.c: Likewise.
      	* gcc.dg/uninit-15-O0.c: Likewise.
      	* gcc.dg/Wall.c: Avoid uninitialized warning.
      	* gcc.dg/Wno-all.c: Likewise.
      	* gcc.dg/pr3074-1.c: Likewise.
      
      From-SVN: r138376
      Richard Guenther committed
  27. 30 Jul, 2008 1 commit
    • [multiple changes] · 2e3f842f
      2008-07-30  Joey Ye  <joey.ye@intel.com>
      	    H.J. Lu  <hongjiu.lu@intel.com>
      
      	* builtins.c (expand_builtin_setjmp_receiver): Replace
      	virtual_incoming_args_rtx with crtl->args.internal_arg_pointer.
      	(expand_builtin_apply_args_1): Likewise.
      	(expand_builtin_longjmp): Need DRAP for stack alignment.
      	(expand_builtin_apply): Likewise.
      
      	* caller-save.c (setup_save_areas): Call assign_stack_local_1
      	instead of assign_stack_local to allow alignment reduction.
      
      	* calls.c (emit_call_1): Need DRAP for stack alignment if
      	return pops.
      	(expand_call): Replace virtual_incoming_args_rtx with
      	crtl->args.internal_arg_pointer.
      	* stmt.c (expand_nl_goto_receiver): Likewise.
      
      	* cfgexpand.c (get_decl_align_unit): Estimate stack variable
      	alignment and store to stack_alignment_estimated and
      	max_used_stack_slot_alignment.
      	(expand_one_var): Likewise.
      	(expand_stack_alignment): New function.
      	(tree_expand_cfg): Initialize max_used_stack_slot_alignment
      	and stack_alignment_estimated fields in rtl_data.  Call
      	expand_stack_alignment at end.
      
      	* defaults.h (INCOMING_STACK_BOUNDARY): New.
      	(MAX_STACK_ALIGNMENT): Likewise.
      	(MAX_SUPPORTED_STACK_ALIGNMENT): Likewise.
      	(SUPPORTS_STACK_ALIGNMENT): Likewise.
      
      	* emit-rtl.c (gen_reg_rtx): Estimate stack alignment for
      	stack alignment when generating virtual registers.
      
      	* function.c (assign_stack_local): Renamed to ...
      	(assign_stack_local_1): This.  Add a parameter to indicate
      	if it is OK to reduce alignment.
      	(assign_stack_local): Use it.
      	(instantiate_new_reg): Instantiate virtual incoming args rtx
      	to vDRAP if stack realignment and DRAP is needed.
      	(assign_parms): Collect parameter/return type alignment and
      	contribute to stack_alignment_estimated.
      	(locate_and_pad_parm): Likewise.
      	(get_arg_pointer_save_area): Replace virtual_incoming_args_rtx
      	with crtl->args.internal_arg_pointer.
      
      	* function.h (rtl_data): Add new field drap_reg,
      	max_used_stack_slot_alignment, stack_alignment_estimated,
      	stack_realign_needed, need_drap, stack_realign_processed and
      	stack_realign_finalized.
      	(stack_realign_fp): New macro.
      	(stack_realign_drap): Likewise.
      
      	* global.c (compute_regsets): Frame pointer is needed when
      	stack is realigned.  Can eliminate frame pointer when stack is
      	realigned and dynamic realigned argument pointer isn't used.
      
      	* reload1.c (update_eliminables):  Frame pointer is needed
      	when stack is realigned.
      	(init_elim_table): Can eliminate frame pointer when stack is
      	realigned and dynamic realigned argument pointer isn't used.
      
      	* rtl.h (assign_stack_local_1): Declare new funtion.
      
      	* target-def.h (TARGET_UPDATE_STACK_BOUNDARY): New.
      	(TARGET_GET_DRAP_RTX): Likewise.
      	(TARGET_CALLS): Add TARGET_UPDATE_STACK_BOUNDARY and
      	TARGET_GET_DRAP_RTX.
      
      	* target.h (gcc_target): Add update_stack_boundary and
      	get_drap_rtx.
      
      	* tree-vectorizer.c (vect_can_force_dr_alignment_p): Replace
      	STACK_BOUNDARY with MAX_STACK_ALIGNMENT.
      
      2008-07-30  Xuepeng Guo  <xuepeng.guo@intel.com>
      	    H.J. Lu  <hongjiu.lu@intel.com>
      
      	* dwarf2out.c (dw_fde_struct): Add stack_realignment, drap_reg,
      	vdrap_reg, stack_realign and drap_reg_saved.
      	(add_cfi): Don't allow redefining CFA when DRAP is used.
      	(reg_save): Handle stack alignment.
      	(dwarf2out_frame_debug_expr): Add rules 16-20 to handle stack
      	alignment.  Don't generate DWARF information for (set fp sp)
      	when DRAP is used.
      	(dwarf2out_begin_prologue): Initialize drap_reg and vdrap_reg
      	to INVALID_REGNUM.
      	(int_loc_descriptor): Move prototype forward.  Also define if
      	DWARF2_UNWIND_INFO is true.
      	(output_cfa_loc): Handle DW_CFA_expression.
      	(build_cfa_aligned_loc): New.
      	(based_loc_descr): Update assert for stack realign.  For local
      	variables, use sp+offset when stack is aligned without drap and
      	fp+offset when stack is aligned with drap.  For arguments, use
      	cfa+offset when drap is used to align stack.
      
      2008-07-30  Joey Ye  <joey.ye@intel.com>
      	    H.J. Lu  <hongjiu.lu@intel.com>
      
      	* config/i386/i386.c (ix86_force_align_arg_pointer_string):
      	Break long line.
      	(ix86_gen_andsp): New.
      	(ix86_user_incoming_stack_boundary): Likewise.
      	(ix86_default_incoming_stack_boundary): Likewise.
      	(ix86_incoming_stack_boundary): Likewise.
      	(ix86_can_eliminate): Likewise.
      	(find_drap_reg): Likewise.
      	(ix86_update_stack_boundary): Likewise.
      	(ix86_get_drap_rtx): Likewise.
      	(ix86_finalize_stack_realign_flags): Likewise.
      	(TARGET_UPDATE_STACK_BOUNDARY): Likewise.
      	(TARGET_GET_DRAP_RTX): Likewise.
      	(override_options): Overide option value for new options.
      	(ix86_function_ok_for_sibcall): Remove check for
      	force_align_arg_pointer.
      	(ix86_handle_cconv_attribute): Likewise.
      	(ix86_function_regparm): Likewise.
      	(setup_incoming_varargs_64): Don't set stack_alignment_needed
      	here.
      	(ix86_va_start): Replace virtual_incoming_args_rtx with
      	crtl->args.internal_arg_pointer.
      	(ix86_select_alt_pic_regnum): Check DRAP register.
      	(ix86_save_reg): Replace force_align_arg_pointer with drap_reg.
      	(ix86_compute_frame_layout): Compute frame layout wrt stack
      	realignment.
      	(ix86_internal_arg_pointer): Just return
      	virtual_incoming_args_rtx.
      	(ix86_expand_prologue): Decide if stack realignment is needed
      	and generate prologue code accordingly.
      	(ix86_expand_epilogue): Generate epilogue code wrt stack
      	realignment is really needed or not.
      	
      	* config/i386/i386.h (MAIN_STACK_BOUNDARY): New.
      	(ABI_STACK_BOUNDARY): Likewise.
      	(PREFERRED_STACK_BOUNDARY_DEFAULT): Likewise.
      	(STACK_REALIGN_DEFAULT): Likewise.
      	(INCOMING_STACK_BOUNDARY): Likewise.
      	(MAX_STACK_ALIGNMENT): Likewise.
      	(ix86_incoming_stack_boundary): Likewise.
      	(FORCE_PREFERRED_STACK_BOUNDARY_IN_MAIN): Removed.
      	(REAL_PIC_OFFSET_TABLE_REGNUM): Updated to use BX_REG.
      	(CAN_ELIMINATE): Defined with ix86_can_eliminate.
      	(machine_function): Remove force_align_arg_pointer.
      
      	* config/i386/i386.md (BX_REG): New.
      	(R13_REG): Likewise.
      
      	* config/i386/i386.opt (mforce_drap): New.
      	(mincoming-stack-boundary): Likewise.
      	(mstackrealign): Add Init(-1).
      
      	* config/i386/i386-protos.h (ix86_can_eliminate): New
      
      2008-07-30  H.J. Lu  <hongjiu.lu@intel.com>
      
      	* doc/extend.texi: Update force_align_arg_pointer.
      
      	* doc/invoke.texi: Document -mincoming-stack-boundary.  Update
      	-mstackrealign.
      
      	* doc/tm.texi (MAX_STACK_ALIGNMENT): Add macro.
      	(INCOMING_STACK_BOUNDARY): Likewise.
      	(TARGET_UPDATE_STACK_BOUNDARY): New target hook.
      	(TARGET_GET_DRAP_RTX): Likewise.
      
      From-SVN: r138335
      H.J. Lu committed