1*67d3ef74SVyacheslav Levytskyy; RUN: llc -verify-machineinstrs -O0 -mtriple=spirv64-unknown-unknown %s -o - | FileCheck %s 2dbd00a59SVyacheslav Levytskyy; RUN: %if spirv-tools %{ llc -O0 -mtriple=spirv64-unknown-unknown %s -o - -filetype=obj | spirv-val %} 3dbd00a59SVyacheslav Levytskyy 4*67d3ef74SVyacheslav Levytskyy; RUN: llc -verify-machineinstrs -O0 -mtriple=spirv32-unknown-unknown %s -o - | FileCheck %s 5dbd00a59SVyacheslav Levytskyy; RUN: %if spirv-tools %{ llc -O0 -mtriple=spirv32-unknown-unknown %s -o - -filetype=obj | spirv-val %} 6dbd00a59SVyacheslav Levytskyy 7dbd00a59SVyacheslav Levytskyy; CHECK-DAG: OpName %[[#Foo:]] "foo" 8dbd00a59SVyacheslav Levytskyy; CHECK-DAG: OpName %[[#CSQRT:]] "csqrt" 9dbd00a59SVyacheslav Levytskyy; CHECK-DAG: %[[#FloatTy:]] = OpTypeFloat 64 10dbd00a59SVyacheslav Levytskyy; CHECK-DAG: %[[#StructTy:]] = OpTypeStruct %[[#FloatTy]] %[[#FloatTy]] 11dbd00a59SVyacheslav Levytskyy; CHECK-DAG: %[[#GPtrStructTy:]] = OpTypePointer Generic %[[#StructTy]] 12dbd00a59SVyacheslav Levytskyy; CHECK-DAG: %[[#FPtrStructTy:]] = OpTypePointer Function %[[#StructTy]] 13dbd00a59SVyacheslav Levytskyy; CHECK-DAG: %[[#WrapTy:]] = OpTypeStruct %[[#StructTy]] 14dbd00a59SVyacheslav Levytskyy; CHECK-DAG: %[[#Int64Ty:]] = OpTypeInt 64 0 15dbd00a59SVyacheslav Levytskyy; CHECK-DAG: %[[#Int32Ty:]] = OpTypeInt 32 0 16dbd00a59SVyacheslav Levytskyy; CHECK-DAG: %[[#C1:]] = OpConstant %[[#Int32Ty]] 1 17dbd00a59SVyacheslav Levytskyy; CHECK-DAG: %[[#ArrayTy:]] = OpTypeArray %[[#Int64Ty]] %[[#C1]] 18dbd00a59SVyacheslav Levytskyy; CHECK-DAG: %[[#SArrayTy:]] = OpTypeStruct %[[#ArrayTy]] 19dbd00a59SVyacheslav Levytskyy; CHECK-DAG: %[[#SSArrayTy:]] = OpTypeStruct %[[#SArrayTy]] 20dbd00a59SVyacheslav Levytskyy; CHECK-DAG: %[[#CWPtrComplexTy:]] = OpTypePointer CrossWorkgroup %[[#WrapTy]] 21dbd00a59SVyacheslav Levytskyy; CHECK-DAG: %[[#IdTy:]] = OpTypePointer Function %[[#SSArrayTy]] 22dbd00a59SVyacheslav Levytskyy; CHECK: %[[#Foo]] = OpFunction 23dbd00a59SVyacheslav Levytskyy; CHECK: OpFunctionParameter %[[#CWPtrComplexTy]] 24dbd00a59SVyacheslav Levytskyy; CHECK: OpFunctionParameter %[[#IdTy]] 25dbd00a59SVyacheslav Levytskyy; CHECK: %[[#CSQRT]] = OpFunction 26dbd00a59SVyacheslav Levytskyy; CHECK: OpFunctionParameter %[[#GPtrStructTy]] 27dbd00a59SVyacheslav Levytskyy; CHECK: OpFunctionParameter %[[#FPtrStructTy]] 28dbd00a59SVyacheslav Levytskyy 29dbd00a59SVyacheslav Levytskyy%"class.id" = type { %"class.array" } 30dbd00a59SVyacheslav Levytskyy%"class.array" = type { [1 x i64] } 31dbd00a59SVyacheslav Levytskyy%"class.complex" = type { { double, double } } 32dbd00a59SVyacheslav Levytskyy 33dbd00a59SVyacheslav Levytskyydefine weak_odr dso_local spir_kernel void @foo(ptr addrspace(1) align 8 %_arg_buf_out1_access, ptr byval(%"class.id") align 8 %_arg_buf_out1_access3) { 34dbd00a59SVyacheslav Levytskyyentry: 35dbd00a59SVyacheslav Levytskyy %tmp.i.i = alloca { double, double }, align 8 36dbd00a59SVyacheslav Levytskyy %byval-temp.i.i = alloca { double, double }, align 8 37dbd00a59SVyacheslav Levytskyy %idxvalue = load i64, ptr %_arg_buf_out1_access3, align 8 38dbd00a59SVyacheslav Levytskyy %add.ptr.i = getelementptr inbounds %"class.complex", ptr addrspace(1) %_arg_buf_out1_access, i64 %idxvalue 39dbd00a59SVyacheslav Levytskyy %tmp.ascast.i.i = addrspacecast ptr %tmp.i.i to ptr addrspace(4) 40dbd00a59SVyacheslav Levytskyy %byval-temp.imagp.i.i = getelementptr inbounds i8, ptr %byval-temp.i.i, i64 8 41dbd00a59SVyacheslav Levytskyy store double -1.000000e+00, ptr %byval-temp.i.i, align 8 42dbd00a59SVyacheslav Levytskyy store double 0.000000e+00, ptr %byval-temp.imagp.i.i, align 8 43dbd00a59SVyacheslav Levytskyy call spir_func void @csqrt(ptr addrspace(4) dead_on_unwind writable sret({ double, double }) align 8 %tmp.ascast.i.i, ptr nonnull byval({ double, double }) align 8 %byval-temp.i.i) 44dbd00a59SVyacheslav Levytskyy %tmp.ascast.real.i.i = load double, ptr %tmp.i.i, align 8 45dbd00a59SVyacheslav Levytskyy %tmp.ascast.imagp.i.i = getelementptr inbounds i8, ptr %tmp.i.i, i64 8 46dbd00a59SVyacheslav Levytskyy %tmp.ascast.imag.i.i = load double, ptr %tmp.ascast.imagp.i.i, align 8 47dbd00a59SVyacheslav Levytskyy store double %tmp.ascast.real.i.i, ptr addrspace(1) %add.ptr.i, align 8 48dbd00a59SVyacheslav Levytskyy %dest = getelementptr inbounds i8, ptr addrspace(1) %add.ptr.i, i64 8 49dbd00a59SVyacheslav Levytskyy store double %tmp.ascast.imag.i.i, ptr addrspace(1) %dest, align 8 50dbd00a59SVyacheslav Levytskyy ret void 51dbd00a59SVyacheslav Levytskyy} 52dbd00a59SVyacheslav Levytskyy 53dbd00a59SVyacheslav Levytskyydefine weak dso_local spir_func void @csqrt(ptr addrspace(4) dead_on_unwind noalias writable sret({ double, double }) align 8 %agg.result, ptr byval({ double, double }) align 8 %z) { 54dbd00a59SVyacheslav Levytskyyentry: 55dbd00a59SVyacheslav Levytskyy %tmp = alloca { double, double }, align 8 56dbd00a59SVyacheslav Levytskyy %byval-temp = alloca { double, double }, align 8 57dbd00a59SVyacheslav Levytskyy %tmp.ascast = addrspacecast ptr %tmp to ptr addrspace(4) 58dbd00a59SVyacheslav Levytskyy %z.ascast.real = load double, ptr %z, align 8 59dbd00a59SVyacheslav Levytskyy %z.ascast.imagp = getelementptr inbounds i8, ptr %z, i64 8 60dbd00a59SVyacheslav Levytskyy %z.ascast.imag = load double, ptr %z.ascast.imagp, align 8 61dbd00a59SVyacheslav Levytskyy %byval-temp.imagp = getelementptr inbounds i8, ptr %byval-temp, i64 8 62dbd00a59SVyacheslav Levytskyy store double %z.ascast.real, ptr %byval-temp, align 8 63dbd00a59SVyacheslav Levytskyy store double %z.ascast.imag, ptr %byval-temp.imagp, align 8 64dbd00a59SVyacheslav Levytskyy call spir_func void @__devicelib_csqrt(ptr addrspace(4) dead_on_unwind writable sret({ double, double }) align 8 %tmp.ascast, ptr nonnull byval({ double, double }) align 8 %byval-temp) #7 65dbd00a59SVyacheslav Levytskyy %tmp.ascast.real = load double, ptr %tmp, align 8 66dbd00a59SVyacheslav Levytskyy %tmp.ascast.imagp = getelementptr inbounds i8, ptr %tmp, i64 8 67dbd00a59SVyacheslav Levytskyy %tmp.ascast.imag = load double, ptr %tmp.ascast.imagp, align 8 68dbd00a59SVyacheslav Levytskyy %agg.result.imagp = getelementptr inbounds i8, ptr addrspace(4) %agg.result, i64 8 69dbd00a59SVyacheslav Levytskyy store double %tmp.ascast.real, ptr addrspace(4) %agg.result, align 8 70dbd00a59SVyacheslav Levytskyy store double %tmp.ascast.imag, ptr addrspace(4) %agg.result.imagp, align 8 71dbd00a59SVyacheslav Levytskyy ret void 72dbd00a59SVyacheslav Levytskyy} 73dbd00a59SVyacheslav Levytskyy 74dbd00a59SVyacheslav Levytskyydeclare extern_weak dso_local spir_func void @__devicelib_csqrt(ptr addrspace(4) dead_on_unwind writable sret({ double, double }) align 8, ptr byval({ double, double }) align 8) local_unnamed_addr #3 75