diff options
author | Chris Smith <cks@gnu.org> | 1993-11-06 10:00:05 +0000 |
---|---|---|
committer | Chris Smith <cks@gnu.org> | 1993-11-06 10:00:05 +0000 |
commit | a39be5d99123923ddd09b846ee4a918d77c04260 (patch) | |
tree | a6648500318a68d9ca4f3a611c758628b56441a7 /gcc | |
parent | 7d454f03476c8b9f823c208319566d8433b3e41a (diff) | |
download | gcc-a39be5d99123923ddd09b846ee4a918d77c04260.zip gcc-a39be5d99123923ddd09b846ee4a918d77c04260.tar.gz gcc-a39be5d99123923ddd09b846ee4a918d77c04260.tar.bz2 |
add untyped_call
From-SVN: r6027
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/config/convex/convex.md | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/gcc/config/convex/convex.md b/gcc/config/convex/convex.md index 37e2696..1cdb78a 100644 --- a/gcc/config/convex/convex.md +++ b/gcc/config/convex/convex.md @@ -1908,6 +1908,44 @@ "" "* return output_call (insn, &operands[1]); ") +;; Call subroutine returning any type. + +(define_expand "untyped_call" + [(parallel [(call (match_operand 0 "" "") + (const_int 0)) + (match_operand 1 "" "") + (match_operand 2 "" "")])] + "" + " +{ + int i; + + emit_call_insn (gen_call_pop (operands[0], const0_rtx, + const0_rtx, const0_rtx)); + + for (i = 0; i < XVECLEN (operands[2], 0); i++) + { + rtx set = XVECEXP (operands[2], 0, i); + emit_move_insn (SET_DEST (set), SET_SRC (set)); + } + + /* The optimizer does not know that the call sets the function value + registers we stored in the result block. We avoid problems by + claiming that all hard registers are used and clobbered at this + point. */ + emit_insn (gen_blockage ()); + + DONE; +}") + +;; UNSPEC_VOLATILE is considered to use and clobber all hard registers and +;; all of memory. This blocks insns from being moved across this point. + +(define_insn "blockage" + [(unspec_volatile [(const_int 0)] 0)] + "" + "") + (define_expand "return" [(return)] "" |