[PATCH] D29490: [ELF] - Use SignExtend when reading R_386_PC8, R_386_PC16 addends.
George Rimar via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Mon Feb 6 08:39:39 PST 2017
grimar updated this revision to Diff 87238.
grimar added a comment.
- Addressed review comments.
https://reviews.llvm.org/D29490
Files:
ELF/Target.cpp
test/ELF/i386-pc8-pc16-addend.s
Index: test/ELF/i386-pc8-pc16-addend.s
===================================================================
--- test/ELF/i386-pc8-pc16-addend.s
+++ test/ELF/i386-pc8-pc16-addend.s
@@ -0,0 +1,19 @@
+# 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.out | FileCheck %s
+# RUN: llvm-readobj -symbols %t.out | FileCheck %s --check-prefix=SYM
+# CHECK: Contents of section .text:
+# CHECK-NEXT: 11000 020000
+## 0x11003 - 0x11000 + addend(-1) = 0x02
+## 0x11003 - 0x11001 + addend(-2) = 0x0000
+# SYM: Symbol {
+# SYM: Name: und
+# SYM-NEXT: Value: 0x11003
+
+.byte und-.-1
+.short und-.-2
+
+.section .und, "ax"
+und:
Index: ELF/Target.cpp
===================================================================
--- ELF/Target.cpp
+++ ELF/Target.cpp
@@ -492,11 +492,13 @@
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:
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D29490.87238.patch
Type: text/x-patch
Size: 1202 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20170206/1ef196d6/attachment.bin>
More information about the llvm-commits
mailing list