i386.c (ix86_force_to_memory, [...]): Update for 64bit.
authorJan Hubicka <jh@suse.cz>
Tue, 3 Apr 2001 17:44:45 +0000 (19:44 +0200)
committerJan Hubicka <hubicka@gcc.gnu.org>
Tue, 3 Apr 2001 17:44:45 +0000 (17:44 +0000)
* i386.c (ix86_force_to_memory, ix86_free_from_memory):
Update for 64bit.

From-SVN: r41062

gcc/ChangeLog
gcc/config/i386/i386.c

index a7e060f8147d7e3a434bab13725c8cc7d2d25c91..51099bee09e6e77e99755f7c8f8c87e0c93debe6 100644 (file)
@@ -1,3 +1,8 @@
+Tue Apr  3 19:41:21 CEST 2001  Jan Hubicka  <jh@suse.cz>
+
+       * i386.c (ix86_force_to_memory, ix86_free_from_memory):
+       Update for 64bit.
+
 2001-04-03  Zack Weinberg  <zackw@stanford.edu>
 
        * config/i386/xm-beos.h, config/i386/xm-isc.h,
index 9d63c5ed23ca72743c6f88c373b70a837ef2a1cb..c50761cafc70f2ea7a5a15316200955343d3195e 100644 (file)
@@ -10147,45 +10147,79 @@ ix86_force_to_memory (mode, operand)
      enum machine_mode mode;
      rtx operand;
 {
+  rtx result;
   if (!reload_completed)
     abort ();
-  switch (mode)
+  if (TARGET_64BIT && TARGET_RED_ZONE)
+    {
+      result = gen_rtx_MEM (mode,
+                           gen_rtx_PLUS (Pmode,
+                                         stack_pointer_rtx,
+                                         GEN_INT (-RED_ZONE_SIZE)));
+      emit_move_insn (result, operand);
+    }
+  else if (TARGET_64BIT && !TARGET_RED_ZONE)
     {
-      case DImode:
+      switch (mode)
        {
-         rtx operands[2];
-         split_di (&operand, 1, operands, operands+1);
+       case HImode:
+       case SImode:
+         operand = gen_lowpart (DImode, operand);
+         /* FALLTHRU */
+       case DImode:
          emit_insn (
-           gen_rtx_SET (VOIDmode,
-                        gen_rtx_MEM (SImode,
-                                     gen_rtx_PRE_DEC (Pmode,
-                                                      stack_pointer_rtx)),
-                        operands[1]));
+                     gen_rtx_SET (VOIDmode,
+                                  gen_rtx_MEM (DImode,
+                                               gen_rtx_PRE_DEC (DImode,
+                                                       stack_pointer_rtx)),
+                                  operand));
+         break;
+       default:
+         abort ();
+       }
+      result = gen_rtx_MEM (mode, stack_pointer_rtx);
+    }
+  else
+    {
+      switch (mode)
+       {
+       case DImode:
+         {
+           rtx operands[2];
+           split_di (&operand, 1, operands, operands + 1);
+           emit_insn (
+                       gen_rtx_SET (VOIDmode,
+                                    gen_rtx_MEM (SImode,
+                                                 gen_rtx_PRE_DEC (Pmode,
+                                                       stack_pointer_rtx)),
+                                    operands[1]));
+           emit_insn (
+                       gen_rtx_SET (VOIDmode,
+                                    gen_rtx_MEM (SImode,
+                                                 gen_rtx_PRE_DEC (Pmode,
+                                                       stack_pointer_rtx)),
+                                    operands[0]));
+         }
+         break;
+       case HImode:
+         /* It is better to store HImodes as SImodes.  */
+         if (!TARGET_PARTIAL_REG_STALL)
+           operand = gen_lowpart (SImode, operand);
+         /* FALLTHRU */
+       case SImode:
          emit_insn (
-           gen_rtx_SET (VOIDmode,
-                        gen_rtx_MEM (SImode,
-                                     gen_rtx_PRE_DEC (Pmode,
-                                                      stack_pointer_rtx)),
-                        operands[0]));
+                     gen_rtx_SET (VOIDmode,
+                                  gen_rtx_MEM (GET_MODE (operand),
+                                               gen_rtx_PRE_DEC (SImode,
+                                                       stack_pointer_rtx)),
+                                  operand));
+         break;
+       default:
+         abort ();
        }
-       break;
-      case HImode:
-       /* It is better to store HImodes as SImodes.  */
-       if (!TARGET_PARTIAL_REG_STALL)
-         operand = gen_lowpart (SImode, operand);
-       /* FALLTHRU */
-      case SImode:
-       emit_insn (
-         gen_rtx_SET (VOIDmode,
-                      gen_rtx_MEM (GET_MODE (operand),
-                                   gen_rtx_PRE_DEC (SImode,
-                                                    stack_pointer_rtx)),
-                      operand));
-       break;
-      default:
-       abort();
+      result = gen_rtx_MEM (mode, stack_pointer_rtx);
     }
-  return gen_rtx_MEM (mode, stack_pointer_rtx);
+  return result;
 }
 
 /* Free operand from the memory.  */
@@ -10193,15 +10227,22 @@ void
 ix86_free_from_memory (mode)
      enum machine_mode mode;
 {
-  /* Use LEA to deallocate stack space.  In peephole2 it will be converted
-     to pop or add instruction if registers are available.  */
-  emit_insn (gen_rtx_SET (VOIDmode, stack_pointer_rtx,
-                         gen_rtx_PLUS (Pmode, stack_pointer_rtx,
-                                       GEN_INT (mode == DImode
-                                                ? 8
-                                                : mode == HImode && TARGET_PARTIAL_REG_STALL
-                                                ? 2
-                                                : 4))));
+  if (!TARGET_64BIT || !TARGET_RED_ZONE)
+    {
+      int size;
+
+      if (mode == DImode || TARGET_64BIT)
+       size = 8;
+      else if (mode == HImode && TARGET_PARTIAL_REG_STALL)
+       size = 2;
+      else
+       size = 4;
+      /* Use LEA to deallocate stack space.  In peephole2 it will be converted
+         to pop or add instruction if registers are available.  */
+      emit_insn (gen_rtx_SET (VOIDmode, stack_pointer_rtx,
+                             gen_rtx_PLUS (Pmode, stack_pointer_rtx,
+                                           GEN_INT (size))));
+    }
 }
 
 /* Put float CONST_DOUBLE in the constant pool instead of fp regs.