diff options
author | Duncan Sands <baldrick@free.fr> | 2008-01-28 19:25:47 +0000 |
---|---|---|
committer | Duncan Sands <baldrick@free.fr> | 2008-01-28 19:25:47 +0000 |
commit | 07d403e222931ff20fdfecca1e1702b2cec2891c (patch) | |
tree | 3a559b3463245db7c35b5017bc8489ad978ab7c7 /test/CFrontend/2008-01-25-ByValReadNone.c | |
parent | 599ddf9a7693a315a03fc77cf612eec53dee5f67 (diff) | |
download | external_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.c | 15 |
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); } |