diff options
author | Richard Sandiford <rdsandiford@googlemail.com> | 2009-10-05 19:29:36 +0000 |
---|---|---|
committer | Richard Sandiford <rsandifo@gcc.gnu.org> | 2009-10-05 19:29:36 +0000 |
commit | 293593b15fbf08603d6fa038e8e4614b41166c9f (patch) | |
tree | 538112e0a1f89859a9a1b75f907ce39732ba1a11 | |
parent | 7cf078dceaaf3fac20ae6cad5077f9cec6256c8f (diff) | |
download | gcc-293593b15fbf08603d6fa038e8e4614b41166c9f.zip gcc-293593b15fbf08603d6fa038e8e4614b41166c9f.tar.gz gcc-293593b15fbf08603d6fa038e8e4614b41166c9f.tar.bz2 |
mips.h (DWARF_FRAME_RETURN_COLUMN): Replace GP_REG_FIRST + 31 with RETURN_ADDR_REGNUM.
gcc/
* config/mips/mips.h (DWARF_FRAME_RETURN_COLUMN): Replace
GP_REG_FIRST + 31 with RETURN_ADDR_REGNUM.
(INCOMING_RETURN_ADDR_RTX): Likewise.
(FUNCTION_PROFILER): Likewise. Replace GP_REG_FIRST + 1
with AT_REGNUM.
* config/mips/sdemtk.h (FUNCTION_PROFILER): Replace GP_REG_FIRST + 31
with RETURN_ADDR_REGNUM.
(MIPS_SAVE_REG_FOR_PROFILING_P): Likewise.
* config/mips/mips.c (mips16_build_call_stub): Replace
GP_REG_FIRST + 31 with RETURN_ADDR_REGNUM, GP_REG_FIRST + 1
with AT_REGNUM and 31 with RETURN_ADDR_REGNUM.
(mips_print_operand_punctuation): Likewise.
(mips_frame_set): Likewise.
(mips16e_output_save_restore): Likewise.
(mips_cfun_might_clobber_call_saved_reg_p): Likewise.
(mips_save_reg_p): Likewise.
(mips_return_addr): Likewise.
(mips_set_return_address): Likewise.
(mips_direct_save_slot_move_p): Likewise.
(mips_output_function_prologue): Likewise.
(mips_restore_reg): Likewise.
(mips_expand_epilogue): Likewise.
(mips_epilogue_uses): Likewise.
* config/mips/mips.md (RETURN_ADD_REGNUM): Define.
(*mov<mode>_ra): Use it instead of a hard-coded 31.
(clear_hazard_<mode>): Likewise.
(call_internal): Likewise.
(call_internal_direct): Likewise.
(call_direct_split): Likewise.
(call_value_internal): Likewise.
(call_value_split): Likewise.
(call_value_internal_direct): Likewise.
(call_value_direct_split): Likewise.
(call_value_multiple_internal): Likewise.
(call_value_multiple_split): Likewise.
From-SVN: r152465
-rw-r--r-- | gcc/ChangeLog | 38 | ||||
-rw-r--r-- | gcc/config/mips/mips.c | 34 | ||||
-rw-r--r-- | gcc/config/mips/mips.h | 6 | ||||
-rw-r--r-- | gcc/config/mips/mips.md | 25 | ||||
-rw-r--r-- | gcc/config/mips/sdemtk.h | 4 |
5 files changed, 73 insertions, 34 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 938b336..1840726 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,41 @@ +2009-10-05 Richard Sandiford <rdsandiford@googlemail.com> + + * config/mips/mips.h (DWARF_FRAME_RETURN_COLUMN): Replace + GP_REG_FIRST + 31 with RETURN_ADDR_REGNUM. + (INCOMING_RETURN_ADDR_RTX): Likewise. + (FUNCTION_PROFILER): Likewise. Replace GP_REG_FIRST + 1 + with AT_REGNUM. + * config/mips/sdemtk.h (FUNCTION_PROFILER): Replace GP_REG_FIRST + 31 + with RETURN_ADDR_REGNUM. + (MIPS_SAVE_REG_FOR_PROFILING_P): Likewise. + * config/mips/mips.c (mips16_build_call_stub): Replace + GP_REG_FIRST + 31 with RETURN_ADDR_REGNUM, GP_REG_FIRST + 1 + with AT_REGNUM and 31 with RETURN_ADDR_REGNUM. + (mips_print_operand_punctuation): Likewise. + (mips_frame_set): Likewise. + (mips16e_output_save_restore): Likewise. + (mips_cfun_might_clobber_call_saved_reg_p): Likewise. + (mips_save_reg_p): Likewise. + (mips_return_addr): Likewise. + (mips_set_return_address): Likewise. + (mips_direct_save_slot_move_p): Likewise. + (mips_output_function_prologue): Likewise. + (mips_restore_reg): Likewise. + (mips_expand_epilogue): Likewise. + (mips_epilogue_uses): Likewise. + * config/mips/mips.md (RETURN_ADD_REGNUM): Define. + (*mov<mode>_ra): Use it instead of a hard-coded 31. + (clear_hazard_<mode>): Likewise. + (call_internal): Likewise. + (call_internal_direct): Likewise. + (call_direct_split): Likewise. + (call_value_internal): Likewise. + (call_value_split): Likewise. + (call_value_internal_direct): Likewise. + (call_value_direct_split): Likewise. + (call_value_multiple_internal): Likewise. + (call_value_multiple_split): Likewise. + 2009-10-05 Eric Botcazou <ebotcazou@adacore.com> Jakub Jelinek <jakub@redhat.com> diff --git a/gcc/config/mips/mips.c b/gcc/config/mips/mips.c index 1bead59..cbe8447 100644 --- a/gcc/config/mips/mips.c +++ b/gcc/config/mips/mips.c @@ -6243,7 +6243,7 @@ mips16_build_call_stub (rtx retval, rtx *fn_ptr, rtx args_size, int fp_code) The stub's caller knows that $18 might be clobbered, even though $18 is usually a call-saved register. */ fprintf (asm_out_file, "\tmove\t%s,%s\n", - reg_names[GP_REG_FIRST + 18], reg_names[GP_REG_FIRST + 31]); + reg_names[GP_REG_FIRST + 18], reg_names[RETURN_ADDR_REGNUM]); output_asm_insn (MIPS_CALL ("jal", &fn, 0, -1), &fn); /* Move the result from floating-point registers to @@ -7276,7 +7276,7 @@ mips_print_operand_punctuation (FILE *file, int ch) break; case '@': - fputs (reg_names[GP_REG_FIRST + 1], file); + fputs (reg_names[AT_REGNUM], file); break; case '^': @@ -8144,8 +8144,8 @@ mips_frame_set (rtx mem, rtx reg) /* If we're saving the return address register and the DWARF return address column differs from the hard register number, adjust the note reg to refer to the former. */ - if (REGNO (reg) == GP_REG_FIRST + 31 - && DWARF_FRAME_RETURN_COLUMN != GP_REG_FIRST + 31) + if (REGNO (reg) == RETURN_ADDR_REGNUM + && DWARF_FRAME_RETURN_COLUMN != RETURN_ADDR_REGNUM) reg = gen_rtx_REG (GET_MODE (reg), DWARF_FRAME_RETURN_COLUMN); set = gen_rtx_SET (VOIDmode, mem, reg); @@ -8595,8 +8595,8 @@ mips16e_output_save_restore (rtx pattern, HOST_WIDE_INT adjust) mips16e_a0_a3_regs[end - 1]); /* Save or restore $31. */ - if (BITSET_P (info.mask, 31)) - s += sprintf (s, ",%s", reg_names[GP_REG_FIRST + 31]); + if (BITSET_P (info.mask, RETURN_ADDR_REGNUM)) + s += sprintf (s, ",%s", reg_names[RETURN_ADDR_REGNUM]); return buffer; } @@ -8764,7 +8764,7 @@ mips_global_pointer (void) return GLOBAL_POINTER_REGNUM; } -/* Return true if current function's prologue must load the global +/* Return true if the current function's prologue must load the global pointer value into pic_offset_table_rtx and store the same value in the function's cprestore slot (if any). @@ -8969,7 +8969,7 @@ mips_cfun_might_clobber_call_saved_reg_p (unsigned int regno) /* If a MIPS16 function returns a value in FPRs, its epilogue will need to call an external libgcc routine. This yet-to-be generated call_insn will clobber $31. */ - if (regno == GP_REG_FIRST + 31 && mips16_cfun_returns_in_fpr_p ()) + if (regno == RETURN_ADDR_REGNUM && mips16_cfun_returns_in_fpr_p ()) return true; /* If REGNO is ordinarily call-clobbered, we must assume that any @@ -9003,7 +9003,7 @@ mips_save_reg_p (unsigned int regno) /* We need to save the incoming return address if __builtin_eh_return is being used to set a different return address. */ - if (regno == GP_REG_FIRST + 31 && crtl->calls_eh_return) + if (regno == RETURN_ADDR_REGNUM && crtl->calls_eh_return) return true; return false; @@ -9378,7 +9378,7 @@ mips_return_addr (int count, rtx frame ATTRIBUTE_UNUSED) if (count != 0) return const0_rtx; - return get_hard_reg_initial_val (Pmode, GP_REG_FIRST + 31); + return get_hard_reg_initial_val (Pmode, RETURN_ADDR_REGNUM); } /* Emit code to change the current function's return address to @@ -9390,7 +9390,7 @@ mips_set_return_address (rtx address, rtx scratch) { rtx slot_address; - gcc_assert (BITSET_P (cfun->machine->frame.mask, 31)); + gcc_assert (BITSET_P (cfun->machine->frame.mask, RETURN_ADDR_REGNUM)); slot_address = mips_add_offset (scratch, stack_pointer_rtx, cfun->machine->frame.gp_sp_offset); mips_emit_move (gen_frame_mem (GET_MODE (address), slot_address), address); @@ -9604,7 +9604,7 @@ static bool mips_direct_save_slot_move_p (unsigned int regno, rtx mem, bool load_p) { /* There is a specific MIPS16 instruction for saving $31 to the stack. */ - if (TARGET_MIPS16 && !load_p && regno == GP_REG_FIRST + 31) + if (TARGET_MIPS16 && !load_p && regno == RETURN_ADDR_REGNUM) return false; return mips_secondary_reload_class (REGNO_REG_CLASS (regno), @@ -9741,7 +9741,7 @@ mips_output_function_prologue (FILE *file, HOST_WIDE_INT size ATTRIBUTE_UNUSED) (frame_pointer_needed ? frame->total_size - frame->hard_frame_pointer_offset : frame->total_size), - reg_names[GP_REG_FIRST + 31], + reg_names[RETURN_ADDR_REGNUM], frame->var_size, frame->num_gp, frame->num_fp, frame->args_size, @@ -10184,7 +10184,7 @@ mips_restore_reg (rtx reg, rtx mem) { /* There's no MIPS16 instruction to load $31 directly. Load into $7 instead and adjust the return insn appropriately. */ - if (TARGET_MIPS16 && REGNO (reg) == GP_REG_FIRST + 31) + if (TARGET_MIPS16 && REGNO (reg) == RETURN_ADDR_REGNUM) reg = gen_rtx_REG (GET_MODE (reg), GP_REG_FIRST + 7); mips_emit_save_slot_move (reg, mem, MIPS_EPILOGUE_TEMP (GET_MODE (reg))); @@ -10399,10 +10399,10 @@ mips_expand_epilogue (bool sibcall_p) address into $7 rather than $31. */ if (TARGET_MIPS16 && !GENERATE_MIPS16E_SAVE_RESTORE - && BITSET_P (frame->mask, 31)) + && BITSET_P (frame->mask, RETURN_ADDR_REGNUM)) regno = GP_REG_FIRST + 7; else - regno = GP_REG_FIRST + 31; + regno = RETURN_ADDR_REGNUM; emit_jump_insn (gen_return_internal (gen_rtx_REG (Pmode, regno))); } } @@ -15830,7 +15830,7 @@ mips_epilogue_uses (unsigned int regno) /* Say that the epilogue uses the return address register. Note that in the case of sibcalls, the values "used by the epilogue" are considered live at the start of the called function. */ - if (regno == 31) + if (regno == RETURN_ADDR_REGNUM) return true; /* If using a GOT, say that the epilogue also uses GOT_VERSION_REGNUM. diff --git a/gcc/config/mips/mips.h b/gcc/config/mips/mips.h index 934e0fa..b17512f 100644 --- a/gcc/config/mips/mips.h +++ b/gcc/config/mips/mips.h @@ -1311,10 +1311,10 @@ enum mips_code_readable_setting { #define DWARF_FRAME_REGNUM(REGNO) mips_dwarf_regno[REGNO] /* The DWARF 2 CFA column which tracks the return address. */ -#define DWARF_FRAME_RETURN_COLUMN (GP_REG_FIRST + 31) +#define DWARF_FRAME_RETURN_COLUMN RETURN_ADDR_REGNUM /* Before the prologue, RA lives in r31. */ -#define INCOMING_RETURN_ADDR_RTX gen_rtx_REG (VOIDmode, GP_REG_FIRST + 31) +#define INCOMING_RETURN_ADDR_RTX gen_rtx_REG (VOIDmode, RETURN_ADDR_REGNUM) /* Describe how we implement __builtin_eh_return. */ #define EH_RETURN_DATA_REGNO(N) \ @@ -2386,7 +2386,7 @@ typedef struct mips_args { } \ mips_push_asm_switch (&mips_noat); \ fprintf (FILE, "\tmove\t%s,%s\t\t# save current return address\n", \ - reg_names[GP_REG_FIRST + 1], reg_names[GP_REG_FIRST + 31]); \ + reg_names[AT_REGNUM], reg_names[RETURN_ADDR_REGNUM]); \ /* _mcount treats $2 as the static chain register. */ \ if (cfun->static_chain_decl != NULL) \ fprintf (FILE, "\tmove\t%s,%s\n", reg_names[2], \ diff --git a/gcc/config/mips/mips.md b/gcc/config/mips/mips.md index 19f3ffc..2d11ed0 100644 --- a/gcc/config/mips/mips.md +++ b/gcc/config/mips/mips.md @@ -82,6 +82,7 @@ (UNSPEC_ADDRESS_FIRST 100) (TLS_GET_TP_REGNUM 3) + (RETURN_ADDR_REGNUM 31) (CPRESTORE_SLOT_REGNUM 76) (GOT_VERSION_REGNUM 79) @@ -4011,7 +4012,7 @@ (define_insn "*mov<mode>_ra" [(set (match_operand:GPR 0 "stack_operand" "=m") - (reg:GPR 31))] + (reg:GPR RETURN_ADDR_REGNUM))] "TARGET_MIPS16" "<store>\t$31,%0" [(set_attr "move_type" "store") @@ -4938,7 +4939,7 @@ (define_insn "clear_hazard_<mode>" [(unspec_volatile [(const_int 0)] UNSPEC_CLEAR_HAZARD) - (clobber (reg:P 31))] + (clobber (reg:P RETURN_ADDR_REGNUM))] "ISA_HAS_SYNCI" { return "%(%<bal\t1f\n" @@ -6123,7 +6124,7 @@ (define_insn_and_split "call_internal" [(call (mem:SI (match_operand 0 "call_insn_operand" "c,S")) (match_operand 1 "" "")) - (clobber (reg:SI 31))] + (clobber (reg:SI RETURN_ADDR_REGNUM))] "" { return TARGET_SPLIT_CALLS ? "#" : MIPS_CALL ("jal", operands, 0, 1); } "reload_completed && TARGET_SPLIT_CALLS && (operands[2] = insn)" @@ -6137,7 +6138,7 @@ (define_insn "call_split" [(call (mem:SI (match_operand 0 "call_insn_operand" "cS")) (match_operand 1 "" "")) - (clobber (reg:SI 31)) + (clobber (reg:SI RETURN_ADDR_REGNUM)) (clobber (reg:SI 28))] "TARGET_SPLIT_CALLS" { return MIPS_CALL ("jal", operands, 0, 1); } @@ -6151,7 +6152,7 @@ [(call (mem:SI (match_operand 0 "const_call_insn_operand")) (match_operand 1)) (const_int 1) - (clobber (reg:SI 31))] + (clobber (reg:SI RETURN_ADDR_REGNUM))] "" { return TARGET_SPLIT_CALLS ? "#" : MIPS_CALL ("jal", operands, 0, -1); } "reload_completed && TARGET_SPLIT_CALLS && (operands[2] = insn)" @@ -6167,7 +6168,7 @@ [(call (mem:SI (match_operand 0 "const_call_insn_operand")) (match_operand 1)) (const_int 1) - (clobber (reg:SI 31)) + (clobber (reg:SI RETURN_ADDR_REGNUM)) (clobber (reg:SI 28))] "TARGET_SPLIT_CALLS" { return MIPS_CALL ("jal", operands, 0, -1); } @@ -6190,7 +6191,7 @@ [(set (match_operand 0 "register_operand" "") (call (mem:SI (match_operand 1 "call_insn_operand" "c,S")) (match_operand 2 "" ""))) - (clobber (reg:SI 31))] + (clobber (reg:SI RETURN_ADDR_REGNUM))] "" { return TARGET_SPLIT_CALLS ? "#" : MIPS_CALL ("jal", operands, 1, 2); } "reload_completed && TARGET_SPLIT_CALLS && (operands[3] = insn)" @@ -6207,7 +6208,7 @@ [(set (match_operand 0 "register_operand" "") (call (mem:SI (match_operand 1 "call_insn_operand" "cS")) (match_operand 2 "" ""))) - (clobber (reg:SI 31)) + (clobber (reg:SI RETURN_ADDR_REGNUM)) (clobber (reg:SI 28))] "TARGET_SPLIT_CALLS" { return MIPS_CALL ("jal", operands, 1, 2); } @@ -6219,7 +6220,7 @@ (call (mem:SI (match_operand 1 "const_call_insn_operand")) (match_operand 2))) (const_int 1) - (clobber (reg:SI 31))] + (clobber (reg:SI RETURN_ADDR_REGNUM))] "" { return TARGET_SPLIT_CALLS ? "#" : MIPS_CALL ("jal", operands, 1, -1); } "reload_completed && TARGET_SPLIT_CALLS && (operands[3] = insn)" @@ -6237,7 +6238,7 @@ (call (mem:SI (match_operand 1 "const_call_insn_operand")) (match_operand 2))) (const_int 1) - (clobber (reg:SI 31)) + (clobber (reg:SI RETURN_ADDR_REGNUM)) (clobber (reg:SI 28))] "TARGET_SPLIT_CALLS" { return MIPS_CALL ("jal", operands, 1, -1); } @@ -6251,7 +6252,7 @@ (set (match_operand 3 "register_operand" "") (call (mem:SI (match_dup 1)) (match_dup 2))) - (clobber (reg:SI 31))] + (clobber (reg:SI RETURN_ADDR_REGNUM))] "" { return TARGET_SPLIT_CALLS ? "#" : MIPS_CALL ("jal", operands, 1, 2); } "reload_completed && TARGET_SPLIT_CALLS && (operands[4] = insn)" @@ -6271,7 +6272,7 @@ (set (match_operand 3 "register_operand" "") (call (mem:SI (match_dup 1)) (match_dup 2))) - (clobber (reg:SI 31)) + (clobber (reg:SI RETURN_ADDR_REGNUM)) (clobber (reg:SI 28))] "TARGET_SPLIT_CALLS" { return MIPS_CALL ("jal", operands, 1, 2); } diff --git a/gcc/config/mips/sdemtk.h b/gcc/config/mips/sdemtk.h index 27dab06..a9bb85e 100644 --- a/gcc/config/mips/sdemtk.h +++ b/gcc/config/mips/sdemtk.h @@ -101,7 +101,7 @@ extern void mips_sync_icache (void *beg, unsigned long len); /* MIPS16 code passes saved $ra in $v1 instead of $at. */ \ fprintf (FILE, "\tmove\t%s,%s\n", \ reg_names[GP_REG_FIRST + (TARGET_MIPS16 ? 3 : 1)], \ - reg_names[GP_REG_FIRST + 31]); \ + reg_names[RETURN_ADDR_REGNUM]); \ fprintf (FILE, "\tjal\t_mcount\n"); \ mips_pop_asm_switch (&mips_noat); \ /* _mcount treats $2 as the static chain register. */ \ @@ -112,4 +112,4 @@ extern void mips_sync_icache (void *beg, unsigned long len); /* ...nor does the call sequence preserve $31. */ #undef MIPS_SAVE_REG_FOR_PROFILING_P -#define MIPS_SAVE_REG_FOR_PROFILING_P(REGNO) ((REGNO) == GP_REG_FIRST + 31) +#define MIPS_SAVE_REG_FOR_PROFILING_P(REGNO) ((REGNO) == RETURN_ADDR_REGNUM) |