stmt.c (expand_return): Don't return anything if size is zero.
authorRichard Kenner <kenner@vlsi1.ultra.nyu.edu>
Sat, 20 Jan 2001 17:47:45 +0000 (17:47 +0000)
committerRichard Kenner <kenner@gcc.gnu.org>
Sat, 20 Jan 2001 17:47:45 +0000 (12:47 -0500)
* stmt.c (expand_return): Don't return anything if size is zero.
Delete redundant assignment to BYTES.
* expr.c (move_block_from_reg): Do nothing if NREGS is zero.

From-SVN: r39156

gcc/ChangeLog
gcc/expr.c
gcc/stmt.c

index cded5b23d6aec8e41746c20ab1236dc0846977a7..3cff034218d4c834b91b59d66a84e80367986866 100644 (file)
@@ -1,3 +1,9 @@
+Sat Jan 20 12:46:57 2001  Richard Kenner  <kenner@vlsi1.ultra.nyu.edu>
+
+       * stmt.c (expand_return): Don't return anything if size is zero.
+       Delete redundant assignment to BYTES.
+       * expr.c (move_block_from_reg): Do nothing if NREGS is zero.
+
 2001-01-20  Marek Michalkiewicz  <marekm@linux.org.pl>
 
        * config/avr/avr.h (INIT_TARGET_OPTABS): Remove most of it, was
index a78be1b132b4b67beb57931d65d13c3fa72830ff..848431e0440825b561f42774e02a6da553143f9c 100644 (file)
@@ -1857,6 +1857,9 @@ move_block_from_reg (regno, x, nregs, size)
 #endif
   enum machine_mode mode;
 
+  if (nregs == 0)
+    return;
+
   /* If SIZE is that of a mode no bigger than a word, just use that
      mode's store operation.  */
   if (size <= UNITS_PER_WORD
index 450b0da7c1af256b0f4a8f80ec94ac4f92f32f24..2399b6f83bf75a8c8a84d4facd4e9e6021246419 100644 (file)
@@ -3016,6 +3016,12 @@ expand_return (retval)
       rtx result_val = expand_expr (retval_rhs, NULL_RTX, VOIDmode, 0);
       enum machine_mode tmpmode, result_reg_mode;
 
+      if (bytes == 0)
+       {
+         expand_null_return ();
+         return;
+       }
+
       /* Structures whose size is not a multiple of a word are aligned
         to the least significant byte (to the right).  On a BYTES_BIG_ENDIAN
         machine, this means we must skip the empty high order bytes when
@@ -3063,15 +3069,12 @@ expand_return (retval)
       /* Find the smallest integer mode large enough to hold the
         entire structure and use that mode instead of BLKmode
         on the USE insn for the return register.   */
-      bytes = int_size_in_bytes (TREE_TYPE (retval_rhs));
       for (tmpmode = GET_CLASS_NARROWEST_MODE (MODE_INT);
           tmpmode != VOIDmode;
           tmpmode = GET_MODE_WIDER_MODE (tmpmode))
-       {
-         /* Have we found a large enough mode?  */
-         if (GET_MODE_SIZE (tmpmode) >= bytes)
-           break;
-       }
+       /* Have we found a large enough mode?  */
+       if (GET_MODE_SIZE (tmpmode) >= bytes)
+         break;
 
       /* No suitable mode found.  */
       if (tmpmode == VOIDmode)