[llvm-commits] [llvm] r108955 - in /llvm/trunk/lib/Target/X86: X86MCInstLower.cpp X86MCInstLower.h
Chris Lattner
sabre at nondot.org
Tue Jul 20 15:45:33 PDT 2010
Author: lattner
Date: Tue Jul 20 17:45:33 2010
New Revision: 108955
URL: http://llvm.org/viewvc/llvm-project?rev=108955&view=rev
Log:
make asmprinter optional, even though passing in null will cause things to explode right now.
Modified:
llvm/trunk/lib/Target/X86/X86MCInstLower.cpp
llvm/trunk/lib/Target/X86/X86MCInstLower.h
Modified: llvm/trunk/lib/Target/X86/X86MCInstLower.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Target/X86/X86MCInstLower.cpp?rev=108955&r1=108954&r2=108955&view=diff
==============================================================================
--- llvm/trunk/lib/Target/X86/X86MCInstLower.cpp (original)
+++ llvm/trunk/lib/Target/X86/X86MCInstLower.cpp Tue Jul 20 17:45:33 2010
@@ -28,11 +28,10 @@
#include "llvm/Type.h"
using namespace llvm;
-X86MCInstLower::X86MCInstLower(MCContext &ctx, Mangler *mang,
- const MachineFunction &mf,
- X86AsmPrinter &asmprinter)
-: Ctx(ctx), Mang(mang), MF(mf), TM(mf.getTarget()), MAI(*TM.getMCAsmInfo()),
- AsmPrinter(asmprinter) {}
+X86MCInstLower::X86MCInstLower(Mangler *mang, const MachineFunction &mf,
+ X86AsmPrinter *asmprinter)
+: Ctx(mf.getContext()), Mang(mang), MF(mf), TM(mf.getTarget()),
+ MAI(*TM.getMCAsmInfo()), AsmPrinter(asmprinter) {}
MachineModuleInfoMachO &X86MCInstLower::getMachOMMI() const {
return MF.getMMI().getObjFileInfo<MachineModuleInfoMachO>();
@@ -182,7 +181,7 @@
// local labels. This is only safe when the symbols are in the same
// section so we are restricting it to jumptable references.
MCSymbol *Label = Ctx.CreateTempSymbol();
- AsmPrinter.OutStreamer.EmitAssignment(Label, Expr);
+ AsmPrinter->OutStreamer.EmitAssignment(Label, Expr);
Expr = MCSymbolRefExpr::Create(Label, Ctx);
}
break;
@@ -327,14 +326,14 @@
MCOp = LowerSymbolOperand(MO, GetSymbolFromOperand(MO));
break;
case MachineOperand::MO_JumpTableIndex:
- MCOp = LowerSymbolOperand(MO, AsmPrinter.GetJTISymbol(MO.getIndex()));
+ MCOp = LowerSymbolOperand(MO, AsmPrinter->GetJTISymbol(MO.getIndex()));
break;
case MachineOperand::MO_ConstantPoolIndex:
- MCOp = LowerSymbolOperand(MO, AsmPrinter.GetCPISymbol(MO.getIndex()));
+ MCOp = LowerSymbolOperand(MO, AsmPrinter->GetCPISymbol(MO.getIndex()));
break;
case MachineOperand::MO_BlockAddress:
MCOp = LowerSymbolOperand(MO,
- AsmPrinter.GetBlockAddressSymbol(MO.getBlockAddress()));
+ AsmPrinter->GetBlockAddressSymbol(MO.getBlockAddress()));
break;
}
@@ -505,7 +504,7 @@
void X86AsmPrinter::EmitInstruction(const MachineInstr *MI) {
- X86MCInstLower MCInstLowering(OutContext, Mang, *MF, *this);
+ X86MCInstLower MCInstLowering(Mang, *MF, this);
switch (MI->getOpcode()) {
case TargetOpcode::DBG_VALUE:
if (isVerbose() && OutStreamer.hasRawTextSupport()) {
Modified: llvm/trunk/lib/Target/X86/X86MCInstLower.h
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Target/X86/X86MCInstLower.h?rev=108955&r1=108954&r2=108955&view=diff
==============================================================================
--- llvm/trunk/lib/Target/X86/X86MCInstLower.h (original)
+++ llvm/trunk/lib/Target/X86/X86MCInstLower.h Tue Jul 20 17:45:33 2010
@@ -34,10 +34,12 @@
const TargetMachine &TM;
const MCAsmInfo &MAI;
- X86AsmPrinter &AsmPrinter;
+ /// AsmPrinter - This is the asmprinter when emission is actually happening,
+ /// or null if an instruction is being lowered for some other reason.
+ X86AsmPrinter *AsmPrinter;
public:
- X86MCInstLower(MCContext &ctx, Mangler *mang, const MachineFunction &MF,
- X86AsmPrinter &asmprinter);
+ X86MCInstLower(Mangler *mang, const MachineFunction &MF,
+ X86AsmPrinter *asmprinter);
void Lower(const MachineInstr *MI, MCInst &OutMI) const;
More information about the llvm-commits
mailing list