aboutsummaryrefslogtreecommitdiff
path: root/gcc/final.c
diff options
context:
space:
mode:
authorTom de Vries <tom@codesourcery.com>2014-06-20 08:02:02 +0000
committerTom de Vries <vries@gcc.gnu.org>2014-06-20 08:02:02 +0000
commit6621ab6860fb6a52bdfc23029770fa5e73fb4c9a (patch)
tree0fd3ef33f4a20318f41bb8a41a35c50494805647 /gcc/final.c
parent5fea81869314bd3283beec1e2f05865c331c3cda (diff)
downloadgcc-6621ab6860fb6a52bdfc23029770fa5e73fb4c9a.zip
gcc-6621ab6860fb6a52bdfc23029770fa5e73fb4c9a.tar.gz
gcc-6621ab6860fb6a52bdfc23029770fa5e73fb4c9a.tar.bz2
Fix finding reg-sets of call insn
2014-06-20 Tom de Vries <tom@codesourcery.com> * final.c (collect_fn_hard_reg_usage): Add separate IOR_HARD_REG_SET for get_call_reg_set_usage. From-SVN: r211841
Diffstat (limited to 'gcc/final.c')
-rw-r--r--gcc/final.c12
1 files changed, 8 insertions, 4 deletions
diff --git a/gcc/final.c b/gcc/final.c
index e67e84b..bbeb50d 100644
--- a/gcc/final.c
+++ b/gcc/final.c
@@ -4775,12 +4775,16 @@ collect_fn_hard_reg_usage (void)
if (!NONDEBUG_INSN_P (insn))
continue;
- find_all_hard_reg_sets (insn, &insn_used_regs, false);
+ if (CALL_P (insn))
+ {
+ if (!get_call_reg_set_usage (insn, &insn_used_regs,
+ call_used_reg_set))
+ return;
- if (CALL_P (insn)
- && !get_call_reg_set_usage (insn, &insn_used_regs, call_used_reg_set))
- return;
+ IOR_HARD_REG_SET (function_used_regs, insn_used_regs);
+ }
+ find_all_hard_reg_sets (insn, &insn_used_regs, false);
IOR_HARD_REG_SET (function_used_regs, insn_used_regs);
}