; RUN: llc -O0 -mtriple=spirv32-unknown-unknown %s -o - | FileCheck %s --check-prefix=CHECK-SPIRV ; CHECK-SPIRV: OpName %[[#r1:]] "r1" ; CHECK-SPIRV: OpName %[[#r2:]] "r2" ; CHECK-SPIRV: OpName %[[#r3:]] "r3" ; CHECK-SPIRV: OpName %[[#r4:]] "r4" ; CHECK-SPIRV: OpName %[[#r5:]] "r5" ; CHECK-SPIRV: OpName %[[#r6:]] "r6" ; CHECK-SPIRV: OpName %[[#r7:]] "r7" ; CHECK-SPIRV: OpName %[[#r8:]] "r8" ; CHECK-SPIRV: OpName %[[#r9:]] "r9" ; CHECK-SPIRV: OpName %[[#r10:]] "r10" ; CHECK-SPIRV: OpName %[[#r11:]] "r11" ; CHECK-SPIRV: OpName %[[#r12:]] "r12" ; CHECK-SPIRV: OpName %[[#r13:]] "r13" ; CHECK-SPIRV: OpName %[[#r14:]] "r14" ; CHECK-SPIRV: OpName %[[#r15:]] "r15" ; CHECK-SPIRV: OpName %[[#r16:]] "r16" ; CHECK-SPIRV: OpName %[[#r17:]] "r17" ; CHECK-SPIRV: OpName %[[#r18:]] "r18" ; CHECK-SPIRV: OpName %[[#r19:]] "r19" ; CHECK-SPIRV: OpName %[[#r20:]] "r20" ; CHECK-SPIRV: OpName %[[#r21:]] "r21" ; CHECK-SPIRV: OpName %[[#r22:]] "r22" ; CHECK-SPIRV: OpName %[[#r23:]] "r23" ; CHECK-SPIRV: OpName %[[#r24:]] "r24" ; CHECK-SPIRV: OpName %[[#r25:]] "r25" ; CHECK-SPIRV: OpName %[[#r26:]] "r26" ; CHECK-SPIRV: OpName %[[#r27:]] "r27" ; CHECK-SPIRV: OpName %[[#r28:]] "r28" ; CHECK-SPIRV: OpName %[[#r29:]] "r29" ; CHECK-SPIRV: OpName %[[#r30:]] "r30" ; CHECK-SPIRV: OpName %[[#r31:]] "r31" ; CHECK-SPIRV: OpName %[[#r32:]] "r32" ; CHECK-SPIRV: OpName %[[#r33:]] "r33" ; CHECK-SPIRV: OpName %[[#r34:]] "r34" ; CHECK-SPIRV: OpName %[[#r35:]] "r35" ; CHECK-SPIRV: OpName %[[#r36:]] "r36" ; CHECK-SPIRV: OpName %[[#r37:]] "r37" ; CHECK-SPIRV: OpName %[[#r38:]] "r38" ; CHECK-SPIRV: OpName %[[#r39:]] "r39" ; CHECK-SPIRV: OpName %[[#r40:]] "r40" ; CHECK-SPIRV: OpName %[[#r41:]] "r41" ; CHECK-SPIRV: OpName %[[#r42:]] "r42" ; CHECK-SPIRV: OpName %[[#r43:]] "r43" ; CHECK-SPIRV: OpName %[[#r44:]] "r44" ; CHECK-SPIRV: OpName %[[#r45:]] "r45" ; CHECK-SPIRV: OpName %[[#r46:]] "r46" ; CHECK-SPIRV: OpName %[[#r47:]] "r47" ; CHECK-SPIRV: OpName %[[#r48:]] "r48" ; CHECK-SPIRV: OpName %[[#r49:]] "r49" ; CHECK-SPIRV: OpName %[[#r50:]] "r50" ; CHECK-SPIRV: OpName %[[#r51:]] "r51" ; CHECK-SPIRV: OpName %[[#r52:]] "r52" ; CHECK-SPIRV: OpName %[[#r53:]] "r53" ; CHECK-SPIRV: OpName %[[#r54:]] "r54" ; CHECK-SPIRV: OpName %[[#r55:]] "r55" ; CHECK-SPIRV: OpName %[[#r56:]] "r56" ; CHECK-SPIRV: OpName %[[#r57:]] "r57" ; CHECK-SPIRV: OpName %[[#r58:]] "r58" ; CHECK-SPIRV: OpName %[[#r59:]] "r59" ; CHECK-SPIRV: OpName %[[#r60:]] "r60" ; CHECK-SPIRV: OpName %[[#r61:]] "r61" ; CHECK-SPIRV: OpName %[[#r62:]] "r62" ; CHECK-SPIRV: OpName %[[#r63:]] "r63" ; CHECK-SPIRV: OpName %[[#r64:]] "r64" ; CHECK-SPIRV: OpName %[[#r65:]] "r65" ; CHECK-SPIRV: OpName %[[#r66:]] "r66" ; CHECK-SPIRV: OpName %[[#r67:]] "r67" ; CHECK-SPIRV: OpName %[[#r68:]] "r68" ; CHECK-SPIRV: OpName %[[#r69:]] "r69" ; CHECK-SPIRV: OpName %[[#r70:]] "r70" ; CHECK-SPIRV: OpName %[[#r71:]] "r71" ; CHECK-SPIRV: OpName %[[#r72:]] "r72" ; CHECK-SPIRV: OpName %[[#r73:]] "r73" ; CHECK-SPIRV: OpName %[[#r74:]] "r74" ; CHECK-SPIRV: OpName %[[#r75:]] "r75" ; CHECK-SPIRV: OpName %[[#r76:]] "r76" ; CHECK-SPIRV: OpName %[[#r77:]] "r77" ; CHECK-SPIRV: OpName %[[#r78:]] "r78" ; CHECK-SPIRV: OpName %[[#r79:]] "r79" ; CHECK-SPIRV: OpName %[[#r80:]] "r80" ; CHECK-SPIRV: OpName %[[#r81:]] "r81" ; CHECK-SPIRV: OpName %[[#r82:]] "r82" ; CHECK-SPIRV: OpName %[[#r83:]] "r83" ; CHECK-SPIRV: OpName %[[#r84:]] "r84" ; CHECK-SPIRV: OpName %[[#r85:]] "r85" ; CHECK-SPIRV: OpName %[[#r86:]] "r86" ; CHECK-SPIRV: OpName %[[#r87:]] "r87" ; CHECK-SPIRV: OpName %[[#r88:]] "r88" ; CHECK-SPIRV: OpName %[[#r89:]] "r89" ; CHECK-SPIRV: OpName %[[#r90:]] "r90" ; CHECK-SPIRV-NOT: OpDecorate %{{.*}} FPFastMathMode ; CHECK-SPIRV: %[[#bool:]] = OpTypeBool ; CHECK-SPIRV: %[[#r1]] = OpFOrdEqual %[[#bool]] ; CHECK-SPIRV: %[[#r2]] = OpFOrdEqual %[[#bool]] ; CHECK-SPIRV: %[[#r3]] = OpFOrdEqual %[[#bool]] ; CHECK-SPIRV: %[[#r4]] = OpFOrdEqual %[[#bool]] ; CHECK-SPIRV: %[[#r5]] = OpFOrdEqual %[[#bool]] ; CHECK-SPIRV: %[[#r6]] = OpFOrdEqual %[[#bool]] ; CHECK-SPIRV: %[[#r7]] = OpFOrdEqual %[[#bool]] ; CHECK-SPIRV: %[[#r8]] = OpFOrdNotEqual %[[#bool]] ; CHECK-SPIRV: %[[#r9]] = OpFOrdNotEqual %[[#bool]] ; CHECK-SPIRV: %[[#r10]] = OpFOrdNotEqual %[[#bool]] ; CHECK-SPIRV: %[[#r11]] = OpFOrdNotEqual %[[#bool]] ; CHECK-SPIRV: %[[#r12]] = OpFOrdNotEqual %[[#bool]] ; CHECK-SPIRV: %[[#r13]] = OpFOrdNotEqual %[[#bool]] ; CHECK-SPIRV: %[[#r14]] = OpFOrdNotEqual %[[#bool]] ; CHECK-SPIRV: %[[#r15]] = OpFOrdLessThan %[[#bool]] ; CHECK-SPIRV: %[[#r16]] = OpFOrdLessThan %[[#bool]] ; CHECK-SPIRV: %[[#r17]] = OpFOrdLessThan %[[#bool]] ; CHECK-SPIRV: %[[#r18]] = OpFOrdLessThan %[[#bool]] ; CHECK-SPIRV: %[[#r19]] = OpFOrdLessThan %[[#bool]] ; CHECK-SPIRV: %[[#r20]] = OpFOrdLessThan %[[#bool]] ; CHECK-SPIRV: %[[#r21]] = OpFOrdLessThan %[[#bool]] ; CHECK-SPIRV: %[[#r22]] = OpFOrdGreaterThan %[[#bool]] ; CHECK-SPIRV: %[[#r23]] = OpFOrdGreaterThan %[[#bool]] ; CHECK-SPIRV: %[[#r24]] = OpFOrdGreaterThan %[[#bool]] ; CHECK-SPIRV: %[[#r25]] = OpFOrdGreaterThan %[[#bool]] ; CHECK-SPIRV: %[[#r26]] = OpFOrdGreaterThan %[[#bool]] ; CHECK-SPIRV: %[[#r27]] = OpFOrdGreaterThan %[[#bool]] ; CHECK-SPIRV: %[[#r28]] = OpFOrdGreaterThan %[[#bool]] ; CHECK-SPIRV: %[[#r29]] = OpFOrdLessThanEqual %[[#bool]] ; CHECK-SPIRV: %[[#r30]] = OpFOrdLessThanEqual %[[#bool]] ; CHECK-SPIRV: %[[#r31]] = OpFOrdLessThanEqual %[[#bool]] ; CHECK-SPIRV: %[[#r32]] = OpFOrdLessThanEqual %[[#bool]] ; CHECK-SPIRV: %[[#r33]] = OpFOrdLessThanEqual %[[#bool]] ; CHECK-SPIRV: %[[#r34]] = OpFOrdLessThanEqual %[[#bool]] ; CHECK-SPIRV: %[[#r35]] = OpFOrdLessThanEqual %[[#bool]] ; CHECK-SPIRV: %[[#r36]] = OpFOrdGreaterThanEqual %[[#bool]] ; CHECK-SPIRV: %[[#r37]] = OpFOrdGreaterThanEqual %[[#bool]] ; CHECK-SPIRV: %[[#r38]] = OpFOrdGreaterThanEqual %[[#bool]] ; CHECK-SPIRV: %[[#r39]] = OpFOrdGreaterThanEqual %[[#bool]] ; CHECK-SPIRV: %[[#r40]] = OpFOrdGreaterThanEqual %[[#bool]] ; CHECK-SPIRV: %[[#r41]] = OpFOrdGreaterThanEqual %[[#bool]] ; CHECK-SPIRV: %[[#r42]] = OpFOrdGreaterThanEqual %[[#bool]] ; CHECK-SPIRV: %[[#r43]] = OpOrdered %[[#bool]] ; CHECK-SPIRV: %[[#r44]] = OpOrdered %[[#bool]] ; CHECK-SPIRV: %[[#r45]] = OpOrdered %[[#bool]] ; CHECK-SPIRV: %[[#r46]] = OpFUnordEqual %[[#bool]] ; CHECK-SPIRV: %[[#r47]] = OpFUnordEqual %[[#bool]] ; CHECK-SPIRV: %[[#r48]] = OpFUnordEqual %[[#bool]] ; CHECK-SPIRV: %[[#r49]] = OpFUnordEqual %[[#bool]] ; CHECK-SPIRV: %[[#r50]] = OpFUnordEqual %[[#bool]] ; CHECK-SPIRV: %[[#r51]] = OpFUnordEqual %[[#bool]] ; CHECK-SPIRV: %[[#r52]] = OpFUnordEqual %[[#bool]] ; CHECK-SPIRV: %[[#r53]] = OpFUnordNotEqual %[[#bool]] ; CHECK-SPIRV: %[[#r54]] = OpFUnordNotEqual %[[#bool]] ; CHECK-SPIRV: %[[#r55]] = OpFUnordNotEqual %[[#bool]] ; CHECK-SPIRV: %[[#r56]] = OpFUnordNotEqual %[[#bool]] ; CHECK-SPIRV: %[[#r57]] = OpFUnordNotEqual %[[#bool]] ; CHECK-SPIRV: %[[#r58]] = OpFUnordNotEqual %[[#bool]] ; CHECK-SPIRV: %[[#r59]] = OpFUnordNotEqual %[[#bool]] ; CHECK-SPIRV: %[[#r60]] = OpFUnordLessThan %[[#bool]] ; CHECK-SPIRV: %[[#r61]] = OpFUnordLessThan %[[#bool]] ; CHECK-SPIRV: %[[#r62]] = OpFUnordLessThan %[[#bool]] ; CHECK-SPIRV: %[[#r63]] = OpFUnordLessThan %[[#bool]] ; CHECK-SPIRV: %[[#r64]] = OpFUnordLessThan %[[#bool]] ; CHECK-SPIRV: %[[#r65]] = OpFUnordLessThan %[[#bool]] ; CHECK-SPIRV: %[[#r66]] = OpFUnordLessThan %[[#bool]] ; CHECK-SPIRV: %[[#r67]] = OpFUnordGreaterThan %[[#bool]] ; CHECK-SPIRV: %[[#r68]] = OpFUnordGreaterThan %[[#bool]] ; CHECK-SPIRV: %[[#r69]] = OpFUnordGreaterThan %[[#bool]] ; CHECK-SPIRV: %[[#r70]] = OpFUnordGreaterThan %[[#bool]] ; CHECK-SPIRV: %[[#r71]] = OpFUnordGreaterThan %[[#bool]] ; CHECK-SPIRV: %[[#r72]] = OpFUnordGreaterThan %[[#bool]] ; CHECK-SPIRV: %[[#r73]] = OpFUnordGreaterThan %[[#bool]] ; CHECK-SPIRV: %[[#r74]] = OpFUnordLessThanEqual %[[#bool]] ; CHECK-SPIRV: %[[#r75]] = OpFUnordLessThanEqual %[[#bool]] ; CHECK-SPIRV: %[[#r76]] = OpFUnordLessThanEqual %[[#bool]] ; CHECK-SPIRV: %[[#r77]] = OpFUnordLessThanEqual %[[#bool]] ; CHECK-SPIRV: %[[#r78]] = OpFUnordLessThanEqual %[[#bool]] ; CHECK-SPIRV: %[[#r79]] = OpFUnordLessThanEqual %[[#bool]] ; CHECK-SPIRV: %[[#r80]] = OpFUnordLessThanEqual %[[#bool]] ; CHECK-SPIRV: %[[#r81]] = OpFUnordGreaterThanEqual %[[#bool]] ; CHECK-SPIRV: %[[#r82]] = OpFUnordGreaterThanEqual %[[#bool]] ; CHECK-SPIRV: %[[#r83]] = OpFUnordGreaterThanEqual %[[#bool]] ; CHECK-SPIRV: %[[#r84]] = OpFUnordGreaterThanEqual %[[#bool]] ; CHECK-SPIRV: %[[#r85]] = OpFUnordGreaterThanEqual %[[#bool]] ; CHECK-SPIRV: %[[#r86]] = OpFUnordGreaterThanEqual %[[#bool]] ; CHECK-SPIRV: %[[#r87]] = OpFUnordGreaterThanEqual %[[#bool]] ; CHECK-SPIRV: %[[#r88]] = OpUnordered %[[#bool]] ; CHECK-SPIRV: %[[#r89]] = OpUnordered %[[#bool]] ; CHECK-SPIRV: %[[#r90]] = OpUnordered %[[#bool]] target datalayout = "e-p:32:32-i64:64-v16:16-v24:32-v32:32-v48:64-v96:128-v192:256-v256:256-v512:512-v1024:1024" target triple = "spirv32-unknown-unknown" ; Function Attrs: nounwind define spir_kernel void @testFCmp(float %a, float %b) local_unnamed_addr #0 !kernel_arg_addr_space !2 !kernel_arg_access_qual !3 !kernel_arg_type !4 !kernel_arg_base_type !4 !kernel_arg_type_qual !5 { entry: %r1 = fcmp oeq float %a, %b %r2 = fcmp nnan oeq float %a, %b %r3 = fcmp ninf oeq float %a, %b %r4 = fcmp nsz oeq float %a, %b %r5 = fcmp arcp oeq float %a, %b %r6 = fcmp fast oeq float %a, %b %r7 = fcmp nnan ninf oeq float %a, %b %r8 = fcmp one float %a, %b %r9 = fcmp nnan one float %a, %b %r10 = fcmp ninf one float %a, %b %r11 = fcmp nsz one float %a, %b %r12 = fcmp arcp one float %a, %b %r13 = fcmp fast one float %a, %b %r14 = fcmp nnan ninf one float %a, %b %r15 = fcmp olt float %a, %b %r16 = fcmp nnan olt float %a, %b %r17 = fcmp ninf olt float %a, %b %r18 = fcmp nsz olt float %a, %b %r19 = fcmp arcp olt float %a, %b %r20 = fcmp fast olt float %a, %b %r21 = fcmp nnan ninf olt float %a, %b %r22 = fcmp ogt float %a, %b %r23 = fcmp nnan ogt float %a, %b %r24 = fcmp ninf ogt float %a, %b %r25 = fcmp nsz ogt float %a, %b %r26 = fcmp arcp ogt float %a, %b %r27 = fcmp fast ogt float %a, %b %r28 = fcmp nnan ninf ogt float %a, %b %r29 = fcmp ole float %a, %b %r30 = fcmp nnan ole float %a, %b %r31 = fcmp ninf ole float %a, %b %r32 = fcmp nsz ole float %a, %b %r33 = fcmp arcp ole float %a, %b %r34 = fcmp fast ole float %a, %b %r35 = fcmp nnan ninf ole float %a, %b %r36 = fcmp oge float %a, %b %r37 = fcmp nnan oge float %a, %b %r38 = fcmp ninf oge float %a, %b %r39 = fcmp nsz oge float %a, %b %r40 = fcmp arcp oge float %a, %b %r41 = fcmp fast oge float %a, %b %r42 = fcmp nnan ninf oge float %a, %b %r43 = fcmp ord float %a, %b %r44 = fcmp ninf ord float %a, %b %r45 = fcmp nsz ord float %a, %b %r46 = fcmp ueq float %a, %b %r47 = fcmp nnan ueq float %a, %b %r48 = fcmp ninf ueq float %a, %b %r49 = fcmp nsz ueq float %a, %b %r50 = fcmp arcp ueq float %a, %b %r51 = fcmp fast ueq float %a, %b %r52 = fcmp nnan ninf ueq float %a, %b %r53 = fcmp une float %a, %b %r54 = fcmp nnan une float %a, %b %r55 = fcmp ninf une float %a, %b %r56 = fcmp nsz une float %a, %b %r57 = fcmp arcp une float %a, %b %r58 = fcmp fast une float %a, %b %r59 = fcmp nnan ninf une float %a, %b %r60 = fcmp ult float %a, %b %r61 = fcmp nnan ult float %a, %b %r62 = fcmp ninf ult float %a, %b %r63 = fcmp nsz ult float %a, %b %r64 = fcmp arcp ult float %a, %b %r65 = fcmp fast ult float %a, %b %r66 = fcmp nnan ninf ult float %a, %b %r67 = fcmp ugt float %a, %b %r68 = fcmp nnan ugt float %a, %b %r69 = fcmp ninf ugt float %a, %b %r70 = fcmp nsz ugt float %a, %b %r71 = fcmp arcp ugt float %a, %b %r72 = fcmp fast ugt float %a, %b %r73 = fcmp nnan ninf ugt float %a, %b %r74 = fcmp ule float %a, %b %r75 = fcmp nnan ule float %a, %b %r76 = fcmp ninf ule float %a, %b %r77 = fcmp nsz ule float %a, %b %r78 = fcmp arcp ule float %a, %b %r79 = fcmp fast ule float %a, %b %r80 = fcmp nnan ninf ule float %a, %b %r81 = fcmp uge float %a, %b %r82 = fcmp nnan uge float %a, %b %r83 = fcmp ninf uge float %a, %b %r84 = fcmp nsz uge float %a, %b %r85 = fcmp arcp uge float %a, %b %r86 = fcmp fast uge float %a, %b %r87 = fcmp nnan ninf uge float %a, %b %r88 = fcmp uno float %a, %b %r89 = fcmp ninf uno float %a, %b %r90 = fcmp nsz uno float %a, %b ret void } attributes #0 = { convergent nounwind writeonly "correctly-rounded-divide-sqrt-fp-math"="false" "denorms-are-zero"="false" "disable-tail-calls"="false" "less-precise-fpmad"="false" "min-legal-vector-width"="0" "no-frame-pointer-elim"="false" "no-infs-fp-math"="false" "no-jump-tables"="false" "no-nans-fp-math"="false" "no-signed-zeros-fp-math"="false" "no-trapping-math"="false" "stack-protector-buffer-size"="8" "uniform-work-group-size"="false" "unsafe-fp-math"="false" "use-soft-float"="false" } !llvm.module.flags = !{!0} !opencl.ocl.version = !{!1} !opencl.spir.version = !{!1} !0 = !{i32 1, !"wchar_size", i32 4} !1 = !{i32 2, i32 0} !2 = !{i32 0, i32 0} !3 = !{!"none", !"none"} !4 = !{!"float", !"float"} !5 = !{!"", !""}