| //===- lib/MC/MCLoggingStreamer.cpp - API Logging Streamer ----------------===// |
| // |
| // The LLVM Compiler Infrastructure |
| // |
| // This file is distributed under the University of Illinois Open Source |
| // License. See LICENSE.TXT for details. |
| // |
| //===----------------------------------------------------------------------===// |
| |
| #include "llvm/MC/MCStreamer.h" |
| #include "llvm/ADT/OwningPtr.h" |
| #include "llvm/ADT/Twine.h" |
| #include "llvm/Support/raw_ostream.h" |
| using namespace llvm; |
| |
| namespace { |
| |
| class MCLoggingStreamer : public MCStreamer { |
| llvm::OwningPtr<MCStreamer> Child; |
| |
| raw_ostream &OS; |
| |
| public: |
| MCLoggingStreamer(MCStreamer *_Child, raw_ostream &_OS) |
| : MCStreamer(_Child->getContext()), Child(_Child), OS(_OS) {} |
| |
| void LogCall(const char *Function) { |
| OS << Function << "\n"; |
| } |
| |
| void LogCall(const char *Function, const Twine &Message) { |
| OS << Function << ": " << Message << "\n"; |
| } |
| |
| virtual bool isVerboseAsm() const { return Child->isVerboseAsm(); } |
| |
| virtual bool hasRawTextSupport() const { return Child->hasRawTextSupport(); } |
| |
| virtual raw_ostream &GetCommentOS() { return Child->GetCommentOS(); } |
| |
| virtual void AddComment(const Twine &T) { |
| LogCall("AddComment", T); |
| return Child->AddComment(T); |
| } |
| |
| virtual void AddBlankLine() { |
| LogCall("AddBlankLine"); |
| return Child->AddBlankLine(); |
| } |
| |
| virtual void SwitchSection(const MCSection *Section) { |
| CurSection = Section; |
| LogCall("SwitchSection"); |
| return Child->SwitchSection(Section); |
| } |
| |
| virtual void InitSections() { |
| LogCall("InitSections"); |
| return Child->InitSections(); |
| } |
| |
| virtual void EmitLabel(MCSymbol *Symbol) { |
| LogCall("EmitLabel"); |
| return Child->EmitLabel(Symbol); |
| } |
| |
| virtual void EmitAssemblerFlag(MCAssemblerFlag Flag) { |
| LogCall("EmitAssemblerFlag"); |
| return Child->EmitAssemblerFlag(Flag); |
| } |
| |
| virtual void EmitThumbFunc(MCSymbol *Func) { |
| LogCall("EmitThumbFunc"); |
| return Child->EmitThumbFunc(Func); |
| } |
| |
| virtual void EmitAssignment(MCSymbol *Symbol, const MCExpr *Value) { |
| LogCall("EmitAssignment"); |
| return Child->EmitAssignment(Symbol, Value); |
| } |
| |
| virtual void EmitWeakReference(MCSymbol *Alias, const MCSymbol *Symbol) { |
| LogCall("EmitWeakReference"); |
| return Child->EmitWeakReference(Alias, Symbol); |
| } |
| |
| virtual void EmitDwarfAdvanceLineAddr(int64_t LineDelta, |
| const MCSymbol *LastLabel, |
| const MCSymbol *Label) { |
| LogCall("EmitDwarfAdvanceLineAddr"); |
| return Child->EmitDwarfAdvanceLineAddr(LineDelta, LastLabel, Label); |
| } |
| |
| virtual void EmitSymbolAttribute(MCSymbol *Symbol, MCSymbolAttr Attribute) { |
| LogCall("EmitSymbolAttribute"); |
| return Child->EmitSymbolAttribute(Symbol, Attribute); |
| } |
| |
| virtual void EmitSymbolDesc(MCSymbol *Symbol, unsigned DescValue) { |
| LogCall("EmitSymbolDesc"); |
| return Child->EmitSymbolDesc(Symbol, DescValue); |
| } |
| |
| virtual void BeginCOFFSymbolDef(const MCSymbol *Symbol) { |
| LogCall("BeginCOFFSymbolDef"); |
| return Child->BeginCOFFSymbolDef(Symbol); |
| } |
| |
| virtual void EmitCOFFSymbolStorageClass(int StorageClass) { |
| LogCall("EmitCOFFSymbolStorageClass"); |
| return Child->EmitCOFFSymbolStorageClass(StorageClass); |
| } |
| |
| virtual void EmitCOFFSymbolType(int Type) { |
| LogCall("EmitCOFFSymbolType"); |
| return Child->EmitCOFFSymbolType(Type); |
| } |
| |
| virtual void EndCOFFSymbolDef() { |
| LogCall("EndCOFFSymbolDef"); |
| return Child->EndCOFFSymbolDef(); |
| } |
| |
| virtual void EmitELFSize(MCSymbol *Symbol, const MCExpr *Value) { |
| LogCall("EmitELFSize"); |
| return Child->EmitELFSize(Symbol, Value); |
| } |
| |
| virtual void EmitCommonSymbol(MCSymbol *Symbol, uint64_t Size, |
| unsigned ByteAlignment) { |
| LogCall("EmitCommonSymbol"); |
| return Child->EmitCommonSymbol(Symbol, Size, ByteAlignment); |
| } |
| |
| virtual void EmitLocalCommonSymbol(MCSymbol *Symbol, uint64_t Size) { |
| LogCall("EmitLocalCommonSymbol"); |
| return Child->EmitLocalCommonSymbol(Symbol, Size); |
| } |
| |
| virtual void EmitZerofill(const MCSection *Section, MCSymbol *Symbol = 0, |
| unsigned Size = 0, unsigned ByteAlignment = 0) { |
| LogCall("EmitZerofill"); |
| return Child->EmitZerofill(Section, Symbol, Size, ByteAlignment); |
| } |
| |
| virtual void EmitTBSSSymbol (const MCSection *Section, MCSymbol *Symbol, |
| uint64_t Size, unsigned ByteAlignment = 0) { |
| LogCall("EmitTBSSSymbol"); |
| return Child->EmitTBSSSymbol(Section, Symbol, Size, ByteAlignment); |
| } |
| |
| virtual void EmitBytes(StringRef Data, unsigned AddrSpace) { |
| LogCall("EmitBytes"); |
| return Child->EmitBytes(Data, AddrSpace); |
| } |
| |
| virtual void EmitValueImpl(const MCExpr *Value, unsigned Size, |
| bool isPCRel, unsigned AddrSpace){ |
| LogCall("EmitValue"); |
| return Child->EmitValueImpl(Value, Size, isPCRel, AddrSpace); |
| } |
| |
| virtual void EmitULEB128Value(const MCExpr *Value, |
| unsigned AddrSpace = 0) { |
| LogCall("EmitULEB128Value"); |
| return Child->EmitULEB128Value(Value, AddrSpace); |
| } |
| |
| virtual void EmitSLEB128Value(const MCExpr *Value, |
| unsigned AddrSpace = 0) { |
| LogCall("EmitSLEB128Value"); |
| return Child->EmitSLEB128Value(Value, AddrSpace); |
| } |
| |
| virtual void EmitGPRel32Value(const MCExpr *Value) { |
| LogCall("EmitGPRel32Value"); |
| return Child->EmitGPRel32Value(Value); |
| } |
| |
| virtual void EmitFill(uint64_t NumBytes, uint8_t FillValue, |
| unsigned AddrSpace) { |
| LogCall("EmitFill"); |
| return Child->EmitFill(NumBytes, FillValue, AddrSpace); |
| } |
| |
| virtual void EmitValueToAlignment(unsigned ByteAlignment, int64_t Value = 0, |
| unsigned ValueSize = 1, |
| unsigned MaxBytesToEmit = 0) { |
| LogCall("EmitValueToAlignment"); |
| return Child->EmitValueToAlignment(ByteAlignment, Value, |
| ValueSize, MaxBytesToEmit); |
| } |
| |
| virtual void EmitCodeAlignment(unsigned ByteAlignment, |
| unsigned MaxBytesToEmit = 0) { |
| LogCall("EmitCodeAlignment"); |
| return Child->EmitCodeAlignment(ByteAlignment, MaxBytesToEmit); |
| } |
| |
| virtual void EmitValueToOffset(const MCExpr *Offset, |
| unsigned char Value = 0) { |
| LogCall("EmitValueToOffset"); |
| return Child->EmitValueToOffset(Offset, Value); |
| } |
| |
| virtual void EmitFileDirective(StringRef Filename) { |
| LogCall("EmitFileDirective", "FileName:" + Filename); |
| return Child->EmitFileDirective(Filename); |
| } |
| |
| virtual bool EmitDwarfFileDirective(unsigned FileNo, StringRef Filename) { |
| LogCall("EmitDwarfFileDirective", |
| "FileNo:" + Twine(FileNo) + " Filename:" + Filename); |
| return Child->EmitDwarfFileDirective(FileNo, Filename); |
| } |
| |
| virtual void EmitDwarfLocDirective(unsigned FileNo, unsigned Line, |
| unsigned Column, unsigned Flags, |
| unsigned Isa, unsigned Discriminator) { |
| LogCall("EmitDwarfLocDirective", |
| "FileNo:" + Twine(FileNo) + " Line:" + Twine(Line) + |
| " Column:" + Twine(Column) + " Flags:" + Twine(Flags) + |
| " Isa:" + Twine(Isa) + " Discriminator:" + Twine(Discriminator)); |
| return Child->EmitDwarfLocDirective(FileNo, Line, Column, Flags, |
| Isa, Discriminator); |
| } |
| |
| virtual void EmitInstruction(const MCInst &Inst) { |
| LogCall("EmitInstruction"); |
| return Child->EmitInstruction(Inst); |
| } |
| |
| virtual void EmitRawText(StringRef String) { |
| LogCall("EmitRawText", "\"" + String + "\""); |
| return Child->EmitRawText(String); |
| } |
| |
| virtual void Finish() { |
| LogCall("Finish"); |
| return Child->Finish(); |
| } |
| |
| }; |
| |
| } // end anonymous namespace. |
| |
| MCStreamer *llvm::createLoggingStreamer(MCStreamer *Child, raw_ostream &OS) { |
| return new MCLoggingStreamer(Child, OS); |
| } |