1 ; RUN: llc -march=amdgcn -verify-machineinstrs < %s | FileCheck -check-prefix=GCN %s 2 ; RUN: llc -march=amdgcn -mcpu=fiji -verify-machineinstrs < %s | FileCheck -check-prefix=GCN %s 3 4 declare i64 @llvm.amdgcn.icmp.i32(i32, i32, i32) #0 5 declare i64 @llvm.amdgcn.icmp.i64(i64, i64, i32) #0 6 7 ; No crash on invalid input 8 ; GCN-LABEL: {{^}}v_icmp_i32_dynamic_cc: 9 ; GCN: s_endpgm 10 define amdgpu_kernel void @v_icmp_i32_dynamic_cc(i64 addrspace(1)* %out, i32 %src, i32 %cc) { 11 %result = call i64 @llvm.amdgcn.icmp.i32(i32 %src, i32 100, i32 %cc) 12 store i64 %result, i64 addrspace(1)* %out 13 ret void 14 } 15 16 ; GCN-LABEL: {{^}}v_icmp_i32_eq: 17 ; GCN: v_cmp_eq_u32_e64 18 define amdgpu_kernel void @v_icmp_i32_eq(i64 addrspace(1)* %out, i32 %src) { 19 %result = call i64 @llvm.amdgcn.icmp.i32(i32 %src, i32 100, i32 32) 20 store i64 %result, i64 addrspace(1)* %out 21 ret void 22 } 23 24 ; GCN-LABEL: {{^}}v_icmp: 25 ; GCN-NOT: v_cmp_eq_u32_e64 26 define amdgpu_kernel void @v_icmp(i64 addrspace(1)* %out, i32 %src) { 27 %result = call i64 @llvm.amdgcn.icmp.i32(i32 %src, i32 100, i32 30) 28 store i64 %result, i64 addrspace(1)* %out 29 ret void 30 } 31 ; GCN-LABEL: {{^}}v_icmp_i32_ne: 32 ; GCN: v_cmp_ne_u32_e64 33 define amdgpu_kernel void @v_icmp_i32_ne(i64 addrspace(1)* %out, i32 %src) { 34 %result = call i64 @llvm.amdgcn.icmp.i32(i32 %src, i32 100, i32 33) 35 store i64 %result, i64 addrspace(1)* %out 36 ret void 37 } 38 39 ; GCN-LABEL: {{^}}v_icmp_u32_ugt: 40 ; GCN: v_cmp_gt_u32_e64 41 define amdgpu_kernel void @v_icmp_u32_ugt(i64 addrspace(1)* %out, i32 %src) { 42 %result = call i64 @llvm.amdgcn.icmp.i32(i32 %src, i32 100, i32 34) 43 store i64 %result, i64 addrspace(1)* %out 44 ret void 45 } 46 47 ; GCN-LABEL: {{^}}v_icmp_u32_uge: 48 ; GCN: v_cmp_ge_u32_e64 49 define amdgpu_kernel void @v_icmp_u32_uge(i64 addrspace(1)* %out, i32 %src) { 50 %result = call i64 @llvm.amdgcn.icmp.i32(i32 %src, i32 100, i32 35) 51 store i64 %result, i64 addrspace(1)* %out 52 ret void 53 } 54 55 ; GCN-LABEL: {{^}}v_icmp_u32_ult: 56 ; GCN: v_cmp_lt_u32_e64 57 define amdgpu_kernel void @v_icmp_u32_ult(i64 addrspace(1)* %out, i32 %src) { 58 %result = call i64 @llvm.amdgcn.icmp.i32(i32 %src, i32 100, i32 36) 59 store i64 %result, i64 addrspace(1)* %out 60 ret void 61 } 62 63 ; GCN-LABEL: {{^}}v_icmp_u32_ule: 64 ; GCN: v_cmp_le_u32_e64 65 define amdgpu_kernel void @v_icmp_u32_ule(i64 addrspace(1)* %out, i32 %src) { 66 %result = call i64 @llvm.amdgcn.icmp.i32(i32 %src, i32 100, i32 37) 67 store i64 %result, i64 addrspace(1)* %out 68 ret void 69 } 70 71 ; GCN-LABEL: {{^}}v_icmp_i32_sgt: 72 ; GCN: v_cmp_gt_i32_e64 73 define amdgpu_kernel void @v_icmp_i32_sgt(i64 addrspace(1)* %out, i32 %src) #1 { 74 %result = call i64 @llvm.amdgcn.icmp.i32(i32 %src, i32 100, i32 38) 75 store i64 %result, i64 addrspace(1)* %out 76 ret void 77 } 78 79 ; GCN-LABEL: {{^}}v_icmp_i32_sge: 80 ; GCN: v_cmp_ge_i32_e64 81 define amdgpu_kernel void @v_icmp_i32_sge(i64 addrspace(1)* %out, i32 %src) { 82 %result = call i64 @llvm.amdgcn.icmp.i32(i32 %src, i32 100, i32 39) 83 store i64 %result, i64 addrspace(1)* %out 84 ret void 85 } 86 87 ; GCN-LABEL: {{^}}v_icmp_i32_slt: 88 ; GCN: v_cmp_lt_i32_e64 89 define amdgpu_kernel void @v_icmp_i32_slt(i64 addrspace(1)* %out, i32 %src) { 90 %result = call i64 @llvm.amdgcn.icmp.i32(i32 %src, i32 100, i32 40) 91 store i64 %result, i64 addrspace(1)* %out 92 ret void 93 } 94 ; GCN-LABEL: {{^}}v_icmp_i32_sle: 95 ; GCN: v_cmp_le_i32_e64 96 define amdgpu_kernel void @v_icmp_i32_sle(i64 addrspace(1)* %out, i32 %src) { 97 %result = call i64 @llvm.amdgcn.icmp.i32(i32 %src, i32 100, i32 41) 98 store i64 %result, i64 addrspace(1)* %out 99 ret void 100 } 101 102 ; GCN-LABEL: {{^}}v_icmp_i64_eq: 103 ; GCN: v_cmp_eq_u64_e64 104 define amdgpu_kernel void @v_icmp_i64_eq(i64 addrspace(1)* %out, i64 %src) { 105 %result = call i64 @llvm.amdgcn.icmp.i64(i64 %src, i64 100, i32 32) 106 store i64 %result, i64 addrspace(1)* %out 107 ret void 108 } 109 110 ; GCN-LABEL: {{^}}v_icmp_i64_ne: 111 ; GCN: v_cmp_ne_u64_e64 112 define amdgpu_kernel void @v_icmp_i64_ne(i64 addrspace(1)* %out, i64 %src) { 113 %result = call i64 @llvm.amdgcn.icmp.i64(i64 %src, i64 100, i32 33) 114 store i64 %result, i64 addrspace(1)* %out 115 ret void 116 } 117 118 ; GCN-LABEL: {{^}}v_icmp_u64_ugt: 119 ; GCN: v_cmp_gt_u64_e64 120 define amdgpu_kernel void @v_icmp_u64_ugt(i64 addrspace(1)* %out, i64 %src) { 121 %result = call i64 @llvm.amdgcn.icmp.i64(i64 %src, i64 100, i32 34) 122 store i64 %result, i64 addrspace(1)* %out 123 ret void 124 } 125 126 ; GCN-LABEL: {{^}}v_icmp_u64_uge: 127 ; GCN: v_cmp_ge_u64_e64 128 define amdgpu_kernel void @v_icmp_u64_uge(i64 addrspace(1)* %out, i64 %src) { 129 %result = call i64 @llvm.amdgcn.icmp.i64(i64 %src, i64 100, i32 35) 130 store i64 %result, i64 addrspace(1)* %out 131 ret void 132 } 133 134 ; GCN-LABEL: {{^}}v_icmp_u64_ult: 135 ; GCN: v_cmp_lt_u64_e64 136 define amdgpu_kernel void @v_icmp_u64_ult(i64 addrspace(1)* %out, i64 %src) { 137 %result = call i64 @llvm.amdgcn.icmp.i64(i64 %src, i64 100, i32 36) 138 store i64 %result, i64 addrspace(1)* %out 139 ret void 140 } 141 142 ; GCN-LABEL: {{^}}v_icmp_u64_ule: 143 ; GCN: v_cmp_le_u64_e64 144 define amdgpu_kernel void @v_icmp_u64_ule(i64 addrspace(1)* %out, i64 %src) { 145 %result = call i64 @llvm.amdgcn.icmp.i64(i64 %src, i64 100, i32 37) 146 store i64 %result, i64 addrspace(1)* %out 147 ret void 148 } 149 150 ; GCN-LABEL: {{^}}v_icmp_i64_sgt: 151 ; GCN: v_cmp_gt_i64_e64 152 define amdgpu_kernel void @v_icmp_i64_sgt(i64 addrspace(1)* %out, i64 %src) { 153 %result = call i64 @llvm.amdgcn.icmp.i64(i64 %src, i64 100, i32 38) 154 store i64 %result, i64 addrspace(1)* %out 155 ret void 156 } 157 158 ; GCN-LABEL: {{^}}v_icmp_i64_sge: 159 ; GCN: v_cmp_ge_i64_e64 160 define amdgpu_kernel void @v_icmp_i64_sge(i64 addrspace(1)* %out, i64 %src) { 161 %result = call i64 @llvm.amdgcn.icmp.i64(i64 %src, i64 100, i32 39) 162 store i64 %result, i64 addrspace(1)* %out 163 ret void 164 } 165 166 ; GCN-LABEL: {{^}}v_icmp_i64_slt: 167 ; GCN: v_cmp_lt_i64_e64 168 define amdgpu_kernel void @v_icmp_i64_slt(i64 addrspace(1)* %out, i64 %src) { 169 %result = call i64 @llvm.amdgcn.icmp.i64(i64 %src, i64 100, i32 40) 170 store i64 %result, i64 addrspace(1)* %out 171 ret void 172 } 173 ; GCN-LABEL: {{^}}v_icmp_i64_sle: 174 ; GCN: v_cmp_le_i64_e64 175 define amdgpu_kernel void @v_icmp_i64_sle(i64 addrspace(1)* %out, i64 %src) { 176 %result = call i64 @llvm.amdgcn.icmp.i64(i64 %src, i64 100, i32 41) 177 store i64 %result, i64 addrspace(1)* %out 178 ret void 179 } 180 181 attributes #0 = { nounwind readnone convergent } 182