| ; RUN: llc -O0 -mtriple=spirv32-unknown-unknown %s -o - | FileCheck %s --check-prefix=CHECK-SPIRV | 
 |  | 
 | ; CHECK-SPIRV:      %[[#bool:]] = OpTypeBool | 
 | ; CHECK-SPIRV:      %[[#bool2:]] = OpTypeVector %[[#bool]] 2 | 
 |  | 
 | ; CHECK-SPIRV:      OpFunction | 
 | ; CHECK-SPIRV-NEXT: %[[#A:]] = OpFunctionParameter %[[#]] | 
 | ; CHECK-SPIRV-NEXT: %[[#B:]] = OpFunctionParameter %[[#]] | 
 | ; CHECK-SPIRV:      %[[#]] = OpUGreaterThan %[[#bool2]] %[[#A]] %[[#B]] | 
 | ; CHECK-SPIRV:      OpFunctionEnd | 
 |  | 
 | ;; kernel void testUGreaterThan(uint2 a, uint2 b, global int2 *res) { | 
 | ;;   res[0] = a > b; | 
 | ;; } | 
 |  | 
 | define dso_local spir_kernel void @testUGreaterThan(<2 x i32> noundef %a, <2 x i32> noundef %b, <2 x i32> addrspace(1)* nocapture noundef writeonly %res) local_unnamed_addr { | 
 | entry: | 
 |   %cmp = icmp ugt <2 x i32> %a, %b | 
 |   %sext = sext <2 x i1> %cmp to <2 x i32> | 
 |   store <2 x i32> %sext, <2 x i32> addrspace(1)* %res, align 8 | 
 |   ret void | 
 | } | 
 |  | 
 | ; CHECK-SPIRV:      OpFunction | 
 | ; CHECK-SPIRV-NEXT: %[[#A:]] = OpFunctionParameter %[[#]] | 
 | ; CHECK-SPIRV-NEXT: %[[#B:]] = OpFunctionParameter %[[#]] | 
 | ; CHECK-SPIRV:      %[[#]] = OpSGreaterThan %[[#bool2]] %[[#A]] %[[#B]] | 
 | ; CHECK-SPIRV:      OpFunctionEnd | 
 |  | 
 | ;; kernel void testSGreaterThan(int2 a, int2 b, global int2 *res) { | 
 | ;;   res[0] = a > b; | 
 | ;; } | 
 |  | 
 | define dso_local spir_kernel void @testSGreaterThan(<2 x i32> noundef %a, <2 x i32> noundef %b, <2 x i32> addrspace(1)* nocapture noundef writeonly %res) local_unnamed_addr { | 
 | entry: | 
 |   %cmp = icmp sgt <2 x i32> %a, %b | 
 |   %sext = sext <2 x i1> %cmp to <2 x i32> | 
 |   store <2 x i32> %sext, <2 x i32> addrspace(1)* %res, align 8 | 
 |   ret void | 
 | } | 
 |  | 
 | ; CHECK-SPIRV:      OpFunction | 
 | ; CHECK-SPIRV-NEXT: %[[#A:]] = OpFunctionParameter %[[#]] | 
 | ; CHECK-SPIRV-NEXT: %[[#B:]] = OpFunctionParameter %[[#]] | 
 | ; CHECK-SPIRV:      %[[#]] = OpUGreaterThanEqual %[[#bool2]] %[[#A]] %[[#B]] | 
 | ; CHECK-SPIRV:      OpFunctionEnd | 
 |  | 
 | ;; kernel void testUGreaterThanEqual(uint2 a, uint2 b, global int2 *res) { | 
 | ;;   res[0] = a >= b; | 
 | ;; } | 
 |  | 
 | define dso_local spir_kernel void @testUGreaterThanEqual(<2 x i32> noundef %a, <2 x i32> noundef %b, <2 x i32> addrspace(1)* nocapture noundef writeonly %res) local_unnamed_addr { | 
 | entry: | 
 |   %cmp = icmp uge <2 x i32> %a, %b | 
 |   %sext = sext <2 x i1> %cmp to <2 x i32> | 
 |   store <2 x i32> %sext, <2 x i32> addrspace(1)* %res, align 8 | 
 |   ret void | 
 | } | 
 |  | 
 | ; CHECK-SPIRV:      OpFunction | 
 | ; CHECK-SPIRV-NEXT: %[[#A:]] = OpFunctionParameter %[[#]] | 
 | ; CHECK-SPIRV-NEXT: %[[#B:]] = OpFunctionParameter %[[#]] | 
 | ; CHECK-SPIRV:      %[[#]] = OpSGreaterThanEqual %[[#bool2]] %[[#A]] %[[#B]] | 
 | ; CHECK-SPIRV:      OpFunctionEnd | 
 |  | 
 | ;; kernel void testSGreaterThanEqual(int2 a, int2 b, global int2 *res) { | 
 | ;;   res[0] = a >= b; | 
 | ;; } | 
 |  | 
 | define dso_local spir_kernel void @testSGreaterThanEqual(<2 x i32> noundef %a, <2 x i32> noundef %b, <2 x i32> addrspace(1)* nocapture noundef writeonly %res) local_unnamed_addr { | 
 | entry: | 
 |   %cmp = icmp sge <2 x i32> %a, %b | 
 |   %sext = sext <2 x i1> %cmp to <2 x i32> | 
 |   store <2 x i32> %sext, <2 x i32> addrspace(1)* %res, align 8 | 
 |   ret void | 
 | } | 
 |  | 
 | ; CHECK-SPIRV:      OpFunction | 
 | ; CHECK-SPIRV-NEXT: %[[#A:]] = OpFunctionParameter %[[#]] | 
 | ; CHECK-SPIRV-NEXT: %[[#B:]] = OpFunctionParameter %[[#]] | 
 | ; CHECK-SPIRV:      %[[#]] = OpULessThan %[[#bool2]] %[[#A]] %[[#B]] | 
 | ; CHECK-SPIRV:      OpFunctionEnd | 
 |  | 
 | ;; kernel void testULessThan(uint2 a, uint2 b, global int2 *res) { | 
 | ;;   res[0] = a < b; | 
 | ;; } | 
 |  | 
 | define dso_local spir_kernel void @testULessThan(<2 x i32> noundef %a, <2 x i32> noundef %b, <2 x i32> addrspace(1)* nocapture noundef writeonly %res) local_unnamed_addr { | 
 | entry: | 
 |   %cmp = icmp ult <2 x i32> %a, %b | 
 |   %sext = sext <2 x i1> %cmp to <2 x i32> | 
 |   store <2 x i32> %sext, <2 x i32> addrspace(1)* %res, align 8 | 
 |   ret void | 
 | } | 
 |  | 
 | ; CHECK-SPIRV:      OpFunction | 
 | ; CHECK-SPIRV-NEXT: %[[#A:]] = OpFunctionParameter %[[#]] | 
 | ; CHECK-SPIRV-NEXT: %[[#B:]] = OpFunctionParameter %[[#]] | 
 | ; CHECK-SPIRV:      %[[#]] = OpSLessThan %[[#bool2]] %[[#A]] %[[#B]] | 
 | ; CHECK-SPIRV:      OpFunctionEnd | 
 |  | 
 | ;; kernel void testSLessThan(int2 a, int2 b, global int2 *res) { | 
 | ;;   res[0] = a < b; | 
 | ;; } | 
 |  | 
 | define dso_local spir_kernel void @testSLessThan(<2 x i32> noundef %a, <2 x i32> noundef %b, <2 x i32> addrspace(1)* nocapture noundef writeonly %res) local_unnamed_addr { | 
 | entry: | 
 |   %cmp = icmp slt <2 x i32> %a, %b | 
 |   %sext = sext <2 x i1> %cmp to <2 x i32> | 
 |   store <2 x i32> %sext, <2 x i32> addrspace(1)* %res, align 8 | 
 |   ret void | 
 | } | 
 |  | 
 | ; CHECK-SPIRV:      OpFunction | 
 | ; CHECK-SPIRV-NEXT: %[[#A:]] = OpFunctionParameter %[[#]] | 
 | ; CHECK-SPIRV-NEXT: %[[#B:]] = OpFunctionParameter %[[#]] | 
 | ; CHECK-SPIRV:      %[[#]] = OpULessThanEqual %[[#bool2]] %[[#A]] %[[#B]] | 
 | ; CHECK-SPIRV:      OpFunctionEnd | 
 |  | 
 | ;; kernel void testULessThanEqual(uint2 a, uint2 b, global int2 *res) { | 
 | ;;   res[0] = a <= b; | 
 | ;; } | 
 |  | 
 | define dso_local spir_kernel void @testULessThanEqual(<2 x i32> noundef %a, <2 x i32> noundef %b, <2 x i32> addrspace(1)* nocapture noundef writeonly %res) local_unnamed_addr { | 
 | entry: | 
 |   %cmp = icmp ule <2 x i32> %a, %b | 
 |   %sext = sext <2 x i1> %cmp to <2 x i32> | 
 |   store <2 x i32> %sext, <2 x i32> addrspace(1)* %res, align 8 | 
 |   ret void | 
 | } | 
 |  | 
 | ; CHECK-SPIRV:      OpFunction | 
 | ; CHECK-SPIRV-NEXT: %[[#A:]] = OpFunctionParameter %[[#]] | 
 | ; CHECK-SPIRV-NEXT: %[[#B:]] = OpFunctionParameter %[[#]] | 
 | ; CHECK-SPIRV:      %[[#]] = OpSLessThanEqual %[[#bool2]] %[[#A]] %[[#B]] | 
 | ; CHECK-SPIRV:      OpFunctionEnd | 
 |  | 
 | ;; kernel void testSLessThanEqual(int2 a, int2 b, global int2 *res) { | 
 | ;;   res[0] = a <= b; | 
 | ;; } | 
 |  | 
 | define dso_local spir_kernel void @testSLessThanEqual(<2 x i32> noundef %a, <2 x i32> noundef %b, <2 x i32> addrspace(1)* nocapture noundef writeonly %res) local_unnamed_addr { | 
 | entry: | 
 |   %cmp = icmp sle <2 x i32> %a, %b | 
 |   %sext = sext <2 x i1> %cmp to <2 x i32> | 
 |   store <2 x i32> %sext, <2 x i32> addrspace(1)* %res, align 8 | 
 |   ret void | 
 | } | 
 |  | 
 | ; CHECK-SPIRV:      OpFunction | 
 | ; CHECK-SPIRV-NEXT: %[[#A:]] = OpFunctionParameter %[[#]] | 
 | ; CHECK-SPIRV-NEXT: %[[#B:]] = OpFunctionParameter %[[#]] | 
 | ; CHECK-SPIRV:      %[[#]] = OpFOrdEqual %[[#bool2]] %[[#A]] %[[#B]] | 
 | ; CHECK-SPIRV:      OpFunctionEnd | 
 |  | 
 | ;; kernel void testFOrdEqual(float2 a, float2 b, global int2 *res) { | 
 | ;;   res[0] = a == b; | 
 | ;; } | 
 |  | 
 | define dso_local spir_kernel void @testFOrdEqual(<2 x float> noundef %a, <2 x float> noundef %b, <2 x i32> addrspace(1)* nocapture noundef writeonly %res) local_unnamed_addr { | 
 | entry: | 
 |   %cmp = fcmp oeq <2 x float> %a, %b | 
 |   %sext = sext <2 x i1> %cmp to <2 x i32> | 
 |   store <2 x i32> %sext, <2 x i32> addrspace(1)* %res, align 8 | 
 |   ret void | 
 | } | 
 |  | 
 | ; CHECK-SPIRV:      OpFunction | 
 | ; CHECK-SPIRV-NEXT: %[[#A:]] = OpFunctionParameter %[[#]] | 
 | ; CHECK-SPIRV-NEXT: %[[#B:]] = OpFunctionParameter %[[#]] | 
 | ; CHECK-SPIRV:      %[[#]] = OpFUnordNotEqual %[[#bool2]] %[[#A]] %[[#B]] | 
 | ; CHECK-SPIRV:      OpFunctionEnd | 
 |  | 
 | ;; kernel void testFUnordNotEqual(float2 a, float2 b, global int2 *res) { | 
 | ;;   res[0] = a != b; | 
 | ;; } | 
 |  | 
 | define dso_local spir_kernel void @testFUnordNotEqual(<2 x float> noundef %a, <2 x float> noundef %b, <2 x i32> addrspace(1)* nocapture noundef writeonly %res) local_unnamed_addr { | 
 | entry: | 
 |   %cmp = fcmp une <2 x float> %a, %b | 
 |   %sext = sext <2 x i1> %cmp to <2 x i32> | 
 |   store <2 x i32> %sext, <2 x i32> addrspace(1)* %res, align 8 | 
 |   ret void | 
 | } | 
 |  | 
 | ; CHECK-SPIRV:      OpFunction | 
 | ; CHECK-SPIRV-NEXT: %[[#A:]] = OpFunctionParameter %[[#]] | 
 | ; CHECK-SPIRV-NEXT: %[[#B:]] = OpFunctionParameter %[[#]] | 
 | ; CHECK-SPIRV:      %[[#]] = OpFOrdGreaterThan %[[#bool2]] %[[#A]] %[[#B]] | 
 | ; CHECK-SPIRV:      OpFunctionEnd | 
 |  | 
 | ;; kernel void testFOrdGreaterThan(float2 a, float2 b, global int2 *res) { | 
 | ;;   res[0] = a > b; | 
 | ;; } | 
 |  | 
 | define dso_local spir_kernel void @testFOrdGreaterThan(<2 x float> noundef %a, <2 x float> noundef %b, <2 x i32> addrspace(1)* nocapture noundef writeonly %res) local_unnamed_addr { | 
 | entry: | 
 |   %cmp = fcmp ogt <2 x float> %a, %b | 
 |   %sext = sext <2 x i1> %cmp to <2 x i32> | 
 |   store <2 x i32> %sext, <2 x i32> addrspace(1)* %res, align 8 | 
 |   ret void | 
 | } | 
 |  | 
 | ; CHECK-SPIRV:      OpFunction | 
 | ; CHECK-SPIRV-NEXT: %[[#A:]] = OpFunctionParameter %[[#]] | 
 | ; CHECK-SPIRV-NEXT: %[[#B:]] = OpFunctionParameter %[[#]] | 
 | ; CHECK-SPIRV:      %[[#]] = OpFOrdGreaterThanEqual %[[#bool2]] %[[#A]] %[[#B]] | 
 | ; CHECK-SPIRV:      OpFunctionEnd | 
 |  | 
 | ;; kernel void testFOrdGreaterThanEqual(float2 a, float2 b, global int2 *res) { | 
 | ;;   res[0] = a >= b; | 
 | ;; } | 
 |  | 
 | define dso_local spir_kernel void @testFOrdGreaterThanEqual(<2 x float> noundef %a, <2 x float> noundef %b, <2 x i32> addrspace(1)* nocapture noundef writeonly %res) local_unnamed_addr { | 
 | entry: | 
 |   %cmp = fcmp oge <2 x float> %a, %b | 
 |   %sext = sext <2 x i1> %cmp to <2 x i32> | 
 |   store <2 x i32> %sext, <2 x i32> addrspace(1)* %res, align 8 | 
 |   ret void | 
 | } | 
 |  | 
 | ; CHECK-SPIRV:      OpFunction | 
 | ; CHECK-SPIRV-NEXT: %[[#A:]] = OpFunctionParameter %[[#]] | 
 | ; CHECK-SPIRV-NEXT: %[[#B:]] = OpFunctionParameter %[[#]] | 
 | ; CHECK-SPIRV:      %[[#]] = OpFOrdLessThan %[[#bool2]] %[[#A]] %[[#B]] | 
 | ; CHECK-SPIRV:      OpFunctionEnd | 
 |  | 
 | ;; kernel void testFOrdLessThan(float2 a, float2 b, global int2 *res) { | 
 | ;;   res[0] = a < b; | 
 | ;; } | 
 |  | 
 | define dso_local spir_kernel void @testFOrdLessThan(<2 x float> noundef %a, <2 x float> noundef %b, <2 x i32> addrspace(1)* nocapture noundef writeonly %res) local_unnamed_addr { | 
 | entry: | 
 |   %cmp = fcmp olt <2 x float> %a, %b | 
 |   %sext = sext <2 x i1> %cmp to <2 x i32> | 
 |   store <2 x i32> %sext, <2 x i32> addrspace(1)* %res, align 8 | 
 |   ret void | 
 | } | 
 |  | 
 | ; CHECK-SPIRV:      OpFunction | 
 | ; CHECK-SPIRV-NEXT: %[[#A:]] = OpFunctionParameter %[[#]] | 
 | ; CHECK-SPIRV-NEXT: %[[#B:]] = OpFunctionParameter %[[#]] | 
 | ; CHECK-SPIRV:      %[[#]] = OpFOrdLessThanEqual %[[#bool2]] %[[#A]] %[[#B]] | 
 | ; CHECK-SPIRV:      OpFunctionEnd | 
 |  | 
 | ;; kernel void testFOrdLessThanEqual(float2 a, float2 b, global int2 *res) { | 
 | ;;   res[0] = a <= b; | 
 | ;; } | 
 |  | 
 | define dso_local spir_kernel void @testFOrdLessThanEqual(<2 x float> noundef %a, <2 x float> noundef %b, <2 x i32> addrspace(1)* nocapture noundef writeonly %res) local_unnamed_addr { | 
 | entry: | 
 |   %cmp = fcmp ole <2 x float> %a, %b | 
 |   %sext = sext <2 x i1> %cmp to <2 x i32> | 
 |   store <2 x i32> %sext, <2 x i32> addrspace(1)* %res, align 8 | 
 |   ret void | 
 | } |