[llvm] [x86] Enable indirect tail calls with more arguments (PR #137643)
Hans Wennborg via llvm-commits
llvm-commits at lists.llvm.org
Fri Feb 13 08:15:41 PST 2026
================
@@ -3489,6 +3520,47 @@ static bool mayUseCarryFlag(X86::CondCode CC) {
return true;
}
+bool X86DAGToDAGISel::checkTCRetRegUsage(SDNode *N, LoadSDNode *Load) const {
+ const X86RegisterInfo *RI = Subtarget->getRegisterInfo();
+ const TargetRegisterClass *TailCallGPRs = RI->getGPRsForTailCall(*MF);
+ unsigned MaxGPRs = TailCallGPRs->getNumRegs();
+ if (Subtarget->is64Bit()) {
+ assert(TailCallGPRs->contains(X86::RSP));
+ assert(TailCallGPRs->contains(X86::RIP));
+ MaxGPRs -= 2; // Can't use RSP or RIP for the address in general.
+ } else {
+ assert(TailCallGPRs->contains(X86::ESP));
+ MaxGPRs -= 1; // Can't use ESP for the address in general.
+ }
+
+ // The load's base and index potentially need two registers.
+ unsigned LoadGPRs = 2;
+
+ if (Load) {
+ // But not if it's loading from a frame slot or global.
+ // XXX: Couldn't we be indexing off of the global though?
+ const SDValue &BasePtr = Load->getBasePtr();
+ if (isa<FrameIndexSDNode>(BasePtr)) {
+ LoadGPRs = 0;
+ } else if (BasePtr->getNumOperands() &&
----------------
zmodem wrote:
Thanks! Done.
https://github.com/llvm/llvm-project/pull/137643
More information about the llvm-commits
mailing list