From: Jakub Jelinek Date: Tue, 24 Jun 2003 17:29:09 +0000 (+0200) Subject: builtins.c (expand_builtin_strcpy): Don't evaluate side-effects in src twice. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=946137a0d6d4bb6d325491f59e0043d67b345377;p=gcc.git builtins.c (expand_builtin_strcpy): Don't evaluate side-effects in src twice. * 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 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 6b63396325f..518723ffbfb 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2003-06-24 Jakub Jelinek + + * builtins.c (expand_builtin_strcpy): Don't evaluate side-effects in + src twice. + 2003-06-24 J"orn Rennecke Back out these patches: diff --git a/gcc/builtins.c b/gcc/builtins.c index 97c3372f2db..372c0c2f437 100644 --- a/gcc/builtins.c +++ b/gcc/builtins.c @@ -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); diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 9a4ca6940e8..2b8cff0ef36 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2003-06-24 Jakub Jelinek + + * gcc.c-torture/execute/string-opt-17.c: New test. + 2003-06-24 Mark Mitchell 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 index 00000000000..76a351bfb6b --- /dev/null +++ b/gcc/testsuite/gcc.c-torture/execute/string-opt-17.c @@ -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); +}