Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / MC / AArch64 / label-arithmetic-darwin.s
blobe6109cc7ec90aeb764d0e2e295f87f8298797206
1 // RUN: llvm-mc -triple aarch64-darwin -filetype=obj %s -o - | llvm-objdump --no-print-imm-hex -r -d - | FileCheck %s
2 // RUN: llvm-mc -triple aarch64-ios -filetype=obj %s -o - | llvm-objdump --no-print-imm-hex -r -d - | FileCheck %s
4 visible:
5 .space 8
6 Lstart:
7 .space 8
8 Lend:
9 adds w0, w1, #(Lend - Lstart)
10 adds x0, x1, #(Lend - Lstart)
11 add w0, w1, #(Lend - Lstart)
12 add x0, x1, #(Lend - Lstart)
13 cmp w0, #(Lend - Lstart)
14 cmp x0, #(Lend - Lstart)
15 sub w0, w1, #(Lend - Lstart)
16 sub x0, x1, #(Lend - Lstart)
17 // CHECK: adds w0, w1, #8
18 // CHECK: adds x0, x1, #8
19 // CHECK: add w0, w1, #8
20 // CHECK: add x0, x1, #8
21 // CHECK: cmp w0, #8
22 // CHECK: cmp x0, #8
23 // CHECK: sub w0, w1, #8
24 // CHECK: sub x0, x1, #8
26 add w0, w1, #(Lend - Lstart), lsl #12
27 cmp w0, #(Lend - Lstart), lsl #12
28 // CHECK: add w0, w1, #8, lsl #12
29 // CHECK: cmp w0, #8, lsl #12
31 add w0, w1, #((Lend - Lstart) >> 2)
32 cmp w0, #((Lend - Lstart) >> 2)
33 // CHECK: add w0, w1, #2
34 // CHECK: cmp w0, #2
36 add w0, w1, #(Lend - Lstart + 12)
37 cmp w0, #(Lend - Lstart + 12)
38 // CHECK: add w0, w1, #20
39 // CHECK: cmp w0, #20
41 add w0, w1, #(Lforward - Lend)
42 cmp w0, #(Lforward - Lend)
43 // CHECK: add w0, w1, #320
44 // CHECK: cmp w0, #320
46 add w0, w1, #(Lstart - visible)
47 cmp w0, #(Lstart - visible)
48 // CHECK: add w0, w1, #8
49 // CHECK: cmp w0, #8
51 // Add some filler so we don't have to modify #(Lforward - Lend) if we add more
52 // instructions above
53 Lfiller:
54 .space 320 - (Lfiller - Lend)
56 Lforward:
57 .space 4
58 add w0, w1, #(. - Lforward)
59 cmp w0, #(. - Lforward)
60 // CHECK: add w0, w1, #4
61 // CHECK: cmp w0, #8