summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gcc/ChangeLog5
-rw-r--r--gcc/web.c10
2 files changed, 11 insertions, 4 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 4c406123b5f..0a7ae768c61 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,8 @@
+2013-05-17 Mike Stump <mikestump@comcast.net>
+
+ * web.c (union_match_dups): Ensure that DF_REF_LOC exists before
+ accessing DF_REF_REAL_LOC.
+
2013-05-17 Jakub Jelinek <jakub@redhat.com>
PR rtl-optimization/57281
diff --git a/gcc/web.c b/gcc/web.c
index 7f667db2cc5..df4c84fd774 100644
--- a/gcc/web.c
+++ b/gcc/web.c
@@ -133,9 +133,10 @@ union_match_dups (rtx insn, struct web_entry *def_entry,
entry = type == OP_IN ? use_entry : def_entry;
for (; *ref; ref++)
{
- if (DF_REF_LOC (*ref) == recog_data.operand_loc[op])
+ rtx *l = DF_REF_LOC (*ref);
+ if (l == recog_data.operand_loc[op])
break;
- if (DF_REF_REAL_LOC (*ref) == recog_data.operand_loc[op])
+ if (l && DF_REF_REAL_LOC (*ref) == recog_data.operand_loc[op])
break;
}
@@ -143,9 +144,10 @@ union_match_dups (rtx insn, struct web_entry *def_entry,
{
for (ref = use_link, entry = use_entry; *ref; ref++)
{
- if (DF_REF_LOC (*ref) == recog_data.operand_loc[op])
+ rtx *l = DF_REF_LOC (*ref);
+ if (l == recog_data.operand_loc[op])
break;
- if (DF_REF_REAL_LOC (*ref) == recog_data.operand_loc[op])
+ if (l && DF_REF_REAL_LOC (*ref) == recog_data.operand_loc[op])
break;
}
}