summaryrefslogtreecommitdiff
path: root/gcc/config/mn10300
diff options
context:
space:
mode:
authorlaw <law@138bc75d-0d04-0410-961f-82ee72b054a4>1997-04-22 16:29:04 +0000
committerlaw <law@138bc75d-0d04-0410-961f-82ee72b054a4>1997-04-22 16:29:04 +0000
commitbe989dda4b2f4c7610751885caeb548aaa60a90d (patch)
tree7fc73a53865d3cf6807ba3fe742397131ead33e4 /gcc/config/mn10300
parentf56cac0d51ddbeb3f90457641138937e02e11d12 (diff)
downloadgcc-be989dda4b2f4c7610751885caeb548aaa60a90d.tar.gz
* mn10300.c (expand_prologue): End the current sequence before
counting the tst insns in the current function. Start a new one before emitting any prologue instructions. * mn10300.h (REGISTER_MOVE_COST): Bump up cost of moves in the same class. * mn10300.md (untyped_call): New expander. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@13955 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/config/mn10300')
-rw-r--r--gcc/config/mn10300/mn10300.c8
-rw-r--r--gcc/config/mn10300/mn10300.h2
-rw-r--r--gcc/config/mn10300/mn10300.md20
3 files changed, 29 insertions, 1 deletions
diff --git a/gcc/config/mn10300/mn10300.c b/gcc/config/mn10300/mn10300.c
index f2161024dc0..2e2bf5b1ea7 100644
--- a/gcc/config/mn10300/mn10300.c
+++ b/gcc/config/mn10300/mn10300.c
@@ -419,6 +419,11 @@ expand_prologue ()
{
unsigned int size;
+ /* We need to end the current sequence so that count_tst_insns can
+ look at all the insns in this function. Normally this would be
+ unsafe, but it's OK in the prologue/epilogue expanders. */
+ end_sequence ();
+
/* Determine if it is profitable to put the value zero into a register
for the entire function. If so, set ZERO_DREG and ZERO_AREG. */
if (regs_ever_live[2] || regs_ever_live[3]
@@ -475,6 +480,9 @@ expand_prologue ()
zero_areg = NULL_RTX;
}
+ /* Start a new sequence. */
+ start_sequence ();
+
/* SIZE includes the fixed stack space needed for function calls. */
size = get_frame_size () + current_function_outgoing_args_size;
size += (current_function_outgoing_args_size ? 4 : 0);
diff --git a/gcc/config/mn10300/mn10300.h b/gcc/config/mn10300/mn10300.h
index d7ac6af3e99..39b307b60ca 100644
--- a/gcc/config/mn10300/mn10300.h
+++ b/gcc/config/mn10300/mn10300.h
@@ -743,7 +743,7 @@ extern struct rtx_def *mn10300_builtin_saveregs ();
return 8;
-#define REGISTER_MOVE_COST(CLASS1, CLASS2) (CLASS1 != CLASS2 ? 4 : 0)
+#define REGISTER_MOVE_COST(CLASS1, CLASS2) (CLASS1 != CLASS2 ? 4 : 2)
/* A crude cut at RTX_COSTS for the MN10300. */
diff --git a/gcc/config/mn10300/mn10300.md b/gcc/config/mn10300/mn10300.md
index d936a02df12..c34b1bc36be 100644
--- a/gcc/config/mn10300/mn10300.md
+++ b/gcc/config/mn10300/mn10300.md
@@ -1234,6 +1234,26 @@
"calls %C1"
[(set_attr "cc" "clobber")])
+(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 (operands[0], 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));
+ }
+ DONE;
+}")
+
(define_insn "nop"
[(const_int 0)]
""