aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorKaveh R. Ghazi <ghazi@caip.rutgers.edu>2003-08-14 14:26:15 +0000
committerKaveh Ghazi <ghazi@gcc.gnu.org>2003-08-14 14:26:15 +0000
commitd256ac69eee99d5cc5c657bad82f9b1b00431c07 (patch)
tree35438dbb637a8112bf49b324e3077f7dc3a5d73b /gcc
parent9e46226d997030a197aaff707ce2cd678a6bd0c4 (diff)
downloadgcc-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/ChangeLog8
-rw-r--r--gcc/testsuite/gcc.c-torture/execute/builtins/lib/strcat.c19
-rw-r--r--gcc/testsuite/gcc.c-torture/execute/builtins/string-9-lib.c1
-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