diff options
author | kan <kan@FreeBSD.org> | 2004-07-28 03:11:36 +0000 |
---|---|---|
committer | kan <kan@FreeBSD.org> | 2004-07-28 03:11:36 +0000 |
commit | 5e00ec74d8ce58f99801200d4d3d0412c7cc1b28 (patch) | |
tree | 052f4bb635f2bea2c5e350bd60c902be100a0d1e /contrib/gcc/ra-rewrite.c | |
parent | 87b8398a7d9f9bf0e28bbcd54a4fc27db2125f38 (diff) | |
download | FreeBSD-src-5e00ec74d8ce58f99801200d4d3d0412c7cc1b28.zip FreeBSD-src-5e00ec74d8ce58f99801200d4d3d0412c7cc1b28.tar.gz |
Gcc 3.4.2 20040728.
Diffstat (limited to 'contrib/gcc/ra-rewrite.c')
-rw-r--r-- | contrib/gcc/ra-rewrite.c | 218 |
1 files changed, 91 insertions, 127 deletions
diff --git a/contrib/gcc/ra-rewrite.c b/contrib/gcc/ra-rewrite.c index 61645e2..44fde7d 100644 --- a/contrib/gcc/ra-rewrite.c +++ b/contrib/gcc/ra-rewrite.c @@ -1,5 +1,5 @@ /* Graph coloring register allocator - Copyright (C) 2001, 2002 Free Software Foundation, Inc. + Copyright (C) 2001, 2002, 2003 Free Software Foundation, Inc. Contributed by Michael Matz <matz@suse.de> and Daniel Berlin <dan@cgsoftware.com>. @@ -20,6 +20,8 @@ #include "config.h" #include "system.h" +#include "coretypes.h" +#include "tm.h" #include "rtl.h" #include "tm_p.h" #include "function.h" @@ -42,33 +44,32 @@ struct rewrite_info; struct rtx_list; -static void spill_coalescing PARAMS ((sbitmap, sbitmap)); -static unsigned HOST_WIDE_INT spill_prop_savings PARAMS ((struct web *, - sbitmap)); -static void spill_prop_insert PARAMS ((struct web *, sbitmap, sbitmap)); -static int spill_propagation PARAMS ((sbitmap, sbitmap, sbitmap)); -static void spill_coalprop PARAMS ((void)); -static void allocate_spill_web PARAMS ((struct web *)); -static void choose_spill_colors PARAMS ((void)); -static void rewrite_program PARAMS ((bitmap)); -static void remember_slot PARAMS ((struct rtx_list **, rtx)); -static int slots_overlap_p PARAMS ((rtx, rtx)); -static void delete_overlapping_slots PARAMS ((struct rtx_list **, rtx)); -static int slot_member_p PARAMS ((struct rtx_list *, rtx)); -static void insert_stores PARAMS ((bitmap)); -static int spill_same_color_p PARAMS ((struct web *, struct web *)); -static bool is_partly_live_1 PARAMS ((sbitmap, struct web *)); -static void update_spill_colors PARAMS ((HARD_REG_SET *, struct web *, int)); -static int spill_is_free PARAMS ((HARD_REG_SET *, struct web *)); -static void emit_loads PARAMS ((struct rewrite_info *, int, rtx)); -static void reloads_to_loads PARAMS ((struct rewrite_info *, struct ref **, - unsigned int, struct web **)); -static void rewrite_program2 PARAMS ((bitmap)); -static void mark_refs_for_checking PARAMS ((struct web *, bitmap)); -static void detect_web_parts_to_rebuild PARAMS ((void)); -static void delete_useless_defs PARAMS ((void)); -static void detect_non_changed_webs PARAMS ((void)); -static void reset_changed_flag PARAMS ((void)); +static void spill_coalescing (sbitmap, sbitmap); +static unsigned HOST_WIDE_INT spill_prop_savings (struct web *, sbitmap); +static void spill_prop_insert (struct web *, sbitmap, sbitmap); +static int spill_propagation (sbitmap, sbitmap, sbitmap); +static void spill_coalprop (void); +static void allocate_spill_web (struct web *); +static void choose_spill_colors (void); +static void rewrite_program (bitmap); +static void remember_slot (struct rtx_list **, rtx); +static int slots_overlap_p (rtx, rtx); +static void delete_overlapping_slots (struct rtx_list **, rtx); +static int slot_member_p (struct rtx_list *, rtx); +static void insert_stores (bitmap); +static int spill_same_color_p (struct web *, struct web *); +static bool is_partly_live_1 (sbitmap, struct web *); +static void update_spill_colors (HARD_REG_SET *, struct web *, int); +static int spill_is_free (HARD_REG_SET *, struct web *); +static void emit_loads (struct rewrite_info *, int, rtx); +static void reloads_to_loads (struct rewrite_info *, struct ref **, + unsigned int, struct web **); +static void rewrite_program2 (bitmap); +static void mark_refs_for_checking (struct web *, bitmap); +static void detect_web_parts_to_rebuild (void); +static void delete_useless_defs (void); +static void detect_non_changed_webs (void); +static void reset_changed_flag (void); /* For tracking some statistics, we count the number (and cost) of deleted move insns. */ @@ -82,8 +83,7 @@ static unsigned HOST_WIDE_INT deleted_move_cost; reduces memory shuffling. */ static void -spill_coalescing (coalesce, spilled) - sbitmap coalesce, spilled; +spill_coalescing (sbitmap coalesce, sbitmap spilled) { struct move_list *ml; struct move *m; @@ -158,9 +158,7 @@ spill_coalescing (coalesce, spilled) SPILLED, in terms of removed move insn cost. */ static unsigned HOST_WIDE_INT -spill_prop_savings (web, spilled) - struct web *web; - sbitmap spilled; +spill_prop_savings (struct web *web, sbitmap spilled) { unsigned HOST_WIDE_INT savings = 0; struct move_list *ml; @@ -194,9 +192,7 @@ spill_prop_savings (web, spilled) to LIST and PROCESSED. */ static void -spill_prop_insert (web, list, processed) - struct web *web; - sbitmap list, processed; +spill_prop_insert (struct web *web, sbitmap list, sbitmap processed) { struct move_list *ml; struct move *m; @@ -230,8 +226,7 @@ spill_prop_insert (web, list, processed) of all webs processed so far, so we don't do work twice. */ static int -spill_propagation (to_prop, spilled, processed) - sbitmap to_prop, spilled, processed; +spill_propagation (sbitmap to_prop, sbitmap spilled, sbitmap processed) { int id; int again = 0; @@ -273,7 +268,7 @@ spill_propagation (to_prop, spilled, processed) spill coalescing and spill propagation, until nothing changes. */ static void -spill_coalprop () +spill_coalprop (void) { sbitmap spilled, processed, to_prop; struct dlist *d; @@ -309,8 +304,7 @@ spill_coalprop () MEM references. */ static void -allocate_spill_web (web) - struct web *web; +allocate_spill_web (struct web *web) { int regno = web->regno; rtx slot; @@ -324,11 +318,10 @@ allocate_spill_web (web) spilling. The heuristic isn't good in any way. */ static void -choose_spill_colors () +choose_spill_colors (void) { struct dlist *d; - unsigned HOST_WIDE_INT *costs = (unsigned HOST_WIDE_INT *) - xmalloc (FIRST_PSEUDO_REGISTER * sizeof (costs[0])); + unsigned HOST_WIDE_INT *costs = xmalloc (FIRST_PSEUDO_REGISTER * sizeof (costs[0])); for (d = WEBS(SPILLED); d; d = d->next) { struct web *web = DLIST_WEB (d); @@ -396,8 +389,7 @@ static bitmap useless_defs; deaths. */ static void -rewrite_program (new_deaths) - bitmap new_deaths; +rewrite_program (bitmap new_deaths) { unsigned int i; struct dlist *d; @@ -452,8 +444,8 @@ rewrite_program (new_deaths) end_sequence (); emit_insn_before (insns, insn); - if (bb->head == insn) - bb->head = NEXT_INSN (prev); + if (BB_HEAD (bb) == insn) + BB_HEAD (bb) = NEXT_INSN (prev); for (insn = PREV_INSN (insn); insn != prev; insn = PREV_INSN (insn)) { @@ -500,8 +492,8 @@ rewrite_program (new_deaths) if (insns) { emit_insn_after (insns, insn); - if (bb->end == insn) - bb->end = PREV_INSN (following); + if (BB_END (bb) == insn) + BB_END (bb) = PREV_INSN (following); for (insn = insns; insn != following; insn = NEXT_INSN (insn)) { set_block_for_insn (insn, bb); @@ -537,13 +529,11 @@ struct rtx_list /* Adds X to *LIST. */ static void -remember_slot (list, x) - struct rtx_list **list; - rtx x; +remember_slot (struct rtx_list **list, rtx x) { struct rtx_list *l; /* PRE: X is not already in LIST. */ - l = (struct rtx_list *) ra_alloc (sizeof (*l)); + l = ra_alloc (sizeof (*l)); l->next = *list; l->x = x; *list = l; @@ -555,8 +545,7 @@ remember_slot (list, x) (plus (basereg) (const_inst x)), otherwise they overlap. */ static int -slots_overlap_p (s1, s2) - rtx s1, s2; +slots_overlap_p (rtx s1, rtx s2) { rtx base1, base2; HOST_WIDE_INT ofs1 = 0, ofs2 = 0; @@ -606,9 +595,7 @@ slots_overlap_p (s1, s2) of slots_overlap_p(). */ static void -delete_overlapping_slots (list, x) - struct rtx_list **list; - rtx x; +delete_overlapping_slots (struct rtx_list **list, rtx x) { while (*list) { @@ -622,9 +609,7 @@ delete_overlapping_slots (list, x) /* Returns nonzero, of X is member of LIST. */ static int -slot_member_p (list, x) - struct rtx_list *list; - rtx x; +slot_member_p (struct rtx_list *list, rtx x) { for (;list; list = list->next) if (rtx_equal_p (list->x, x)) @@ -639,8 +624,7 @@ slot_member_p (list, x) containing deaths. */ static void -insert_stores (new_deaths) - bitmap new_deaths; +insert_stores (bitmap new_deaths) { rtx insn; rtx last_slot = NULL_RTX; @@ -701,8 +685,8 @@ insert_stores (new_deaths) if (insns) { emit_insn_after (insns, insn); - if (bb->end == insn) - bb->end = PREV_INSN (following); + if (BB_END (bb) == insn) + BB_END (bb) = PREV_INSN (following); for (ni = insns; ni != following; ni = NEXT_INSN (ni)) { set_block_for_insn (ni, bb); @@ -749,8 +733,7 @@ insert_stores (new_deaths) they are not the same width. */ static int -spill_same_color_p (web1, web2) - struct web *web1, *web2; +spill_same_color_p (struct web *web1, struct web *web2) { int c1, size1, c2, size2; if ((c1 = alias (web1)->color) < 0 || c1 == an_unusable_color) @@ -771,9 +754,7 @@ spill_same_color_p (web1, web2) subwebs (or WEB itself) is live. */ static bool -is_partly_live_1 (live, web) - sbitmap live; - struct web *web; +is_partly_live_1 (sbitmap live, struct web *web) { do if (TEST_BIT (live, web->id)) @@ -792,10 +773,7 @@ is_partly_live_1 (live, web) is nonzero), or remove them. */ static void -update_spill_colors (in_use, web, add) - HARD_REG_SET *in_use; - struct web *web; - int add; +update_spill_colors (HARD_REG_SET *in_use, struct web *web, int add) { int c, size; if ((c = alias (find_web_for_subweb (web))->color) < 0 @@ -824,9 +802,7 @@ update_spill_colors (in_use, web, add) Generally, if WEB can't be left colorized return 1. */ static int -spill_is_free (in_use, web) - HARD_REG_SET *in_use; - struct web *web; +spill_is_free (HARD_REG_SET *in_use, struct web *web) { int c, size; if ((c = alias (web)->color) < 0) @@ -880,10 +856,7 @@ struct rewrite_info loads. LAST_BLOCK_INSN is the last insn of the current basic block. */ static void -emit_loads (ri, nl_first_reload, last_block_insn) - struct rewrite_info *ri; - int nl_first_reload; - rtx last_block_insn; +emit_loads (struct rewrite_info *ri, int nl_first_reload, rtx last_block_insn) { int j; for (j = ri->nl_size; j;) @@ -968,8 +941,8 @@ emit_loads (ri, nl_first_reload, last_block_insn) rtx foll = NEXT_INSN (after); bb = BLOCK_FOR_INSN (after); emit_insn_after (ni, after); - if (bb->end == after) - bb->end = PREV_INSN (foll); + if (BB_END (bb) == after) + BB_END (bb) = PREV_INSN (foll); for (ni = NEXT_INSN (after); ni != foll; ni = NEXT_INSN (ni)) { set_block_for_insn (ni, bb); @@ -981,8 +954,8 @@ emit_loads (ri, nl_first_reload, last_block_insn) rtx prev = PREV_INSN (before); bb = BLOCK_FOR_INSN (before); emit_insn_before (ni, before); - if (bb->head == before) - bb->head = NEXT_INSN (prev); + if (BB_HEAD (bb) == before) + BB_HEAD (bb) = NEXT_INSN (prev); for (; ni != before; ni = NEXT_INSN (ni)) { set_block_for_insn (ni, bb); @@ -1017,11 +990,8 @@ emit_loads (ri, nl_first_reload, last_block_insn) and whose colors isn't free anymore, on the needed_loads list. */ static void -reloads_to_loads (ri, refs, num_refs, ref2web) - struct rewrite_info *ri; - struct ref **refs; - unsigned int num_refs; - struct web **ref2web; +reloads_to_loads (struct rewrite_info *ri, struct ref **refs, + unsigned int num_refs, struct web **ref2web) { unsigned int n; int num_reloads = ri->num_reloads; @@ -1080,14 +1050,13 @@ reloads_to_loads (ri, refs, num_refs, ref2web) containing deaths). */ static void -rewrite_program2 (new_deaths) - bitmap new_deaths; +rewrite_program2 (bitmap new_deaths) { - basic_block bb; + basic_block bb = NULL; int nl_first_reload; struct rewrite_info ri; rtx insn; - ri.needed_loads = (struct web **) xmalloc (num_webs * sizeof (struct web *)); + ri.needed_loads = xmalloc (num_webs * sizeof (struct web *)); ri.need_reload = BITMAP_XMALLOC (); ri.scratch = BITMAP_XMALLOC (); ri.live = sbitmap_alloc (num_webs); @@ -1444,9 +1413,7 @@ rewrite_program2 (new_deaths) Also remember all IDs of its uses in USES_AS_BITMAP. */ static void -mark_refs_for_checking (web, uses_as_bitmap) - struct web *web; - bitmap uses_as_bitmap; +mark_refs_for_checking (struct web *web, bitmap uses_as_bitmap) { unsigned int i; for (i = 0; i < web->num_uses; i++) @@ -1472,7 +1439,7 @@ mark_refs_for_checking (web, uses_as_bitmap) information, we will rebuild. */ static void -detect_web_parts_to_rebuild () +detect_web_parts_to_rebuild (void) { bitmap uses_as_bitmap; unsigned int i, pass; @@ -1487,7 +1454,7 @@ detect_web_parts_to_rebuild () sbitmap_zero (already_webs); /* We need to recheck all uses of all webs involved in spilling (and the uses added by spill insns, but those are not analyzed yet). - Those are the spilled webs themself, webs coalesced to spilled ones, + Those are the spilled webs themselves, webs coalesced to spilled ones, and webs conflicting with any of them. */ for (pass = 0; pass < 2; pass++) for (d = (pass == 0) ? WEBS(SPILLED) : WEBS(COALESCED); d; d = d->next) @@ -1543,7 +1510,7 @@ detect_web_parts_to_rebuild () /* We also recheck unconditionally all uses of any hardregs. This means we _can_ delete all these uses from the live_at_end[] bitmaps. - And because we sometimes delete insn refering to hardregs (when + And because we sometimes delete insn referring to hardregs (when they became useless because they setup a rematerializable pseudo, which then was rematerialized), some of those uses will go away with the next df_analyse(). This means we even _must_ delete those uses from @@ -1584,7 +1551,7 @@ static unsigned HOST_WIDE_INT deleted_def_cost; which wasn't live. Try to delete all those insns. */ static void -delete_useless_defs () +delete_useless_defs (void) { unsigned int i; /* If the insn only sets the def without any sideeffect (besides @@ -1612,7 +1579,7 @@ delete_useless_defs () in this pass). */ static void -detect_non_changed_webs () +detect_non_changed_webs (void) { struct dlist *d, *d_next; for (d = WEBS(SPILLED); d; d = d_next) @@ -1638,7 +1605,7 @@ detect_non_changed_webs () /* Before spilling we clear the changed flags for all spilled webs. */ static void -reset_changed_flag () +reset_changed_flag (void) { struct dlist *d; for (d = WEBS(SPILLED); d; d = d->next) @@ -1651,7 +1618,7 @@ reset_changed_flag () building the interference graph in the next pass. */ void -actual_spill () +actual_spill (void) { int i; bitmap new_deaths = BITMAP_XMALLOC (); @@ -1686,8 +1653,7 @@ static bitmap regnos_coalesced_to_hardregs; use those pseudos and set up ra_reg_renumber. */ void -emit_colors (df) - struct df *df; +emit_colors (struct df *df) { unsigned int i; int si; @@ -1748,7 +1714,7 @@ emit_colors (df) } ra_max_regno = max_regno = max_reg_num (); allocate_reg_info (max_regno, FALSE, FALSE); - ra_reg_renumber = (short *) xmalloc (max_regno * sizeof (short)); + ra_reg_renumber = xmalloc (max_regno * sizeof (short)); for (si = 0; si < max_regno; si++) ra_reg_renumber[si] = -1; @@ -1839,7 +1805,7 @@ emit_colors (df) /* Delete some coalesced moves from the insn stream. */ void -delete_moves () +delete_moves (void) { struct move_list *ml; struct web *s, *t; @@ -1884,7 +1850,7 @@ delete_moves () } } -/* Due to resons documented elsewhere we create different pseudos +/* Due to reasons documented elsewhere we create different pseudos for all webs coalesced to hardregs. For these parts life_analysis() might have added REG_DEAD notes without considering, that only this part but not the whole coalesced web dies. The RTL is correct, there is no @@ -1897,7 +1863,7 @@ delete_moves () that comes later) Bah. */ void -remove_suspicious_death_notes () +remove_suspicious_death_notes (void) { rtx insn; for (insn = get_insns(); insn; insn = NEXT_INSN (insn)) @@ -1926,8 +1892,7 @@ remove_suspicious_death_notes () is nonzero, also free ra_reg_renumber and reset ra_max_regno. */ void -setup_renumber (free_it) - int free_it; +setup_renumber (int free_it) { int i; max_regno = max_reg_num (); @@ -1948,27 +1913,26 @@ setup_renumber (free_it) and removed moves or useless defs. */ void -dump_cost (level) - unsigned int level; +dump_cost (unsigned int level) { ra_debug_msg (level, "Instructions for spilling\n added:\n"); - ra_debug_msg (level, " loads =%d cost=", emitted_spill_loads); - ra_debug_msg (level, HOST_WIDE_INT_PRINT_UNSIGNED, spill_load_cost); - ra_debug_msg (level, "\n stores=%d cost=", emitted_spill_stores); - ra_debug_msg (level, HOST_WIDE_INT_PRINT_UNSIGNED, spill_store_cost); - ra_debug_msg (level, "\n remat =%d cost=", emitted_remat); - ra_debug_msg (level, HOST_WIDE_INT_PRINT_UNSIGNED, spill_remat_cost); - ra_debug_msg (level, "\n removed:\n moves =%d cost=", deleted_move_insns); - ra_debug_msg (level, HOST_WIDE_INT_PRINT_UNSIGNED, deleted_move_cost); - ra_debug_msg (level, "\n others=%d cost=", deleted_def_insns); - ra_debug_msg (level, HOST_WIDE_INT_PRINT_UNSIGNED, deleted_def_cost); - ra_debug_msg (level, "\n"); + ra_debug_msg (level, " loads =%d cost=" HOST_WIDE_INT_PRINT_UNSIGNED "\n", + emitted_spill_loads, spill_load_cost); + ra_debug_msg (level, " stores=%d cost=" HOST_WIDE_INT_PRINT_UNSIGNED "\n", + emitted_spill_stores, spill_store_cost); + ra_debug_msg (level, " remat =%d cost=" HOST_WIDE_INT_PRINT_UNSIGNED "\n", + emitted_remat, spill_remat_cost); + ra_debug_msg (level, " removed:\n moves =%d cost=" + HOST_WIDE_INT_PRINT_UNSIGNED "\n", + deleted_move_insns, deleted_move_cost); + ra_debug_msg (level, " others=%d cost=" HOST_WIDE_INT_PRINT_UNSIGNED "\n", + deleted_def_insns, deleted_def_cost); } /* Initialization of the rewrite phase. */ void -ra_rewrite_init () +ra_rewrite_init (void) { emitted_spill_loads = 0; emitted_spill_stores = 0; |