annotate test/MC/AArch64/label-arithmetic-elf.s @ 121:803732b1fca8

LLVM 5.0
author kono
date Fri, 27 Oct 2017 17:07:41 +0900
parents 1172e4bd9c6f
children c2174574ed3a
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
120
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
1 // RUN: llvm-mc -triple aarch64-elf -filetype=obj %s -o - | llvm-objdump -d - | FileCheck %s
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
2
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
3 start:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
4 .space 8
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
5 end:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
6 // CHECK-LABEL: end:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
7
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
8 adds w0, w1, #(end - start)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
9 adds x0, x1, #(end - start)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
10 add w0, w1, #(end - start)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
11 add x0, x1, #(end - start)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
12 cmp w0, #(end - start)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
13 cmp x0, #(end - start)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
14 sub w0, w1, #(end - start)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
15 sub x0, x1, #(end - start)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
16 // CHECK: adds w0, w1, #8
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
17 // CHECK: adds x0, x1, #8
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
18 // CHECK: add w0, w1, #8
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
19 // CHECK: add x0, x1, #8
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
20 // CHECK: cmp w0, #8
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
21 // CHECK: cmp x0, #8
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
22 // CHECK: sub w0, w1, #8
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
23 // CHECK: sub x0, x1, #8
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
24
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
25 add w0, w1, #(end - start), lsl #12
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
26 cmp w0, #(end - start), lsl #12
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
27 // CHECK: add w0, w1, #8, lsl #12
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
28 // CHECK: cmp w0, #8, lsl #12
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
29
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
30 add w0, w1, #((end - start) >> 2)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
31 cmp w0, #((end - start) >> 2)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
32 // CHECK: add w0, w1, #2
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
33 // CHECK: cmp w0, #2
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
34
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
35 add w0, w1, #(end - start + 12)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
36 cmp w0, #(end - start + 12)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
37 // CHECK: add w0, w1, #20
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
38 // CHECK: cmp w0, #20
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
39
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
40 add w0, w1, #(forward - end)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
41 cmp w0, #(forward - end)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
42 // CHECK: add w0, w1, #320
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
43 // CHECK: cmp w0, #320
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
44
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
45 // Add some filler so we don't have to modify #(forward - end) if we add more
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
46 // instructions above
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
47 .Lfiller:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
48 .space 320 - (.Lfiller - end)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
49
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
50 forward:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
51 .space 8
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
52
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
53 .Lstart:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
54 .space 8
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
55 .Lend:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
56 add w0, w1, #(.Lend - .Lstart)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
57 cmp w0, #(.Lend - .Lstart)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
58 // CHECK: add w0, w1, #8
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
59 // CHECK: cmp w0, #8
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
60
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
61 .Lprivate1:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
62 .space 8
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
63 notprivate:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
64 .space 8
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
65 .Lprivate2:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
66 add w0, w1, #(.Lprivate2 - .Lprivate1)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
67 cmp w0, #(.Lprivate2 - .Lprivate1)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
68 // CHECK: add w0, w1, #16
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
69 // CHECK: cmp w0, #16
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
70
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
71 .type foo, @function
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
72 foo:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
73 // CHECK-LABEL: foo:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
74
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
75 add w0, w1, #(foo - .Lprivate2)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
76 cmp w0, #(foo - .Lprivate2)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
77 // CHECK: add w0, w1, #8
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
78 // CHECK: cmp w0, #8
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
79
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
80 ret
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
81
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
82 .type goo, @function
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
83 goo:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
84 // CHECK-LABEL: goo:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
85
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
86 add w0, w1, #(goo - foo)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
87 cmp w0, #(goo - foo)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
88 // CHECK: add w0, w1, #12
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
89 // CHECK: cmp w0, #12
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
90
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
91 add w0, w1, #(. - goo)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
92 cmp w0, #(. - goo)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
93 // CHECK: add w0, w1, #8
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
94 // CHECK: cmp w0, #12
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
95
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
96 ret