1 // RUN
: llvm-mc
-triple aarch64-elf
-filetype
=obj
%s
-o
- | llvm-objdump
--no-print-imm-hex
-d
- | FileCheck
%s
8 adds w0
, w1
, #(end - start)
9 adds x0
, x1
, #(end - start)
10 add w0
, w1
, #(end - start)
11 add x0
, x1
, #(end - start)
12 cmp w0
, #(end - start)
13 cmp x0
, #(end - start)
14 sub w0
, w1
, #(end - start)
15 sub x0
, x1
, #(end - start)
16 // FIXME
: adr x1
, #(end - start) // This could be supported, but currently doesn't work
17 // CHECK
: adds w0
, w1
, #8
18 // CHECK
: adds x0
, x1
, #8
19 // CHECK
: add w0
, w1
, #8
20 // CHECK
: add x0
, x1
, #8
23 // CHECK
: sub w0
, w1
, #8
24 // CHECK
: sub x0
, x1
, #8
27 add w0
, w1
, #(end - start), lsl #12
28 cmp w0
, #(end - start), lsl #12
29 // CHECK
: add w0
, w1
, #8, lsl #12
30 // CHECK
: cmp w0
, #8, lsl #12
32 add w0
, w1
, #((end - start) >> 2)
33 cmp w0
, #((end - start) >> 2)
34 // CHECK
: add w0
, w1
, #2
37 add w0
, w1
, #(end - start + 12)
38 cmp w0
, #(end - start + 12)
39 // CHECK
: add w0
, w1
, #20
42 add w0
, w1
, #(forward - end)
43 cmp w0
, #(forward - end)
44 // CHECK
: add w0
, w1
, #320
45 // CHECK
: cmp w0
, #320
47 // Add some filler so we don
't have to modify #(forward - end) if we add more
50 .space 320 - (.Lfiller - end)
58 add w0, w1, #(.Lend - .Lstart)
59 cmp w0, #(.Lend - .Lstart)
60 // CHECK: add w0, w1, #8
68 add w0, w1, #(.Lprivate2 - .Lprivate1)
69 cmp w0, #(.Lprivate2 - .Lprivate1)
70 // CHECK: add w0, w1, #16
75 // CHECK-LABEL: <foo>:
77 add w0, w1, #(foo - .Lprivate2)
78 cmp w0, #(foo - .Lprivate2)
79 // CHECK: add w0, w1, #8
86 // CHECK-LABEL: <goo>:
88 add w0, w1, #(goo - foo)
90 // CHECK: add w0, w1, #12
93 add w0, w1, #(. - goo)
95 // CHECK: add w0, w1, #8