aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMike Stump <mikestump@comcast.net>2013-05-14 17:43:57 +0000
committerMike Stump <mrs@gcc.gnu.org>2013-05-14 17:43:57 +0000
commite7180acbb92275577a02326efb3ad2671a3f73b7 (patch)
tree8f73141ddbcd16b4863cb33eac109d97856d9cc0
parentfd6beed48d5783b4dd6bb6a4aabff7491041eeeb (diff)
downloadgcc-e7180acbb92275577a02326efb3ad2671a3f73b7.zip
gcc-e7180acbb92275577a02326efb3ad2671a3f73b7.tar.gz
gcc-e7180acbb92275577a02326efb3ad2671a3f73b7.tar.bz2
* web.c (union_match_dups): Also check DF_REF_REAL_LOC.
From-SVN: r198896
-rw-r--r--gcc/ChangeLog4
-rw-r--r--gcc/web.c16
2 files changed, 16 insertions, 4 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 58e0f95..62255a3 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,7 @@
+2013-05-14 Mike Stump <mikestump@comcast.net>
+
+ * web.c (union_match_dups): Also check DF_REF_REAL_LOC.
+
2013-05-14 Steven Bosscher <steven@gcc.gnu.org>
* resource.h (struct resources): Remove unch_memory member.
diff --git a/gcc/web.c b/gcc/web.c
index d09d1d5..7f667db 100644
--- a/gcc/web.c
+++ b/gcc/web.c
@@ -132,14 +132,22 @@ union_match_dups (rtx insn, struct web_entry *def_entry,
ref = type == OP_IN ? use_link : def_link;
entry = type == OP_IN ? use_entry : def_entry;
for (; *ref; ref++)
- if (DF_REF_LOC (*ref) == recog_data.operand_loc[op])
- break;
+ {
+ if (DF_REF_LOC (*ref) == recog_data.operand_loc[op])
+ break;
+ if (DF_REF_REAL_LOC (*ref) == recog_data.operand_loc[op])
+ break;
+ }
if (!*ref && type == OP_INOUT)
{
for (ref = use_link, entry = use_entry; *ref; ref++)
- if (DF_REF_LOC (*ref) == recog_data.operand_loc[op])
- break;
+ {
+ if (DF_REF_LOC (*ref) == recog_data.operand_loc[op])
+ break;
+ if (DF_REF_REAL_LOC (*ref) == recog_data.operand_loc[op])
+ break;
+ }
}
gcc_assert (*ref);