Eliminate using declarations

llvm-svn: 9543
This commit is contained in:
Chris Lattner 2003-10-27 21:44:09 +00:00
parent 5e004e8ce0
commit 233989316c
1 changed files with 26 additions and 25 deletions

View File

@ -25,22 +25,20 @@
#include "Support/StringExtras.h" #include "Support/StringExtras.h"
#include <algorithm> #include <algorithm>
#include <sstream> #include <sstream>
using std::vector;
using std::string;
static cl::opt<bool> static cl::opt<bool>
DisablePtrHashing("tracedisablehashdisable", cl::Hidden, DisablePtrHashing("tracedisablehashdisable", cl::Hidden,
cl::desc("Disable pointer hashing in the -trace or -tracem " cl::desc("Disable pointer hashing in the -trace or -tracem "
"passes")); "passes"));
static cl::list<string> static cl::list<std::string>
TraceFuncNames("tracefunc", cl::desc("Only trace specific functions in the " TraceFuncNames("tracefunc", cl::desc("Only trace specific functions in the "
"-trace or -tracem passes"), "-trace or -tracem passes"),
cl::value_desc("function"), cl::Hidden); cl::value_desc("function"), cl::Hidden);
static void TraceValuesAtBBExit(BasicBlock *BB, static void TraceValuesAtBBExit(BasicBlock *BB,
Function *Printf, Function* HashPtrToSeqNum, Function *Printf, Function* HashPtrToSeqNum,
vector<Instruction*> *valuesStoredInFunction); std::vector<Instruction*> *valuesStoredInFunction);
// We trace a particular function if no functions to trace were specified // We trace a particular function if no functions to trace were specified
// or if the function is in the specified list. // or if the function is in the specified list.
@ -79,7 +77,8 @@ namespace {
// //
bool doit(Function *M); bool doit(Function *M);
virtual void handleBasicBlock(BasicBlock *BB, vector<Instruction*> &VI) = 0; virtual void handleBasicBlock(BasicBlock *BB,
std::vector<Instruction*> &VI) = 0;
// runOnFunction - This method does the work. // runOnFunction - This method does the work.
// //
@ -92,12 +91,14 @@ namespace {
struct FunctionTracer : public InsertTraceCode { struct FunctionTracer : public InsertTraceCode {
// Ignore basic blocks here... // Ignore basic blocks here...
virtual void handleBasicBlock(BasicBlock *BB, vector<Instruction*> &VI) {} virtual void handleBasicBlock(BasicBlock *BB,
std::vector<Instruction*> &VI) {}
}; };
struct BasicBlockTracer : public InsertTraceCode { struct BasicBlockTracer : public InsertTraceCode {
// Trace basic blocks here... // Trace basic blocks here...
virtual void handleBasicBlock(BasicBlock *BB, vector<Instruction*> &VI) { virtual void handleBasicBlock(BasicBlock *BB,
std::vector<Instruction*> &VI) {
TraceValuesAtBBExit(BB, externalFuncs.PrintfFunc, TraceValuesAtBBExit(BB, externalFuncs.PrintfFunc,
externalFuncs.HashPtrFunc, &VI); externalFuncs.HashPtrFunc, &VI);
} }
@ -123,7 +124,7 @@ Pass *createTraceValuesPassForBasicBlocks() { // Trace BB's and functions
void ExternalFuncs::doInitialization(Module &M) { void ExternalFuncs::doInitialization(Module &M) {
const Type *SBP = PointerType::get(Type::SByteTy); const Type *SBP = PointerType::get(Type::SByteTy);
const FunctionType *MTy = const FunctionType *MTy =
FunctionType::get(Type::IntTy, vector<const Type*>(1, SBP), true); FunctionType::get(Type::IntTy, std::vector<const Type*>(1, SBP), true);
PrintfFunc = M.getOrInsertFunction("printf", MTy); PrintfFunc = M.getOrInsertFunction("printf", MTy);
// uint (sbyte*) // uint (sbyte*)
@ -150,7 +151,7 @@ bool InsertTraceCode::doInitialization(Module &M) {
} }
static inline GlobalVariable *getStringRef(Module *M, const string &str) { static inline GlobalVariable *getStringRef(Module *M, const std::string &str) {
// Create a constant internal string reference... // Create a constant internal string reference...
Constant *Init = ConstantArray::get(str); Constant *Init = ConstantArray::get(str);
@ -204,7 +205,7 @@ static bool ShouldTraceValue(const Instruction *I) {
(isa<LoadInst>(I) || LiveAtBBExit(I)); (isa<LoadInst>(I) || LiveAtBBExit(I));
} }
static string getPrintfCodeFor(const Value *V) { static std::string getPrintfCodeFor(const Value *V) {
if (V == 0) return ""; if (V == 0) return "";
if (V->getType()->isFloatingPoint()) if (V->getType()->isFloatingPoint())
return "%g"; return "%g";
@ -221,12 +222,12 @@ static string getPrintfCodeFor(const Value *V) {
static void InsertPrintInst(Value *V, BasicBlock *BB, Instruction *InsertBefore, static void InsertPrintInst(Value *V, BasicBlock *BB, Instruction *InsertBefore,
string Message, std::string Message,
Function *Printf, Function* HashPtrToSeqNum) { Function *Printf, Function* HashPtrToSeqNum) {
// Escape Message by replacing all % characters with %% chars. // Escape Message by replacing all % characters with %% chars.
string Tmp; std::string Tmp;
std::swap(Tmp, Message); std::swap(Tmp, Message);
string::iterator I = std::find(Tmp.begin(), Tmp.end(), '%'); std::string::iterator I = std::find(Tmp.begin(), Tmp.end(), '%');
while (I != Tmp.end()) { while (I != Tmp.end()) {
Message.append(Tmp.begin(), I); Message.append(Tmp.begin(), I);
Message += "%%"; Message += "%%";
@ -242,7 +243,7 @@ static void InsertPrintInst(Value *V, BasicBlock *BB, Instruction *InsertBefore,
// Turn the format string into an sbyte * // Turn the format string into an sbyte *
Constant *GEP =ConstantExpr::getGetElementPtr(ConstantPointerRef::get(fmtVal), Constant *GEP =ConstantExpr::getGetElementPtr(ConstantPointerRef::get(fmtVal),
vector<Constant*>(2,Constant::getNullValue(Type::LongTy))); std::vector<Constant*>(2,Constant::getNullValue(Type::LongTy)));
// Insert a call to the hash function if this is a pointer value // Insert a call to the hash function if this is a pointer value
if (V && isa<PointerType>(V->getType()) && !DisablePtrHashing) { if (V && isa<PointerType>(V->getType()) && !DisablePtrHashing) {
@ -250,12 +251,12 @@ static void InsertPrintInst(Value *V, BasicBlock *BB, Instruction *InsertBefore,
if (V->getType() != SBP) // Cast pointer to be sbyte* if (V->getType() != SBP) // Cast pointer to be sbyte*
V = new CastInst(V, SBP, "Hash_cast", InsertBefore); V = new CastInst(V, SBP, "Hash_cast", InsertBefore);
vector<Value*> HashArgs(1, V); std::vector<Value*> HashArgs(1, V);
V = new CallInst(HashPtrToSeqNum, HashArgs, "ptrSeqNum", InsertBefore); V = new CallInst(HashPtrToSeqNum, HashArgs, "ptrSeqNum", InsertBefore);
} }
// Insert the first print instruction to print the string flag: // Insert the first print instruction to print the string flag:
vector<Value*> PrintArgs; std::vector<Value*> PrintArgs;
PrintArgs.push_back(GEP); PrintArgs.push_back(GEP);
if (V) PrintArgs.push_back(V); if (V) PrintArgs.push_back(V);
new CallInst(Printf, PrintArgs, "trace", InsertBefore); new CallInst(Printf, PrintArgs, "trace", InsertBefore);
@ -264,7 +265,7 @@ static void InsertPrintInst(Value *V, BasicBlock *BB, Instruction *InsertBefore,
static void InsertVerbosePrintInst(Value *V, BasicBlock *BB, static void InsertVerbosePrintInst(Value *V, BasicBlock *BB,
Instruction *InsertBefore, Instruction *InsertBefore,
const string &Message, Function *Printf, const std::string &Message, Function *Printf,
Function* HashPtrToSeqNum) { Function* HashPtrToSeqNum) {
std::ostringstream OutStr; std::ostringstream OutStr;
if (V) WriteAsOperand(OutStr, V); if (V) WriteAsOperand(OutStr, V);
@ -281,7 +282,7 @@ InsertReleaseInst(Value *V, BasicBlock *BB,
if (V->getType() != SBP) // Cast pointer to be sbyte* if (V->getType() != SBP) // Cast pointer to be sbyte*
V = new CastInst(V, SBP, "RPSN_cast", InsertBefore); V = new CastInst(V, SBP, "RPSN_cast", InsertBefore);
vector<Value*> releaseArgs(1, V); std::vector<Value*> releaseArgs(1, V);
new CallInst(ReleasePtrFunc, releaseArgs, "", InsertBefore); new CallInst(ReleasePtrFunc, releaseArgs, "", InsertBefore);
} }
@ -293,7 +294,7 @@ InsertRecordInst(Value *V, BasicBlock *BB,
if (V->getType() != SBP) // Cast pointer to be sbyte* if (V->getType() != SBP) // Cast pointer to be sbyte*
V = new CastInst(V, SBP, "RP_cast", InsertBefore); V = new CastInst(V, SBP, "RP_cast", InsertBefore);
vector<Value*> releaseArgs(1, V); std::vector<Value*> releaseArgs(1, V);
new CallInst(RecordPtrFunc, releaseArgs, "", InsertBefore); new CallInst(RecordPtrFunc, releaseArgs, "", InsertBefore);
} }
@ -324,7 +325,7 @@ ReleasePtrSeqNumbers(BasicBlock *BB,
// //
static void TraceValuesAtBBExit(BasicBlock *BB, static void TraceValuesAtBBExit(BasicBlock *BB,
Function *Printf, Function* HashPtrToSeqNum, Function *Printf, Function* HashPtrToSeqNum,
vector<Instruction*> *valuesStoredInFunction) { std::vector<Instruction*> *valuesStoredInFunction) {
// Get an iterator to point to the insertion location, which is // Get an iterator to point to the insertion location, which is
// just before the terminator instruction. // just before the terminator instruction.
// //
@ -395,8 +396,8 @@ bool InsertTraceCode::runOnFunction(Function &F) {
if (!TraceThisFunction(F)) if (!TraceThisFunction(F))
return false; return false;
vector<Instruction*> valuesStoredInFunction; std::vector<Instruction*> valuesStoredInFunction;
vector<BasicBlock*> exitBlocks; std::vector<BasicBlock*> exitBlocks;
// Insert code to trace values at function entry // Insert code to trace values at function entry
InsertCodeToShowFunctionEntry(F, externalFuncs.PrintfFunc, InsertCodeToShowFunctionEntry(F, externalFuncs.PrintfFunc,
@ -404,7 +405,7 @@ bool InsertTraceCode::runOnFunction(Function &F) {
// Push a pointer set for recording alloca'd pointers at entry. // Push a pointer set for recording alloca'd pointers at entry.
if (!DisablePtrHashing) if (!DisablePtrHashing)
new CallInst(externalFuncs.PushOnEntryFunc, vector<Value*>(), "", new CallInst(externalFuncs.PushOnEntryFunc, std::vector<Value*>(), "",
F.getEntryBlock().begin()); F.getEntryBlock().begin());
for (Function::iterator BB = F.begin(); BB != F.end(); ++BB) { for (Function::iterator BB = F.begin(); BB != F.end(); ++BB) {
@ -426,8 +427,8 @@ bool InsertTraceCode::runOnFunction(Function &F) {
// Release all recorded pointers before RETURN. Do this LAST! // Release all recorded pointers before RETURN. Do this LAST!
if (!DisablePtrHashing) if (!DisablePtrHashing)
new CallInst(externalFuncs.ReleaseOnReturnFunc, vector<Value*>(), "", new CallInst(externalFuncs.ReleaseOnReturnFunc, std::vector<Value*>(),
exitBlocks[i]->getTerminator()); "", exitBlocks[i]->getTerminator());
} }
return true; return true;