aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorRevital Eres <revital.eres@linaro.org>2011-05-11 07:40:26 +0000
committerRevital Eres <revitale@gcc.gnu.org>2011-05-11 07:40:26 +0000
commitca7566250ff8874b9bd02fb1215d0ee2ba43eef7 (patch)
treef10942cfe3e5254db2a4fa19afd22a8f0a324af4 /gcc
parentb8abece3d06f66a8fb8b2a7dcabfb54a5b397c7b (diff)
downloadgcc-ca7566250ff8874b9bd02fb1215d0ee2ba43eef7.zip
gcc-ca7566250ff8874b9bd02fb1215d0ee2ba43eef7.tar.gz
gcc-ca7566250ff8874b9bd02fb1215d0ee2ba43eef7.tar.bz2
Skip DEBUG_INSNs while recognizing doloop
From-SVN: r173647
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog5
-rw-r--r--gcc/modulo-sched.c4
2 files changed, 7 insertions, 2 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 1ea9d00..60e7c76 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,5 +1,10 @@
2011-05-11 Revital Eres <revital.eres@linaro.org>
+ * modulo-sched.c (doloop_register_get): Ignore DEBUG_INSNs while
+ recognizing doloop.
+
+2011-05-11 Revital Eres <revital.eres@linaro.org>
+
* loop-doloop.c (doloop_condition_get): Use prev_nondebug_insn
instead of PREV_INSN.
diff --git a/gcc/modulo-sched.c b/gcc/modulo-sched.c
index 091c005..0f525af 100644
--- a/gcc/modulo-sched.c
+++ b/gcc/modulo-sched.c
@@ -310,10 +310,10 @@ doloop_register_get (rtx head ATTRIBUTE_UNUSED, rtx tail ATTRIBUTE_UNUSED)
either a single (parallel) branch-on-count or a (non-parallel)
branch immediately preceded by a single (decrement) insn. */
first_insn_not_to_check = (GET_CODE (PATTERN (tail)) == PARALLEL ? tail
- : PREV_INSN (tail));
+ : prev_nondebug_insn (tail));
for (insn = head; insn != first_insn_not_to_check; insn = NEXT_INSN (insn))
- if (reg_mentioned_p (reg, insn))
+ if (reg_mentioned_p (reg, insn) && !DEBUG_INSN_P (insn))
{
if (dump_file)
{