aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorMaciej W. Rozycki <macro@linux-mips.org>2005-08-25 11:30:19 +0000
committerMaciej W. Rozycki <macro@gcc.gnu.org>2005-08-25 11:30:19 +0000
commita5e668d53debcd73c2cf1721f57f38f89291bb7b (patch)
tree0e939143a34edd32e3d3c522f3c63d898e19a91c /gcc
parent40f15089964c9fc63d84293ca2f30e7437e0bc5b (diff)
downloadgcc-a5e668d53debcd73c2cf1721f57f38f89291bb7b.zip
gcc-a5e668d53debcd73c2cf1721f57f38f89291bb7b.tar.gz
gcc-a5e668d53debcd73c2cf1721f57f38f89291bb7b.tar.bz2
* gcc.c-torture/execute/frame-address.c: New test.
From-SVN: r103485
Diffstat (limited to 'gcc')
-rw-r--r--gcc/testsuite/ChangeLog4
-rw-r--r--gcc/testsuite/gcc.c-torture/execute/frame-address.c42
2 files changed, 46 insertions, 0 deletions
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index dc238f7..9ec4234 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,7 @@
+2005-08-26 Maciej W. Rozycki <macro@linux-mips.org>
+
+ * gcc.c-torture/execute/frame-address.c: New test.
+
2005-08-25 Nathan Sidwell <nathan@codesourcery.com>
PR c++/20817
diff --git a/gcc/testsuite/gcc.c-torture/execute/frame-address.c b/gcc/testsuite/gcc.c-torture/execute/frame-address.c
new file mode 100644
index 0000000..bf9443c
--- /dev/null
+++ b/gcc/testsuite/gcc.c-torture/execute/frame-address.c
@@ -0,0 +1,42 @@
+int check_fa_work (const char *, const char *) __attribute__((noinline));
+int check_fa_mid (const char *) __attribute__((noinline));
+int check_fa (char *) __attribute__((noinline));
+int how_much (void) __attribute__((noinline));
+
+int check_fa_work (const char *c, const char *f)
+{
+ const char d = 0;
+
+ if (c >= &d)
+ return c >= f && f >= &d;
+ else
+ return c <= f && f <= &d;
+}
+
+int check_fa_mid (const char *c)
+{
+ const char *f = __builtin_frame_address (0);
+
+ return check_fa_work (c, f);
+}
+
+int check_fa (char *unused)
+{
+ const char c = 0;
+
+ return check_fa_mid (&c);
+}
+
+int how_much (void)
+{
+ return 8;
+}
+
+int main (void)
+{
+ char *unused = __builtin_alloca (how_much ());
+
+ if (!check_fa(unused))
+ abort();
+ return 0;
+}