diff options
author | Kaveh R. Ghazi <ghazi@caip.rutgers.edu> | 2003-08-14 14:26:15 +0000 |
---|---|---|
committer | Kaveh Ghazi <ghazi@gcc.gnu.org> | 2003-08-14 14:26:15 +0000 |
commit | d256ac69eee99d5cc5c657bad82f9b1b00431c07 (patch) | |
tree | 35438dbb637a8112bf49b324e3077f7dc3a5d73b /gcc | |
parent | 9e46226d997030a197aaff707ce2cd678a6bd0c4 (diff) | |
download | gcc-d256ac69eee99d5cc5c657bad82f9b1b00431c07.zip gcc-d256ac69eee99d5cc5c657bad82f9b1b00431c07.tar.gz gcc-d256ac69eee99d5cc5c657bad82f9b1b00431c07.tar.bz2 |
strcat.c: New.
* gcc.c-torture/execute/builtins/lib/strcat.c: New.
* gcc.c-torture/execute/builtins/string-9-lib.c: New.
* gcc.c-torture/execute/builtins/string-9.c: New, from
string-opt-9.c. Adjust for execute/builtins framework.
* gcc.c-torture/execute/string-opt-9.c: Delete.
From-SVN: r70435
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/testsuite/ChangeLog | 8 | ||||
-rw-r--r-- | gcc/testsuite/gcc.c-torture/execute/builtins/lib/strcat.c | 19 | ||||
-rw-r--r-- | gcc/testsuite/gcc.c-torture/execute/builtins/string-9-lib.c | 1 | ||||
-rw-r--r-- | gcc/testsuite/gcc.c-torture/execute/builtins/string-9.c (renamed from gcc/testsuite/gcc.c-torture/execute/string-opt-9.c) | 27 |
4 files changed, 40 insertions, 15 deletions
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 035358b..e491ea1 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,11 @@ +2003-08-14 Kaveh R. Ghazi <ghazi@caip.rutgers.edu> + + * gcc.c-torture/execute/builtins/lib/strcat.c: New. + * gcc.c-torture/execute/builtins/string-9-lib.c: New. + * gcc.c-torture/execute/builtins/string-9.c: New, from + string-opt-9.c. Adjust for execute/builtins framework. + * gcc.c-torture/execute/string-opt-9.c: Delete. + 2003-08-12 Mark Mitchell <mark@codesourcery.com> * g++.dg/init/new8.C: Use __SIZE_TYPE__ to get the type of size_t. diff --git a/gcc/testsuite/gcc.c-torture/execute/builtins/lib/strcat.c b/gcc/testsuite/gcc.c-torture/execute/builtins/lib/strcat.c new file mode 100644 index 0000000..2cced80 --- /dev/null +++ b/gcc/testsuite/gcc.c-torture/execute/builtins/lib/strcat.c @@ -0,0 +1,19 @@ +extern int inside_main; +extern void abort(void); + +char * +strcat (char *dst, const char *src) +{ + char *p = dst; + +#ifdef __OPTIMIZE__ + if (inside_main) + abort (); +#endif + + while (*p) + p++; + while ((*p++ = *src++)) + ; + return dst; +} diff --git a/gcc/testsuite/gcc.c-torture/execute/builtins/string-9-lib.c b/gcc/testsuite/gcc.c-torture/execute/builtins/string-9-lib.c new file mode 100644 index 0000000..0a0bbb8 --- /dev/null +++ b/gcc/testsuite/gcc.c-torture/execute/builtins/string-9-lib.c @@ -0,0 +1 @@ +#include "lib/strcat.c" diff --git a/gcc/testsuite/gcc.c-torture/execute/string-opt-9.c b/gcc/testsuite/gcc.c-torture/execute/builtins/string-9.c index 0c21957..ba70c39 100644 --- a/gcc/testsuite/gcc.c-torture/execute/string-opt-9.c +++ b/gcc/testsuite/gcc.c-torture/execute/builtins/string-9.c @@ -5,6 +5,7 @@ Written by Kaveh R. Ghazi, 11/27/2000. */ +extern int inside_main; extern void abort (void); typedef __SIZE_TYPE__ size_t; extern char *strcat (char *, const char *); @@ -15,7 +16,7 @@ extern int memcmp (const void *, const void *, size_t); #define RESET_DST_WITH(FILLER) \ do { memset (dst, 'X', sizeof (dst)); strcpy (dst, (FILLER)); } while (0) -int main () +void main_test (void) { const char *const s1 = "hello world"; const char *const s2 = ""; @@ -38,6 +39,13 @@ int main () abort(); #ifndef __OPTIMIZE_SIZE__ +# if !defined __i386__ && !defined __x86_64__ + /* The functions below might not be optimized into direct stores on all + arches. It depends on how many instructions would be generated and + what limits the architecture chooses in STORE_BY_PIECES_P. */ + inside_main = 0; +# endif + RESET_DST_WITH (s1); if (strcat (dst, " 1111") != dst || memcmp (dst, "hello world 1111\0XXX", 20)) @@ -58,6 +66,9 @@ int main () "is "), "a "), "test"), "."); if (memcmp (dst, "hello world: this is a test.\0X", 30)) abort(); + + /* Set inside_main again. */ + inside_main = 1; #endif /* Test at least one instance of the __builtin_ style. We do this @@ -65,18 +76,4 @@ int main () RESET_DST_WITH (s1); if (__builtin_strcat (dst, "") != dst || strcmp (dst, s1)) abort(); - - return 0; } - -#ifdef __OPTIMIZE__ -/* When optimizing, all the above cases should be transformed into - something else. So any remaining calls to the original function - should abort. */ -__attribute__ ((noinline)) -static char * -strcat (char *s1, const char *s2) -{ - abort(); -} -#endif |