summaryrefslogtreecommitdiff
path: root/gcc/final.c
diff options
context:
space:
mode:
authorlaw <law@138bc75d-0d04-0410-961f-82ee72b054a4>2000-06-13 16:06:26 +0000
committerlaw <law@138bc75d-0d04-0410-961f-82ee72b054a4>2000-06-13 16:06:26 +0000
commit07c6fb8736fc84b5978f0111447afbd7caf478df (patch)
tree92faf5042f2368cd34d4381090cd55578905517c /gcc/final.c
parent358104ac5711cc5ee1b453355bfcf335c2278048 (diff)
downloadgcc-07c6fb8736fc84b5978f0111447afbd7caf478df.tar.gz
* final.c (final_scan_insn): Delete notes between cc0 setter and
user when restarting from setter. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@34517 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/final.c')
-rw-r--r--gcc/final.c20
1 files changed, 19 insertions, 1 deletions
diff --git a/gcc/final.c b/gcc/final.c
index ae0e9cbd0fe..35782db678d 100644
--- a/gcc/final.c
+++ b/gcc/final.c
@@ -2943,10 +2943,28 @@ final_scan_insn (insn, file, optimize, prescan, nopeepholes)
needs to be reinserted. */
if (template == 0)
{
+ rtx prev;
+
if (prev_nonnote_insn (insn) != last_ignored_compare)
abort ();
new_block = 0;
- return prev_nonnote_insn (insn);
+
+ /* We have already processed the notes between the setter and
+ the user. Make sure we don't process them again, this is
+ particularly important if one of the notes is a block
+ scope note or an EH note. */
+ for (prev = insn;
+ prev != last_ignored_compare;
+ prev = PREV_INSN (prev))
+ {
+ if (GET_CODE (prev) == NOTE)
+ {
+ NOTE_LINE_NUMBER (prev) = NOTE_INSN_DELETED;
+ NOTE_SOURCE_FILE (prev) = 0;
+ }
+ }
+
+ return prev;
}
/* If the template is the string "#", it means that this insn must