-
Notifications
You must be signed in to change notification settings - Fork 12.4k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[RISCV] Insert simple landing pad before indirect jumps for Zicfilp. (#…
…91860) This patch is based on #91855. This patch inserts simple landing pad ([pr])before indirct jumps. And this also make option riscv-landing-pad-label influence this feature. [pr]: riscv-non-isa/riscv-elf-psabi-doc#417
- Loading branch information
Showing
8 changed files
with
275 additions
and
5 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,89 @@ | ||
//===------------ RISCVLandingPadSetup.cpp ---------------------------------==// | ||
// | ||
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. | ||
// See https://llvm.org/LICENSE.txt for license information. | ||
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception | ||
// | ||
//===----------------------------------------------------------------------===// | ||
// | ||
// This is a RISC-V pass to setup landing pad labels for indirect jumps. | ||
// Currently this pass only supports fixed labels. | ||
// | ||
//===----------------------------------------------------------------------===// | ||
|
||
#include "RISCV.h" | ||
#include "RISCVInstrInfo.h" | ||
#include "RISCVSubtarget.h" | ||
#include "llvm/CodeGen/MachineFunctionPass.h" | ||
#include "llvm/CodeGen/MachineInstrBuilder.h" | ||
#include "llvm/InitializePasses.h" | ||
|
||
using namespace llvm; | ||
|
||
#define DEBUG_TYPE "riscv-lpad-setup" | ||
#define PASS_NAME "RISC-V Landing Pad Setup" | ||
|
||
extern cl::opt<uint32_t> PreferredLandingPadLabel; | ||
|
||
namespace { | ||
|
||
class RISCVLandingPadSetup : public MachineFunctionPass { | ||
public: | ||
static char ID; | ||
|
||
RISCVLandingPadSetup() : MachineFunctionPass(ID) {} | ||
|
||
bool runOnMachineFunction(MachineFunction &F) override; | ||
|
||
StringRef getPassName() const override { return PASS_NAME; } | ||
|
||
void getAnalysisUsage(AnalysisUsage &AU) const override { | ||
AU.setPreservesCFG(); | ||
MachineFunctionPass::getAnalysisUsage(AU); | ||
} | ||
}; | ||
|
||
} // end anonymous namespace | ||
|
||
bool RISCVLandingPadSetup::runOnMachineFunction(MachineFunction &MF) { | ||
const auto &STI = MF.getSubtarget<RISCVSubtarget>(); | ||
const RISCVInstrInfo &TII = *STI.getInstrInfo(); | ||
|
||
if (!STI.hasStdExtZicfilp()) | ||
return false; | ||
|
||
uint32_t Label = 0; | ||
if (PreferredLandingPadLabel.getNumOccurrences() > 0) { | ||
if (!isUInt<20>(PreferredLandingPadLabel)) | ||
report_fatal_error("riscv-landing-pad-label=<val>, <val> needs to fit in " | ||
"unsigned 20-bits"); | ||
Label = PreferredLandingPadLabel; | ||
} | ||
|
||
// Zicfilp does not check X7 if landing pad label is zero. | ||
if (Label == 0) | ||
return false; | ||
|
||
bool Changed = false; | ||
for (MachineBasicBlock &MBB : MF) | ||
for (MachineInstr &MI : llvm::make_early_inc_range(MBB)) { | ||
if (MI.getOpcode() != RISCV::PseudoBRINDNonX7 && | ||
MI.getOpcode() != RISCV::PseudoCALLIndirectNonX7 && | ||
MI.getOpcode() != RISCV::PseudoTAILIndirectNonX7) | ||
continue; | ||
BuildMI(MBB, MI, MI.getDebugLoc(), TII.get(RISCV::LUI), RISCV::X7) | ||
.addImm(Label); | ||
MachineInstrBuilder(MF, &MI).addUse(RISCV::X7, RegState::ImplicitKill); | ||
Changed = true; | ||
} | ||
|
||
return Changed; | ||
} | ||
|
||
INITIALIZE_PASS(RISCVLandingPadSetup, DEBUG_TYPE, PASS_NAME, false, false) | ||
|
||
char RISCVLandingPadSetup::ID = 0; | ||
|
||
FunctionPass *llvm::createRISCVLandingPadSetupPass() { | ||
return new RISCVLandingPadSetup(); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters