diff options
author | vmakarov <vmakarov@138bc75d-0d04-0410-961f-82ee72b054a4> | 2008-11-19 21:20:44 +0000 |
---|---|---|
committer | vmakarov <vmakarov@138bc75d-0d04-0410-961f-82ee72b054a4> | 2008-11-19 21:20:44 +0000 |
commit | 69f8e08094a3f6e518c08f323bc2687ffe696c9e (patch) | |
tree | 5b79c7c3d997c7b687af33f6229b6111cc84177b /gcc/ira-int.h | |
parent | d046014d4feb3098f10fd9f83d0288772628c3aa (diff) | |
download | gcc-69f8e08094a3f6e518c08f323bc2687ffe696c9e.tar.gz |
2008-11-15 Vladimir Makarov <vmakarov@redhat.com>
PR bootstrap/37790
* ira-int.h (ira_copy_allocno_live_range_list,
ira_merge_allocno_live_ranges,
ira_allocno_live_ranges_intersect_p,
ira_finish_allocno_live_range_list): New prototypes.
(ira_allocno_live_ranges_intersect_p,
ira_pseudo_live_ranges_intersect_p): Remove.
* ira-conflicts.c (ira_allocno_live_ranges_intersect_p,
ira_pseudo_live_ranges_intersect_p): Rename to
allocnos_have_intersected_live_ranges_p and
pseudos_have_intersected_live_ranges_p. Move them from here to
...
* ira-color.c: ... here
(coalesced_allocno_conflict_p): Use
allocnos_have_intersected_live_ranges_p.
(coalesced_allocnos_living_at_program_points,
coalesced_allocnos_live_at_points_p,
set_coalesced_allocnos_live_points): Remove.
(slot_coalesced_allocnos_live_ranges,
slot_coalesced_allocno_live_ranges_intersect_p,
setup_slot_coalesced_allocno_live_ranges): New.
(coalesce_spill_slots): Use ranges of coalesced allocnos.
(ira_sort_regnos_for_alter_reg): Use
allocnos_have_intersected_live_ranges_p.
(ira_reuse_stack_slot): Use
pseudos_have_intersected_live_ranges_p.
* global.c (pseudo_for_reload_consideration_p): Check
flag_ira_share_spill_slots too.
* ira-build.c (copy_allocno_live_range_list): Rename to
ira_copy_allocno_live_range_list. Make it external.
(merge_ranges): Rename to ira_merge_allocno_live_ranges. Make it
external.
(ira_allocno_live_ranges_intersect_p): New.
(ira_finish_allocno_live_range_list): New.
(finish_allocno): Use it.
(remove_unnecessary_allocnos): Use ira_merge_allocno_live_ranges.
(copy_info_to_removed_store_destinations): Ditto. Use
ira_copy_allocno_live_range_list.
(ira_flattening): Use ira_merge_allocno_live_ranges.
* ira.c (too_high_register_pressure_p): New function.
(ira): Switch off sharing spill slots if the pressure is too high.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@142017 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/ira-int.h')
-rw-r--r-- | gcc/ira-int.h | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/gcc/ira-int.h b/gcc/ira-int.h index 0b2e9280388..7f5479b7b57 100644 --- a/gcc/ira-int.h +++ b/gcc/ira-int.h @@ -862,7 +862,14 @@ extern void ira_add_allocno_conflict (ira_allocno_t, ira_allocno_t); extern void ira_print_expanded_allocno (ira_allocno_t); extern allocno_live_range_t ira_create_allocno_live_range (ira_allocno_t, int, int, allocno_live_range_t); +extern allocno_live_range_t ira_copy_allocno_live_range_list + (allocno_live_range_t); +extern allocno_live_range_t ira_merge_allocno_live_ranges + (allocno_live_range_t, allocno_live_range_t); +extern bool ira_allocno_live_ranges_intersect_p (allocno_live_range_t, + allocno_live_range_t); extern void ira_finish_allocno_live_range (allocno_live_range_t); +extern void ira_finish_allocno_live_range_list (allocno_live_range_t); extern void ira_free_allocno_updated_costs (ira_allocno_t); extern ira_copy_t ira_create_copy (ira_allocno_t, ira_allocno_t, int, bool, rtx, ira_loop_tree_node_t); @@ -898,8 +905,6 @@ extern void ira_compress_allocno_live_ranges (void); extern void ira_finish_allocno_live_ranges (void); /* ira-conflicts.c */ -extern bool ira_allocno_live_ranges_intersect_p (ira_allocno_t, ira_allocno_t); -extern bool ira_pseudo_live_ranges_intersect_p (int, int); extern void ira_debug_conflicts (bool); extern void ira_build_conflicts (void); |