1. 01 Jun, 2002 1 commit
    • basic-block.h (struct basic_block_def): New field loop_father. · 2ecfd709
      	* basic-block.h (struct basic_block_def): New field loop_father.
      	(BB_VISITED): New flag.
      	(struct loop): New field pred, removed field shared.
      	(struct loops): New field parray.
      	(LOOP_EXITS_DOMS): Removed.
      	(flow_loop_tree_node_add, flow_loop_tree_node_remove,
      	flow_loop_nested_p, flow_bb_inside_loop_p, get_loop_body,
      	dfs_enumerate_from, loop_preheader_edge, loop_latch_edge,
      	add_bb_to_loop, remove_bb_from_loops, find_common_loop,
      	verify_loop_structure): Declare.
      	* cfg.c (entry_exit_blocks): Initialize loop_father field.
      	* cfganal.c (dfs_enumerate_from): New function.
      	* cfgloop.c (HEAVY_EDGE_RATIO): New constant.
      	(flow_loop_entry_edges_find, flow_loop_exit_edges_find,
      	flow_loop_nodes_find, flow_loop_level_compute, flow_loop_nested_p,
      	flow_loop_dump, flow_loops_dump, flow_loops_free,
      	flow_loop_tree_node_add, flow_loop_level_compute,
      	flow_loops_level_compute, flow_loop_scan, flow_loops_update,
      	flow_loop_outside_edge_p): Modified for new infrastructure.
      	(make_forwarder_block, canonicalize_loop_headers, glb_enum_p,
      	redirect_edge_with_latch_update, flow_loop_free): New static functions.
      	(flow_loop_tree_node_remove, flow_bb_inside_loop_p,
      	get_loop_body, add_bb_to_loop, remove_bb_from_loops,
      	find_common_loop, verify_loop_structure, loop_latch_edge,
      	loop_preheader_edge): New functions.
      	(flow_loops_cfg_dump): Do not show dominators, as this information
      	does not remain up to date long.
      	(flow_loops_find): Store results in new format.
      	* predict.c (propagate_freq, estimate_probability,
      	estimate_loops_at_level, estimate_bb_frequencies): Use new loop
      	infrastructure.
      
      From-SVN: r54142
      Zdenek Dvorak committed
  2. 28 May, 2002 2 commits
    • basic-block.h (last_basic_block): Declare. · bf77398c
      	* basic-block.h (last_basic_block): Declare.
      	(expunge_block_nocompact): Declaration removed.
      	(compact_blocks): Declare.
      	* cfg.c (last_basic_block): New variable.
      	(expunge_block_nocompact): Removed.
      	(expunge_block): Do not compact basic blocks.
      	(compact_blocks): New.
      	* cfganal.c (flow_call_edges_add): Use the fact that bb indices no
      	longer change.
      	* cfgbuild.c (find_basic_blocks_1, find_basic_blocks): Set
      	last_basic_block.
      	* cfgcleanup.c (merge_blocks_move_predecessor_nojumps): Do not change
      	real positions of blocks.
      	(delete_unreachable_blocks): Simplified -- quadratic behavior now
      	cannot occur.
      	(cleanup_cfg): Compact blocks.
      	* cfgrtl.c (create_basic_block): Insert basic blocks to the end of
      	basic_block_info varray.
      	(flow_delete_block): Comment update.
      	(back_edge_of_syntactic_loop_p): Modify position check code.
      	(verify_flow_info): Update checking.
      	* flow.c (calculate_global_regs_live): Use FOR_EACH_BB.
      	* ifcvt.c (SET_ORIG_INDEX, ORIG_INDEX): Removed.
      	(find_if_case_1, find_if_case_2, if_convert): Use the fact that bb
      	indices no longer change.
      	* lcm.c (optimize_mode_switching): Replace n_basic_blocks with
      	last_basic_block.
      	* predict.c (estimate_bb_frequencies): Remove unneccessary code.
      	* profile.c (branch_prob): Compact blocks.
      	* sched-rgn.c (find_rgns): Replace n_basic_blocks with
      	last_basic_block.
      
      From-SVN: r53957
      Zdenek Dvorak committed
  3. 26 May, 2002 1 commit
  4. 23 May, 2002 2 commits
    • bb-reorder.c (make_reorder_chain, [...]): Use FOR_EACH_BB macros to iterate over basic block chain. · e0082a72
      	* bb-reorder.c (make_reorder_chain, make_reorder_chain_1):
      	Use FOR_EACH_BB macros to iterate over basic block chain.
      	* cfg.c (clear_edges, clear_bb_flags, dump_flow_info,
      	alloc_aux_for_blocks, clear_aux_for_blocks, alloc_aux_for_edges):
      	Likewise.
      	* cfganal.c (set_edge_can_fallthru_flag, flow_call_edges_add,
      	find_unreachable_blocks, create_edge_list, verify_edge_list,
      	remove_fake_edges, add_noreturn_fake_exit_edges,
      	flow_preorder_transversal_compute, flow_dfs_compute_reverse_execute):
      	Likewise.
      	* cfgbuild.c (make_edges, find_basic_blocks, find_many_sub_basic_blocks,
      	find_sub_basic_blocks): Likewise.
      	* cfgcleanup.c (try_optimize_cfg, delete_unreachable_blocks):
      	Likewise.
      	* cfglayout.c (record_effective_endpoints, cleanup_unconditional_jumps):
      	Likewise.
      	* cfgloop.c (flow_loops_cfg_dump, flow_loops_find):
      	Likewise.
      	* cfgrtl.c (compute_bb_for_insn, tidy_fallthru_edges,
      	commit_edge_insertions, commit_edge_insertions_watch_calls,
      	print_rtl_with_bb, verify_flow_info, purge_all_dead_edges): Likewise.
      	* combine.c (combine_instructions, reg_dead_at_p): Likewise.
      	* conflict.c (conflict_graph_compute): Likewise.
      	* df.c (df_bitmaps_alloc, df_bitmaps_free, df_alloc, df_analyse_1,
      	df_modified_p, df_refs_unlink, df_dump): Likewise.
      	* dominance.c (calc_dfs_tree, calculate_dominance_info): Likewise.
      	* final.c (compute_alignments): Likewise.
      	* flow.c (update_life_info, update_life_info_in_dirty_blocks,
      	delete_noop_moves, calculate_global_regs_live, allocate_bb_life_data,
      	count_or_remove_death_notes): Likewise.
      	* gcse.c (oprs_unchanged_p, record_last_reg_set_info,
      	compute_hash_table, compute_kill_rd, compute_rd, compute_ae_kill,
      	classic_gcse, compute_transp, cprop, compute_pre_data,
      	compute_transpout, invalidate_nonnull_info,
      	delete_null_pointer_checks_1, delete_null_pointer_checks,
      	compute_code_hoist_vbeinout, hoist_code, compute_ld_motion_mems,
      	compute_store_table, build_store_vectors, store_motion): Likewise.
      	* global.c (global_conflicts, mark_elimination): Likewise.
      	* graph.c (print_rtl_graph_with_bb): Likewise.
      	* haifa-sched.c (sched_init): Likewise.
      	* ifcvt.c (if_convert): Likewise.
      	* lcm.c (compute_antinout_edge, compute_laterin, compute_insert_delete,
      	compute_available, compute_nearerout, compute_rev_insert_delete,
      	optimize_mode_switching): Likewise.
      	* local-alloc.c (local_alloc, update_equiv_regs): Likewise.
      	* predict.c (estimate_probability, note_prediction_to_br_prob,
      	propagate_freq, counts_to_freqs, expensive_function_p,
      	estimate_bb_frequencies): Likewise.
      	* profile.c (instrument_edges, get_exec_counts,
      	compute_branch_probabilities, compute_checksum, branch_prob,
      	find_spanning_tree): Likewise.
      	* recog.c (split_all_insns, peephole2_optimize): Likewise.
      	* reg-stack.c (reg_to_stack, convert_regs_entry, convert_regs):
      	Likewise.
      	* regclass.c (scan_one_insn, regclass): Likewise.
      	* regmove.c (mark_flags_life_zones, regmove_optimize,
      	record_stack_memrefs): Likewise.
      	* regrename.c (regrename_optimize, copyprop_hardreg_forward): Likewise.
      	* reload1.c (reload, reload_combine, fixup_abnormal_edges): Likewise.
      	* resource.c (find_basic_block): Likewise.
      	* sched-ebb.c (schedule_ebbs): Likewise.
      	* sched-rgn.c (is_cfg_nonregular, build_control_flow,
      	find_single_block_region, find_rgns, schedule_insns)
      	* sibcall.c (optimize_sibling_and_tail_recursive_call)
      	* ssa-ccp.c (optimize_unexecutable_edges,
      	ssa_ccp_df_delete_unreachable_insns): Likewise.
      	* ssa-dce.c (ssa_eliminate_dead_code): Likewise.
      	* ssa.c (find_evaluations, compute_dominance_frontiers_1,
      	rename_block, convert_to_ssa, compute_conservative_reg_partition,
      	compute_coalesced_reg_partition, rename_equivalent_regs,
      	convert_from_ssa): Likewise.
      	* config/ia64/ia64.c (emit_predicate_relation_info, process_epilogue,
      	process_for_unwind_directive): Likewise.
      
      	* df.c (FOR_ALL_BBS): Removed.
      	* gcse.c (struct null_pointer_info): Type of current_block field
      	changed.
      	(struct reg_avail_info): Type of last_bb field changed.
      	* config/ia64/ia64.c (block_num): Removed.
      	(need_copy_state): Type changed.
      	(last_block): New.
      
      From-SVN: r53804
      Zdenek Dvorak committed
    • cfg.c (dump_flow_info): Print results of maybe_hot/probably_never_executed predicates. · 0f72964f
      	* cfg.c (dump_flow_info): Print results of
      	maybe_hot/probably_never_executed predicates.
      	* toplev.c (open_dump_file): Print function frequency.
      
      From-SVN: r53796
      Jan Hubicka committed
  5. 22 May, 2002 1 commit
  6. 19 May, 2002 1 commit
    • basic_block.h (struct basic_block_def): Added prev_bb and next_bb fields. · 918ed612
      	* basic_block.h (struct basic_block_def): Added prev_bb and next_bb
      	fields.
      	(FOR_BB_BETWEEN, FOR_ALL_BB, FOR_ALL_BB_REVERSE): New macros for
      	traversing basic block chain.
      	(create_basic_block_structure, create_basic_block): Declaration changed.
      	(link_block, unlink_block): Declare.
      	* cfg.c (entry_exit_blocks): Initialize new fields.
      	(link_block, unlink_block): New.
      	(expunge_block_nocompact): Unlink basic block.
      	(dump_flow_info): Print prev_bb/next_bb fields.
      	* cfgbuild.c (find_basic_blocks_1, find_basic_blocks): Modified.
      	* cfgcleanup.c (merge_blocks_move_predecessor_nojumps): Modified.
      	* cfglayout.c (fixup_reorder_chain, cfg_layout_duplicate_bb): Modified.
      	* cfgrtl.c (create_basic_block_structure, create_basic_block,
      	split_block, force_nonfallthru_and_redirect, split_edge): Modified.
      	(verify_flow_info): Check that list agrees with numbering.
      
      From-SVN: r53642
      Zdenek Dvorak committed
  7. 17 May, 2002 1 commit
  8. 16 May, 2002 1 commit
  9. 11 May, 2002 1 commit
    • i386.md (testsi to testqi spliters): New. · 6c81a490
      	* i386.md (testsi to testqi spliters): New.
      
      	2002-01-14  Josef Zlomek  <zlomek@matfyz.cz>
      
      	cfg.c (dump_edge_info): added dumping of EDGE_CAN_FALLTHRU.
      
      	Wed Jan  9 2002  Josef Zlomek  <zlomj9am@artax.karlin.mff.cuni.cz>
      
      	* basic-block.h: New flag EDGE_CAN_FALLTHRU
      	* cfganal.c (set_edge_can_fallthru_flag): New function; marks the edges
      	that can be made fallthru.
      
      	Mon Nov 12 16:25:53 CET 2001  Jan Hubicka  <jh@suse.cz>
      
      	* cfglayout.c (cleanup_unconditional_jumps): New static function.
      	(cfg_layout_initialize): Use it.
      
      Co-Authored-By: Pavel Nejedly <bim@atrey.karlin.mff.cuni.cz>
      
      From-SVN: r53383
      Jan Hubicka committed
  10. 10 Apr, 2002 1 commit
    • basic-block.h (flow_delete_block_noexpunge): Declare. · 6a58eee9
      	* basic-block.h (flow_delete_block_noexpunge): Declare.
      	(expunge_block_nocompact): Declare.
      	* cfg.c (expunge_block_nocompact): Split out from ...
      	(expunge_block): ... here.
      	* cfgrtl.c (can_delete_label_p): Don't use exception_handler_labels.
      	(flow_delete_block_noexpunge): Split out from ...
      	(flow_delete_block): ... here.
      	* cfgcleanup.c (delete_unreachable_blocks): Compact while
      	removing dead blocks.
      	* except.c (exception_handler_labels): Remove.
      	(exception_handler_label_map): New.
      	(struct eh_region): Add aka member.
      	(mark_ehl_map_entry, mark_ehl_map, free_region): New.
      	(ehl_hash, ehl_eq, ehl_free, add_ehl_entry): New.
      	(for_each_eh_label, for_each_eh_label_1): New.
      	(init_eh): Register exception_handler_label_map.
      	(free_eh_status): Use free_region.
      	(find_exception_handler_labels): Use the map, not the list.
      	(remove_exception_handler_label): Likewise.
      	(maybe_remove_eh_handler): Likewise.
      	(remove_eh_handler): Use the region aka bitmap.
      	* except.h (exception_handler_labels): Remove.
      	(for_each_eh_label): Declare.
      	* jump.c (rebuild_jump_labels): Don't check exception_handler_labels.
      	* loop.c (invalidate_loops_containing_label): New.
      	(find_and_verify_loops): Use it.  Use for_each_eh_label.
      	* sched-rgn.c (is_cfg_nonregular): Use
      	current_function_has_exception_handlers.
      
      From-SVN: r52100
      Richard Henderson committed
  11. 30 Mar, 2002 1 commit
  12. 11 Mar, 2002 1 commit
  13. 05 Mar, 2002 1 commit
  14. 28 Feb, 2002 1 commit
    • basic-block.h (BB_REACHABLE): Renumber. · 38c1593d
      	* basic-block.h (BB_REACHABLE): Renumber.
      	(BB_DIRTY, BB_NEW): New flags.
      	(clear_bb_flags): Declare.
      	(update_life_info_in_dirty_blocks): Declare.
      	* cfg.c (clear_bb_flags): New function.
      	* cfgrtl.c (create_basic_block_structure): Set flags to BB_NEW.
      	* emit-rtl.c (add_insn_after, add_insn_before, remove_insn,
      	reorder_insns, emit_insn_after): Mark block as dirty.
      	* flow.c (update_life_info): Fix clearing of PROP_LOG_LINKS.
      	(update_life_info_in_dirty_blocks): New function.
      	* recog.c (apply_change_group): Dirtify block.
      
      	* cse.c (cse_insn): Reorder emitting of jump insn to keep
      	cfg consistent.
      	* gcse.c (delete_null_pointer_checks): Likewise.
      
      	* toplev.c (dump_file_index): Move cse2 after bp,
      	add DFI_null
      	(dump_file_info): Similary.
      	(rest_of_compilation): Avoid most of CFG rebuilds;
      	do first if converision after null pointer checks, do cse2
      	after branch prediction; avoid full liveness rebuild after
      	initializing subregs.
      	* invoke.texi (-d options): Document -du, renumber.
      
      	* cfgcleanup.c (bb_flags): Remove BB_UPDATE_LIFE.
      	(notice_new_block): Do not set BB_UPDATE_LIFE.
      	(try_forward_edges, merge_blocks_move_predecessor_nojumps,
      	 merge_blocks_move_successor_nojumps, merge_blocks,
      	 try_crossjump_to_edge): Likewise.
      	(try_optimize_cfg): Likewise; use update_life_info_in_dirty_blocks.
      	* cfgrtl.c (merge_blocks_nomove): Copy b's flags to a.
      	* ifcvt.c (SET_UPDATE_LIFE, UPDATE_LIFE): Kill.
      	(merge_of_block): Do not use life_data_ok.
      	(find_if_case_1): Do not use SET_UPDATE_LIFE.
      	(if_convert): Use BB_DIRTY mechanizm to update life.
      	* lcm.c (optimize_mode_switching): Update
      	update_life_info_in_dirty_blocks
      
      From-SVN: r50127
      Jan Hubicka committed
  15. 22 Dec, 2001 1 commit
  16. 21 Nov, 2001 1 commit
  17. 11 Nov, 2001 1 commit
    • ChangeLog.2, [...]: Fix spelling errors. · eaec9b3d
      	* ChangeLog.2, ChangeLog.3, ChangeLog.4, ChangeLog.5, ChangeLog,
      	cfg.c, cfganal.c, cfgcleanup.c, cfglayout.c, cfgloop.c, cfgrtl.c,
      	collect2.c, combine.c, config.in, configure, configure.in,
      	conflict.c, dwarf2out.c, dwarfout.c, except.c, final.c, flow.c,
      	genattrtab.c, ggc-page.c, jump.c, lcm.c, predict.c, reg-stack.c,
      	reload1.c, rtlanal.c, sched-rgn.c, toplev.c, unwind-dw2-fde.h: Fix
      	spelling errors.
      
      From-SVN: r46928
      Joseph Myers committed
  18. 04 Nov, 2001 1 commit
    • ChangeLog.2, [...]: Fix spelling errors. · f5143c46
      	* ChangeLog.2, ChangeLog.4, ChangeLog.5, ChangeLog,
      	FSFChangeLog.10, FSFChangeLog.11, alias.c, attribs.c,
      	caller-save.c, calls.c, cfg.c, cfganal.c, cfgcleanup.c, cfgrtl.c,
      	cppmacro.c, fold-const.c, ifcvt.c, local-alloc.c, profile.c,
      	sched-int.h, toplev.c, config/alpha/alpha.c,
      	config/alpha/alpha.md, config/c4x/c4x.h, config/cris/cris.h,
      	config/cris/cris.md, config/i370/i370.md, config/i386/i386.c,
      	config/i386/i386.h, config/i386/i386.md, config/i386/xm-djgpp.h,
      	config/ia64/ia64.c, config/m68hc11/m68hc11.c, config/m68k/m68k.md,
      	config/mcore/mcore.h, config/mmix/mmix.c, config/ns32k/ns32k.h,
      	config/ns32k/ns32k.md, config/rs6000/rs6000.c,
      	config/rs6000/sysv4.h, config/sh/sh.md: Fix spelling errors.
      
      From-SVN: r46760
      Joseph Myers committed
  19. 28 Oct, 2001 2 commits
    • ChangeLog.0, [...]: Fix spelling errors. · ff7cc307
      	* ChangeLog.0, ChangeLog.1, ChangeLog.2, ChangeLog.3, ChangeLog.4,
      	ChangeLog.5, ChangeLog, FSFChangeLog.10, FSFChangeLog.11,
      	c-common.c, c-common.h, c-parse.in, c-typeck.c, cfg.c, config.gcc,
      	configure, configure.in, except.c, except.h, flow.c, function.c,
      	gcc.c, gcse.c, genrecog.c, libgcc2.c, loop.c, loop.h, params.def,
      	predict.def, predict.h, reg-stack.c, regmove.c, sched-deps.c,
      	sched-int.h, sibcall.c, ssa.c, stringpool.c, toplev.c, tree.c,
      	unroll.c: Fix spelling errors.
      
      From-SVN: r46595
      Joseph Myers committed
    • ChangeLog.0, [...]: Fix spelling errors. · f63d1bf7
      	* ChangeLog.0, ChangeLog.1, ChangeLog.2, ChangeLog.3, ChangeLog.4,
      	ChangeLog.5, ChangeLog, ChangeLog.lib, FSFChangeLog.10, ONEWS,
      	c-common.c, caller-save.c, cfg.c, cfgcleanup.c, cfgrtl.c,
      	collect2.c, df.h, diagnostic.h, final.c, gcse.c, gthr.h,
      	haifa-sched.c, jump.c, local-alloc.c, profile.c, protoize.c,
      	regmove.c, reload1.c, rtlanal.c, sched-vis.c, ssa.c, stmt.c,
      	system.h, toplev.c: Fix spelling errors.
      
      From-SVN: r46580
      Joseph Myers committed
  20. 26 Oct, 2001 1 commit
    • cfg.c (clear_aux_for_blocks): Split out of ... · 108c1afc
              * cfg.c (clear_aux_for_blocks): Split out of ...
              (free_aux_for_blocks): here.
              (clear_aux_for_edges): Split from ...
              (free_aux_for_edges): here.
              * basic-block.h: Declare them.
              * lcm.c (compute_antinout_edge): Use them.
              (compute_laterin, compute_available, compute_nearerout): Likewise.
              (optimize_mode_switching): Likewise.
      
      From-SVN: r46534
      Richard Henderson committed
  21. 16 Oct, 2001 1 commit
  22. 11 Oct, 2001 1 commit
    • alias.c: Remove uses of "register" specifier in declarations of arguments and local... · b3694847
      2001-10-10  Stan Shebs  <shebs@apple.com>
      
              * alias.c: Remove uses of "register" specifier in declarations
              of arguments and local variables.
              * c-common.c: Ditto.
              * c-convert.c: Ditto.
              * c-decl.c: Ditto.
              * c-format.c: Ditto.
              * c-semantics.c: Ditto.
              * c-typeck.c: Ditto.
              * caller-save.c: Ditto.
              * calls.c: Ditto.
              * cfg.c: Ditto.
              * cfgbuild.c: Ditto.
              * cfgrtl.c: Ditto.
              * collect2.c: Ditto.
              * combine.c: Ditto.
              * convert.c: Ditto.
              * cppexp.c: Ditto.
              * cppfiles.c: Ditto.
              * cse.c: Ditto.
              * dbxout.c: Ditto.
              * defaults.h: Ditto.
              * df.c: Ditto.
              * dwarf2out.c: Ditto.
              * dwarfout.c: Ditto.
              * emit-rtl.c: Ditto.
              * explow.c: Ditto.
              * expmed.c: Ditto.
              * expr.c: Ditto.
              * final.c: Ditto.
              * fix-header.c: Ditto.
              * floatlib.c: Ditto.
              * flow.c: Ditto.
              * fold-const.c: Ditto.
              * function.c: Ditto.
              * gcc.c: Ditto.
              * gcse.c: Ditto.
              * gen-protos.c: Ditto.
              * genattrtab.c: Ditto.
              * gencheck.c: Ditto.
              * genconfig.c: Ditto.
              * genemit.c: Ditto.
              * genextract.c: Ditto.
              * genflags.c: Ditto.
              * gengenrtl.c: Ditto.
              * genoutput.c: Ditto.
              * genpeep.c: Ditto.
              * genrecog.c: Ditto.
              * gensupport.c: Ditto.
              * global.c: Ditto.
              * gmon.c: Ditto.
              * graph.c: Ditto.
              * haifa-sched.c: Ditto.
              * hard-reg-set.h: Ditto.
              * hash.c: Ditto.
              * integrate.c: Ditto.
              * jump.c: Ditto.
              * lists.c: Ditto.
              * local-alloc.c: Ditto.
              * loop.c: Ditto.
              * mips-tdump.c: Ditto.
              * mips-tfile.c: Ditto.
              * optabs.c: Ditto.
              * prefix.c: Ditto.
              * print-rtl.c: Ditto.
              * read-rtl.c: Ditto.
              * real.c: Ditto.
              * recog.c: Ditto.
              * reg-stack.c: Ditto.
              * regclass.c: Ditto.
              * regmove.c: Ditto.
              * reload.c: Ditto.
              * reload1.c: Ditto.
              * reorg.c: Ditto.
              * resource.c: Ditto.
              * rtl.c: Ditto.
              * rtlanal.c: Ditto.
              * scan.c: Ditto.
              * sched-deps.c: Ditto.
              * sched-rgn.c: Ditto.
              * sdbout.c: Ditto.
              * simplify-rtx.c: Ditto.
              * stmt.c: Ditto.
              * stor-layout.c: Ditto.
              * toplev.c: Ditto.
              * tradcif.y: Ditto.
              * tradcpp.c: Ditto.
              * tree.c: Ditto.
              * unroll.c: Ditto.
              * varasm.c: Ditto.
              * xcoffout.c: Ditto.
      
      From-SVN: r46173
      Stan Shebs committed
  23. 09 Oct, 2001 1 commit
    • c-common.h: Fix comment formatting. · 2ba84f36
      	* c-common.h: Fix comment formatting.
      	* c-dump.c: Likewise.
      	* cfg.c: Likewise.
      	* diagnostic.h: Likewise.
      	* except.c: Likewise.
      	* gcc.h: Likewise.
      	* gcov-io.h: Likewise.
      	* genattrtab.c: Likewise.
      	* output.h: Likewise.
      	* predict.h: Likewise.
      	* reload1.c: Likewise.
      	* reload.h: Likewise.
      	* resource.h: Likewise.
      	* scan.h: Likewise.
      	* system.h: Likewise.
      	* tree.h: Likewise.
      	* tree-inline.c: Likewise.
      	* tsystem.h: Likewise.
      	* varasm.c: Likewise.
      	* xcoffout.h: Likewise.
      
      From-SVN: r46122
      Kazu Hirata committed
  24. 25 Sep, 2001 1 commit
    • Makefile.in (cfgrtl.o): Add. · ca6c03ca
      	* Makefile.in (cfgrtl.o): Add.
      	* basic-block.h (alloc_block, alloc_aux_for_block, alloc_aux_for_blocks,
      	free_aux_for_block, alloc_aux_for_edge, alloc_aux_for_edges,
      	free_aux_for_edge): Declare.
      	* cfg.c
      	(HAVE_return): Undefine.
      	* basic-block.h (alloc_block, alloc_aux_for_block, alloc_aux_for_blocks,
      	free_aux_for_block, alloc_aux_for_edge, alloc_aux_for_edges,
      	free_aux_for_edge): New global functions.
      	(first_delete_block): New static variable.
      	(init_flow): Clear first_delete_block.
      	(basic_block_for_insn, label_value_list, tail_recursion_label_list,
      	 can_delete_note_p, can_delete_label_p, commit_one_edge_insertion,
      	 try_redirect_by_replacing_jump, last_loop_beg_note,
      	 back_edge_of_syntactic_loop_p, force_nonfallthru_and_redirect,
      	 delete_insn, delete_insn_chain, create_basic_block_structure,
      	 create_basic_block, flow_delete_block, compute_bb_for_insn,
      	 free_bb_for_insn, update_bb_for_insn, set_block_for_insn,
      	 set_block_for_new_insns, split_block, merge_blocks_nomove,
      	 block_label, try_redirect_by_replacing_jump, last_loop_beg_note,
      	 redirect_edge_and_branch, force_nonfallthru_and_redirect,
      	 force_nonfallthru, redirect_edge_and_branch_force, tidy_fallthru_edge,
      	 tidy_fallthru_edges, split_edge, insert_insn_on_edge,
      	 commit_one_edge_insertion, commit_edge_insertions, dump_bb, debug_bb,
      	 debug_bb_n, print_rtl_with_bb, verify_flow_info, purge_dead_edges,
      	 purge_all_dead_edges): Move to ....
      	* cfgrtl.c: New file; .... Here.
      
      	* bb-reorder.c (fixup_reorder_chain): Use alloc_aux_for_block.
      	(reroder_basic_block): Use alloc_aux_for_blocks.
      	* predict.c (estimate_bb_frequencies): Likewise; use
      	alloc_aux_for_edges.
      	* profile.c (compute_branch_probabilities): Likewise.
      	(branch_prob): Likewise.
      	* reg-stack.c (reg_to_stack): Likewise.
      
      	* emit-rtl.c (emit_insns_after): Never return NULL.
      
      	* basic-block.h (set_block_for_new_insns): Delete.
      	* cfgrtl.c (set_block_for_new_insns): Delete.
      
      	* cfgcleanup.c (try_optimize_cfg): Add fake exit edges for noreturn
      	calls when crossjumping.
      
      	* cfgcleanup.c (try_simplify_condjump): Cleanup invert_jump call.
      	* unroll.c (copy_loop_body): Use delete_insn.
      
      	* final.c (final, final_scan_insn): Use delete_insn/delete_note.
      	* function.c (fixup_var_refs_insn, fixup_var_refs_1,
      	keep_stack_depressed): Likewise.
      	* gcse.c (cprop_cc0_jump): Likewise.
      	* local-alloc.c (update_equiv_regs): Likewise.
      	* loop.c (scan_loop, loop_delete_insns): Likewise.
      	* regmove.c (try_auto_increment, fixup_match_1): Likewise.
      	* reload1.c (reload, calculate_needs_all_insns, reload_as_needed,
      	delete_output_reload, delete_address_reloads_1,
      	reload_cse_delete_noop_set, reload_combine, reload_cse_move2add):
      	Likewise.
      	* sibcall.c (replace_call_placeholder): Likewise.
      	* cse.c (cse_insn): Likewise.
      
      From-SVN: r45807
      Jan Hubicka committed
  25. 21 Sep, 2001 1 commit
    • basic-block.h (flow_delete_insn, [...]): Kill. · 53c17031
      	* basic-block.h (flow_delete_insn, flow_delete_insn_chain): Kill.
      	* cfg.c (delete_insn): Rename from ....; use remove_insn; do not
      	remove some labels.
      	(flow_delete_insn): This one.
      	(delete_insn_chain): Rename from ...; do not care labels.
      	(flow_delete_insn_chain): ... this one.
      	(flow_delete_block): Remove the insns one BB has been expunged.
      	(merge_blocks_nomove): Likewise.
      	(try_redirect_by_replacing_jump): Use delete_insn[_chain]; do not care
      	updating BB boundaries.
      	(tidy_fallthru_edge): Likewise.
      	(commit_one_edge_insertion): Likewise.
      	* cfgbuild.c (find_basic_block): Likewise.
      	(find_basic_blocks_1): Likewise.
      	* cfgcleanup.c (merge_blocks_move_predecessor_nojumps): Likewise.
      	(try_crossjump_to_edge): Likewise.
      	(try_optimize_cfg): Likewise.
      	* cse.c (delete_trivially_dead_insns): Likewise.
      	* df.c (df_insn_delete): Likewise.
      	* doloop.c (doloop_modify): Use delete_related_insns.
      	* emit-rtl.c (try_split): Likewise.
      	(remove_insn): Update BB boundaries.
      	* expect.c (connect_post_landing_pads): Use delete_related_insns.
      	* flow.c (delete_dead_jumptables): Use delete_insn[_chain]; do not care
      	updating BB boundaries.
      	(propagate_block_delete_insn): Likewise.
      	(propagate_block_delete_libcall): Likewise.
      	* function.c (delete_handlers): Use delete_related_insns.
      	(thread_prologue_and_epilogue_insns): Likewise.
      	* gcse.c (delete_null_pointer_checks): Use delete_related_insns.
      	* genpeep.c (gen_peephole): Use delete_related_insns.
      	* ifcvt.c (noce_process_if_block): Use delete_insn; do not care updating
      	BB boundaries.
      	(find_cond_trap): Likewise.
      	* integrate.c (save_for_inline): Use delete_related_insns.
      	(copy_insn_list): Likewise.
      	* jump.c (pruge_linie_number_notes): Likewise.
      	(duplicate_loop_exit_test): Likewise.
      	(delete_computation): Likewise.
      	(delete_related_insn): Rename from ...; use delete_insn
      	(delete_insn): ... this one.
      	(redirect_jump): Use delete_related_insns.
      	* loop.c (scan_loop): Likewise.
      	(move_movables): Likewise.
      	(find_and_verify_loops): Likewise.
      	(check_dbra_loop): Likewise.
      	* recog.c (peephole2_optimize): Likewise.
      	* reg-stack.c (delete_insn_for_stacker): Remove.
      	(move_for_stack_reg): Use delete_insn.
      	* regmove.c (combine_stack_adjustments_for_block): Likewise.
      	* reload1.c (delete_address_reloads): Use delete_related_insns.
      	(fixup_abnormal_edges): Use delete_insn.
      	* recog.c (emit_delay_sequence): Use delete_related_insns.
      	(delete_from-delay_slot): Likewise.
      	(delete_scheduled_jump): likewise.
      	(optimize_skip): Likewise.
      	(try_merge_delay_insns): Likewise.
      	(full_simple_delay_slots): Likewise.
      	(fill_slots_from_thread): Likewise.
      	(relax_delay_slots): Likewise.
      	(make_return_insns): Likewise.
      	(dbr_schedule): Likewise.
      	* rtl.h (delete_insn): Rename to delete_related_insns.
      	(delete_insn, delete_insn_chain): New prototypes.
      	* ssa-ccp (sse_fast_dce):  Remove deleting of DEF, as it is done
      	by df_insn_delete already.
      	* ssa-dce.c (delete_insn_bb): Use delete_insn.
      	* ssa.c (convert_from_ssa): Use delete_related_insns.
      	* unroll.c (unroll_loop): Likewise.
      	(calculate_giv_inc): Likewise.
      	(copy_loop_body): Likewise.
      
      	* i386-protos.h (ix86_libcall_value, ix86_function_value,
      	ix86_function_arg_regno_p, ix86_function_arg_boundary,
      	ix86_return_in_memory, ix86_function_value): Declare.
      	* i386.c (x86_64_int_parameter_registers, x86_64_int_return_registers):
      	new static valurables.
      	(x86_64_reg_class): New enum
      	(x86_64_reg_class_name): New array.
      	(classify_argument, examine_argument, construct_container,
      	 merge_classes): New static functions.
      	(optimization_options): Enable flag_omit_frame_pointer and disable
      	flag_pcc_struct_return on 64bit.
      	(ix86_libcall_value, ix86_function_value,
      	ix86_function_arg_regno_p, ix86_function_arg_boundary,
      	ix86_return_in_memory, ix86_function_value): New global functions.
      	(init_cumulative_args): Refuse regparm on x86_64, set maybe_vaarg.
      	(function_arg_advance): Handle x86_64 passing conventions.
      	(function_arg): Likewise.
      	* i386.h (FUNCTION_ARG_BOUNDARY): New macro.
      	(RETURN_IN_MEMORY): Move offline.
      	(FUNCTION_VALUE, LIBCALL_VALUE): Likewise.
      	(FUNCTION_VALUE_REGNO_P): New macro.
      	(FUNCTION_ARG_REGNO_P): Move offline.
      	(struct ix86_args): Add maybe_vaarg.
      	* next.h (FUNCTION_VALUE_REGNO_P): Delete.
      	* unix.h (FUNCTION_VALUE_REGNO_P): Delete.
      
      From-SVN: r45726
      Jan Hubicka committed
  26. 19 Sep, 2001 1 commit
  27. 16 Sep, 2001 1 commit
    • basic-block.h (free_bb_for_insn): Declare. · 3c030e88
      	* basic-block.h (free_bb_for_insn): Declare.
      	* bb-reorder.c (label_for_bb): Use block_label.
      	(emit_jump_to_block_after): Remove.
      	(insert_intra_1): Do not update block_for_insn.
      	(insert_inter_bb_scope_notes): Likewise; update bb->end
      	* cfg.c (free_bb_for_insn): New.
      	(try_rediret_by_replacing_jump): Avoid set_block_for_new_insns call.
      	(force_nonfallthru_and_redirect): Likewise; do not update BB boundaries.
      	(commit_one_edge_insertion): Likewise.
      	(commit_one_edge_insertion): Do not update BB boundary.
      	(commit_edge_insertions): Do not call compute_bb_for_insn.
      	* cfgbuild.c (find_basic_blocks): Do not free basic_block_for_insn.
      	* cfgcleanup.c (merge_blocks_move_predecessor): Use reorder_insns_nobb.
      	(merge_blocks_move_successor_nojumps): Likewise.
      	(try_crossjump_to_edge): Do not update block_for_insn.
      	* combine.c (combine_instructions): Remove compute_bb_for_insn call.
      	* df.c (df_pattern_emit_later): Do not update BB boundary.
      	(df_jump_pattern_emit_after): Likewise.
      	(df_insn_move_before): Use emit_insn_before.
      	* emit-rtl.c (try_split): Emit after trial to get bb boundary updated
      	 properly.
      	(add_insn_after, add_insn_before, emit_insns_after): Update BB
      	boundaries and basic_block_for_insn.
      	(reorder_insns_nobb): Rename from reorder_insns.
      	(reorder_insns): New.
      	(emit_block_insn_before, emit_block_insn_after): Kill.
      	* flow.c (check_function_return_warnings): Do not call
      	compute_bb_for_insn; Do not free basic_block_for_insn.
      	(attempt_auto_inc): Do not update basic_block_for_insn.
      	* function.c (emit_return_into_block): Likewise;
      	do not update BB boundaries.
      	* gcse.c (handle_avail_expr): Do not update basic_block_for_insn.
      	(insert_insn_end_bb): Use emit_insn_before; Likewise.
      	(pre_insert_copy_insn): Likewise.
      	(update_ld_motion_notes): Likewise.
      	(insert_insn_start_bb): Likewise.
      	(replace_store_insn): Likewise.
      	* ifcvt.c (noce_process_if_block): Likewise.
      	(if_convert): Do not call compute_bb_for_insn.
      	* lcm.c (optimize_mode_switching): Do not update BB boundaries.
      	Use emit_insn_before and emit_insn_after.
      	* recog.c (split_all_insns): Do not update BB boundaries;
      	Do not call compute_bb_for_insn.
      	(peephole2_optimize): Do not update BB boundaries.
      	* reg-stack.c (emit_pop_insn): Use emit_insn_after and
      	emit_insn_before.
      	(emit_swap_insn): Likewise.
      	(convert_regs_1): Likewise.
      	* reload1.c (reload): Call compute_bb_for_insn.
      	* rtl.h (reorder_insns_nobb): Declare.
      	* ssa.c (rename_equivalent_regs): Use emit_insn_before.
      	* toplev.c (rest_of_compilation): Call free_bb_for_insn
      	at places CFG is invalidated; do not call compute_bb_for_insn.
      
      	* cfg.c (expunge_block): Invalidate BB structure.
      
      	* (merge_blocks_nomove): Update properly BLOCK_FOR_INSN
      	array.
      
      	* cfg.c (verify_flow_info): Verify the basic_block_for_insn array.
      
      From-SVN: r45647
      Jan Hubicka committed
  28. 12 Sep, 2001 1 commit
  29. 11 Sep, 2001 2 commits
    • basic-block.h (EDGE_CRITICAL): Remove; renumber other flags. · 4262e623
      	* basic-block.h (EDGE_CRITICAL): Remove; renumber other flags.
      	(EDGE_CRITICAL_P): New predicate.
      	* cfg.c (force_nonfallthru_and_redirect, split_edge): Kill EDGE_CRITICAL
      	handling.
      	(insert_insn_on_edge): Use EDGE_CRITICAL_P.
      	(dump_edge_info): Remove "crit".
      	* cfganal.c (mark_critical_edges): Kill.
      	* cfgbuild.c (find_basic_blocks): Remove mark_critical_edges call.
      	* cfgcleanup.c (cleanup_cfg): Likewise.
      	* profile.c (instrument_edges): Use EDGE_CRITICAL_P.
      	(find_spanning_tree): Likewise.
      	* reg-stack.c (convert_regs_1): Likewise.
      	* ssa.c (mark_regs_equivalent_over_bad_edges): Likewise.
      
      	* basic-block.h (create_basic_block_structure): New.
      	(create_basic_block): Update prototype.
      	(force_nonfallthru): New.
      	* bb-reorder.c (fixup_reorder_chain): Fixup use force_nonfallthru.
      	* cfg.c (create_basic_block_structure): Rename from create_basic_block;
      	handle updating of block_for_insn, creating of empty BBs and BBs at
      	the end of INSN chain.
      	(create_basic_block): New function.
      	(split_block): Use create_basic_block.
      	(force_nonfallthru_and_redirect): Break out from ...; cleanup
      	(redirect_edge_and_branch_force): ... here.
      	(force_nonfallthru): New.
      	(split_edge): Rewrite to use force_nonfallthru and create_block.
      	* cfgbuild.c (find_basic_blocks_1): Use create_basic_block_structure.
      	(find_basic_blocks): Free basic_block_for_insn.
      	* cfgcleanup.c (merge_blocks): Use force_nonfallthru.
      
      	* cfg.c: Fix formating.
      	* cfgcleanup.c: Fix formating.
      	(merge_blocks, tail_recursion_label_p): Return bool.
      	(merge_blocks_move_predecessor_nojumps,
      	 merge_blocks_move_successor_nojumps): Return void.
      
      From-SVN: r45549
      Jan Hubicka committed
    • basic-block.h (cached_make_edge, [...]): New. · 7ded4467
      	* basic-block.h (cached_make_edge, make_single_succ): New.
      	(make_edge): Remove first parameter.
      	* bb-reroder.c (fixup_reorder_chain): Use make_single_succ_edge.
      	* cfg.c (cached_make_edge): Rename from make_edge; return newly
      	created edge; use obstack allocation.
      	(make_edge, make_single_succ_edge): New.
      	(first_removed_edge): New static variable.
      	(init_flow): Initialize first_removed_edge and n_edges.
      	(clear_edges): Use remove_edge.
      	(flow_delete_block): Likewise.
      	(remove_edge): Add removed edges to the removed edges list.
      	(split_block, redirect_edge_and_branch_force, split_edge):
      	Use make_edge.
      	* cfganal.c (flow_call_edges_add): Updaet make_edge call.
      	(add_noreturn_fake_exit_edges): Likewise.
      	(connect_infinite_loops_to_exit): Liekwise.
      	* cfgbuild.c (make_label_edge, make_edges, find_sub_basic_blocks):
      	Use cached_make_edge.
      	* cfgcleanup.c (try_crossjump_to_edge): Use make_single_succ_edge.
      	* profile.c (branch_prob): Update make_edge call.
      	* ssa-dce.c (ssa_eliminate_dead_code): Likewise.
      
      From-SVN: r45540
      Jan Hubicka committed
  30. 10 Sep, 2001 1 commit
    • Makefile.in (cfg.o, [...]): New. · 402209ff
      	* Makefile.in (cfg.o, cfganal.o, cfgloop.o, cfgbuild.o, cfgcleanup.o):
      	New.
      	* basic-block.h (flow_obstack, label_value_list,
      	tail_recursion_label_list): Declare
      	(tidy_fallthru_edges): Declare.
      	(expunge_block, last_loop_beg_note): Delete.
      	(can_fallthru, flow_nodes_print, flow_edge_list_print): Declare.
      	* cfg.c: New file
      	(basic_block_for_insn, label_value_list): Move from flow.c; make global.
      	(n_basic_blocks, n_edges, basic_block_info, entry_exit_blocks,
      	init_flow, clear_edges, can_delete_note_p, can_delete_label_p,
      	flow_delete_insn, flow_delete_insn_chain, create_basic_block,
      	expunge_block, flow_delete_block, compute_bb_for_insn,
      	update_bb_for_insn, set_block_for_insn, set_block_for_new_insns,
      	make_edge, remove_edge, redirect_edge_succ, redirect_edge_succ_nodup,
      	redirect_edge_pred, split_block, marge_blocks_nomove, block_label,
      	try_redirect_by_replacing_jump, last_loop_beg_note,
      	redirect_edge_and_branch, redirect_edge_and_branch_force,
      	tidy_fallthru_edge, tidy_fallthru_edges, back_edge_of_syntactic_loop_p,
      	split_edge, insert_insn_on_edge, commit_one_edge_insertion,
      	commit_edge_insertions, dump_flow_info, debug_flow_info,
      	dump_edge_info, dump_bb, debug_bb, debug_bb_n, print_rtl_with_bb,
      	verify_flow_info, purge_dead_edges, purge_all_dead_edges):
      	Move here from flow.c
      	* cfganal.c: New file.
      	(forwarder_block_p, can_fallthru, mark_critical_edges,
      	 mark_dfs_back_edges, need_fake_edge_p, flow_call_edges_add,
      	 find_unreachable_blocks, create_edge_list, free_edge_list,
      	 print_edge_list, verify_edge_list, find_edge_index, flow_nodes_print,
      	 flow_edge_list_print, remove_fake_successors, remove_fake_edges,
      	 add_noreturn_fake_exit_edges, connect_infinite_loops_to_exit,
      	 flow_reverse_top_sort_order_compute, flow_depth_first_order_compute,
      	 flow_dfs_compute_reverse_init, flow_dfs-compute_reverse_add_bb,
      	 flow_dfs-compute_reverse_execute, flow_dfs_compute_reverse_finish);
      	Move here from flow.c
      	* cfgbuild.c: New file
      	(count_basic_blocks, find_label_refs, make_label_edge, make_eh_edge,
      	 make_edges, find_basic_blocks_1, find_basic_blocks,
      	 find_sub_basic_blocks): Move here from flow.c
      	* cfgcleanup.c: New file.
      	(try_simplify_condjump, try_forward_edges, tail_recursion_label_p,
      	 merge_blocks_move_predecessor_nojumps,
      	 merge_blocks_move_successor_nojumps, merge_blocks,
      	 flow_find_cross_jump, outgoing_edges_match, try_crossjump_to_edge,
      	 try_crossjump_bb, try_optimize_cfg): Move here from flow.c
      	(delete_unreachable_blocks, cleanup_cfg): Likewise; return true
      	if succeeded.
      	* cfgloop.c: New file
      	(flow_loops_cfg_dump, flow_loop_nested_p, flow_loop_dump,
      	 flow_loops_dump, flow_loops_free, flow_loop_entry_edges_find,
      	 flow_loop_exit_edges_find, flow_loop_nodes_find,
      	 flow_loop_pre_header_scan, flow_loop_pre_header_find,
      	 flow_loop_tree_node_add, flow_loops_tree_build,
      	 flow_loop_level_compute, flow_loops_level_compute, flow_loop_scan,
      	 flow_loops_find, flow_loops_update, flow_loop_outside_edge_p):
      	Move here from flow.c
      	* flow.c: Remove everything moved elsewhere
      	* output.h (cleanup_cfg): Return bool.
      
      	* bb-reorder.c (reorder_block_def): Remove 'index'.
      	(insert_intra_1): Add argument BB, set block for new note.
      	(make_reorder_chain): Do not depdent on BB indexes.
      	(make_reorder_chain_1): Do not use BB indexes.
      	(label_for_bb): Likewise; set BB for new insn.
      	(emit_jump_to_block_after): Likewise.
      	(fixup_reoder_chain): Sanity check that all basic blocks
      	are chained; verify newly created insn chain; remove
      	undocnitional jump simplifying; Do not use BB indexes;
      	properly initialize count and frequency information;
      	dump reordered sequence.
      	(insert_intra_bb_scope_notes): update call of insert_intra_1.
      	(insert_inter_bb_scope_notes): Set block for new insn.
      	(reorder_basic_blocks): Dump flow info before reoredering.
      
      From-SVN: r45504
      Jan Hubicka committed