1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2025-01-31 12:41:49 +01:00
llvm-mirror/test/CodeGen/X86/machine-sink-and-implicit-null-checks.ll
Philip Reames 23dcf5ab2d Migrate last batch of tests to gc-live bundle format
For context of anyone following along, we've not completed the migration of statepoint to the operand bundle form.  The only remaining piece is to actually version the statepoint intrinsic to remove the old inline operand sets.  That will follow when I have some time; delay is useful here to allow downstream migrations.
2020-06-26 10:28:27 -07:00

84 lines
2.1 KiB
LLVM

; RUN: llc -mtriple=x86_64-apple-macosx -O3 -enable-implicit-null-checks -o - < %s 2>&1 | FileCheck %s
declare void @throw0()
declare void @throw1()
define i1 @f(i8* %p0, i8* %p1) {
entry:
%c0 = icmp eq i8* %p0, null
br i1 %c0, label %throw0, label %continue0, !make.implicit !0
continue0:
%v0 = load i8, i8* %p0
%c1 = icmp eq i8* %p1, null
br i1 %c1, label %throw1, label %continue1, !make.implicit !0
continue1:
%v1 = load i8, i8* %p1
%v = icmp eq i8 %v0, %v1
ret i1 %v
throw0:
call void @throw0()
unreachable
throw1:
call void @throw1()
unreachable
}
declare void @foo()
declare token @llvm.experimental.gc.statepoint.p0f_isVoidf(i64, i32, void ()*, i32, i32, ...)
declare i8 addrspace(1)* @llvm.experimental.gc.relocate.p1i8(token, i32, i32) nounwind readonly
; Check for a crash. The crash is not specific to statepoints, but
; gc.statpeoint is an easy way to generate a fill instruction in
; %continue0 (which causes the llc crash).
define i1 @g(i8 addrspace(1)* %p0, i8* %p1) gc "statepoint-example" {
entry:
%c0 = icmp eq i8 addrspace(1)* %p0, null
%tok = call token (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) ["gc-live"(i8 addrspace(1)* %p0)]
%p0.relocated = call coldcc i8 addrspace(1)* @llvm.experimental.gc.relocate.p1i8(token %tok, i32 0, i32 0) ; (%p0, %p0)
br i1 %c0, label %throw0, label %continue0, !make.implicit !0
continue0:
%c1 = icmp eq i8* %p1, null
br i1 %c1, label %throw1, label %continue1, !make.implicit !0
continue1:
%v0 = load i8, i8 addrspace(1)* %p0.relocated
%v1 = load i8, i8* %p1
%v = icmp eq i8 %v0, %v1
ret i1 %v
throw0:
call void @throw0()
unreachable
throw1:
call void @throw1()
unreachable
}
; Check that we have two implicit null checks in @f
; CHECK: __LLVM_FaultMaps:
; CHECK-NEXT: .byte 1
; CHECK-NEXT: .byte 0
; CHECK-NEXT: .short 0
; CHECK-NEXT: .long 1
; FunctionInfo[0] =
; FunctionAddress =
; CHECK-NEXT: .quad _f
; NumFaultingPCs =
; CHECK-NEXT: .long 2
; Reserved =
; CHECK-NEXT: .long 0
!0 = !{}