diff options
author | Fangrui Song <i@maskray.me> | 2025-03-29 19:08:07 -0700 |
---|---|---|
committer | Fangrui Song <i@maskray.me> | 2025-03-29 19:08:07 -0700 |
commit | db603a09dabefc6847423c8968578ce6d54a7a2d (patch) | |
tree | 7bbb406166ebc61e580ed607b6dbf63c7450c9a7 /llvm/lib/MC/ELFObjectWriter.cpp | |
parent | d8b078d5509d84da987c18cb357aac867051881c (diff) | |
download | llvm-db603a09dabefc6847423c8968578ce6d54a7a2d.zip llvm-db603a09dabefc6847423c8968578ce6d54a7a2d.tar.gz llvm-db603a09dabefc6847423c8968578ce6d54a7a2d.tar.bz2 |
[MC] Move ELF-specific handleAddSubRelocations to ELFObjectWriter::recordRelocation
Diffstat (limited to 'llvm/lib/MC/ELFObjectWriter.cpp')
-rw-r--r-- | llvm/lib/MC/ELFObjectWriter.cpp | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/llvm/lib/MC/ELFObjectWriter.cpp b/llvm/lib/MC/ELFObjectWriter.cpp index 22af6d9..f3445da 100644 --- a/llvm/lib/MC/ELFObjectWriter.cpp +++ b/llvm/lib/MC/ELFObjectWriter.cpp @@ -1377,6 +1377,12 @@ void ELFObjectWriter::recordRelocation(MCAssembler &Asm, const MCTargetOptions *TO = Ctx.getTargetOptions(); if (auto *RefB = Target.getSubSym()) { + // When there is no relocation specifier, a linker relaxation target may + // emit ADD/SUB relocations for A-B+C. + if (Target.getSymA() && Backend.handleAddSubRelocations( + Asm, *Fragment, Fixup, Target, FixedValue)) + return; + const auto &SymB = cast<MCSymbolELF>(*RefB); if (SymB.isUndefined()) { Ctx.reportError(Fixup.getLoc(), |