diff --git a/lld/ELF/Target.cpp b/lld/ELF/Target.cpp index 4cc8a43b708b..8a28f4debe3b 100644 --- a/lld/ELF/Target.cpp +++ b/lld/ELF/Target.cpp @@ -491,11 +491,13 @@ int64_t X86TargetInfo::getImplicitAddend(const uint8_t *Buf, default: return 0; case R_386_8: - case R_386_PC8: return *Buf; + case R_386_PC8: + return SignExtend64<8>(*Buf); case R_386_16: - case R_386_PC16: return read16le(Buf); + case R_386_PC16: + return SignExtend64<16>(read16le(Buf)); case R_386_32: case R_386_GOT32: case R_386_GOT32X: diff --git a/lld/test/ELF/i386-pc8-pc16-addend.s b/lld/test/ELF/i386-pc8-pc16-addend.s new file mode 100644 index 000000000000..9d6424df3600 --- /dev/null +++ b/lld/test/ELF/i386-pc8-pc16-addend.s @@ -0,0 +1,17 @@ +# REQUIRES: x86 +# RUN: llvm-mc -filetype=obj -triple=i386-pc-linux-gnu %s -o %t1.o + +# RUN: ld.lld %t1.o -o %t.out +# RUN: llvm-objdump -s -t %t.out | FileCheck %s +# CHECK: Contents of section .text: +# CHECK-NEXT: 11000 020000 +## 0x11003 - 0x11000 + addend(-1) = 0x02 +## 0x11003 - 0x11001 + addend(-2) = 0x0000 +# CHECK: SYMBOL TABLE: +# CHECK: 00011003 .und + +.byte und-.-1 +.short und-.-2 + +.section .und, "ax" +und: