Skip to content

Commit c0f2cea

Browse files
committed
Revert "[AArch64] Lower calls with rv_marker attribute ."
This reverts commit a87fccb. A test appears to fail with expensive checks. Reverting while I investigate.
1 parent 0519722 commit c0f2cea

File tree

6 files changed

+2
-242
lines changed

6 files changed

+2
-242
lines changed

llvm/lib/Target/AArch64/AArch64ExpandPseudoInsts.cpp

Lines changed: 0 additions & 44 deletions
Original file line numberDiff line numberDiff line change
@@ -83,8 +83,6 @@ class AArch64ExpandPseudo : public MachineFunctionPass {
8383
bool expandSVESpillFill(MachineBasicBlock &MBB,
8484
MachineBasicBlock::iterator MBBI, unsigned Opc,
8585
unsigned N);
86-
bool expandCALL_RVMARKER(MachineBasicBlock &MBB,
87-
MachineBasicBlock::iterator MBBI);
8886
};
8987

9088
} // end anonymous namespace
@@ -629,46 +627,6 @@ bool AArch64ExpandPseudo::expandSVESpillFill(MachineBasicBlock &MBB,
629627
return true;
630628
}
631629

632-
bool AArch64ExpandPseudo::expandCALL_RVMARKER(
633-
MachineBasicBlock &MBB, MachineBasicBlock::iterator MBBI) {
634-
// Expand CALL_RVMARKER pseudo to a branch, followed by the special `mov x29,
635-
// x29` marker. Mark the sequence as bundle, to avoid passes moving other code
636-
// in between.
637-
MachineInstr &MI = *MBBI;
638-
639-
MachineInstr *OriginalCall;
640-
MachineOperand &CallTarget = MI.getOperand(0);
641-
assert((CallTarget.isGlobal() || CallTarget.isReg()) &&
642-
"invalid operand for regular call");
643-
unsigned Opc = CallTarget.isGlobal() ? AArch64::BL : AArch64::BLR;
644-
OriginalCall = BuildMI(MBB, MBBI, MI.getDebugLoc(), TII->get(Opc)).getInstr();
645-
OriginalCall->addOperand(CallTarget);
646-
647-
unsigned RegMaskStartIdx = 1;
648-
// Skip register arguments. Those are added during ISel, but are not
649-
// needed for the concrete branch.
650-
while (!MI.getOperand(RegMaskStartIdx).isRegMask()) {
651-
assert(MI.getOperand(RegMaskStartIdx).isReg() &&
652-
"should only skip register operands");
653-
RegMaskStartIdx++;
654-
}
655-
for (; RegMaskStartIdx < MI.getNumOperands(); ++RegMaskStartIdx)
656-
OriginalCall->addOperand(MI.getOperand(RegMaskStartIdx));
657-
658-
auto *Marker = BuildMI(MBB, MBBI, MI.getDebugLoc(), TII->get(AArch64::ORRXrs))
659-
.addReg(AArch64::FP)
660-
.addReg(AArch64::XZR)
661-
.addReg(AArch64::FP)
662-
.addImm(0)
663-
.getInstr();
664-
if (MI.shouldUpdateCallSiteInfo())
665-
MBB.getParent()->moveCallSiteInfo(&MI, Marker);
666-
MI.eraseFromParent();
667-
finalizeBundle(MBB, OriginalCall->getIterator(),
668-
std::next(Marker->getIterator()));
669-
return true;
670-
}
671-
672630
/// If MBBI references a pseudo instruction that should be expanded here,
673631
/// do the expansion and return true. Otherwise return false.
674632
bool AArch64ExpandPseudo::expandMI(MachineBasicBlock &MBB,
@@ -1056,8 +1014,6 @@ bool AArch64ExpandPseudo::expandMI(MachineBasicBlock &MBB,
10561014
return expandSVESpillFill(MBB, MBBI, AArch64::LDR_ZXI, 3);
10571015
case AArch64::LDR_ZZXI:
10581016
return expandSVESpillFill(MBB, MBBI, AArch64::LDR_ZXI, 2);
1059-
case AArch64::BLR_RVMARKER:
1060-
return expandCALL_RVMARKER(MBB, MBBI);
10611017
}
10621018
return false;
10631019
}

llvm/lib/Target/AArch64/AArch64ISelLowering.cpp

