mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-02-08 21:32:39 +00:00
ValueEnumerator - debug dump().
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@146070 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
bd15090aa2
commit
4e6c03fc3d
@ -19,6 +19,8 @@
|
|||||||
#include "llvm/Module.h"
|
#include "llvm/Module.h"
|
||||||
#include "llvm/ValueSymbolTable.h"
|
#include "llvm/ValueSymbolTable.h"
|
||||||
#include "llvm/Instructions.h"
|
#include "llvm/Instructions.h"
|
||||||
|
#include "llvm/Support/Debug.h"
|
||||||
|
#include "llvm/Support/raw_ostream.h"
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
using namespace llvm;
|
using namespace llvm;
|
||||||
|
|
||||||
@ -107,7 +109,6 @@ ValueEnumerator::ValueEnumerator(const Module *M) {
|
|||||||
OptimizeConstants(FirstConstant, Values.size());
|
OptimizeConstants(FirstConstant, Values.size());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
unsigned ValueEnumerator::getInstructionID(const Instruction *Inst) const {
|
unsigned ValueEnumerator::getInstructionID(const Instruction *Inst) const {
|
||||||
InstructionMapType::const_iterator I = InstructionMap.find(Inst);
|
InstructionMapType::const_iterator I = InstructionMap.find(Inst);
|
||||||
assert(I != InstructionMap.end() && "Instruction is not mapped!");
|
assert(I != InstructionMap.end() && "Instruction is not mapped!");
|
||||||
@ -130,6 +131,43 @@ unsigned ValueEnumerator::getValueID(const Value *V) const {
|
|||||||
return I->second-1;
|
return I->second-1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void ValueEnumerator::dump() const {
|
||||||
|
print(dbgs(), ValueMap, "Default");
|
||||||
|
dbgs() << '\n';
|
||||||
|
print(dbgs(), MDValueMap, "MetaData");
|
||||||
|
dbgs() << '\n';
|
||||||
|
}
|
||||||
|
|
||||||
|
void ValueEnumerator::print(raw_ostream &OS, const ValueMapType &Map,
|
||||||
|
const char *Name) const {
|
||||||
|
|
||||||
|
OS << "Map Name: " << Name << "\n";
|
||||||
|
OS << "Size: " << Map.size() << "\n";
|
||||||
|
for (ValueMapType::const_iterator I = Map.begin(),
|
||||||
|
E = Map.end(); I != E; ++I) {
|
||||||
|
|
||||||
|
const Value *V = I->first;
|
||||||
|
if (V->hasName())
|
||||||
|
OS << "Value: " << V->getName();
|
||||||
|
else
|
||||||
|
OS << "Value: [null]\n";
|
||||||
|
V->dump();
|
||||||
|
|
||||||
|
OS << " Uses(" << std::distance(V->use_begin(),V->use_end()) << "):";
|
||||||
|
for (Value::const_use_iterator UI = V->use_begin(), UE = V->use_end();
|
||||||
|
UI != UE; ++UI) {
|
||||||
|
if (UI != V->use_begin())
|
||||||
|
OS << ",";
|
||||||
|
if((*UI)->hasName())
|
||||||
|
OS << " " << (*UI)->getName();
|
||||||
|
else
|
||||||
|
OS << " [null]";
|
||||||
|
|
||||||
|
}
|
||||||
|
OS << "\n\n";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Optimize constant ordering.
|
// Optimize constant ordering.
|
||||||
namespace {
|
namespace {
|
||||||
struct CstSortPredicate {
|
struct CstSortPredicate {
|
||||||
|
@ -32,6 +32,7 @@ class NamedMDNode;
|
|||||||
class AttrListPtr;
|
class AttrListPtr;
|
||||||
class ValueSymbolTable;
|
class ValueSymbolTable;
|
||||||
class MDSymbolTable;
|
class MDSymbolTable;
|
||||||
|
class raw_ostream;
|
||||||
|
|
||||||
class ValueEnumerator {
|
class ValueEnumerator {
|
||||||
public:
|
public:
|
||||||
@ -83,6 +84,9 @@ private:
|
|||||||
public:
|
public:
|
||||||
ValueEnumerator(const Module *M);
|
ValueEnumerator(const Module *M);
|
||||||
|
|
||||||
|
void dump() const;
|
||||||
|
void print(raw_ostream &OS, const ValueMapType &Map, const char *Name) const;
|
||||||
|
|
||||||
unsigned getValueID(const Value *V) const;
|
unsigned getValueID(const Value *V) const;
|
||||||
|
|
||||||
unsigned getTypeID(Type *T) const {
|
unsigned getTypeID(Type *T) const {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user