forked from OSchip/llvm-project
Print debug info attached with an instruction.
llvm-svn: 82075
This commit is contained in:
parent
5d8cfb217c
commit
dec23fd825
|
@ -312,9 +312,11 @@ public:
|
||||||
/// ID values are 1 or higher. This ID is set by RegisterMDKind.
|
/// ID values are 1 or higher. This ID is set by RegisterMDKind.
|
||||||
typedef unsigned MDKindID;
|
typedef unsigned MDKindID;
|
||||||
class Metadata {
|
class Metadata {
|
||||||
private:
|
public:
|
||||||
typedef std::pair<MDKindID, WeakVH> MDPairTy;
|
typedef std::pair<MDKindID, WeakVH> MDPairTy;
|
||||||
typedef SmallVector<MDPairTy, 2> MDMapTy;
|
typedef SmallVector<MDPairTy, 2> MDMapTy;
|
||||||
|
|
||||||
|
private:
|
||||||
typedef DenseMap<const Instruction *, MDMapTy> MDStoreTy;
|
typedef DenseMap<const Instruction *, MDMapTy> MDStoreTy;
|
||||||
|
|
||||||
/// MetadataStore - Collection of metadata used in this context.
|
/// MetadataStore - Collection of metadata used in this context.
|
||||||
|
@ -324,7 +326,6 @@ private:
|
||||||
StringMap<unsigned> MDHandlerNames;
|
StringMap<unsigned> MDHandlerNames;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
/// RegisterMDKind - Register a new metadata kind and return its ID.
|
/// RegisterMDKind - Register a new metadata kind and return its ID.
|
||||||
/// A metadata kind can be registered only once.
|
/// A metadata kind can be registered only once.
|
||||||
MDKindID RegisterMDKind(const char *Name);
|
MDKindID RegisterMDKind(const char *Name);
|
||||||
|
@ -337,6 +338,9 @@ public:
|
||||||
/// If the metadata is not found then return 0.
|
/// If the metadata is not found then return 0.
|
||||||
MDNode *getMD(MDKindID Kind, const Instruction *Inst);
|
MDNode *getMD(MDKindID Kind, const Instruction *Inst);
|
||||||
|
|
||||||
|
/// getMDs - Get the metadata attached with an Instruction.
|
||||||
|
const MDMapTy *getMDs(const Instruction *Inst);
|
||||||
|
|
||||||
/// setMD - Attach the metadata of given kind with an Instruction.
|
/// setMD - Attach the metadata of given kind with an Instruction.
|
||||||
void setMD(MDKindID Kind, MDNode *Node, Instruction *Inst);
|
void setMD(MDKindID Kind, MDNode *Node, Instruction *Inst);
|
||||||
|
|
||||||
|
|
|
@ -678,6 +678,8 @@ void SlotTracker::processFunction() {
|
||||||
|
|
||||||
ST_DEBUG("Inserting Instructions:\n");
|
ST_DEBUG("Inserting Instructions:\n");
|
||||||
|
|
||||||
|
Metadata &TheMetadata = TheFunction->getContext().getMetadata();
|
||||||
|
|
||||||
// Add all of the basic blocks and instructions with no names.
|
// Add all of the basic blocks and instructions with no names.
|
||||||
for (Function::const_iterator BB = TheFunction->begin(),
|
for (Function::const_iterator BB = TheFunction->begin(),
|
||||||
E = TheFunction->end(); BB != E; ++BB) {
|
E = TheFunction->end(); BB != E; ++BB) {
|
||||||
|
@ -691,6 +693,14 @@ void SlotTracker::processFunction() {
|
||||||
for (unsigned i = 0, e = I->getNumOperands(); i != e; ++i)
|
for (unsigned i = 0, e = I->getNumOperands(); i != e; ++i)
|
||||||
if (MDNode *N = dyn_cast_or_null<MDNode>(I->getOperand(i)))
|
if (MDNode *N = dyn_cast_or_null<MDNode>(I->getOperand(i)))
|
||||||
CreateMetadataSlot(N);
|
CreateMetadataSlot(N);
|
||||||
|
|
||||||
|
// Process metadata attached with this instruction.
|
||||||
|
const Metadata::MDMapTy *MDs = TheMetadata.getMDs(I);
|
||||||
|
if (MDs)
|
||||||
|
for (Metadata::MDMapTy::const_iterator MI = MDs->begin(),
|
||||||
|
ME = MDs->end(); MI != ME; ++MI)
|
||||||
|
if (MDNode *MDN = dyn_cast_or_null<MDNode>(MI->second))
|
||||||
|
CreateMetadataSlot(MDN);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1255,6 +1265,7 @@ class AssemblyWriter {
|
||||||
// Each MDNode is assigned unique MetadataIDNo.
|
// Each MDNode is assigned unique MetadataIDNo.
|
||||||
std::map<const MDNode *, unsigned> MDNodes;
|
std::map<const MDNode *, unsigned> MDNodes;
|
||||||
unsigned MetadataIDNo;
|
unsigned MetadataIDNo;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
inline AssemblyWriter(formatted_raw_ostream &o, SlotTracker &Mac,
|
inline AssemblyWriter(formatted_raw_ostream &o, SlotTracker &Mac,
|
||||||
const Module *M,
|
const Module *M,
|
||||||
|
@ -1979,6 +1990,11 @@ void AssemblyWriter::printInstruction(const Instruction &I) {
|
||||||
Out << ", align " << cast<StoreInst>(I).getAlignment();
|
Out << ", align " << cast<StoreInst>(I).getAlignment();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Print DebugInfo
|
||||||
|
Metadata &TheMetadata = I.getContext().getMetadata();
|
||||||
|
unsigned MDDbgKind = TheMetadata.getMDKind("dbg");
|
||||||
|
if (const MDNode *Dbg = TheMetadata.getMD(MDDbgKind, &I))
|
||||||
|
Out << ", dbg !" << Machine.getMetadataSlot(Dbg);
|
||||||
printInfoComment(I);
|
printInfoComment(I);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -308,6 +308,15 @@ MDNode *Metadata::getMD(MDKindID MDKind, const Instruction *Inst) {
|
||||||
return Node;
|
return Node;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// getMDs - Get the metadata attached with an Instruction.
|
||||||
|
const Metadata::MDMapTy *Metadata::getMDs(const Instruction *Inst) {
|
||||||
|
MDStoreTy::iterator I = MetadataStore.find(Inst);
|
||||||
|
if (I == MetadataStore.end())
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
return &(I->second);
|
||||||
|
}
|
||||||
|
|
||||||
/// ValueIsDeleted - This handler is used to update metadata store
|
/// ValueIsDeleted - This handler is used to update metadata store
|
||||||
/// when a value is deleted.
|
/// when a value is deleted.
|
||||||
void Metadata::ValueIsDeleted(const Instruction *Inst) {
|
void Metadata::ValueIsDeleted(const Instruction *Inst) {
|
||||||
|
|
Loading…
Reference in New Issue