diff --git a/lib/Target/ARM/MCTargetDesc/ARMAsmBackend.cpp b/lib/Target/ARM/MCTargetDesc/ARMAsmBackend.cpp index a1eeeab2841..aeab5be78ab 100644 --- a/lib/Target/ARM/MCTargetDesc/ARMAsmBackend.cpp +++ b/lib/Target/ARM/MCTargetDesc/ARMAsmBackend.cpp @@ -1000,6 +1000,7 @@ static unsigned getFixupKindContainerSizeBytes(unsigned Kind) { case ARM::fixup_arm_pcrel_10_unscaled: case ARM::fixup_arm_ldst_pcrel_12: case ARM::fixup_arm_pcrel_10: + case ARM::fixup_arm_pcrel_9: case ARM::fixup_arm_adr_pcrel_12: case ARM::fixup_arm_uncondbl: case ARM::fixup_arm_condbl: diff --git a/test/MC/ARM/fixup-pcrel9.s b/test/MC/ARM/fixup-pcrel9.s new file mode 100644 index 00000000000..620b6799a07 --- /dev/null +++ b/test/MC/ARM/fixup-pcrel9.s @@ -0,0 +1,18 @@ +// RUN: llvm-mc -triple=armebv8.2a-eabi -filetype=obj < %s | llvm-objdump -s - | FileCheck %s --check-prefix=CHECK-BE +// RUN: llvm-mc -triple=armv8.2a-eabi -filetype=obj < %s | llvm-objdump -s - | FileCheck %s --check-prefix=CHECK-LE + + .text + .fpu crypto-neon-fp-armv8 + .arch_extension fp16 + +.section s_pcrel_9,"ax",%progbits +// CHECK-BE-LABEL: Contents of section s_pcrel_9 +// CHECK-LE-LABEL: Contents of section s_pcrel_9 +// CHECK-BE: 0000 ed9f0902 +// CHECK-LE: 0000 02099fed + vldr.16 s0, .LCPI0_0 + nop + bx lr +.LCPI0_0: + .short 28012 +