Commit 70fa887c145e99205a41f6e8d255d8397eca8bb4
1 parent
a6cc84f4
Relax qemu_ld/st constraints for !SOFTMMU case
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@5038 c046a42c-6fe2-441c-8c8c-71466251a162
Showing
1 changed file
with
14 additions
and
1 deletions
tcg/ppc/tcg-target.c
| @@ -222,6 +222,7 @@ static int target_parse_constraint(TCGArgConstraint *ct, const char **pct_str) | @@ -222,6 +222,7 @@ static int target_parse_constraint(TCGArgConstraint *ct, const char **pct_str) | ||
| 222 | ct->ct |= TCG_CT_REG; | 222 | ct->ct |= TCG_CT_REG; |
| 223 | tcg_regset_set32(ct->u.regs, 0, 0xffffffff); | 223 | tcg_regset_set32(ct->u.regs, 0, 0xffffffff); |
| 224 | break; | 224 | break; |
| 225 | +#ifdef CONFIG_SOFTMMU | ||
| 225 | case 'L': /* qemu_ld constraint */ | 226 | case 'L': /* qemu_ld constraint */ |
| 226 | ct->ct |= TCG_CT_REG; | 227 | ct->ct |= TCG_CT_REG; |
| 227 | tcg_regset_set32(ct->u.regs, 0, 0xffffffff); | 228 | tcg_regset_set32(ct->u.regs, 0, 0xffffffff); |
| @@ -247,6 +248,18 @@ static int target_parse_constraint(TCGArgConstraint *ct, const char **pct_str) | @@ -247,6 +248,18 @@ static int target_parse_constraint(TCGArgConstraint *ct, const char **pct_str) | ||
| 247 | tcg_regset_reset_reg(ct->u.regs, TCG_REG_R6); | 248 | tcg_regset_reset_reg(ct->u.regs, TCG_REG_R6); |
| 248 | tcg_regset_reset_reg(ct->u.regs, TCG_REG_R7); | 249 | tcg_regset_reset_reg(ct->u.regs, TCG_REG_R7); |
| 249 | break; | 250 | break; |
| 251 | +#else | ||
| 252 | + case 'L': | ||
| 253 | + case 'K': | ||
| 254 | + ct->ct |= TCG_CT_REG; | ||
| 255 | + tcg_regset_set32(ct->u.regs, 0, 0xffffffff); | ||
| 256 | + break; | ||
| 257 | + case 'M': | ||
| 258 | + ct->ct |= TCG_CT_REG; | ||
| 259 | + tcg_regset_set32(ct->u.regs, 0, 0xffffffff); | ||
| 260 | + tcg_regset_reset_reg(ct->u.regs, TCG_REG_R3); | ||
| 261 | + break; | ||
| 262 | +#endif | ||
| 250 | default: | 263 | default: |
| 251 | return -1; | 264 | return -1; |
| 252 | } | 265 | } |
| @@ -785,7 +798,7 @@ static void tcg_out_qemu_st (TCGContext *s, const TCGArg *args, int opc) | @@ -785,7 +798,7 @@ static void tcg_out_qemu_st (TCGContext *s, const TCGArg *args, int opc) | ||
| 785 | /* r0 = env->tlb_table[mem_index][index].addend + addr */ | 798 | /* r0 = env->tlb_table[mem_index][index].addend + addr */ |
| 786 | 799 | ||
| 787 | #else /* !CONFIG_SOFTMMU */ | 800 | #else /* !CONFIG_SOFTMMU */ |
| 788 | - r1 = 4; | 801 | + r1 = 3; |
| 789 | r0 = addr_reg; | 802 | r0 = addr_reg; |
| 790 | #endif | 803 | #endif |
| 791 | 804 |