builtins.c (expand_builtin_strcpy): Don't evaluate side-effects in src twice.
authorJakub Jelinek <jakub@redhat.com>
Tue, 24 Jun 2003 17:29:09 +0000 (19:29 +0200)
committerJakub Jelinek <jakub@gcc.gnu.org>
Tue, 24 Jun 2003 17:29:09 +0000 (19:29 +0200)
* builtins.c (expand_builtin_strcpy): Don't evaluate side-effects in
src twice.

* gcc.c-torture/execute/string-opt-17.c: New test.

From-SVN: r68431

gcc/ChangeLog
gcc/builtins.c
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.c-torture/execute/string-opt-17.c [new file with mode: 0644]

index 6b63396325f4d8c72b149dbd8d6860c0da4d4f34..518723ffbfbdc04253b776b2731ede35e5546957 100644 (file)
@@ -1,3 +1,8 @@
+2003-06-24  Jakub Jelinek  <jakub@redhat.com>
+
+       * builtins.c (expand_builtin_strcpy): Don't evaluate side-effects in
+       src twice.
+
 2003-06-24  J"orn Rennecke <joern.rennecke@superh.com>
 
        Back out these patches:
index 97c3372f2dbeb532567540174a8acf8b2cf6b4f0..372c0c2f4371379e60498b9063ddbc70c3e871f7 100644 (file)
@@ -2788,7 +2788,7 @@ expand_builtin_strcpy (tree arglist, rtx target, enum machine_mode mode)
 
   src = TREE_VALUE (TREE_CHAIN (arglist));
   len = c_strlen (src);
-  if (len == 0)
+  if (len == 0 || TREE_SIDE_EFFECTS (len))
     return 0;
 
   dst = TREE_VALUE (arglist);
index 9a4ca6940e835cbd702e67886d94e113e795b156..2b8cff0ef363e8880bc34c5a3b3b27cd04866c5b 100644 (file)
@@ -1,3 +1,7 @@
+2003-06-24  Jakub Jelinek  <jakub@redhat.com>
+
+       * gcc.c-torture/execute/string-opt-17.c: New test.
+
 2003-06-24  Mark Mitchell  <mark@codesourcery.com>
 
        PR c++/5754
diff --git a/gcc/testsuite/gcc.c-torture/execute/string-opt-17.c b/gcc/testsuite/gcc.c-torture/execute/string-opt-17.c
new file mode 100644 (file)
index 0000000..76a351b
--- /dev/null
@@ -0,0 +1,45 @@
+/* Copyright (C) 2003  Free Software Foundation.
+
+   Test strcpy optimizations don't evaluate side-effects twice.
+      
+   Written by Jakub Jelinek, June 23, 2003.  */
+
+typedef __SIZE_TYPE__ size_t;
+extern char *strcpy (char *, const char *);
+extern int memcmp (const void *, const void *, size_t);
+extern void abort (void);
+extern void exit (int);
+
+size_t
+test1 (char *s, size_t i)
+{
+  strcpy (s, "foobarbaz" + i++);
+  return i;
+}
+
+size_t
+check2 (void)
+{
+  static size_t r = 5;
+  if (r != 5)
+    abort ();
+  return ++r;
+}
+
+void
+test2 (char *s)
+{
+  strcpy (s, "foobarbaz" + check2 ());
+}
+
+int
+main (void)
+{
+  char buf[10];
+  if (test1 (buf, 7) != 8 || memcmp (buf, "az", 3))
+    abort ();
+  test2 (buf);
+  if (memcmp (buf, "baz", 4))
+    abort ();
+  exit (0);
+}