spu.h (ARG_POINTER_CFA_OFFSET): Define.
* config/spu/spu.h (ARG_POINTER_CFA_OFFSET): Define. * config/spu/spu.c (spu_expand_prologue): Set RTX_FRAME_RELATED_P for insn setting up the frame pointer. Do not set it for insns setting up scratch registers or storing the backchain. From-SVN: r120125
This commit is contained in:
parent
3721b9e1ee
commit
10d55907ce
@ -1,3 +1,10 @@
|
|||||||
|
2006-12-22 Ulrich Weigand <uweigand@de.ibm.com>
|
||||||
|
|
||||||
|
* config/spu/spu.h (ARG_POINTER_CFA_OFFSET): Define.
|
||||||
|
* config/spu/spu.c (spu_expand_prologue): Set RTX_FRAME_RELATED_P
|
||||||
|
for insn setting up the frame pointer. Do not set it for insns
|
||||||
|
setting up scratch registers or storing the backchain.
|
||||||
|
|
||||||
2006-12-21 Eric Botcazou <ebotcazou@adacore.com>
|
2006-12-21 Eric Botcazou <ebotcazou@adacore.com>
|
||||||
|
|
||||||
PR other/29639
|
PR other/29639
|
||||||
|
@ -1629,21 +1629,18 @@ spu_expand_prologue (void)
|
|||||||
{
|
{
|
||||||
/* In this case we save the back chain first. */
|
/* In this case we save the back chain first. */
|
||||||
insn = frame_emit_store (STACK_POINTER_REGNUM, sp_reg, -total_size);
|
insn = frame_emit_store (STACK_POINTER_REGNUM, sp_reg, -total_size);
|
||||||
RTX_FRAME_RELATED_P (insn) = 1;
|
|
||||||
insn =
|
insn =
|
||||||
frame_emit_add_imm (sp_reg, sp_reg, -total_size, scratch_reg_0);
|
frame_emit_add_imm (sp_reg, sp_reg, -total_size, scratch_reg_0);
|
||||||
}
|
}
|
||||||
else if (satisfies_constraint_K (GEN_INT (-total_size)))
|
else if (satisfies_constraint_K (GEN_INT (-total_size)))
|
||||||
{
|
{
|
||||||
insn = emit_move_insn (scratch_reg_0, sp_reg);
|
insn = emit_move_insn (scratch_reg_0, sp_reg);
|
||||||
RTX_FRAME_RELATED_P (insn) = 1;
|
|
||||||
insn =
|
insn =
|
||||||
emit_insn (gen_addsi3 (sp_reg, sp_reg, GEN_INT (-total_size)));
|
emit_insn (gen_addsi3 (sp_reg, sp_reg, GEN_INT (-total_size)));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
insn = emit_move_insn (scratch_reg_0, sp_reg);
|
insn = emit_move_insn (scratch_reg_0, sp_reg);
|
||||||
RTX_FRAME_RELATED_P (insn) = 1;
|
|
||||||
insn =
|
insn =
|
||||||
frame_emit_add_imm (sp_reg, sp_reg, -total_size, scratch_reg_1);
|
frame_emit_add_imm (sp_reg, sp_reg, -total_size, scratch_reg_1);
|
||||||
}
|
}
|
||||||
@ -1656,7 +1653,6 @@ spu_expand_prologue (void)
|
|||||||
{
|
{
|
||||||
/* Save the back chain ptr */
|
/* Save the back chain ptr */
|
||||||
insn = frame_emit_store (REGNO (scratch_reg_0), sp_reg, 0);
|
insn = frame_emit_store (REGNO (scratch_reg_0), sp_reg, 0);
|
||||||
RTX_FRAME_RELATED_P (insn) = 1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (frame_pointer_needed)
|
if (frame_pointer_needed)
|
||||||
@ -1665,7 +1661,12 @@ spu_expand_prologue (void)
|
|||||||
HOST_WIDE_INT fp_offset = STACK_POINTER_OFFSET
|
HOST_WIDE_INT fp_offset = STACK_POINTER_OFFSET
|
||||||
+ current_function_outgoing_args_size;
|
+ current_function_outgoing_args_size;
|
||||||
/* Set the new frame_pointer */
|
/* Set the new frame_pointer */
|
||||||
frame_emit_add_imm (fp_reg, sp_reg, fp_offset, scratch_reg_0);
|
insn = frame_emit_add_imm (fp_reg, sp_reg, fp_offset, scratch_reg_0);
|
||||||
|
RTX_FRAME_RELATED_P (insn) = 1;
|
||||||
|
real = gen_addsi3 (fp_reg, sp_reg, GEN_INT (fp_offset));
|
||||||
|
REG_NOTES (insn) =
|
||||||
|
gen_rtx_EXPR_LIST (REG_FRAME_RELATED_EXPR,
|
||||||
|
real, REG_NOTES (insn));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -265,6 +265,8 @@ targetm.resolve_overloaded_builtin = spu_resolve_overloaded_builtin; \
|
|||||||
|
|
||||||
#define INCOMING_RETURN_ADDR_RTX gen_rtx_REG(Pmode, LINK_REGISTER_REGNUM)
|
#define INCOMING_RETURN_ADDR_RTX gen_rtx_REG(Pmode, LINK_REGISTER_REGNUM)
|
||||||
|
|
||||||
|
#define ARG_POINTER_CFA_OFFSET(FNDECL) (-STACK_POINTER_OFFSET)
|
||||||
|
|
||||||
|
|
||||||
/* Stack Checking */
|
/* Stack Checking */
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user