aboutsummaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorMark Seaborn <mseaborn@chromium.org>2013-05-31 09:56:47 -0700
committerMark Seaborn <mseaborn@chromium.org>2013-05-31 09:56:47 -0700
commitb74fb76de6dba430089e94fd5e8d0fa856cda3cc (patch)
treef2f11f6e40421cc3803a52e7f831f3c78d444cf3 /test
parent99c2f236a1a09b6c550e91b71dabbbb0e634ea37 (diff)
PNaCl: Remove and disallow llvm.invariant.start/end intrinsics
These markers work in a similar way to llvm.lifetime.start/end, so we should remove them for similar reasons: it's not very well defined how one marker cancels out the effects of the other. Arguably, invariant.start/end are less useful than lifetime.start/end. They are ignored by the backend. They are generated in fewer places: invariant.start is generated by Clang (at -O1 or higher) when a const global is initialised with a non-POD initialiser. invariant.end is apparently not generated at all. Do the stripping in ReplacePtrsWithInts for consistency with the existing lifetime.start/end stripping. BUG=https://code.google.com/p/nativeclient/issues/detail?id=3443 TEST=PNaCl toolchain trybots Review URL: https://codereview.chromium.org/15995004
Diffstat (limited to 'test')
-rw-r--r--test/Transforms/NaCl/replace-ptrs-with-ints.ll12
1 files changed, 12 insertions, 0 deletions
diff --git a/test/Transforms/NaCl/replace-ptrs-with-ints.ll b/test/Transforms/NaCl/replace-ptrs-with-ints.ll
index bab6101848..d7e85f6da6 100644
--- a/test/Transforms/NaCl/replace-ptrs-with-ints.ll
+++ b/test/Transforms/NaCl/replace-ptrs-with-ints.ll
@@ -447,6 +447,8 @@ define void @debug_value(i32 %val, i8* %ptr) {
declare void @llvm.lifetime.start(i64 %size, i8* %ptr)
+declare void @llvm.invariant.start(i64 %size, i8* %ptr)
+declare void @llvm.invariant.end(i64 %size, i8* %ptr)
; GVN can introduce the following horrible corner case of a lifetime
; marker referencing a PHI node. But we convert the phi to i32 type,
@@ -486,6 +488,16 @@ define void @alloca_lifetime_via_bitcast() {
; CHECK-NEXT: %buf = alloca [4 x i8]
; CHECK-NEXT: ret void
+define void @strip_invariant_markers() {
+ %buf = alloca i8
+ call void @llvm.invariant.start(i64 1, i8* %buf)
+ call void @llvm.invariant.end(i64 1, i8* %buf)
+ ret void
+}
+; CHECK: define void @strip_invariant_markers() {
+; CHECK-NEXT: %buf = alloca [1 x i8]
+; CHECK-NEXT: ret void
+
; "nocapture" and "noalias" only apply to pointers, so must be stripped.
define void @nocapture_attr(i8* nocapture noalias %ptr) {