[PATCH] D38614: [ELF][MIPS] Check for overflow when writing R_MIPS_CALL16 and R_MIPS_TLS_GOTTPREL
Alexander Richardson via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Fri Oct 6 04:02:44 PDT 2017
arichardson updated this revision to Diff 117976.
arichardson edited the summary of this revision.
arichardson added a comment.
Added a test case.
I noticed that test case no longer works with https://reviews.llvm.org/D31528 (Multi-GOT) and I'm not sure how to create one that works with it.
https://reviews.llvm.org/D38614
Files:
ELF/Arch/Mips.cpp
test/ELF/mips-out-of-bounds-call16-reloc.s
Index: test/ELF/mips-out-of-bounds-call16-reloc.s
===================================================================
--- /dev/null
+++ test/ELF/mips-out-of-bounds-call16-reloc.s
@@ -0,0 +1,29 @@
+# Check that we create an error on an out-of-bounds R_MIPS_CALL_16
+
+# REQUIRES: mips
+# RUN: llvm-mc -filetype=obj -triple=mips64-unknown-linux %s -o %t1.o
+# RUN: not ld.lld %t1.o -o %t.exe 2>&1 | FileCheck %s
+
+# CHECK: relocation R_MIPS_CALL16 out of range
+
+.macro generate_values
+ .irp i, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9,
+ .irp j, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9,
+ .irp k, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9,
+ .irp l, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9,
+ .text
+ .globl sym_\i\j\k\l
+ sym_\i\j\k\l:
+ nop
+ lw $25,%call16(sym_\i\j\k\l)($28)
+ .endr
+ .endr
+ .endr
+ .endr
+.endm
+
+generate_values
+
+.globl __start
+__start:
+ nop
Index: ELF/Arch/Mips.cpp
===================================================================
--- ELF/Arch/Mips.cpp
+++ ELF/Arch/Mips.cpp
@@ -501,21 +501,21 @@
writeMicroRelocation32<E>(Loc, Val, 16, 0);
}
break;
+ case R_MIPS_CALL16:
case R_MIPS_GOT_DISP:
case R_MIPS_GOT_PAGE:
case R_MIPS_GPREL16:
case R_MIPS_TLS_GD:
+ case R_MIPS_TLS_GOTTPREL:
case R_MIPS_TLS_LDM:
checkInt<16>(Loc, Val, Type);
LLVM_FALLTHROUGH;
- case R_MIPS_CALL16:
case R_MIPS_CALL_LO16:
case R_MIPS_GOT_LO16:
case R_MIPS_GOT_OFST:
case R_MIPS_LO16:
case R_MIPS_PCLO16:
case R_MIPS_TLS_DTPREL_LO16:
- case R_MIPS_TLS_GOTTPREL:
case R_MIPS_TLS_TPREL_LO16:
writeRelocation<E>(Loc, Val, 16, 0);
break;
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D38614.117976.patch
Type: text/x-patch
Size: 1653 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20171006/c80051ad/attachment.bin>
More information about the llvm-commits
mailing list