56d343
2015-12-04  Jakub Jelinek  <jakub@redhat.com>
56d343
56d343
	PR tree-optimization/68680
56d343
	* calls.c (special_function_p): Return ECF_MAY_BE_ALLOCA for
56d343
	BUILT_IN_ALLOCA{,_WITH_ALIGN}.
56d343
56d343
	* gcc.target/i386/pr68680.c: New test.
56d343
56d343
--- gcc/calls.c	(revision 231278)
56d343
+++ gcc/calls.c	(revision 231279)
56d343
@@ -564,6 +564,17 @@ special_function_p (const_tree fndecl, i
56d343
 	flags |= ECF_NORETURN;
56d343
     }
56d343
 
56d343
+  if (DECL_BUILT_IN_CLASS (fndecl) == BUILT_IN_NORMAL)
56d343
+    switch (DECL_FUNCTION_CODE (fndecl))
56d343
+      {
56d343
+      case BUILT_IN_ALLOCA:
56d343
+      case BUILT_IN_ALLOCA_WITH_ALIGN:
56d343
+	flags |= ECF_MAY_BE_ALLOCA;
56d343
+	break;
56d343
+      default:
56d343
+	break;
56d343
+      }
56d343
+
56d343
   return flags;
56d343
 }
56d343
 
56d343
--- gcc/testsuite/gcc.target/i386/pr68680.c	(revision 0)
56d343
+++ gcc/testsuite/gcc.target/i386/pr68680.c	(revision 231279)
56d343
@@ -0,0 +1,15 @@
56d343
+/* PR tree-optimization/68680 */
56d343
+/* { dg-do compile } */
56d343
+/* { dg-options "-O2 -fstack-protector-strong" } */
56d343
+
56d343
+int foo (char *);
56d343
+
56d343
+int
56d343
+bar (unsigned long x)
56d343
+{
56d343
+  char a[x];
56d343
+  return foo (a);
56d343
+}
56d343
+
56d343
+/* Verify that this function is stack protected.  */
56d343
+/* { dg-final { scan-assembler "stack_chk_fail" } } */