mirror of
git://gcc.gnu.org/git/gcc.git
synced 2025-04-06 05:20:26 +08:00
mips.md (cprestore): Provide two alternatives...
* config/mips/mips.md (cprestore): Provide two alternatives, one for an in-range offset and one for an out-of-range offset. Wrap the latter in .set macro/.set nomacro if it's inside a .set nomacro block. From-SVN: r85405
This commit is contained in:
parent
b73ce23b1d
commit
b8b044f117
@ -1,3 +1,9 @@
|
||||
2004-08-01 Richard Sandiford <rsandifo@redhat.com>
|
||||
|
||||
* config/mips/mips.md (cprestore): Provide two alternatives, one for
|
||||
an in-range offset and one for an out-of-range offset. Wrap the latter
|
||||
in .set macro/.set nomacro if it's inside a .set nomacro block.
|
||||
|
||||
2004-08-01 Richard Sandiford <rsandifo@redhat.com>
|
||||
|
||||
* config/mips/mips-protos.h (mips_gp_save_slot): Remove.
|
||||
|
@ -4787,16 +4787,21 @@ dsrl\t%3,%3,1\n\
|
||||
(set_attr "mode" "none")
|
||||
(set_attr "length" "0")])
|
||||
|
||||
;; Emit a .cprestore directive, which expands to a single store instruction.
|
||||
;; Note that we continue to use .cprestore for explicit reloc code so that
|
||||
;; jals inside inlines asms will work correctly.
|
||||
;; Emit a .cprestore directive, which normally expands to a single store
|
||||
;; instruction. Note that we continue to use .cprestore for explicit reloc
|
||||
;; code so that jals inside inline asms will work correctly.
|
||||
(define_insn "cprestore"
|
||||
[(unspec_volatile [(match_operand 0 "const_int_operand" "")]
|
||||
[(unspec_volatile [(match_operand 0 "const_int_operand" "I,i")]
|
||||
UNSPEC_CPRESTORE)]
|
||||
""
|
||||
".cprestore\t%0"
|
||||
{
|
||||
if (set_nomacro && which_alternative == 1)
|
||||
return ".set\tmacro\;.cprestore\t%0\;.set\tnomacro";
|
||||
else
|
||||
return ".cprestore\t%0";
|
||||
}
|
||||
[(set_attr "type" "store")
|
||||
(set_attr "length" "4")])
|
||||
(set_attr "length" "4,12")])
|
||||
|
||||
;; Block moves, see mips.c for more details.
|
||||
;; Argument 0 is the destination
|
||||
|
Loading…
x
Reference in New Issue
Block a user