[llvm] [BOLT][AArch64] Partial support for lite mode (PR #133014)
Paschalis Mpeis via llvm-commits
llvm-commits at lists.llvm.org
Wed Mar 26 04:14:25 PDT 2025
================
@@ -1673,12 +1678,104 @@ bool BinaryFunction::scanExternalRefs() {
if (BranchTargetSymbol) {
BC.MIB->replaceBranchTarget(Instruction, BranchTargetSymbol,
Emitter.LocalCtx.get());
- } else if (!llvm::any_of(Instruction,
- [](const MCOperand &Op) { return Op.isExpr(); })) {
- // Skip assembly if the instruction may not have any symbolic operands.
- continue;
} else {
+ bool NeedsPatch = false;
analyzeInstructionForFuncReference(Instruction);
+ for (unsigned OpNum = 0; OpNum < MCPlus::getNumPrimeOperands(Instruction);
+ ++OpNum) {
+ const MCSymbol *Symbol = BC.MIB->getTargetSymbol(Instruction, OpNum);
+ if (!Symbol)
+ continue;
+ if (!ignoreReference(Symbol)) {
+ NeedsPatch = true;
+ break;
+ }
+ }
+ if (!NeedsPatch)
+ continue;
+ }
+
+ // For AArch64, we need to undo relaxation done by the linker if the target
+ // of the instruction is a function that we plan to move.
+ const Relocation *Rel;
+ if (BC.isAArch64() && (Rel = getRelocationAt(Offset))) {
+ // NOP+ADR sequence can originate from either ADRP+ADD or ADRP+LDR.
+ // In either case, we convert it into ADRP+ADD.
+ if (BC.MIB->isADR(Instruction) &&
+ (Rel->Type == ELF::R_AARCH64_ADD_ABS_LO12_NC ||
+ Rel->Type == ELF::R_AARCH64_LD64_GOT_LO12_NC)) {
----------------
paschalis-mpeis wrote:
Hey Amir,
That is because these are the relocation types that linkers may optimize as per our ABI.
See [aaelf64.rst#relocation-optimization](https://github.com/ARM-software/abi-aa/blob/main/aaelf64/aaelf64.rst#relocation-optimization). Same for comments [here](https://github.com/llvm/llvm-project/pull/133014/files#r2013084103) and [here](https://github.com/llvm/llvm-project/pull/133014/files#r2013080842).
Maybe is good if we reference the ABI in some comment?
https://github.com/llvm/llvm-project/pull/133014
More information about the llvm-commits
mailing list