mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-01 00:33:09 +00:00
Trace loads and stores as they happen (stores were being
remembered in valuesStoredInFunction, but never traced at function return, and that's too late to be finding the error anyway). Stores trace both the value and the address being stored to, but after some experience I think only values should be traced. The pointer hash table just fills up far too quickly if every store address were traced. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@7169 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
0517c5ac92
commit
919fc8c367
@ -164,7 +164,9 @@ static inline GlobalVariable *getStringRef(Module *M, const string &str) {
|
|||||||
|
|
||||||
//
|
//
|
||||||
// Check if this instruction has any uses outside its basic block,
|
// Check if this instruction has any uses outside its basic block,
|
||||||
// or if it used by either a Call or Return instruction.
|
// or if it used by either a Call or Return instruction (ditto).
|
||||||
|
// (Values stored to memory within this BB are live at end of BB but are
|
||||||
|
// traced at the store instruction, not where they are computed.)
|
||||||
//
|
//
|
||||||
static inline bool LiveAtBBExit(const Instruction* I) {
|
static inline bool LiveAtBBExit(const Instruction* I) {
|
||||||
const BasicBlock *BB = I->getParent();
|
const BasicBlock *BB = I->getParent();
|
||||||
@ -188,10 +190,16 @@ static inline bool TraceThisOpCode(unsigned opCode) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// Trace a value computed by an instruction if it is non-void, it is computed
|
||||||
|
// by a real computation, not just a copy (see TraceThisOpCode), and
|
||||||
|
// -- it is a load instruction: we want to check values read from memory
|
||||||
|
// -- or it is live at exit from the basic block (i.e., ignore local temps)
|
||||||
|
//
|
||||||
static bool ShouldTraceValue(const Instruction *I) {
|
static bool ShouldTraceValue(const Instruction *I) {
|
||||||
return
|
return
|
||||||
I->getType() != Type::VoidTy && LiveAtBBExit(I) &&
|
I->getType() != Type::VoidTy &&
|
||||||
TraceThisOpCode(I->getOpcode());
|
TraceThisOpCode(I->getOpcode()) &&
|
||||||
|
(isa<LoadInst>(I) || LiveAtBBExit(I));
|
||||||
}
|
}
|
||||||
|
|
||||||
static string getPrintfCodeFor(const Value *V) {
|
static string getPrintfCodeFor(const Value *V) {
|
||||||
@ -331,14 +339,13 @@ static void TraceValuesAtBBExit(BasicBlock *BB,
|
|||||||
//
|
//
|
||||||
for (BasicBlock::iterator II = BB->begin(); &*II != InsertPos; ++II) {
|
for (BasicBlock::iterator II = BB->begin(); &*II != InsertPos; ++II) {
|
||||||
if (StoreInst *SI = dyn_cast<StoreInst>(II)) {
|
if (StoreInst *SI = dyn_cast<StoreInst>(II)) {
|
||||||
assert(valuesStoredInFunction &&
|
// Trace the stored value and address
|
||||||
"Should not be printing a store instruction at function exit");
|
InsertVerbosePrintInst(SI->getOperand(0), BB, InsertPos,
|
||||||
LoadInst *LI = new LoadInst(SI->getPointerOperand(), "reload." +
|
" (store value) ", Printf, HashPtrToSeqNum);
|
||||||
SI->getPointerOperand()->getName(),
|
InsertVerbosePrintInst(SI->getOperand(1), BB, InsertPos,
|
||||||
InsertPos);
|
" (store addr ) ", Printf, HashPtrToSeqNum);
|
||||||
valuesStoredInFunction->push_back(LI);
|
|
||||||
}
|
}
|
||||||
if (ShouldTraceValue(II))
|
else if (ShouldTraceValue(II))
|
||||||
InsertVerbosePrintInst(II, BB, InsertPos, " ", Printf, HashPtrToSeqNum);
|
InsertVerbosePrintInst(II, BB, InsertPos, " ", Printf, HashPtrToSeqNum);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user