[PATCH] [Verifier] Assert gc_relocate always return a pointer type
Chen Li
meloli87 at gmail.com
Wed May 13 10:57:57 PDT 2015
Add an assert for address space and testcase.
http://reviews.llvm.org/D9695
Files:
lib/IR/Verifier.cpp
test/Verifier/gc_relocate_addrspace.ll
Index: lib/IR/Verifier.cpp
===================================================================
--- lib/IR/Verifier.cpp
+++ lib/IR/Verifier.cpp
@@ -3441,7 +3441,16 @@
&CI);
// gc_relocate does not need to be the same type as the relocated pointer.
- // It can casted to the correct type later if it's desired
+ // It can casted to the correct type later if it's desired. However, it
+ // must be a pointer type and have the same address space
+ GCRelocateOperands Operands(&CI);
+ Assert(CI.getType()->isPointerTy() && Operands.getDerivedPtr()->getType()->isPointerTy(),
+ "gc.relocate: relocating a pointer should always return a pointer", &CI);
+
+ Assert(cast<PointerType>(CI.getType())->getAddressSpace() ==
+ cast<PointerType>(Operands.getDerivedPtr()->getType())->getAddressSpace(),
+ "gc.relocate: relocating a pointer shouldn't change its address space", &CI);
+
break;
}
};
Index: test/Verifier/gc_relocate_addrspace.ll
===================================================================
--- /dev/null
+++ test/Verifier/gc_relocate_addrspace.ll
@@ -0,0 +1,23 @@
+; RUN: not llvm-as -disable-output <%s 2>&1 | FileCheck %s
+; This is to verify that gc_relocate must return a pointer with the same
+; address space with the relocated value.
+
+; CHECK: gc.relocate: relocating a pointer shouldn't change its address space
+; CHECK-NEXT: %obj.relocated = call coldcc i8* @llvm.experimental.gc.relocate.p0i8(i32 %safepoint_token, i32 7, i32 7) ;
+
+declare void @foo()
+
+; Function Attrs: nounwind
+declare i32 @llvm.experimental.gc.statepoint.p0f_isVoidf(i64, i32, void ()*, i32, i32, ...) #0
+
+define void @test1(i64 addrspace(1)* %obj) gc "statepoint-example" {
+entry:
+ %safepoint_token = call i32 (i64, i32, void ()*, i32, i32, ...) @llvm.experimental.gc.statepoint.p0f_isVoidf(i64 0, i32 0, void ()* @foo, i32 0, i32 0, i32 0, i32 0, i64 addrspace(1)* %obj)
+ %obj.relocated = call coldcc i8* @llvm.experimental.gc.relocate.p0i8(i32 %safepoint_token, i32 7, i32 7) ; (%obj, %obj)
+ ret void
+}
+
+; Function Attrs: nounwind
+declare i8* @llvm.experimental.gc.relocate.p0i8(i32, i32, i32) #0
+
+attributes #0 = { nounwind }
EMAIL PREFERENCES
http://reviews.llvm.org/settings/panel/emailpreferences/
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D9695.25712.patch
Type: text/x-patch
Size: 2225 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20150513/57d200a3/attachment.bin>
More information about the llvm-commits
mailing list