Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / AArch64 / GlobalISel / legalize-lrint.mir
blobddc4f07e1a14609e80f1ca8e80662e7104c4be21
1 # NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
2 # RUN: llc -verify-machineinstrs -mtriple aarch64-unknown-unknown -run-pass=legalizer %s -o - | FileCheck %s
3 ---
4 name:            testmsws
5 alignment:       4
6 tracksRegLiveness: true
7 liveins:
8   - { reg: '$s0' }
9 body:             |
10   bb.1:
11     liveins: $s0
13     ; CHECK-LABEL: name: testmsws
14     ; CHECK: liveins: $s0
15     ; CHECK: [[COPY:%[0-9]+]]:_(s32) = COPY $s0
16     ; CHECK: [[INTRINSIC_LRINT:%[0-9]+]]:_(s64) = G_INTRINSIC_LRINT [[COPY]](s32)
17     ; CHECK: [[TRUNC:%[0-9]+]]:_(s32) = G_TRUNC [[INTRINSIC_LRINT]](s64)
18     ; CHECK: $w0 = COPY [[TRUNC]](s32)
19     ; CHECK: RET_ReallyLR implicit $w0
20     %0:_(s32) = COPY $s0
21     %1:_(s64) = G_INTRINSIC_LRINT %0(s32)
22     %2:_(s32) = G_TRUNC %1(s64)
23     $w0 = COPY %2(s32)
24     RET_ReallyLR implicit $w0
26 ...
27 ---
28 name:            testmsxs
29 alignment:       4
30 tracksRegLiveness: true
31 liveins:
32   - { reg: '$s0' }
33 body:             |
34   bb.1:
35     liveins: $s0
37     ; CHECK-LABEL: name: testmsxs
38     ; CHECK: liveins: $s0
39     ; CHECK: [[COPY:%[0-9]+]]:_(s32) = COPY $s0
40     ; CHECK: [[INTRINSIC_LRINT:%[0-9]+]]:_(s64) = G_INTRINSIC_LRINT [[COPY]](s32)
41     ; CHECK: $x0 = COPY [[INTRINSIC_LRINT]](s64)
42     ; CHECK: RET_ReallyLR implicit $x0
43     %0:_(s32) = COPY $s0
44     %1:_(s64) = G_INTRINSIC_LRINT %0(s32)
45     $x0 = COPY %1(s64)
46     RET_ReallyLR implicit $x0
48 ...
49 ---
50 name:            testmswd
51 alignment:       4
52 tracksRegLiveness: true
53 liveins:
54   - { reg: '$d0' }
55 body:             |
56   bb.1:
57     liveins: $d0
59     ; CHECK-LABEL: name: testmswd
60     ; CHECK: liveins: $d0
61     ; CHECK: [[COPY:%[0-9]+]]:_(s64) = COPY $d0
62     ; CHECK: [[INTRINSIC_LRINT:%[0-9]+]]:_(s64) = G_INTRINSIC_LRINT [[COPY]](s64)
63     ; CHECK: [[TRUNC:%[0-9]+]]:_(s32) = G_TRUNC [[INTRINSIC_LRINT]](s64)
64     ; CHECK: $w0 = COPY [[TRUNC]](s32)
65     ; CHECK: RET_ReallyLR implicit $w0
66     %0:_(s64) = COPY $d0
67     %1:_(s64) = G_INTRINSIC_LRINT %0(s64)
68     %2:_(s32) = G_TRUNC %1(s64)
69     $w0 = COPY %2(s32)
70     RET_ReallyLR implicit $w0
72 ...
73 ---
74 name:            testmsxd
75 alignment:       4
76 tracksRegLiveness: true
77 liveins:
78   - { reg: '$d0' }
79 body:             |
80   bb.1:
81     liveins: $d0
83     ; CHECK-LABEL: name: testmsxd
84     ; CHECK: liveins: $d0
85     ; CHECK: [[COPY:%[0-9]+]]:_(s64) = COPY $d0
86     ; CHECK: [[INTRINSIC_LRINT:%[0-9]+]]:_(s64) = G_INTRINSIC_LRINT [[COPY]](s64)
87     ; CHECK: $x0 = COPY [[INTRINSIC_LRINT]](s64)
88     ; CHECK: RET_ReallyLR implicit $x0
89     %0:_(s64) = COPY $d0
90     %1:_(s64) = G_INTRINSIC_LRINT %0(s64)
91     $x0 = COPY %1(s64)
92     RET_ReallyLR implicit $x0
94 ...