From 52d972392150fc1a07734a90ba55586e7cee710b Mon Sep 17 00:00:00 2001 From: thorpej Date: Mon, 30 Sep 2002 21:43:01 +0000 Subject: [PATCH] * gcc.c-torture/execute/ffs-1.c: New test. * gcc.c-torture/execute/ffs-2.c: Ditto. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@57671 138bc75d-0d04-0410-961f-82ee72b054a4 --- gcc/testsuite/ChangeLog | 5 ++++ gcc/testsuite/gcc.c-torture/execute/ffs-1.c | 12 ++++++++ gcc/testsuite/gcc.c-torture/execute/ffs-2.c | 44 +++++++++++++++++++++++++++++ 3 files changed, 61 insertions(+) create mode 100644 gcc/testsuite/gcc.c-torture/execute/ffs-1.c create mode 100644 gcc/testsuite/gcc.c-torture/execute/ffs-2.c diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 2a84ea84780..c1ccc252465 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2002-09-30 Jason Thorpe + + * gcc.c-torture/execute/ffs-1.c: New test. + * gcc.c-torture/execute/ffs-2.c: Ditto. + 2002-09-30 Nathan Sidwell * g++.dg/overload/member1.C: New test. diff --git a/gcc/testsuite/gcc.c-torture/execute/ffs-1.c b/gcc/testsuite/gcc.c-torture/execute/ffs-1.c new file mode 100644 index 00000000000..da82e55805d --- /dev/null +++ b/gcc/testsuite/gcc.c-torture/execute/ffs-1.c @@ -0,0 +1,12 @@ +__volatile int a = 0; + +extern void abort (void); +extern void exit (int); + +int +main (void) +{ + if (__builtin_ffs (a) != 0) + abort (); + exit (0); +} diff --git a/gcc/testsuite/gcc.c-torture/execute/ffs-2.c b/gcc/testsuite/gcc.c-torture/execute/ffs-2.c new file mode 100644 index 00000000000..ae246cebf85 --- /dev/null +++ b/gcc/testsuite/gcc.c-torture/execute/ffs-2.c @@ -0,0 +1,44 @@ +struct + { + int input; + int output; + } +ffstesttab[] = + { +#if __INT_MAX__ >= 2147483647 + /* at least 32-bit integers */ + { 0x80000000, 32 }, + { 0xa5a5a5a5, 1 }, + { 0x5a5a5a5a, 2 }, + { 0xcafe0000, 18 }, +#endif +#if __INT_MAX__ >= 32767 + /* at least 16-bit integers */ + { 0x8000, 16 }, + { 0xa5a5, 1 }, + { 0x5a5a, 2 }, + { 0x0ca0, 6 }, +#endif +#if __INT_MAX__ < 32767 +#error integers are too small +#endif + }; + +#define NFFSTESTS (sizeof (ffstesttab) / sizeof (ffstesttab[0])) + +extern void abort (void); +extern void exit (int); + +int +main (void) +{ + int i; + + for (i = 0; i < NFFSTESTS; i++) + { + if (__builtin_ffs (ffstesttab[i].input) != ffstesttab[i].output) + abort (); + } + + exit (0); +} -- 2.11.4.GIT