aboutsummaryrefslogtreecommitdiff
path: root/gcc/config/rx
diff options
context:
space:
mode:
authornickc <nickc@138bc75d-0d04-0410-961f-82ee72b054a4>2015-06-08 13:57:58 +0000
committernickc <nickc@138bc75d-0d04-0410-961f-82ee72b054a4>2015-06-08 13:57:58 +0000
commit942ca7014fa98b7b4620749d64ee616d91018196 (patch)
treefc186b27117ad066504d7a44e648253e3f72c084 /gcc/config/rx
parent76a3604a15e340c36462f835a292701bcd309bc0 (diff)
* config/rx/rx.c (rx_function_value): Do not promote vector types.
(rx_promote_function_mode): Likewise. * config/rx/rx.h (LIBCALL_VALUE): Likewise. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@224228 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/config/rx')
-rw-r--r--gcc/config/rx/rx.c20
-rw-r--r--gcc/config/rx/rx.h1
2 files changed, 16 insertions, 5 deletions
diff --git a/gcc/config/rx/rx.c b/gcc/config/rx/rx.c
index 5262fbf84ca..5bf38dfbb43 100644
--- a/gcc/config/rx/rx.c
+++ b/gcc/config/rx/rx.c
@@ -477,11 +477,18 @@ rx_print_operand_address (FILE * file, rtx addr)
addr = XEXP (addr, 0);
gcc_assert (XINT (addr, 1) == UNSPEC_CONST);
- /* FIXME: Putting this case label here is an appalling abuse of the C language. */
- case UNSPEC:
addr = XVECEXP (addr, 0, 0);
gcc_assert (CONST_INT_P (addr));
+ fprintf (file, "#");
+ output_addr_const (file, addr);
+ break;
}
+ fprintf (file, "#");
+ output_addr_const (file, XEXP (addr, 0));
+ break;
+
+ case UNSPEC:
+ addr = XVECEXP (addr, 0, 0);
/* Fall through. */
case LABEL_REF:
case SYMBOL_REF:
@@ -1174,6 +1181,8 @@ rx_function_value (const_tree ret_type,
if (GET_MODE_SIZE (mode) > 0
&& GET_MODE_SIZE (mode) < 4
&& ! COMPLEX_MODE_P (mode)
+ && ! VECTOR_TYPE_P (ret_type)
+ && ! VECTOR_MODE_P (mode)
)
return gen_rtx_REG (SImode, FUNC_RETURN_REGNUM);
@@ -1193,6 +1202,8 @@ rx_promote_function_mode (const_tree type ATTRIBUTE_UNUSED,
if (for_return != 1
|| GET_MODE_SIZE (mode) >= 4
|| COMPLEX_MODE_P (mode)
+ || VECTOR_MODE_P (mode)
+ || VECTOR_TYPE_P (type)
|| GET_MODE_SIZE (mode) < 1)
return mode;
@@ -1712,7 +1723,6 @@ gen_safe_add (rtx dest, rtx src, rtx val, bool is_frame_related)
if (is_frame_related)
RTX_FRAME_RELATED_P (insn) = 1;
- return;
}
static void
@@ -1746,7 +1756,7 @@ rx_expand_prologue (void)
if (flag_stack_usage_info)
current_function_static_stack_size = frame_size + stack_size;
-
+
/* If we use any of the callee-saved registers, save them now. */
if (mask)
{
@@ -1852,7 +1862,7 @@ rx_expand_prologue (void)
GEN_INT (- (HOST_WIDE_INT) frame_size), true);
else
gen_safe_add (stack_pointer_rtx, frame_pointer_rtx, NULL_RTX,
- true);
+ false /* False because the epilogue will use the FP not the SP. */);
}
}
diff --git a/gcc/config/rx/rx.h b/gcc/config/rx/rx.h
index 8391b5b25b0..d2d6bce48c8 100644
--- a/gcc/config/rx/rx.h
+++ b/gcc/config/rx/rx.h
@@ -267,6 +267,7 @@ enum reg_class
#define LIBCALL_VALUE(MODE) \
gen_rtx_REG (((GET_MODE_CLASS (MODE) != MODE_INT \
|| COMPLEX_MODE_P (MODE) \
+ || VECTOR_MODE_P (MODE) \
|| GET_MODE_SIZE (MODE) >= 4) \
? (MODE) \
: SImode), \