Add basic CFI methods to the streamer interface.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@119972 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Rafael Espindola 2010-11-22 14:27:24 +00:00
parent 85bbff6c94
commit cdfecc8759
4 changed files with 133 additions and 7 deletions

View File

@ -352,6 +352,14 @@ namespace llvm {
unsigned Isa,
unsigned Discriminator);
virtual bool EmitCFIStartProc();
virtual bool EmitCFIEndProc();
virtual bool EmitCFIDefCfaOffset(int64_t Offset);
virtual bool EmitCFIDefCfaRegister(int64_t Register);
virtual bool EmitCFIOffset(int64_t Register, int64_t Offset);
virtual bool EmitCFIPersonality(const MCSymbol *Sym);
virtual bool EmitCFILsda(const MCSymbol *Sym);
/// EmitInstruction - Emit the given @p Instruction into the current
/// section.
virtual void EmitInstruction(const MCInst &Inst) = 0;

View File

@ -177,6 +177,14 @@ public:
unsigned Column, unsigned Flags,
unsigned Isa, unsigned Discriminator);
virtual bool EmitCFIStartProc();
virtual bool EmitCFIEndProc();
virtual bool EmitCFIDefCfaOffset(int64_t Offset);
virtual bool EmitCFIDefCfaRegister(int64_t Register);
virtual bool EmitCFIOffset(int64_t Register, int64_t Offset);
virtual bool EmitCFIPersonality(const MCSymbol *Sym);
virtual bool EmitCFILsda(const MCSymbol *Sym);
virtual void EmitInstruction(const MCInst &Inst);
/// EmitRawText - If this file is backed by an assembly streamer, this dumps
@ -702,6 +710,76 @@ void MCAsmStreamer::EmitDwarfLocDirective(unsigned FileNo, unsigned Line,
EmitEOL();
}
bool MCAsmStreamer::EmitCFIStartProc() {
if (this->MCStreamer::EmitCFIStartProc())
return true;
OS << ".cfi_startproc";
EmitEOL();
return false;
}
bool MCAsmStreamer::EmitCFIEndProc() {
if (this->MCStreamer::EmitCFIEndProc())
return true;
OS << ".cfi_endproc";
EmitEOL();
return false;
}
bool MCAsmStreamer::EmitCFIDefCfaOffset(int64_t Offset) {
if (this->MCStreamer::EmitCFIDefCfaOffset(Offset))
return true;
OS << ".cfi_def_cfa_offset " << Offset;
EmitEOL();
return false;
}
bool MCAsmStreamer::EmitCFIDefCfaRegister(int64_t Register) {
if (this->MCStreamer::EmitCFIDefCfaRegister(Register))
return true;
OS << ".cfi_def_cfa_register " << Register;
EmitEOL();
return false;
}
bool MCAsmStreamer::EmitCFIOffset(int64_t Register, int64_t Offset) {
if (this->MCStreamer::EmitCFIOffset(Register, Offset))
return true;
OS << ".cfi_offset " << Register << ", " << Offset;
EmitEOL();
return false;
}
bool MCAsmStreamer::EmitCFIPersonality(const MCSymbol *Sym) {
if (this->MCStreamer::EmitCFIPersonality(Sym))
return true;
OS << ".cfi_personality 0, " << *Sym;
EmitEOL();
return false;
}
bool MCAsmStreamer::EmitCFILsda(const MCSymbol *Sym) {
if (this->MCStreamer::EmitCFILsda(Sym))
return true;
OS << ".cfi_lsda 0, " << *Sym;
EmitEOL();
return false;
}
void MCAsmStreamer::AddEncodingComment(const MCInst &Inst) {
raw_ostream &OS = GetCommentOS();
SmallString<256> Code;

View File

@ -2151,13 +2151,13 @@ bool GenericAsmParser::ParseDirectiveStabs(StringRef Directive,
/// ::= .cfi_startproc
bool GenericAsmParser::ParseDirectiveCFIStartProc(StringRef,
SMLoc DirectiveLoc) {
return false;
return getStreamer().EmitCFIStartProc();
}
/// ParseDirectiveCFIEndProc
/// ::= .cfi_endproc
bool GenericAsmParser::ParseDirectiveCFIEndProc(StringRef, SMLoc DirectiveLoc) {
return false;
return getStreamer().EmitCFIEndProc();
}
/// ParseDirectiveCFIDefCfaOffset
@ -2168,7 +2168,7 @@ bool GenericAsmParser::ParseDirectiveCFIDefCfaOffset(StringRef,
if (getParser().ParseAbsoluteExpression(Offset))
return true;
return false;
return getStreamer().EmitCFIDefCfaOffset(Offset);
}
/// ParseDirectiveCFIDefCfaRegister
@ -2178,7 +2178,8 @@ bool GenericAsmParser::ParseDirectiveCFIDefCfaRegister(StringRef,
int64_t Register = 0;
if (getParser().ParseAbsoluteExpression(Register))
return true;
return false;
return getStreamer().EmitCFIDefCfaRegister(Register);
}
/// ParseDirectiveCFIOffset
@ -2196,13 +2197,13 @@ bool GenericAsmParser::ParseDirectiveCFIOffset(StringRef, SMLoc DirectiveLoc) {
if (getParser().ParseAbsoluteExpression(Offset))
return true;
return false;
return getStreamer().EmitCFIOffset(Register, Offset);
}
/// ParseDirectiveCFIPersonalityOrLsda
/// ::= .cfi_personality encoding, [symbol_name]
/// ::= .cfi_lsda encoding, [symbol_name]
bool GenericAsmParser::ParseDirectiveCFIPersonalityOrLsda(StringRef,
bool GenericAsmParser::ParseDirectiveCFIPersonalityOrLsda(StringRef IDVal,
SMLoc DirectiveLoc) {
int64_t Encoding = 0;
if (getParser().ParseAbsoluteExpression(Encoding))
@ -2210,6 +2211,9 @@ bool GenericAsmParser::ParseDirectiveCFIPersonalityOrLsda(StringRef,
if (Encoding == 255)
return false;
if (Encoding != 0)
return TokError("unsupported encoding.");
if (getLexer().isNot(AsmToken::Comma))
return TokError("unexpected token in directive");
Lex();
@ -2217,7 +2221,15 @@ bool GenericAsmParser::ParseDirectiveCFIPersonalityOrLsda(StringRef,
StringRef Name;
if (getParser().ParseIdentifier(Name))
return TokError("expected identifier in directive");
return false;
MCSymbol *Sym = getContext().GetOrCreateSymbol(Name);
if (IDVal == ".cfi_personality")
return getStreamer().EmitCFIPersonality(Sym);
else {
assert(IDVal == ".cfi_lsda");
return getStreamer().EmitCFILsda(Sym);
}
}
/// ParseDirectiveMacrosOnOff

View File

@ -77,6 +77,34 @@ void MCStreamer::EmitDwarfLocDirective(unsigned FileNo, unsigned Line,
Discriminator);
}
bool MCStreamer::EmitCFIStartProc() {
return false;
}
bool MCStreamer::EmitCFIEndProc() {
return false;
}
bool MCStreamer::EmitCFIDefCfaOffset(int64_t Offset) {
return false;
}
bool MCStreamer::EmitCFIDefCfaRegister(int64_t Register) {
return false;
}
bool MCStreamer::EmitCFIOffset(int64_t Register, int64_t Offset) {
return false;
}
bool MCStreamer::EmitCFIPersonality(const MCSymbol *Sym) {
return false;
}
bool MCStreamer::EmitCFILsda(const MCSymbol *Sym) {
return false;
}
/// EmitRawText - If this file is backed by an assembly streamer, this dumps
/// the specified string in the output .s file. This capability is
/// indicated by the hasRawTextSupport() predicate.