From 1bc5aee63eb72b341f506ad058502cd0361f0d10 Mon Sep 17 00:00:00 2001 From: Ben Cheng Date: Tue, 25 Mar 2014 22:37:19 -0700 Subject: Initial checkin of GCC 4.9.0 from trunk (r208799). Change-Id: I48a3c08bb98542aa215912a75f03c0890e497dba --- .../gcc/testsuite/gcc.target/i386/align-main-1.c | 28 ++++++++++++++++++++++ 1 file changed, 28 insertions(+) create mode 100644 gcc-4.9/gcc/testsuite/gcc.target/i386/align-main-1.c (limited to 'gcc-4.9/gcc/testsuite/gcc.target/i386/align-main-1.c') diff --git a/gcc-4.9/gcc/testsuite/gcc.target/i386/align-main-1.c b/gcc-4.9/gcc/testsuite/gcc.target/i386/align-main-1.c new file mode 100644 index 000000000..f62284f43 --- /dev/null +++ b/gcc-4.9/gcc/testsuite/gcc.target/i386/align-main-1.c @@ -0,0 +1,28 @@ +/* Test for stack alignment when PREFERRED_STACK_BOUNDARY < alignment + of local variable. */ +/* { dg-do compile } */ +/* { dg-options "-O2 -mpreferred-stack-boundary=6 -mincoming-stack-boundary=6" } */ +/* { dg-final { scan-assembler "and\[lq\]?\[\\t \]*\\$-128,\[\\t \]*%\[re\]?sp" } } */ +/* { dg-final { scan-assembler-not "and\[lq\]?\[\\t \]*\\$-64,\[\\t \]*%\[re\]?sp" } } */ +/* { dg-skip-if "Options about stack-boundary aren't support" { x86_64-*-mingw* } { "*" } { "" } } */ + +#include + +#define ALIGNMENT 128 + +typedef int aligned __attribute__((aligned(ALIGNMENT))); +extern void abort(void); + +__attribute__ ((noinline)) +void check(void * a) +{ + if (((ptrdiff_t)a & (ALIGNMENT-1)) != 0) + abort(); +} + +int main() +{ + aligned a = 1; + check(&a); + return 0; +} -- cgit v1.2.3