* config/i386/i386.c (ix86_compute_frame_layout): Do add bottom
authorrth <rth@138bc75d-0d04-0410-961f-82ee72b054a4>
Wed, 29 May 2002 20:29:21 +0000 (20:29 +0000)
committerrth <rth@138bc75d-0d04-0410-961f-82ee72b054a4>
Wed, 29 May 2002 20:29:21 +0000 (20:29 +0000)
        alignment for alloca.

* gcc.c-torture/execute/alloca-1.c: New.

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

gcc/ChangeLog
gcc/config/i386/i386.c
gcc/testsuite/gcc.c-torture/execute/alloca-1.c [new file with mode: 0644]

index a761931..14069a7 100644 (file)
@@ -1,5 +1,10 @@
 2002-05-29  Richard Henderson  <rth@redhat.com>
 
+       * config/i386/i386.c (ix86_compute_frame_layout): Do add bottom
+       alignment for alloca.
+
+2002-05-29  Richard Henderson  <rth@redhat.com>
+
        * config/i386/i386.c (output_pic_addr_const): Lowercase rip.
        (print_operand_address): Only add rip for symbolic addresses
        for which we do not have another relocation type.
index 5170c99..877f355 100644 (file)
@@ -4148,8 +4148,9 @@ ix86_compute_frame_layout (frame)
   else
     frame->outgoing_arguments_size = 0;
 
-  /* Align stack boundary.  Only needed if we're calling another function.  */
-  if (!current_function_is_leaf)
+  /* Align stack boundary.  Only needed if we're calling another function
+     or using alloca.  */
+  if (!current_function_is_leaf || current_function_calls_alloca)
     frame->padding2 = ((offset + preferred_alignment - 1)
                       & -preferred_alignment) - offset;
   else
diff --git a/gcc/testsuite/gcc.c-torture/execute/alloca-1.c b/gcc/testsuite/gcc.c-torture/execute/alloca-1.c
new file mode 100644 (file)
index 0000000..a8d1384
--- /dev/null
@@ -0,0 +1,21 @@
+/* Verify that alloca storage is sufficiently aligned.  */
+/* ??? May fail if BIGGEST_ALIGNMENT > STACK_BOUNDARY.  Which, I guess
+   can only happen on !STRICT_ALIGNMENT targets.  */
+
+typedef __SIZE_TYPE__ size_t;
+
+struct dummy { int x __attribute__((aligned)); };
+#define BIGGEST_ALIGNMENT __alignof__(struct dummy)
+
+_Bool foo(void)
+{
+  char *p = __builtin_alloca(32);
+  return ((size_t)p & (BIGGEST_ALIGNMENT - 1)) == 0;
+}
+
+int main()
+{
+  if (!foo())
+    abort ();
+  return 0;
+}