; RUN: llvm-as %s -o %t.bc ; RUN: llvm-spirv %t.bc -o %t.spv ; RUN: llvm-spirv %t.spv -to-text -o %t.spt ; RUN: FileCheck < %t.spt %s --check-prefix=CHECK-SPIRV ; RUN: llvm-spirv -r %t.spv -o %t.rev.bc ; RUN: llvm-dis %t.rev.bc ; RUN: FileCheck < %t.rev.ll %s --check-prefix=CHECK-LLVM ; TODO: update or remove test following deprecation of float binop constant expressions. ; XFAIL: * target datalayout = "e-i64:64-v16:16-v24:32-v32:32-v48:64-v96:128-v192:256-v256:256-v512:512-v1024:1024-n8:16:32:64" target triple = "spir64" define linkonce_odr hidden spir_func void @foo() { entry: ; CHECK-SPIRV-DAG: Constant [[#]] [[#CONSTANT1:]] 65793 ; CHECK-SPIRV-DAG: Constant [[#]] [[#CONSTANT2:]] 131586 ; CHECK-SPIRV: ConstantComposite [[#]] [[#COMPOS0:]] [[#CONSTANT1]] ; 124 is OpBitcast opcode ; CHECK-SPIRV: SpecConstantOp [[#]] [[#BITCAST_RES0:]] 124 [[#COMPOS0]] ; 81 is OpCompositeExtract opcode ; CHECK-SPIRV: SpecConstantOp [[#]] [[#EXTRACT_RES0:]] 81 [[#BITCAST_RES0]] 0 ; CHECK-SPIRV: ConstantComposite [[#]] [[#COMPOS1:]] [[#CONSTANT2]] ; CHECK-SPIRV: SpecConstantOp [[#]] [[#BITCAST_RES1:]] 124 [[#COMPOS1]] ; CHECK-SPIRV: SpecConstantOp [[#]] [[#EXTRACT_RES1:]] 81 [[#BITCAST_RES1]] 0 ; 129 is OpFAdd opcode ; CHECK-SPIRV: SpecConstantOp [[#]] [[#MEMBER_1:]] 129 [[#EXTRACT_RES0:]] [[#EXTRACT_RES1]] ; CHECK-SPIRV: SpecConstantOp [[#]] [[#EXTRACT_RES2:]] 81 [[#BITCAST_RES0]] 1 ; CHECK-SPIRV: SpecConstantOp [[#]] [[#EXTRACT_RES3:]] 81 [[#BITCAST_RES1]] 1 ; CHECK-SPIRV: SpecConstantOp [[#]] [[#MEMBER_2:]] 129 [[#EXTRACT_RES2]] [[#EXTRACT_RES3]] ; CHECK-SPIRV: SpecConstantOp [[#]] [[#BITCAST_RES2:]] 81 [[#BITCAST_RES0]] 2 ; CHECK-SPIRV: SpecConstantOp [[#]] [[#BITCAST_RES2:]] 81 [[#BITCAST_RES1]] 2 ; CHECK-SPIRV: SpecConstantOp [[#]] [[#MEMBER_3:]] 129 [[#]] [[#BITCAST_RES2]] ; CHECK-SPIRV: Undef [[#]] [[#MEMBER_4:]] ; CHECK-SPIRV: ConstantComposite [[#]] [[#FINAL_COMPOS:]] [[#MEMBER_1]] [[#MEMBER_2]] [[#MEMBER_3]] [[#MEMBER_4]] ; CHECK-SPIRV: DebugValue [[#]] [[#FINAL_COMPOS]] ; CHECK-LLVM: call void @llvm.dbg.value( ; CHECK-LLVM-SAME: metadata <4 x half> < ; CHECK-LLVM-SAME: half fadd ( ; CHECK-LLVM-SAME: half extractelement (<4 x half> bitcast (<2 x i32> to <4 x half>), i32 0), ; CHECK-LLVM-SAME: half extractelement (<4 x half> bitcast (<2 x i32> to <4 x half>), i32 0)), ; CHECK-LLVM-SAME: half fadd ( ; CHECK-LLVM-SAME: half extractelement (<4 x half> bitcast (<2 x i32> to <4 x half>), i32 1), ; CHECK-LLVM-SAME: half extractelement (<4 x half> bitcast (<2 x i32> to <4 x half>), i32 1)), ; CHECK-LLVM-SAME: half fadd ( ; CHECK-LLVM-SAME: half extractelement (<4 x half> bitcast (<2 x i32> to <4 x half>), i32 2), ; CHECK-LLVM-SAME: half extractelement (<4 x half> bitcast (<2 x i32> to <4 x half>), i32 2)), ; CHECK-LLVM-SAME: half undef>, ; CHECK-LLVM-SAME: metadata ![[#]], metadata !DIExpression()), !dbg ![[#]] call void @llvm.dbg.value( metadata <4 x half> < half fadd ( half extractelement (<4 x half> bitcast (<2 x i32> to <4 x half>), i32 0), half extractelement (<4 x half> bitcast (<2 x i32> to <4 x half>), i32 0)), half fadd ( half extractelement (<4 x half> bitcast (<2 x i32> to <4 x half>), i32 1), half extractelement (<4 x half> bitcast (<2 x i32> to <4 x half>), i32 1)), half fadd ( half extractelement (<4 x half> bitcast (<2 x i32> to <4 x half>), i32 2), half extractelement (<4 x half> bitcast (<2 x i32> to <4 x half>), i32 2)), half undef>, metadata !12, metadata !DIExpression()), !dbg !7 ret void } ; Function Attrs: nofree nosync nounwind readnone speculatable willreturn declare void @llvm.dbg.value(metadata, metadata, metadata) !llvm.dbg.cu = !{!0} !llvm.module.flags = !{!3, !4} !opencl.used.extensions = !{!2} !opencl.used.optional.core.features = !{!2} !opencl.compiler.options = !{!2} !llvm.ident = !{!5} !0 = distinct !DICompileUnit(language: DW_LANG_C_plus_plus_14, file: !1, producer: "clang version 13.0.0 (https://github.com/intel/llvm.git)", isOptimized: false, runtimeVersion: 0, emissionKind: FullDebug, enums: !2, nameTableKind: None) !1 = !DIFile(filename: "main.cpp", directory: "/export/users") !2 = !{} !3 = !{i32 2, !"Debug Info Version", i32 3} !4 = !{i32 1, !"wchar_size", i32 4} !5 = !{!"clang version 13.0.0"} !6 = distinct !DISubprogram(name: "main", scope: !1, file: !1, line: 1, type: !8, scopeLine: 4, flags: DIFlagPrototyped, spFlags: DISPFlagDefinition, unit: !0, retainedNodes: !2) !7 = !DILocation(line: 1, scope: !6, inlinedAt: !11) !8 = !DISubroutineType(types: !9) !9 = !{!10} !10 = !DIBasicType(name: "int", size: 32, encoding: DW_ATE_signed) !11 = !DILocation(line: 1, column: 0, scope: !6) !12 = !DILocalVariable(name: "resVec", scope: !6, file: !1, line: 1, type: !13) !13 = distinct !DICompositeType(tag: DW_TAG_class_type, name: "vec", scope: !6, file: !1, line: 1, size: 64, flags: DIFlagTypePassByValue, elements: !2)