summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorrsandifo <rsandifo@138bc75d-0d04-0410-961f-82ee72b054a4>2010-07-12 19:04:21 +0000
committerrsandifo <rsandifo@138bc75d-0d04-0410-961f-82ee72b054a4>2010-07-12 19:04:21 +0000
commit03a75ccf13890665c526af2ed013c1bd3d043d8a (patch)
treed585bd9a727662ed7182cfeb363f23fa1011da6b
parent22d65d2c5f380476cb0375bfb086d95c4f10b7fb (diff)
downloadgcc-03a75ccf13890665c526af2ed013c1bd3d043d8a.tar.gz
gcc/
* reginfo.c (init_reg_sets): Don't zero globals here. Update comment to say that the function can be called more than once. * target-globals.c (save_target_globals): Call init_reg_sets. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@162110 138bc75d-0d04-0410-961f-82ee72b054a4
-rw-r--r--gcc/ChangeLog6
-rw-r--r--gcc/reginfo.c6
-rw-r--r--gcc/target-globals.c1
3 files changed, 10 insertions, 3 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index f8075c596fa..0f2a7defaba 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,5 +1,11 @@
2010-07-12 Richard Sandiford <rdsandiford@googlemail.com>
+ * reginfo.c (init_reg_sets): Don't zero globals here. Update comment
+ to say that the function can be called more than once.
+ * target-globals.c (save_target_globals): Call init_reg_sets.
+
+2010-07-12 Richard Sandiford <rdsandiford@googlemail.com>
+
* Makefile.in (bb-reorder.o, target-globals.o): Depend on bb-reorder.h
* bb-reorder.h: New file.
* bb-reorder.c (default_target_bb_reorder): New variable.
diff --git a/gcc/reginfo.c b/gcc/reginfo.c
index deb62b761a4..0fc86d3627f 100644
--- a/gcc/reginfo.c
+++ b/gcc/reginfo.c
@@ -142,8 +142,9 @@ reg_set_to_hard_reg_set (HARD_REG_SET *to, const_bitmap from)
}
}
-/* Function called only once to initialize the above data on reg usage.
- Once this is done, various switches may override. */
+/* Function called only once per target_globals to initialize the
+ target_hard_regs structure. Once this is done, various switches
+ may override. */
void
init_reg_sets (void)
{
@@ -186,7 +187,6 @@ init_reg_sets (void)
memcpy (reg_alloc_order, initial_reg_alloc_order, sizeof reg_alloc_order);
#endif
memcpy (reg_names, initial_reg_names, sizeof reg_names);
- memset (global_regs, 0, sizeof global_regs);
}
/* Initialize may_move_cost and friends for mode M. */
diff --git a/gcc/target-globals.c b/gcc/target-globals.c
index 49b9dc85457..7a4058ebd18 100644
--- a/gcc/target-globals.c
+++ b/gcc/target-globals.c
@@ -80,6 +80,7 @@ save_target_globals (void)
g->gcse = XCNEW (struct target_gcse);
g->bb_reorder = XCNEW (struct target_bb_reorder);
restore_target_globals (g);
+ init_reg_sets ();
target_reinit ();
return g;
}