1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc < %s --mtriple=aarch64 -verify-machineinstrs | FileCheck %s --check-prefixes=CHECK,CHECK-SD
3 ; RUN: llc < %s --mtriple=aarch64 -global-isel -verify-machineinstrs | FileCheck %s --check-prefixes=CHECK,CHECK-GI
5 declare i8 @llvm.ctlz.i8(i8, i1)
6 declare i16 @llvm.ctlz.i16(i16, i1)
7 declare i32 @llvm.ctlz.i32(i32, i1)
8 declare i64 @llvm.ctlz.i64(i64, i1)
10 define i8 @ctlo_i8(i8 %x) {
11 ; CHECK-SD-LABEL: ctlo_i8:
13 ; CHECK-SD-NEXT: mov w8, #-1 // =0xffffffff
14 ; CHECK-SD-NEXT: eor w8, w8, w0, lsl #24
15 ; CHECK-SD-NEXT: clz w0, w8
18 ; CHECK-GI-LABEL: ctlo_i8:
20 ; CHECK-GI-NEXT: mov w8, #255 // =0xff
21 ; CHECK-GI-NEXT: bic w8, w8, w0
22 ; CHECK-GI-NEXT: clz w8, w8
23 ; CHECK-GI-NEXT: sub w0, w8, #24
26 %tmp2 = call i8 @llvm.ctlz.i8( i8 %tmp1, i1 false )
30 define i8 @ctlo_i8_undef(i8 %x) {
31 ; CHECK-SD-LABEL: ctlo_i8_undef:
33 ; CHECK-SD-NEXT: mvn w8, w0
34 ; CHECK-SD-NEXT: lsl w8, w8, #24
35 ; CHECK-SD-NEXT: clz w0, w8
38 ; CHECK-GI-LABEL: ctlo_i8_undef:
40 ; CHECK-GI-NEXT: mov w8, #255 // =0xff
41 ; CHECK-GI-NEXT: bic w8, w8, w0
42 ; CHECK-GI-NEXT: clz w8, w8
43 ; CHECK-GI-NEXT: sub w0, w8, #24
46 %tmp2 = call i8 @llvm.ctlz.i8( i8 %tmp1, i1 true )
50 define i16 @ctlo_i16(i16 %x) {
51 ; CHECK-SD-LABEL: ctlo_i16:
53 ; CHECK-SD-NEXT: mov w8, #-1 // =0xffffffff
54 ; CHECK-SD-NEXT: eor w8, w8, w0, lsl #16
55 ; CHECK-SD-NEXT: clz w0, w8
58 ; CHECK-GI-LABEL: ctlo_i16:
60 ; CHECK-GI-NEXT: mov w8, #65535 // =0xffff
61 ; CHECK-GI-NEXT: bic w8, w8, w0
62 ; CHECK-GI-NEXT: clz w8, w8
63 ; CHECK-GI-NEXT: sub w0, w8, #16
65 %tmp1 = xor i16 %x, -1
66 %tmp2 = call i16 @llvm.ctlz.i16( i16 %tmp1, i1 false )
70 define i16 @ctlo_i16_undef(i16 %x) {
71 ; CHECK-SD-LABEL: ctlo_i16_undef:
73 ; CHECK-SD-NEXT: mvn w8, w0
74 ; CHECK-SD-NEXT: lsl w8, w8, #16
75 ; CHECK-SD-NEXT: clz w0, w8
78 ; CHECK-GI-LABEL: ctlo_i16_undef:
80 ; CHECK-GI-NEXT: mov w8, #65535 // =0xffff
81 ; CHECK-GI-NEXT: bic w8, w8, w0
82 ; CHECK-GI-NEXT: clz w8, w8
83 ; CHECK-GI-NEXT: sub w0, w8, #16
85 %tmp1 = xor i16 %x, -1
86 %tmp2 = call i16 @llvm.ctlz.i16( i16 %tmp1, i1 true )
90 define i32 @ctlo_i32(i32 %x) {
91 ; CHECK-LABEL: ctlo_i32:
93 ; CHECK-NEXT: mvn w8, w0
94 ; CHECK-NEXT: clz w0, w8
96 %tmp1 = xor i32 %x, -1
97 %tmp2 = call i32 @llvm.ctlz.i32( i32 %tmp1, i1 false )
101 define i32 @ctlo_i32_undef(i32 %x) {
102 ; CHECK-LABEL: ctlo_i32_undef:
104 ; CHECK-NEXT: mvn w8, w0
105 ; CHECK-NEXT: clz w0, w8
107 %tmp1 = xor i32 %x, -1
108 %tmp2 = call i32 @llvm.ctlz.i32( i32 %tmp1, i1 true )
112 define i64 @ctlo_i64(i64 %x) {
113 ; CHECK-LABEL: ctlo_i64:
115 ; CHECK-NEXT: mvn x8, x0
116 ; CHECK-NEXT: clz x0, x8
118 %tmp1 = xor i64 %x, -1
119 %tmp2 = call i64 @llvm.ctlz.i64( i64 %tmp1, i1 false )
123 define i64 @ctlo_i64_undef(i64 %x) {
124 ; CHECK-LABEL: ctlo_i64_undef:
126 ; CHECK-NEXT: mvn x8, x0
127 ; CHECK-NEXT: clz x0, x8
129 %tmp1 = xor i64 %x, -1
130 %tmp2 = call i64 @llvm.ctlz.i64( i64 %tmp1, i1 true )