dwarf2out.c (dwarf2out_frame_debug_expr): Consult the dwarf_register_span hook when emitting unwind information for...
* dwarf2out.c (dwarf2out_frame_debug_expr): Consult the dwarf_register_span hook when emitting unwind information for register-to-memory saves. * config/rs6000/rs6000.c (spe_synthesize_frame): Delete. (rs6000_frame_related): Remove call to spe_synthesize_frame. From-SVN: r132981
This commit is contained in:
parent
71458b8a12
commit
48081aae38
3 changed files with 35 additions and 68 deletions
|
@ -1,3 +1,11 @@
|
|||
2008-03-06 Nathan Froyd <froydnj@codesourcery.com>
|
||||
|
||||
* dwarf2out.c (dwarf2out_frame_debug_expr): Consult the
|
||||
dwarf_register_span hook when emitting unwind information for
|
||||
register-to-memory saves.
|
||||
* config/rs6000/rs6000.c (spe_synthesize_frame): Delete.
|
||||
(rs6000_frame_related): Remove call to spe_synthesize_frame.
|
||||
|
||||
2008-03-06 Jakub Jelinek <jakub@redhat.com>
|
||||
|
||||
* gimplify.c (goa_lhs_expr_p): Allow different ADDR_EXPR nodes
|
||||
|
|
|
@ -732,7 +732,6 @@ static const char *rs6000_invalid_within_doloop (const_rtx);
|
|||
static rtx rs6000_generate_compare (enum rtx_code);
|
||||
static void rs6000_emit_stack_tie (void);
|
||||
static void rs6000_frame_related (rtx, rtx, HOST_WIDE_INT, rtx, rtx);
|
||||
static rtx spe_synthesize_frame_save (rtx);
|
||||
static bool spe_func_has_64bit_regs_p (void);
|
||||
static void emit_frame_save (rtx, rtx, enum machine_mode, unsigned int,
|
||||
int, HOST_WIDE_INT);
|
||||
|
@ -15386,77 +15385,12 @@ rs6000_frame_related (rtx insn, rtx reg, HOST_WIDE_INT val,
|
|||
}
|
||||
}
|
||||
|
||||
if (TARGET_SPE)
|
||||
real = spe_synthesize_frame_save (real);
|
||||
|
||||
RTX_FRAME_RELATED_P (insn) = 1;
|
||||
REG_NOTES (insn) = gen_rtx_EXPR_LIST (REG_FRAME_RELATED_EXPR,
|
||||
real,
|
||||
REG_NOTES (insn));
|
||||
}
|
||||
|
||||
/* Given an SPE frame note, return a PARALLEL of SETs with the
|
||||
original note, plus a synthetic register save. */
|
||||
|
||||
static rtx
|
||||
spe_synthesize_frame_save (rtx real)
|
||||
{
|
||||
rtx synth, offset, reg, real2;
|
||||
|
||||
if (GET_CODE (real) != SET
|
||||
|| GET_MODE (SET_SRC (real)) != V2SImode)
|
||||
return real;
|
||||
|
||||
/* For the SPE, registers saved in 64-bits, get a PARALLEL for their
|
||||
frame related note. The parallel contains a set of the register
|
||||
being saved, and another set to a synthetic register (n+1200).
|
||||
This is so we can differentiate between 64-bit and 32-bit saves.
|
||||
Words cannot describe this nastiness. */
|
||||
|
||||
gcc_assert (GET_CODE (SET_DEST (real)) == MEM
|
||||
&& GET_CODE (XEXP (SET_DEST (real), 0)) == PLUS
|
||||
&& GET_CODE (SET_SRC (real)) == REG);
|
||||
|
||||
/* Transform:
|
||||
(set (mem (plus (reg x) (const y)))
|
||||
(reg z))
|
||||
into:
|
||||
(set (mem (plus (reg x) (const y+4)))
|
||||
(reg z+1200))
|
||||
*/
|
||||
|
||||
real2 = copy_rtx (real);
|
||||
PUT_MODE (SET_DEST (real2), SImode);
|
||||
reg = SET_SRC (real2);
|
||||
real2 = replace_rtx (real2, reg, gen_rtx_REG (SImode, REGNO (reg)));
|
||||
synth = copy_rtx (real2);
|
||||
|
||||
if (BYTES_BIG_ENDIAN)
|
||||
{
|
||||
offset = XEXP (XEXP (SET_DEST (real2), 0), 1);
|
||||
real2 = replace_rtx (real2, offset, GEN_INT (INTVAL (offset) + 4));
|
||||
}
|
||||
|
||||
reg = SET_SRC (synth);
|
||||
|
||||
synth = replace_rtx (synth, reg,
|
||||
gen_rtx_REG (SImode, REGNO (reg) + 1200));
|
||||
|
||||
offset = XEXP (XEXP (SET_DEST (synth), 0), 1);
|
||||
synth = replace_rtx (synth, offset,
|
||||
GEN_INT (INTVAL (offset)
|
||||
+ (BYTES_BIG_ENDIAN ? 0 : 4)));
|
||||
|
||||
RTX_FRAME_RELATED_P (synth) = 1;
|
||||
RTX_FRAME_RELATED_P (real2) = 1;
|
||||
if (BYTES_BIG_ENDIAN)
|
||||
real = gen_rtx_PARALLEL (VOIDmode, gen_rtvec (2, synth, real2));
|
||||
else
|
||||
real = gen_rtx_PARALLEL (VOIDmode, gen_rtvec (2, real2, synth));
|
||||
|
||||
return real;
|
||||
}
|
||||
|
||||
/* Returns an insn that has a vrsave set operation with the
|
||||
appropriate CLOBBERs. */
|
||||
|
||||
|
|
|
@ -1534,7 +1534,7 @@ static dw_cfa_location cfa_temp;
|
|||
static void
|
||||
dwarf2out_frame_debug_expr (rtx expr, const char *label)
|
||||
{
|
||||
rtx src, dest;
|
||||
rtx src, dest, span;
|
||||
HOST_WIDE_INT offset;
|
||||
|
||||
/* If RTX_FRAME_RELATED_P is set on a PARALLEL, process each member of
|
||||
|
@ -1884,7 +1884,32 @@ dwarf2out_frame_debug_expr (rtx expr, const char *label)
|
|||
}
|
||||
|
||||
def_cfa_1 (label, &cfa);
|
||||
queue_reg_save (label, src, NULL_RTX, offset);
|
||||
{
|
||||
span = targetm.dwarf_register_span (src);
|
||||
|
||||
if (!span)
|
||||
queue_reg_save (label, src, NULL_RTX, offset);
|
||||
else
|
||||
{
|
||||
/* We have a PARALLEL describing where the contents of SRC
|
||||
live. Queue register saves for each piece of the
|
||||
PARALLEL. */
|
||||
int par_index;
|
||||
int limit;
|
||||
HOST_WIDE_INT span_offset = offset;
|
||||
|
||||
gcc_assert (GET_CODE (span) == PARALLEL);
|
||||
|
||||
limit = XVECLEN (span, 0);
|
||||
for (par_index = 0; par_index < limit; par_index++)
|
||||
{
|
||||
rtx elem = XVECEXP (span, 0, par_index);
|
||||
|
||||
queue_reg_save (label, elem, NULL_RTX, span_offset);
|
||||
span_offset += GET_MODE_SIZE (GET_MODE (elem));
|
||||
}
|
||||
}
|
||||
}
|
||||
break;
|
||||
|
||||
default:
|
||||
|
|
Loading…
Add table
Reference in a new issue