[Frontend] Remove unused includes (NFC) (#116927)
[llvm-project.git] / llvm / test / CodeGen / SPIRV / instructions / bitwise-i1.ll
blob8d3657b36454bfe615a6a9f9d1b4dd118b99a10a
1 ; This test ensures that LLVM IR bitwise instructions result in logical SPIR-V instructions
2 ; when applied to i1 type
4 ; RUN: llc -O0 -mtriple=spirv32-unknown-unknown %s -o - | FileCheck %s
5 ; RUN: %if spirv-tools %{ llc -O0 -mtriple=spirv32-unknown-unknown %s -o - -filetype=obj | spirv-val %}
7 ; CHECK-DAG: %[[#Char:]] = OpTypeInt 8 0
8 ; CHECK-DAG: %[[#Vec2Char:]] = OpTypeVector %[[#Char]] 2
9 ; CHECK-DAG: %[[#Bool:]] = OpTypeBool
10 ; CHECK-DAG: %[[#Vec2Bool:]] = OpTypeVector %[[#Bool]] 2
12 ; CHECK: OpBitwiseAnd %[[#Char]]
13 ; CHECK: OpBitwiseOr %[[#Char]]
14 ; CHECK: OpBitwiseXor %[[#Char]]
15 ; CHECK: OpBitwiseAnd %[[#Vec2Char]]
16 ; CHECK: OpBitwiseOr %[[#Vec2Char]]
17 ; CHECK: OpBitwiseXor %[[#Vec2Char]]
19 ; CHECK: OpLogicalAnd %[[#Bool]]
21 ; CHECK: OpLogicalAnd %[[#Bool]]
22 ; CHECK: OpLogicalOr %[[#Bool]]
23 ; CHECK: OpLogicalNotEqual %[[#Bool]]
24 ; CHECK: OpLogicalAnd %[[#Vec2Bool]]
25 ; CHECK: OpLogicalOr %[[#Vec2Bool]]
26 ; CHECK: OpLogicalNotEqual %[[#Vec2Bool]]
28 define void @test1(i8 noundef %arg1, i8 noundef %arg2) {
29   %cond1 = and i8 %arg1, %arg2
30   %cond2 = or i8 %arg1, %arg2
31   %cond3 = xor i8 %arg1, %arg2
32   ret void
35 define void @test1v(<2 x i8> noundef %arg1, <2 x i8> noundef %arg2) {
36   %cond1 = and <2 x i8> %arg1, %arg2
37   %cond2 = or <2 x i8> %arg1, %arg2
38   %cond3 = xor <2 x i8> %arg1, %arg2
39   ret void
42 define void @test2(float noundef %real, float noundef %imag) {
43 entry:
44   %realabs = tail call spir_func noundef float @_Z16__spirv_ocl_fabsf(float noundef %real)
45   %cond1 = fcmp oeq float %realabs, 1.000000e+00
46   %cond2 = fcmp oeq float %imag, 0.000000e+00
47   %cond3 = and i1 %cond1, %cond2
48   br i1 %cond3, label %midlbl, label %cleanup
49 midlbl:
50   br label %cleanup
51 cleanup:
52   ret void
55 define void @test3(i1 noundef %arg1, i1 noundef %arg2) {
56   %cond1 = and i1 %arg1, %arg2
57   %cond2 = or i1 %arg1, %arg2
58   %cond3 = xor i1 %arg1, %arg2
59   ret void
62 define void @test3v(<2 x i1> noundef %arg1, <2 x i1> noundef %arg2) {
63   %cond1 = and <2 x i1> %arg1, %arg2
64   %cond2 = or <2 x i1> %arg1, %arg2
65   %cond3 = xor <2 x i1> %arg1, %arg2
66   ret void
69 declare dso_local spir_func noundef float @_Z16__spirv_ocl_fabsf(float noundef)