From fee2770d39a87ebacc4537e7536e8a05f6f54f7b Mon Sep 17 00:00:00 2001 From: Richard Stallman Date: Sun, 9 May 1993 04:56:08 +0000 Subject: [PATCH] (call_insn_operand): New function. From-SVN: r4393 --- gcc/config/i386/i386.c | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) diff --git a/gcc/config/i386/i386.c b/gcc/config/i386/i386.c index fe85584444f..7aecf5c9ecc 100644 --- a/gcc/config/i386/i386.c +++ b/gcc/config/i386/i386.c @@ -514,6 +514,26 @@ symbolic_operand (op, mode) return 0; } } + +/* Test for a valid operand for a call instruction. + Don't allow the arg pointer register or virtual regs + since they may change into reg + const, which the patterns + can't handle yet. */ + +int +call_insn_operand (op, mode) + rtx op; + enum machine_mode mode; +{ + if (GET_CODE (op) == MEM + && (CONSTANT_ADDRESS_P (XEXP (op, 0)) + || (GET_CODE (XEXP (op, 0)) == REG + && XEXP (op, 0) != arg_pointer_rtx + && !(REGNO (XEXP (op, 0)) >= FIRST_PSEUDO_REGISTER + && REGNO (XEXP (op, 0)) <= LAST_VIRTUAL_REGISTER)))) + return 1; + return 0; +} /* Returns 1 if OP contains a symbol reference */ -- 2.30.2