mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-04-09 16:45:03 +00:00
Factor some code to needsCFIMoves. Avoid printing moves when we don't have to.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@130501 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
ce3a022b8c
commit
a432997745
@ -185,6 +185,8 @@ namespace llvm {
|
||||
|
||||
void emitPrologLabel(const MachineInstr &MI);
|
||||
|
||||
bool needsCFIMoves();
|
||||
|
||||
/// EmitConstantPool - Print to the current output stream assembly
|
||||
/// representations of the constants in the constant pool MCP. This is
|
||||
/// used to print out constants which have been "spilled to memory" by
|
||||
|
@ -38,6 +38,7 @@
|
||||
#include "llvm/Target/TargetInstrInfo.h"
|
||||
#include "llvm/Target/TargetLowering.h"
|
||||
#include "llvm/Target/TargetLoweringObjectFile.h"
|
||||
#include "llvm/Target/TargetOptions.h"
|
||||
#include "llvm/Target/TargetRegisterInfo.h"
|
||||
#include "llvm/Assembly/Writer.h"
|
||||
#include "llvm/ADT/SmallString.h"
|
||||
@ -591,6 +592,19 @@ static bool EmitDebugValueComment(const MachineInstr *MI, AsmPrinter &AP) {
|
||||
return true;
|
||||
}
|
||||
|
||||
bool AsmPrinter::needsCFIMoves() {
|
||||
if (UnwindTablesMandatory)
|
||||
return true;
|
||||
|
||||
if (MMI->hasDebugInfo() && !MAI->doesDwarfRequireFrameSection())
|
||||
return true;
|
||||
|
||||
if (MF->getFunction()->doesNotThrow())
|
||||
return false;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
void AsmPrinter::emitPrologLabel(const MachineInstr &MI) {
|
||||
MCSymbol *Label = MI.getOperand(0).getMCSymbol();
|
||||
|
||||
@ -601,8 +615,10 @@ void AsmPrinter::emitPrologLabel(const MachineInstr &MI) {
|
||||
if (MAI->getExceptionHandlingType() != ExceptionHandling::DwarfCFI)
|
||||
return;
|
||||
|
||||
const MachineFunction &MF = *MI.getParent()->getParent();
|
||||
MachineModuleInfo &MMI = MF.getMMI();
|
||||
if (!needsCFIMoves())
|
||||
return;
|
||||
|
||||
MachineModuleInfo &MMI = MF->getMMI();
|
||||
std::vector<MachineMove> &Moves = MMI.getFrameMoves();
|
||||
bool FoundOne = false;
|
||||
(void)FoundOne;
|
||||
|
@ -78,8 +78,7 @@ void DwarfCFIException::BeginFunction(const MachineFunction *MF) {
|
||||
shouldEmitTable = !MMI->getLandingPads().empty();
|
||||
|
||||
// See if we need frame move info.
|
||||
shouldEmitMoves = MMI->hasDebugInfo() ||
|
||||
!Asm->MF->getFunction()->doesNotThrow() || UnwindTablesMandatory;
|
||||
shouldEmitMoves = Asm->needsCFIMoves();
|
||||
|
||||
if (shouldEmitMoves || shouldEmitTable)
|
||||
// Assumes in correct section after the entry point.
|
||||
|
Loading…
x
Reference in New Issue
Block a user