7 changes: 7 additions & 0 deletions llvm/test/MC/AArch64/elf-reloc-movw.s
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,10 @@
movz x19, #:abs_g2_s:some_label
movn x19, #:abs_g2_s:some_label

movz x19, #:abs_g1:some_label + 20 - 10
movn x19, #:abs_g2_s:some_label - 20 + 10
movk x11, #:abs_g3:some_label + 2 * 10

// OBJ: Relocations [
// OBJ-NEXT: Section {{.*}} .rela.text {
// OBJ-NEXT: 0x0 R_AARCH64_MOVW_UABS_G0 some_label 0x0
Expand All @@ -38,5 +42,8 @@
// OBJ-NEXT: 0x2C R_AARCH64_MOVW_SABS_G1 some_label 0x0
// OBJ-NEXT: 0x30 R_AARCH64_MOVW_SABS_G2 some_label 0x0
// OBJ-NEXT: 0x34 R_AARCH64_MOVW_SABS_G2 some_label 0x0
// OBJ-NEXT: 0x38 R_AARCH64_MOVW_UABS_G1 some_label 0xA
// OBJ-NEXT: 0x3C R_AARCH64_MOVW_SABS_G2 some_label 0xFFFFFFFFFFFFFFF6
// OBJ-NEXT: 0x40 R_AARCH64_MOVW_UABS_G3 some_label 0x14
// OBJ-NEXT: }
// OBJ-NEXT: ]
2 changes: 2 additions & 0 deletions llvm/test/MC/AArch64/label-arithmetic-elf.s
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ end:
cmp x0, #(end - start)
sub w0, w1, #(end - start)
sub x0, x1, #(end - start)
// FIXME: adr x1, #(end - start) // This could be supported, but currently doesn't work
// CHECK: adds w0, w1, #8
// CHECK: adds x0, x1, #8
// CHECK: add w0, w1, #8
Expand All @@ -21,6 +22,7 @@ end:
// CHECK: cmp x0, #8
// CHECK: sub w0, w1, #8
// CHECK: sub x0, x1, #8
// FIXME: adr x1, #8

add w0, w1, #(end - start), lsl #12
cmp w0, #(end - start), lsl #12
Expand Down