Lines changed: 1 addition & 11 deletions
Original file line numberDiff line numberDiff line change
@@ -1934,7 +1934,6 @@ const char *AArch64TargetLowering::getTargetNodeName(unsigned Opcode) const {
19341934
MAKE_CASE(AArch64ISD::INDEX_VECTOR)
19351935
MAKE_CASE(AArch64ISD::UABD)
19361936
MAKE_CASE(AArch64ISD::SABD)
1937-
MAKE_CASE(AArch64ISD::CALL_RVMARKER)
19381937
}
19391938
#undef MAKE_CASE
19401939
return nullptr;
@@ -5540,17 +5539,8 @@ AArch64TargetLowering::LowerCall(CallLoweringInfo &CLI,
55405539
return Ret;
55415540
}
55425541

5543-
unsigned CallOpc = AArch64ISD::CALL;
5544-
// Calls marked with "rv_marker" are special. They should be expanded to the
5545-
// call, directly followed by a special marker sequence. Use the CALL_RVMARKER
5546-
// to do that.
5547-
if (CLI.CB && CLI.CB->hasRetAttr("rv_marker")) {
5548-
assert(!IsTailCall && "tail calls cannot be marked with rv_marker");
5549-
CallOpc = AArch64ISD::CALL_RVMARKER;
5550-
}
5551-
55525542
// Returns a chain and a flag for retval copy to use.
5553-
Chain = DAG.getNode(CallOpc, DL, NodeTys, Ops);
5543+
Chain = DAG.getNode(AArch64ISD::CALL, DL, NodeTys, Ops);
55545544
DAG.addNoMergeSiteInfo(Chain.getNode(), CLI.NoMerge);
55555545
InFlag = Chain.getValue(1);
55565546
DAG.addCallSiteInfo(Chain.getNode(), std::move(CSInfo));

llvm/lib/Target/AArch64/AArch64ISelLowering.h

Lines changed: 1 addition & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -417,11 +417,7 @@ enum NodeType : unsigned {
417417

418418
LDP,
419419
STP,
420-
STNP,
421-
422-
// Pseudo for a OBJC call that gets emitted together with a special `mov
423-
// x29, x29` marker instruction.
424-
CALL_RVMARKER
420+
STNP
425421
};
426422

427423
} // end namespace AArch64ISD

llvm/lib/Target/AArch64/AArch64InstrInfo.td

Lines changed: 0 additions & 12 deletions
Original file line numberDiff line numberDiff line change
@@ -399,12 +399,6 @@ def AArch64call : SDNode<"AArch64ISD::CALL",
399399
SDTypeProfile<0, -1, [SDTCisPtrTy<0>]>,
400400
[SDNPHasChain, SDNPOptInGlue, SDNPOutGlue,
401401
SDNPVariadic]>;
402-
403-
def AArch64call_rvmarker: SDNode<"AArch64ISD::CALL_RVMARKER",
404-
SDTypeProfile<0, -1, [SDTCisPtrTy<0>]>,
405-
[SDNPHasChain, SDNPOptInGlue, SDNPOutGlue,
406-
SDNPVariadic]>;
407-
408402
def AArch64brcond : SDNode<"AArch64ISD::BRCOND", SDT_AArch64Brcond,
409403
[SDNPHasChain]>;
410404
def AArch64cbz : SDNode<"AArch64ISD::CBZ", SDT_AArch64cbz,
@@ -2095,8 +2089,6 @@ let isCall = 1, Defs = [LR], Uses = [SP] in {
20952089
def BLRNoIP : Pseudo<(outs), (ins GPR64noip:$Rn), []>,
20962090
Sched<[WriteBrReg]>,
20972091
PseudoInstExpansion<(BLR GPR64:$Rn)>;
2098-
def BLR_RVMARKER : Pseudo<(outs), (ins variable_ops), []>,
2099-
Sched<[WriteBrReg]>;
21002092
} // isCall
21012093

21022094
def : Pat<(AArch64call GPR64:$Rn),
@@ -2106,10 +2098,6 @@ def : Pat<(AArch64call GPR64noip:$Rn),
21062098
(BLRNoIP GPR64noip:$Rn)>,
21072099
Requires<[SLSBLRMitigation]>;
21082100

2109-
def : Pat<(AArch64call_rvmarker GPR64:$Rn),
2110-
(BLR_RVMARKER GPR64:$Rn)>,
2111-
Requires<[NoSLSBLRMitigation]>;
2112-
21132101
let isBranch = 1, isTerminator = 1, isBarrier = 1, isIndirectBranch = 1 in {
21142102
def BR : BranchReg<0b0000, "br", [(brind GPR64:$Rn)]>;
21152103
} // isBranch, isTerminator, isBarrier, isIndirectBranch

llvm/test/CodeGen/AArch64/call-rv-marker.ll

Lines changed: 0 additions & 149 deletions
This file was deleted.

llvm/test/CodeGen/AArch64/expand-blr-rvmarker-pseudo.mir

Lines changed: 0 additions & 21 deletions
This file was deleted.

0 commit comments

Comments
 (0)