OSDN Git Service

* config/xtensa/xtensa.c (function_arg): Generalize logic so that it
authorbwilson <bwilson@138bc75d-0d04-0410-961f-82ee72b054a4>
Thu, 22 Jan 2004 21:42:33 +0000 (21:42 +0000)
committerbwilson <bwilson@138bc75d-0d04-0410-961f-82ee72b054a4>
Thu, 22 Jan 2004 21:42:33 +0000 (21:42 +0000)
handles complex and vector modes.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@76373 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/ChangeLog
gcc/config/xtensa/xtensa.c

index 6a33f57..6c63263 100644 (file)
@@ -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.
 2004-01-22  Kazu Hirata  <kazu@cs.umass.edu>
 
        * config/h8300/h8300.h (REG_OK_FOR_INDEX_P_STRICT): Remove.
index e8926c9..d7e2902 100644 (file)
@@ -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
   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)
     {
       && regno < A7_REG
       && regno + words > A7_REG)
     {