aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDavid Malcolm <dmalcolm@redhat.com>2014-08-25 21:22:02 +0000
committerDavid Malcolm <dmalcolm@gcc.gnu.org>2014-08-25 21:22:02 +0000
commitb311fd0f70cb3687dd0c2fd01beb358aba3fdb79 (patch)
tree45d21174cb693c4107abd15c5d5388f51572e027
parentce1ce33a037057b77a99ed0613f4369546dc82cd (diff)
downloadgcc-b311fd0f70cb3687dd0c2fd01beb358aba3fdb79.zip
gcc-b311fd0f70cb3687dd0c2fd01beb358aba3fdb79.tar.gz
gcc-b311fd0f70cb3687dd0c2fd01beb358aba3fdb79.tar.bz2
Eliminate BB_NOTE_LIST scaffolding
gcc/ * sel-sched-ir.h (struct sel_region_bb_info_def): Strengthen field "note_list" from rtx to rtx_insn *. (BB_NOTE_LIST): Replace this function and... (SET_BB_NOTE_LIST): ...this function with... (BB_NOTE_LIST): ...the former macro implementation. * sched-int.h (concat_note_lists): Strengthen param "from_end" and local "from_start" from rtx to rtx_insn *. Strengthen param "to_endp" from rtx * to rtx_insn **. * haifa-sched.c (concat_note_lists): Likewise. * sel-sched-ir.c (init_bb): Eliminate SET_BB_NOTE_LIST in favor of BB_NOTE_LIST. (sel_restore_notes): Likewise. (move_bb_info): Likewise. (BB_NOTE_LIST): Delete this function. (SET_BB_NOTE_LIST): Delete this function. * sel-sched.c (create_block_for_bookkeeping): Eliminate SET_BB_NOTE_LIST in favor of BB_NOTE_LIST. / * rtx-classes-status.txt (TODO): Remove SET_BB_NOTE_LIST. From-SVN: r214482
-rw-r--r--ChangeLog4
-rw-r--r--gcc/ChangeLog22
-rw-r--r--gcc/haifa-sched.c4
-rw-r--r--gcc/sched-int.h2
-rw-r--r--gcc/sel-sched-ir.c19
-rw-r--r--gcc/sel-sched-ir.h5
-rw-r--r--gcc/sel-sched.c4
-rw-r--r--rtx-classes-status.txt1
8 files changed, 37 insertions, 24 deletions
diff --git a/ChangeLog b/ChangeLog
index 8363862..1cf31c4 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,9 @@
2014-08-25 David Malcolm <dmalcolm@redhat.com>
+ * rtx-classes-status.txt (TODO): Remove SET_BB_NOTE_LIST.
+
+2014-08-25 David Malcolm <dmalcolm@redhat.com>
+
* rtx-classes-status.txt (TODO): Remove SET_BB_FOOTER.
2014-08-25 David Malcolm <dmalcolm@redhat.com>
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 665e2d7..0dc27a0 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,5 +1,27 @@
2014-08-25 David Malcolm <dmalcolm@redhat.com>
+ * sel-sched-ir.h (struct sel_region_bb_info_def): Strengthen field
+ "note_list" from rtx to rtx_insn *.
+ (BB_NOTE_LIST): Replace this function and...
+ (SET_BB_NOTE_LIST): ...this function with...
+ (BB_NOTE_LIST): ...the former macro implementation.
+
+ * sched-int.h (concat_note_lists): Strengthen param "from_end" and
+ local "from_start" from rtx to rtx_insn *. Strengthen param
+ "to_endp" from rtx * to rtx_insn **.
+
+ * haifa-sched.c (concat_note_lists): Likewise.
+ * sel-sched-ir.c (init_bb): Eliminate SET_BB_NOTE_LIST in favor of
+ BB_NOTE_LIST.
+ (sel_restore_notes): Likewise.
+ (move_bb_info): Likewise.
+ (BB_NOTE_LIST): Delete this function.
+ (SET_BB_NOTE_LIST): Delete this function.
+ * sel-sched.c (create_block_for_bookkeeping): Eliminate
+ SET_BB_NOTE_LIST in favor of BB_NOTE_LIST.
+
+2014-08-25 David Malcolm <dmalcolm@redhat.com>
+
* target.def (reorder): Strengthen param "ready" of this DEFHOOK
from rtx * to rtx_insn **.
(reorder2): Likewise.
diff --git a/gcc/haifa-sched.c b/gcc/haifa-sched.c
index 18f5726..45938bd 100644
--- a/gcc/haifa-sched.c
+++ b/gcc/haifa-sched.c
@@ -4005,9 +4005,9 @@ schedule_insn (rtx_insn *insn)
/* Add note list that ends on FROM_END to the end of TO_ENDP. */
void
-concat_note_lists (rtx from_end, rtx *to_endp)
+concat_note_lists (rtx_insn *from_end, rtx_insn **to_endp)
{
- rtx from_start;
+ rtx_insn *from_start;
/* It's easy when have nothing to concat. */
if (from_end == NULL)
diff --git a/gcc/sched-int.h b/gcc/sched-int.h
index 2e52722..9f2a3e4 100644
--- a/gcc/sched-int.h
+++ b/gcc/sched-int.h
@@ -1370,7 +1370,7 @@ extern int sched_speculate_insn (rtx, ds_t, rtx *);
extern void unlink_bb_notes (basic_block, basic_block);
extern void add_block (basic_block, basic_block);
extern rtx_note *bb_note (basic_block);
-extern void concat_note_lists (rtx, rtx *);
+extern void concat_note_lists (rtx_insn *, rtx_insn **);
extern rtx_insn *sched_emit_insn (rtx);
extern rtx get_ready_element (int);
extern int number_in_ready (void);
diff --git a/gcc/sel-sched-ir.c b/gcc/sel-sched-ir.c
index 0531b28..c36658f 100644
--- a/gcc/sel-sched-ir.c
+++ b/gcc/sel-sched-ir.c
@@ -4623,7 +4623,7 @@ static void
init_bb (basic_block bb)
{
remove_notes (bb_note (bb), BB_END (bb));
- SET_BB_NOTE_LIST (bb) = note_list;
+ BB_NOTE_LIST (bb) = note_list;
}
void
@@ -4658,7 +4658,7 @@ sel_restore_notes (void)
{
note_list = BB_NOTE_LIST (first);
restore_other_notes (NULL, first);
- SET_BB_NOTE_LIST (first) = NULL_RTX;
+ BB_NOTE_LIST (first) = NULL;
FOR_BB_INSNS (first, insn)
if (NONDEBUG_INSN_P (insn))
@@ -5266,8 +5266,8 @@ move_bb_info (basic_block merge_bb, basic_block empty_bb)
{
if (in_current_region_p (merge_bb))
concat_note_lists (BB_NOTE_LIST (empty_bb),
- &SET_BB_NOTE_LIST (merge_bb));
- SET_BB_NOTE_LIST (empty_bb) = NULL_RTX;
+ &BB_NOTE_LIST (merge_bb));
+ BB_NOTE_LIST (empty_bb) = NULL;
}
@@ -6456,17 +6456,6 @@ rtx& SET_VINSN_INSN_RTX (vinsn_t vi)
return vi->insn_rtx;
}
-rtx_insn *BB_NOTE_LIST (basic_block bb)
-{
- rtx note_list = SEL_REGION_BB_INFO (bb)->note_list;
- return safe_as_a <rtx_insn *> (note_list);
-}
-
-rtx& SET_BB_NOTE_LIST (basic_block bb)
-{
- return SEL_REGION_BB_INFO (bb)->note_list;
-}
-
rtx_insn *BND_TO (bnd_t bnd)
{
return safe_as_a <rtx_insn *> (bnd->to);
diff --git a/gcc/sel-sched-ir.h b/gcc/sel-sched-ir.h
index d2bf7e2..2af7f03 100644
--- a/gcc/sel-sched-ir.h
+++ b/gcc/sel-sched-ir.h
@@ -898,7 +898,7 @@ struct sel_region_bb_info_def
{
/* This insn stream is constructed in such a way that it should be
traversed by PREV_INSN field - (*not* NEXT_INSN). */
- rtx note_list;
+ rtx_insn *note_list;
/* Cached availability set at the beginning of a block.
See also AV_LEVEL () for conditions when this av_set can be used. */
@@ -921,8 +921,7 @@ extern vec<sel_region_bb_info_def> sel_region_bb_info;
A note_list is a list of various notes that was scattered across BB
before scheduling, and will be appended at the beginning of BB after
scheduling is finished. */
-extern rtx_insn *BB_NOTE_LIST (basic_block);
-extern rtx& SET_BB_NOTE_LIST (basic_block);
+#define BB_NOTE_LIST(BB) (SEL_REGION_BB_INFO (BB)->note_list)
#define BB_AV_SET(BB) (SEL_REGION_BB_INFO (BB)->av_set)
#define BB_AV_LEVEL(BB) (SEL_REGION_BB_INFO (BB)->av_level)
diff --git a/gcc/sel-sched.c b/gcc/sel-sched.c
index 91d194a..15c375c 100644
--- a/gcc/sel-sched.c
+++ b/gcc/sel-sched.c
@@ -4586,8 +4586,8 @@ create_block_for_bookkeeping (edge e1, edge e2)
/* Move note_list from the upper bb. */
gcc_assert (BB_NOTE_LIST (new_bb) == NULL_RTX);
- SET_BB_NOTE_LIST (new_bb) = BB_NOTE_LIST (bb);
- SET_BB_NOTE_LIST (bb) = NULL_RTX;
+ BB_NOTE_LIST (new_bb) = BB_NOTE_LIST (bb);
+ BB_NOTE_LIST (bb) = NULL;
gcc_assert (e2->dest == bb);
diff --git a/rtx-classes-status.txt b/rtx-classes-status.txt
index 85ce474..dd44bbf 100644
--- a/rtx-classes-status.txt
+++ b/rtx-classes-status.txt
@@ -16,7 +16,6 @@ TODO: "Scaffolding" to be removed
=================================
* DF_REF_INSN
* SET_BB_HEAD, SET_BB_END, SET_BB_HEADER
-* SET_BB_NOTE_LIST
* SET_BND_TO
* SET_DEP_PRO, SET_DEP_CON
* SET_NEXT_INSN, SET_PREV_INSN