diff options
author | mkuvyrkov <mkuvyrkov@138bc75d-0d04-0410-961f-82ee72b054a4> | 2009-07-09 18:15:22 +0000 |
---|---|---|
committer | mkuvyrkov <mkuvyrkov@138bc75d-0d04-0410-961f-82ee72b054a4> | 2009-07-09 18:15:22 +0000 |
commit | 4db82bc99870e5503860c49ac55ffbd8a3fdcf52 (patch) | |
tree | 3cb914bdfcf5212d19e7a8855b5c111e763388ba | |
parent | 30b38676a534b789072b190f016b941cb2d95be4 (diff) | |
download | gcc-4db82bc99870e5503860c49ac55ffbd8a3fdcf52.tar.gz |
* haifa-sched.c (insn_finishes_cycle_p): New static function.
(max_issue): Use it.
* sched-int.h (struct sched_info: insn_finishes_block_p): New
scheduler hook.
* sched-rgn.c (rgn_insn_finishes_block_p): Implement it.
(region_sched_info): Update.
* sched-ebb.c (ebb_sched_info): Update.
* modulo-sched.c (sms_sched_info): Update.
* sel-sched-ir.c (sched_sel_haifa_sched_info): Update.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@149427 138bc75d-0d04-0410-961f-82ee72b054a4
-rw-r--r-- | gcc/ChangeLog | 12 | ||||
-rw-r--r-- | gcc/haifa-sched.c | 22 | ||||
-rw-r--r-- | gcc/modulo-sched.c | 1 | ||||
-rw-r--r-- | gcc/sched-ebb.c | 1 | ||||
-rw-r--r-- | gcc/sched-int.h | 4 | ||||
-rw-r--r-- | gcc/sched-rgn.c | 14 | ||||
-rw-r--r-- | gcc/sel-sched-ir.c | 1 |
7 files changed, 54 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 9813255fdb8..01dff9e73c6 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,4 +1,16 @@ 2009-07-09 Maxim Kuvyrkov <maxim@codesourcery.com> + + * haifa-sched.c (insn_finishes_cycle_p): New static function. + (max_issue): Use it. + * sched-int.h (struct sched_info: insn_finishes_block_p): New + scheduler hook. + * sched-rgn.c (rgn_insn_finishes_block_p): Implement it. + (region_sched_info): Update. + * sched-ebb.c (ebb_sched_info): Update. + * modulo-sched.c (sms_sched_info): Update. + * sel-sched-ir.c (sched_sel_haifa_sched_info): Update. + +2009-07-09 Maxim Kuvyrkov <maxim@codesourcery.com> * varasm.c (build_constant_desc): Don't share RTL in pool entries. diff --git a/gcc/haifa-sched.c b/gcc/haifa-sched.c index eff10c87628..66be7e5d94b 100644 --- a/gcc/haifa-sched.c +++ b/gcc/haifa-sched.c @@ -1990,6 +1990,23 @@ move_insn (rtx insn, rtx last, rtx nt) SCHED_GROUP_P (insn) = 0; } +/* Return true if scheduling INSN will finish current clock cycle. */ +static bool +insn_finishes_cycle_p (rtx insn) +{ + if (SCHED_GROUP_P (insn)) + /* After issuing INSN, rest of the sched_group will be forced to issue + in order. Don't make any plans for the rest of cycle. */ + return true; + + /* Finishing the block will, apparently, finish the cycle. */ + if (current_sched_info->insn_finishes_block_p + && current_sched_info->insn_finishes_block_p (insn)) + return true; + + return false; +} + /* The following structure describe an entry of the stack of choices. */ struct choice_entry { @@ -2168,7 +2185,10 @@ max_issue (struct ready_list *ready, int privileged_n, state_t state, delay = state_transition (state, insn); if (delay < 0) { - if (state_dead_lock_p (state)) + if (state_dead_lock_p (state) + || insn_finishes_cycle_p (insn)) + /* We won't issue any more instructions in the next + choice_state. */ top->rest = 0; else top->rest--; diff --git a/gcc/modulo-sched.c b/gcc/modulo-sched.c index 6089580ed4d..dbe77d9c54c 100644 --- a/gcc/modulo-sched.c +++ b/gcc/modulo-sched.c @@ -270,6 +270,7 @@ static struct haifa_sched_info sms_sched_info = NULL, sms_print_insn, NULL, + NULL, /* insn_finishes_block_p */ NULL, NULL, NULL, NULL, 0, 0, diff --git a/gcc/sched-ebb.c b/gcc/sched-ebb.c index 2773a36d1bd..b3e6c7a7265 100644 --- a/gcc/sched-ebb.c +++ b/gcc/sched-ebb.c @@ -286,6 +286,7 @@ static struct haifa_sched_info ebb_sched_info = rank, ebb_print_insn, ebb_contributes_to_priority, + NULL, /* insn_finishes_block_p */ NULL, NULL, NULL, NULL, diff --git a/gcc/sched-int.h b/gcc/sched-int.h index 1b6a0345a01..aa5007ba863 100644 --- a/gcc/sched-int.h +++ b/gcc/sched-int.h @@ -570,6 +570,10 @@ struct haifa_sched_info calculations. */ int (*contributes_to_priority) (rtx, rtx); + /* Return true if scheduling insn (passed as the parameter) will trigger + finish of scheduling current block. */ + bool (*insn_finishes_block_p) (rtx); + /* The boundaries of the set of insns to be scheduled. */ rtx prev_head, next_tail; diff --git a/gcc/sched-rgn.c b/gcc/sched-rgn.c index 004064ecf42..a913faa217a 100644 --- a/gcc/sched-rgn.c +++ b/gcc/sched-rgn.c @@ -2338,6 +2338,19 @@ static const struct sched_deps_info_def rgn_const_sel_sched_deps_info = 0, 0, 0 }; +/* Return true if scheduling INSN will trigger finish of scheduling + current block. */ +static bool +rgn_insn_finishes_block_p (rtx insn) +{ + if (INSN_BB (insn) == target_bb + && sched_target_n_insns + 1 == target_n_insns) + /* INSN is the last not-scheduled instruction in the current block. */ + return true; + + return false; +} + /* Used in schedule_insns to initialize current_sched_info for scheduling regions (or single basic blocks). */ @@ -2350,6 +2363,7 @@ static const struct haifa_sched_info rgn_const_sched_info = rgn_rank, rgn_print_insn, contributes_to_priority, + rgn_insn_finishes_block_p, NULL, NULL, NULL, NULL, diff --git a/gcc/sel-sched-ir.c b/gcc/sel-sched-ir.c index 698612fb9a2..2932800f569 100644 --- a/gcc/sel-sched-ir.c +++ b/gcc/sel-sched-ir.c @@ -5427,6 +5427,7 @@ static struct haifa_sched_info sched_sel_haifa_sched_info = NULL, /* rgn_rank */ sel_print_insn, /* rgn_print_insn */ contributes_to_priority, + NULL, /* insn_finishes_block_p */ NULL, NULL, NULL, NULL, |