| From e672184af6a43b773131181270c7a8c5c5273bd8 Mon Sep 17 00:00:00 2001 |
| From: Nagaraju Mekala <nmekala@xilix.com> |
| Date: Thu, 23 Feb 2017 17:09:04 +0530 |
| Subject: [PATCH 35/63] Fixing the issue with the builtin_alloc. register r18 |
| was not properly handling the stack pattern which was resolved by using free |
| available register |
| |
| signed-off-by:nagaraju mekala <nmekala@xilinx.com> |
| --- |
| gcc/config/microblaze/microblaze.md | 8 ++++---- |
| 1 file changed, 4 insertions(+), 4 deletions(-) |
| |
| diff --git a/gcc/config/microblaze/microblaze.md b/gcc/config/microblaze/microblaze.md |
| index 67b298a..7bae957 100644 |
| --- a/gcc/config/microblaze/microblaze.md |
| +++ b/gcc/config/microblaze/microblaze.md |
| @@ -2078,10 +2078,10 @@ |
| "" |
| { |
| rtx retaddr = gen_rtx_MEM (Pmode, stack_pointer_rtx); |
| - rtx rtmp = gen_rtx_REG (SImode, R_TMP); |
| + rtx reg = gen_reg_rtx (Pmode); |
| rtx neg_op0; |
| |
| - emit_move_insn (rtmp, retaddr); |
| + emit_move_insn (reg, retaddr); |
| if (GET_CODE (operands[1]) != CONST_INT) |
| { |
| neg_op0 = gen_reg_rtx (Pmode); |
| @@ -2090,9 +2090,9 @@ |
| neg_op0 = GEN_INT (- INTVAL (operands[1])); |
| |
| emit_insn (gen_addsi3 (stack_pointer_rtx, stack_pointer_rtx, neg_op0)); |
| - emit_move_insn (gen_rtx_MEM (Pmode, stack_pointer_rtx), rtmp); |
| + emit_move_insn (gen_rtx_MEM (Pmode, stack_pointer_rtx), reg); |
| emit_move_insn (operands[0], virtual_stack_dynamic_rtx); |
| - emit_insn (gen_rtx_CLOBBER (SImode, rtmp)); |
| + emit_insn (gen_rtx_CLOBBER (SImode, reg)); |
| DONE; |
| } |
| ) |
| -- |
| 2.7.4 |
| |