OSDN Git Service

* function.c (expand_function_start): Don't abort on PARALLEL
authorrth <rth@138bc75d-0d04-0410-961f-82ee72b054a4>
Fri, 25 May 2001 19:05:24 +0000 (19:05 +0000)
committerrth <rth@138bc75d-0d04-0410-961f-82ee72b054a4>
Fri, 25 May 2001 19:05:24 +0000 (19:05 +0000)
        returns from hard_function_value.

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

gcc/ChangeLog
gcc/function.c

index 091d66f..cdf1ca5 100644 (file)
@@ -1,5 +1,10 @@
 2001-05-25  Richard Henderson  <rth@redhat.com>
 
+       * function.c (expand_function_start): Don't abort on PARALLEL
+       returns from hard_function_value.
+
+2001-05-25  Richard Henderson  <rth@redhat.com>
+
        * config/i386/i386.md: Revert previous change.  Do not apply
        the peephole if the components do not die after the sequence.
 
index 6aeed3e..161173e 100644 (file)
@@ -6378,17 +6378,19 @@ expand_function_start (subr, parms_have_cleanups)
        = hard_function_value (TREE_TYPE (DECL_RESULT (subr)),
                               subr, 1);
 
-      /* Since we know the return value is not an aggregate, we should
-        have a REG here.  */
-      if (!REG_P (hard_reg))
-       abort ();
+      /* Structures that are returned in registers are not aggregate_value_p,
+        so we may see a PARALLEL.  Don't play pseudo games with this.  */
+      if (! REG_P (hard_reg))
+       SET_DECL_RTL (DECL_RESULT (subr), hard_reg);
+      else
+       {
+         /* Create the pseudo.  */
+         SET_DECL_RTL (DECL_RESULT (subr), gen_reg_rtx (GET_MODE (hard_reg)));
 
-      /* Create the pseudo.  */
-      SET_DECL_RTL (DECL_RESULT (subr), 
-                   gen_reg_rtx (GET_MODE (hard_reg)));
-      /* Needed because we may need to move this to memory
-        in case it's a named return value whose address is taken.  */
-      DECL_REGISTER (DECL_RESULT (subr)) = 1;
+         /* Needed because we may need to move this to memory
+            in case it's a named return value whose address is taken.  */
+         DECL_REGISTER (DECL_RESULT (subr)) = 1;
+       }
     }
 
   /* Initialize rtx for parameters and local variables.