[llvm] [BOLT] Add --pad-funcs-before=func:n (PR #117924)
Maksim Panchenko via llvm-commits
llvm-commits at lists.llvm.org
Wed Dec 4 19:36:14 PST 2024
================
@@ -319,6 +349,36 @@ bool BinaryEmitter::emitFunction(BinaryFunction &Function,
Streamer.emitCodeAlignment(Function.getAlign(), &*BC.STI);
}
+ if (size_t Padding = opts::padFunctionBefore(Function)) {
+ // Handle padFuncsBefore after the above alignment logic but before
+ // symbol addresses are decided; with the intent that the nops are
+ // not executed and the original alignment logic is preserved.
+ if (!BC.HasRelocations) {
+ errs() << "BOLT-ERROR: -pad-before-funcs is not supported in "
+ << "non-relocation mode\n";
+ exit(1);
+ }
+
+ // Preserve Function.getMinAlign().
+ if (!isAligned(Function.getMinAlign(), Padding)) {
+ errs() << "BOLT-ERROR: User-requested " << Padding
+ << " padding bytes before function " << Function
+ << " is not a multiple of the minimum function alignment ("
+ << Function.getMinAlign().value() << ").\n";
+ exit(1);
+ }
+
+ LLVM_DEBUG(dbgs() << "BOLT-DEBUG: padding function " << Function << " with "
----------------
maksfb wrote:
Maybe use a different message from the other padding? Unless there's more debug output in-between the two and there is no chance to misattribute the output.
https://github.com/llvm/llvm-project/pull/117924
More information about the llvm-commits
mailing list