aboutsummaryrefslogtreecommitdiffstats
path: root/test/CFrontend/2008-01-25-ByValReadNone.c
diff options
context:
space:
mode:
authorDuncan Sands <baldrick@free.fr>2008-01-28 19:25:47 +0000
committerDuncan Sands <baldrick@free.fr>2008-01-28 19:25:47 +0000
commit07d403e222931ff20fdfecca1e1702b2cec2891c (patch)
tree3a559b3463245db7c35b5017bc8489ad978ab7c7 /test/CFrontend/2008-01-25-ByValReadNone.c
parent599ddf9a7693a315a03fc77cf612eec53dee5f67 (diff)
downloadexternal_llvm-07d403e222931ff20fdfecca1e1702b2cec2891c.zip
external_llvm-07d403e222931ff20fdfecca1e1702b2cec2891c.tar.gz
external_llvm-07d403e222931ff20fdfecca1e1702b2cec2891c.tar.bz2
Pure/const functions with ByVal parameters cannot
be marked readonly either. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@46456 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/CFrontend/2008-01-25-ByValReadNone.c')
-rw-r--r--test/CFrontend/2008-01-25-ByValReadNone.c15
1 files changed, 10 insertions, 5 deletions
diff --git a/test/CFrontend/2008-01-25-ByValReadNone.c b/test/CFrontend/2008-01-25-ByValReadNone.c
index afbf970..8ec6052 100644
--- a/test/CFrontend/2008-01-25-ByValReadNone.c
+++ b/test/CFrontend/2008-01-25-ByValReadNone.c
@@ -1,10 +1,15 @@
-// RUN: %llvmgcc -O3 -S -o - -emit-llvm %s | grep readonly
+// RUN: %llvmgcc -O3 -S -o - -emit-llvm %s | not grep readonly
// RUN: %llvmgcc -O3 -S -o - -emit-llvm %s | not grep readnone
-// The struct being passed byval means that we need to mark the
-// function readonly instead of readnone. Readnone would allow
-// stores to the arg to be deleted in the caller.
+// The struct being passed byval means that we cannot mark the
+// function readnone. Readnone would allow stores to the arg to
+// be deleted in the caller. We also don't allow readonly since
+// the callee might write to the byval parameter. The inliner
+// would have to assume the worse and introduce an explicit
+// temporary when inlining such a function, which is costly for
+// the common case in which the byval argument is not written.
struct S { int A[1000]; };
int __attribute__ ((const)) f(struct S x) { return x.A[0]; }
-
+int g(struct S x) __attribute__ ((pure));
+int h(struct S x) { return g(x); }