aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBob Wilson <bob.wilson@acm.org>2004-01-22 21:42:33 +0000
committerBob Wilson <bwilson@gcc.gnu.org>2004-01-22 21:42:33 +0000
commitb16417d6156db62e5135262b3ab7da4bfa01ba48 (patch)
treeec908692ab5d6c4294397b7b7a2ef16ffcd6a143
parent0dce1c0fcb90265b98cb72aa086b40b0edd75d08 (diff)
downloadgcc-b16417d6156db62e5135262b3ab7da4bfa01ba48.zip
gcc-b16417d6156db62e5135262b3ab7da4bfa01ba48.tar.gz
gcc-b16417d6156db62e5135262b3ab7da4bfa01ba48.tar.bz2
xtensa.c (function_arg): Generalize logic so that it handles complex and vector modes.
* config/xtensa/xtensa.c (function_arg): Generalize logic so that it handles complex and vector modes. From-SVN: r76373
-rw-r--r--gcc/ChangeLog5
-rw-r--r--gcc/config/xtensa/xtensa.c10
2 files changed, 10 insertions, 5 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 6a33f57..6c63263 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,8 @@
+2004-01-22 Bob Wilson <bob.wilson@acm.org>
+
+ * config/xtensa/xtensa.c (function_arg): Generalize logic so that it
+ handles complex and vector modes.
+
2004-01-22 Kazu Hirata <kazu@cs.umass.edu>
* config/h8300/h8300.h (REG_OK_FOR_INDEX_P_STRICT): Remove.
diff --git a/gcc/config/xtensa/xtensa.c b/gcc/config/xtensa/xtensa.c
index e8926c9..d7e2902 100644
--- a/gcc/config/xtensa/xtensa.c
+++ b/gcc/config/xtensa/xtensa.c
@@ -1753,12 +1753,12 @@ function_arg (CUMULATIVE_ARGS *cum, enum machine_mode mode, tree type,
result_mode = (mode == BLKmode ? TYPE_MODE (type) : mode);
/* We need to make sure that references to a7 are represented with
- rtx that is not equal to hard_frame_pointer_rtx. For BLKmode and
- modes bigger than 2 words (because we only have patterns for
- modes of 2 words or smaller), we can't control the expansion
- unless we explicitly list the individual registers in a PARALLEL. */
+ rtx that is not equal to hard_frame_pointer_rtx. For multi-word
+ modes for which we don't define move patterns, we can't control
+ the expansion unless we explicitly list the individual registers
+ in a PARALLEL. */
- if ((mode == BLKmode || words > 2)
+ if (mode != DImode && mode != DFmode
&& regno < A7_REG
&& regno + words > A7_REG)
{