mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-10-20 19:42:54 +02:00
Print .frame via the target streamer.
llvm-svn: 200186
This commit is contained in:
parent
436aae7633
commit
3cc89c008e
@ -11,6 +11,7 @@
|
|||||||
//
|
//
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
#include "InstPrinter/MipsInstPrinter.h"
|
||||||
#include "MipsTargetStreamer.h"
|
#include "MipsTargetStreamer.h"
|
||||||
#include "MipsMCTargetDesc.h"
|
#include "MipsMCTargetDesc.h"
|
||||||
#include "llvm/MC/MCELF.h"
|
#include "llvm/MC/MCELF.h"
|
||||||
@ -85,6 +86,14 @@ void MipsTargetAsmStreamer::emitDirectiveOptionPic0() {
|
|||||||
OS << "\t.option\tpic0\n";
|
OS << "\t.option\tpic0\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void MipsTargetAsmStreamer::emitFrame(unsigned StackReg, unsigned StackSize,
|
||||||
|
unsigned ReturnReg) {
|
||||||
|
OS << "\t.frame\t$"
|
||||||
|
<< StringRef(MipsInstPrinter::getRegisterName(StackReg)).lower() << ","
|
||||||
|
<< StackSize << ",$"
|
||||||
|
<< StringRef(MipsInstPrinter::getRegisterName(ReturnReg)).lower();
|
||||||
|
}
|
||||||
|
|
||||||
// This part is for ELF object output.
|
// This part is for ELF object output.
|
||||||
MipsTargetELFStreamer::MipsTargetELFStreamer(MCStreamer &S,
|
MipsTargetELFStreamer::MipsTargetELFStreamer(MCStreamer &S,
|
||||||
const MCSubtargetInfo &STI)
|
const MCSubtargetInfo &STI)
|
||||||
@ -208,3 +217,8 @@ void MipsTargetELFStreamer::emitDirectiveOptionPic0() {
|
|||||||
Flags &= ~ELF::EF_MIPS_PIC;
|
Flags &= ~ELF::EF_MIPS_PIC;
|
||||||
MCA.setELFHeaderEFlags(Flags);
|
MCA.setELFHeaderEFlags(Flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void MipsTargetELFStreamer::emitFrame(unsigned StackReg, unsigned StackSize,
|
||||||
|
unsigned ReturnReg) {
|
||||||
|
// FIXME: implement.
|
||||||
|
}
|
||||||
|
@ -248,11 +248,7 @@ void MipsAsmPrinter::emitFrameDirective() {
|
|||||||
unsigned returnReg = RI.getRARegister();
|
unsigned returnReg = RI.getRARegister();
|
||||||
unsigned stackSize = MF->getFrameInfo()->getStackSize();
|
unsigned stackSize = MF->getFrameInfo()->getStackSize();
|
||||||
|
|
||||||
if (OutStreamer.hasRawTextSupport())
|
getTargetStreamer().emitFrame(stackReg, stackSize, returnReg);
|
||||||
OutStreamer.EmitRawText("\t.frame\t$" +
|
|
||||||
StringRef(MipsInstPrinter::getRegisterName(stackReg)).lower() +
|
|
||||||
"," + Twine(stackSize) + ",$" +
|
|
||||||
StringRef(MipsInstPrinter::getRegisterName(returnReg)).lower());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Emit Set directives.
|
/// Emit Set directives.
|
||||||
|
@ -35,6 +35,8 @@ public:
|
|||||||
virtual void emitDirectiveEnt(const MCSymbol &Symbol) = 0;
|
virtual void emitDirectiveEnt(const MCSymbol &Symbol) = 0;
|
||||||
virtual void emitDirectiveAbiCalls() = 0;
|
virtual void emitDirectiveAbiCalls() = 0;
|
||||||
virtual void emitDirectiveOptionPic0() = 0;
|
virtual void emitDirectiveOptionPic0() = 0;
|
||||||
|
virtual void emitFrame(unsigned StackReg, unsigned StackSize,
|
||||||
|
unsigned ReturnReg) = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
// This part is for ascii assembly output
|
// This part is for ascii assembly output
|
||||||
@ -59,6 +61,8 @@ public:
|
|||||||
virtual void emitDirectiveEnt(const MCSymbol &Symbol);
|
virtual void emitDirectiveEnt(const MCSymbol &Symbol);
|
||||||
virtual void emitDirectiveAbiCalls();
|
virtual void emitDirectiveAbiCalls();
|
||||||
virtual void emitDirectiveOptionPic0();
|
virtual void emitDirectiveOptionPic0();
|
||||||
|
virtual void emitFrame(unsigned StackReg, unsigned StackSize,
|
||||||
|
unsigned ReturnReg);
|
||||||
};
|
};
|
||||||
|
|
||||||
// This part is for ELF object output
|
// This part is for ELF object output
|
||||||
@ -88,6 +92,8 @@ public:
|
|||||||
virtual void emitDirectiveEnt(const MCSymbol &Symbol);
|
virtual void emitDirectiveEnt(const MCSymbol &Symbol);
|
||||||
virtual void emitDirectiveAbiCalls();
|
virtual void emitDirectiveAbiCalls();
|
||||||
virtual void emitDirectiveOptionPic0();
|
virtual void emitDirectiveOptionPic0();
|
||||||
|
virtual void emitFrame(unsigned StackReg, unsigned StackSize,
|
||||||
|
unsigned ReturnReg);
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user