summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--lld/ELF/InputSection.cpp12
-rw-r--r--lld/test/ELF/ppc64-error-toc-restore.s2
-rw-r--r--lld/test/ELF/ppc64-error-toc-tail-call.s2
3 files changed, 8 insertions, 8 deletions
diff --git a/lld/ELF/InputSection.cpp b/lld/ELF/InputSection.cpp
index dfe8f5003bd..4717914d914 100644
--- a/lld/ELF/InputSection.cpp
+++ b/lld/ELF/InputSection.cpp
@@ -740,13 +740,13 @@ void InputSectionBase::relocateAlloc(uint8_t *Buf, uint8_t *BufEnd) {
break;
case R_PPC_PLT_OPD:
// Patch a nop (0x60000000) to a ld.
- if (BufLoc + 8 <= BufEnd && read32(BufLoc + 4) == 0x60000000) {
- write32(BufLoc + 4, 0xe8410018); // ld %r2, 24(%r1)
- } else {
- error(getErrorLocation(BufLoc) + "error: call lacks nop, can't restore toc.");
- return;
+ if (BufLoc + 8 > BufEnd || read32(BufLoc + 4) != 0x60000000) {
+ error(getErrorLocation(BufLoc) + "call lacks nop, can't restore toc");
+ break;
}
- LLVM_FALLTHROUGH;
+ write32(BufLoc + 4, 0xe8410018); // ld %r2, 24(%r1)
+ Target->relocateOne(BufLoc, Type, TargetVA);
+ break;
default:
Target->relocateOne(BufLoc, Type, TargetVA);
break;
diff --git a/lld/test/ELF/ppc64-error-toc-restore.s b/lld/test/ELF/ppc64-error-toc-restore.s
index d9adbd8ded1..8122409c737 100644
--- a/lld/test/ELF/ppc64-error-toc-restore.s
+++ b/lld/test/ELF/ppc64-error-toc-restore.s
@@ -5,7 +5,7 @@
// REQUIRES: ppc
# Calling external function bar needs a nop
-// CHECK: error: call lacks nop, can't restore toc
+// CHECK: call lacks nop, can't restore toc
.text
.abiversion 2
diff --git a/lld/test/ELF/ppc64-error-toc-tail-call.s b/lld/test/ELF/ppc64-error-toc-tail-call.s
index 3c096d367f1..5f86f60aaff 100644
--- a/lld/test/ELF/ppc64-error-toc-tail-call.s
+++ b/lld/test/ELF/ppc64-error-toc-tail-call.s
@@ -5,7 +5,7 @@
// REQUIRES: ppc
# A tail call to an external function without a nop should issue an error.
-// CHECK: error: call lacks nop, can't restore toc
+// CHECK: call lacks nop, can't restore toc
.text
.abiversion 2
OpenPOWER on IntegriCloud