[llvm-objdump] - Remove one overload of reportError. NFCI.
[llvm-complete.git] / test / CodeGen / AArch64 / GlobalISel / select-scalar-shift-imm.mir
blob2afc067882e17b2749a38b61766932b1d990ce68
1 # NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
2 # RUN: llc -mtriple=aarch64-- -O0 -run-pass=instruction-select -verify-machineinstrs %s -global-isel-abort=1 -o - | FileCheck %s
3 ---
4 name:            shl_cimm_32
5 legalized:       true
6 regBankSelected: true
7 body:             |
8   bb.1:
9     liveins: $w0
11     ; CHECK-LABEL: name: shl_cimm_32
12     ; CHECK: [[COPY:%[0-9]+]]:gpr32 = COPY $w0
13     ; CHECK: [[UBFMWri:%[0-9]+]]:gpr32 = UBFMWri [[COPY]], 24, 23
14     ; CHECK: $w0 = COPY [[UBFMWri]]
15     ; CHECK: RET_ReallyLR implicit $w0
16     %0:gpr(s32) = COPY $w0
17     %1:gpr(s32) = G_CONSTANT i32 8
18     %2:gpr(s32) = G_SHL %0, %1(s32)
19     $w0 = COPY %2(s32)
20     RET_ReallyLR implicit $w0
22 ...
23 ---
24 name:            shl_cimm_64
25 legalized:       true
26 regBankSelected: true
27 body:             |
28   bb.1:
29     liveins: $x0
31     ; CHECK-LABEL: name: shl_cimm_64
32     ; CHECK: [[COPY:%[0-9]+]]:gpr64 = COPY $x0
33     ; CHECK: [[UBFMXri:%[0-9]+]]:gpr64 = UBFMXri [[COPY]], 56, 55
34     ; CHECK: $x0 = COPY [[UBFMXri]]
35     ; CHECK: RET_ReallyLR implicit $x0
36     %0:gpr(s64) = COPY $x0
37     %1:gpr(s64) = G_CONSTANT i64 8
38     %2:gpr(s64) = G_SHL %0, %1(s64)
39     $x0 = COPY %2(s64)
40     RET_ReallyLR implicit $x0
42 ...
43 ---
44 name:            lshr_cimm_32
45 legalized:       true
46 regBankSelected: true
47 body:             |
48   bb.1:
49     liveins: $w0
51     ; CHECK-LABEL: name: lshr_cimm_32
52     ; CHECK: [[COPY:%[0-9]+]]:gpr32 = COPY $w0
53     ; CHECK: [[UBFMWri:%[0-9]+]]:gpr32 = UBFMWri [[COPY]], 8, 31
54     ; CHECK: $w0 = COPY [[UBFMWri]]
55     ; CHECK: RET_ReallyLR implicit $w0
56     %0:gpr(s32) = COPY $w0
57     %3:gpr(s64) = G_CONSTANT i64 8
58     %2:gpr(s32) = G_LSHR %0, %3(s64)
59     $w0 = COPY %2(s32)
60     RET_ReallyLR implicit $w0
62 ...
63 ---
64 name:            lshr_cimm_64
65 legalized:       true
66 regBankSelected: true
67 body:             |
68   bb.1:
69     liveins: $x0
71     ; CHECK-LABEL: name: lshr_cimm_64
72     ; CHECK: [[COPY:%[0-9]+]]:gpr64 = COPY $x0
73     ; CHECK: [[UBFMXri:%[0-9]+]]:gpr64 = UBFMXri [[COPY]], 8, 63
74     ; CHECK: $x0 = COPY [[UBFMXri]]
75     ; CHECK: RET_ReallyLR implicit $x0
76     %0:gpr(s64) = COPY $x0
77     %1:gpr(s64) = G_CONSTANT i64 8
78     %2:gpr(s64) = G_LSHR %0, %1(s64)
79     $x0 = COPY %2(s64)
80     RET_ReallyLR implicit $x0
82 ...
83 ---
84 name:            ashr_cimm_32
85 legalized:       true
86 regBankSelected: true
87 body:             |
88   bb.1:
89     liveins: $w0
91     ; CHECK-LABEL: name: ashr_cimm_32
92     ; CHECK: [[COPY:%[0-9]+]]:gpr32 = COPY $w0
93     ; CHECK: [[SBFMWri:%[0-9]+]]:gpr32 = SBFMWri [[COPY]], 8, 31
94     ; CHECK: $w0 = COPY [[SBFMWri]]
95     ; CHECK: RET_ReallyLR implicit $w0
96     %0:gpr(s32) = COPY $w0
97     %3:gpr(s64) = G_CONSTANT i64 8
98     %2:gpr(s32) = G_ASHR %0, %3(s64)
99     $w0 = COPY %2(s32)
100     RET_ReallyLR implicit $w0
104 name:            ashr_cimm_64
105 legalized:       true
106 regBankSelected: true
107 body:             |
108   bb.1:
109     liveins: $x0
111     ; CHECK-LABEL: name: ashr_cimm_64
112     ; CHECK: [[COPY:%[0-9]+]]:gpr64 = COPY $x0
113     ; CHECK: [[SBFMXri:%[0-9]+]]:gpr64 = SBFMXri [[COPY]], 8, 63
114     ; CHECK: $x0 = COPY [[SBFMXri]]
115     ; CHECK: RET_ReallyLR implicit $x0
116     %0:gpr(s64) = COPY $x0
117     %1:gpr(s64) = G_CONSTANT i64 8
118     %2:gpr(s64) = G_ASHR %0, %1(s64)
119     $x0 = COPY %2(s64)
120     RET_ReallyLR implicit $x0
124 name:            lshr_32_notimm64
125 legalized:       true
126 regBankSelected: true
127 body:             |
128   bb.1:
129     liveins: $w0
131     ; CHECK-LABEL: name: lshr_32_notimm64
132     ; CHECK: [[COPY:%[0-9]+]]:gpr32 = COPY $w0
133     ; CHECK: [[MOVi64imm:%[0-9]+]]:gpr64 = MOVi64imm 8
134     ; CHECK: [[ANDXri:%[0-9]+]]:gpr64sp = ANDXri [[MOVi64imm]], 8000
135     ; CHECK: [[COPY1:%[0-9]+]]:gpr32 = COPY [[ANDXri]].sub_32
136     ; CHECK: [[LSRVWr:%[0-9]+]]:gpr32 = LSRVWr [[COPY]], [[COPY1]]
137     ; CHECK: $w0 = COPY [[LSRVWr]]
138     ; CHECK: RET_ReallyLR implicit $w0
139     %0:gpr(s32) = COPY $w0
140     %3:gpr(s64) = G_CONSTANT i64 8
141     %4:gpr(s64) = G_AND %3, %3
142     %2:gpr(s32) = G_LSHR %0, %4(s64)
143     $w0 = COPY %2(s32)
144     RET_ReallyLR implicit $w0
148 name:            ashr_32_notimm64
149 legalized:       true
150 regBankSelected: true
151 body:             |
152   bb.1:
153     liveins: $w0
155     ; CHECK-LABEL: name: ashr_32_notimm64
156     ; CHECK: [[COPY:%[0-9]+]]:gpr32 = COPY $w0
157     ; CHECK: [[MOVi64imm:%[0-9]+]]:gpr64 = MOVi64imm 8
158     ; CHECK: [[ANDXri:%[0-9]+]]:gpr64sp = ANDXri [[MOVi64imm]], 8000
159     ; CHECK: [[COPY1:%[0-9]+]]:gpr32 = COPY [[ANDXri]].sub_32
160     ; CHECK: [[ASRVWr:%[0-9]+]]:gpr32 = ASRVWr [[COPY]], [[COPY1]]
161     ; CHECK: $w0 = COPY [[ASRVWr]]
162     ; CHECK: RET_ReallyLR implicit $w0
163     %0:gpr(s32) = COPY $w0
164     %3:gpr(s64) = G_CONSTANT i64 8
165     %4:gpr(s64) = G_AND %3, %3
166     %2:gpr(s32) = G_ASHR %0, %4(s64)
167     $w0 = COPY %2(s32)
168     RET_ReallyLR implicit $w0