; RUN: llc -O0 -mtriple=spirv64-unknown-unknown %s -o - | FileCheck %s --check-prefix=CHECK-SPIRV
; CHECK-SPIRV-NOT: OpCapability ExpectAssumeKHR
; CHECK-SPIRV-NOT: OpExtension "SPV_KHR_expect_assume"
; CHECK-SPIRV: OpFunction
; CHECK-SPIRV-NOT: %[[#]] = OpExpectKHR %[[#]] %[[#]] %[[#]]
; CHECK-SPIRV: %[[#RES1:]] = OpSConvert %[[#]] %[[#]]
; CHECK-SPIRV: %[[#]] = OpINotEqual %[[#]] %[[#RES1]] %[[#]]
; CHECK-SPIRV: OpFunction
; CHECK-SPIRV: %[[#RES2:]] = OpSConvert %[[#]] %[[#]]
; CHECK-SPIRV-NOT: %[[#]] = OpExpectKHR %[[#]] %[[#]] %[[#]]
; CHECK-SPIRV: %[[#]] = OpINotEqual %[[#]] %[[#RES2]] %[[#]]
%"class._ZTSZ4mainE3$_0.anon" = type { i8 }
define spir_kernel void @_ZTSZ4mainE15kernel_function() {
entry:
%0 = alloca %"class._ZTSZ4mainE3$_0.anon", align 1
%1 = bitcast %"class._ZTSZ4mainE3$_0.anon"* %0 to i8*
call void @llvm.lifetime.start.p0i8(i64 1, i8* %1)
%2 = addrspacecast %"class._ZTSZ4mainE3$_0.anon"* %0 to %"class._ZTSZ4mainE3$_0.anon" addrspace(4)*
call spir_func void @"_ZZ4mainENK3$_0clEv"(%"class._ZTSZ4mainE3$_0.anon" addrspace(4)* %2)
%3 = bitcast %"class._ZTSZ4mainE3$_0.anon"* %0 to i8*
call void @llvm.lifetime.end.p0i8(i64 1, i8* %3)
ret void
}
declare void @llvm.lifetime.start.p0i8(i64 immarg, i8* nocapture)
define internal spir_func void @"_ZZ4mainENK3$_0clEv"(%"class._ZTSZ4mainE3$_0.anon" addrspace(4)* %this) align 2 {
entry:
%this.addr = alloca %"class._ZTSZ4mainE3$_0.anon" addrspace(4)*, align 8
%a = alloca i32, align 4
%b = alloca i32, align 4
store %"class._ZTSZ4mainE3$_0.anon" addrspace(4)* %this, %"class._ZTSZ4mainE3$_0.anon" addrspace(4)** %this.addr, align 8
%this1 = load %"class._ZTSZ4mainE3$_0.anon" addrspace(4)*, %"class._ZTSZ4mainE3$_0.anon" addrspace(4)** %this.addr, align 8
%0 = bitcast i32* %a to i8*
call void @llvm.lifetime.start.p0i8(i64 4, i8* %0)
%call = call spir_func i32 @_Z12expect_consti(i32 1)
store i32 %call, i32* %a, align 4
%1 = bitcast i32* %b to i8*
call void @llvm.lifetime.start.p0i8(i64 4, i8* %1)
%call2 = call spir_func i32 @_Z10expect_funi(i32 2)
store i32 %call2, i32* %b, align 4
%2 = bitcast i32* %b to i8*
call void @llvm.lifetime.end.p0i8(i64 4, i8* %2)
%3 = bitcast i32* %a to i8*
call void @llvm.lifetime.end.p0i8(i64 4, i8* %3)
ret void
}
declare void @llvm.lifetime.end.p0i8(i64 immarg, i8* nocapture)
define spir_func i32 @_Z12expect_consti(i32 %x) {
entry:
%retval = alloca i32, align 4
%x.addr = alloca i32, align 4
store i32 %x, i32* %x.addr, align 4
%0 = load i32, i32* %x.addr, align 4
%conv = sext i32 %0 to i64
%expval = call i64 @llvm.expect.i64(i64 %conv, i64 1)
%tobool = icmp ne i64 %expval, 0
br i1 %tobool, label %if.then, label %if.end
if.then: ; preds = %entry
store i32 0, i32* %retval, align 4
br label %return
if.end: ; preds = %entry
%1 = load i32, i32* %x.addr, align 4
store i32 %1, i32* %retval, align 4
br label %return
return: ; preds = %if.end, %if.then
%2 = load i32, i32* %retval, align 4
ret i32 %2
}
define spir_func i32 @_Z10expect_funi(i32 %x) {
entry:
%retval = alloca i32, align 4
%x.addr = alloca i32, align 4
store i32 %x, i32* %x.addr, align 4
%0 = load i32, i32* %x.addr, align 4
%conv = sext i32 %0 to i64
%call = call spir_func i32 @_Z3foov()
%conv1 = sext i32 %call to i64
%expval = call i64 @llvm.expect.i64(i64 %conv, i64 %conv1)
%tobool = icmp ne i64 %expval, 0
br i1 %tobool, label %if.then, label %if.end
if.then: ; preds = %entry
store i32 0, i32* %retval, align 4
br label %return
if.end: ; preds = %entry
%1 = load i32, i32* %x.addr, align 4
store i32 %1, i32* %retval, align 4
br label %return
return: ; preds = %if.end, %if.then
%2 = load i32, i32* %retval, align 4
ret i32 %2
}
declare i64 @llvm.expect.i64(i64, i64)
declare spir_func i32 @_Z3foov()