mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-06-15 21:24:00 +00:00
Add statistics to the loop extractor. The loop extractor has successfully
extracted all 63 loops for Olden/bh without crashing and without miscompiling the program!!! git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@12491 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@ -22,9 +22,12 @@
|
|||||||
#include "llvm/Analysis/LoopInfo.h"
|
#include "llvm/Analysis/LoopInfo.h"
|
||||||
#include "llvm/Transforms/Scalar.h"
|
#include "llvm/Transforms/Scalar.h"
|
||||||
#include "llvm/Transforms/Utils/FunctionUtils.h"
|
#include "llvm/Transforms/Utils/FunctionUtils.h"
|
||||||
|
#include "Support/Statistic.h"
|
||||||
using namespace llvm;
|
using namespace llvm;
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
Statistic<> NumExtracted("loop-extract", "Number of loops extracted");
|
||||||
|
|
||||||
// FIXME: This is not a function pass, but the PassManager doesn't allow
|
// FIXME: This is not a function pass, but the PassManager doesn't allow
|
||||||
// Module passes to require FunctionPasses, so we can't get loop info if we're
|
// Module passes to require FunctionPasses, so we can't get loop info if we're
|
||||||
// not a function pass.
|
// not a function pass.
|
||||||
@ -72,6 +75,7 @@ bool LoopExtractor::runOnFunction(Function &F) {
|
|||||||
if (NumLoops == 0) return Changed;
|
if (NumLoops == 0) return Changed;
|
||||||
--NumLoops;
|
--NumLoops;
|
||||||
Changed |= ExtractLoop(DS, *i) != 0;
|
Changed |= ExtractLoop(DS, *i) != 0;
|
||||||
|
++NumExtracted;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// Otherwise there is exactly one top-level loop. If this function is more
|
// Otherwise there is exactly one top-level loop. If this function is more
|
||||||
@ -99,6 +103,7 @@ bool LoopExtractor::runOnFunction(Function &F) {
|
|||||||
if (NumLoops == 0) return Changed;
|
if (NumLoops == 0) return Changed;
|
||||||
--NumLoops;
|
--NumLoops;
|
||||||
Changed |= ExtractLoop(DS, TLL) != 0;
|
Changed |= ExtractLoop(DS, TLL) != 0;
|
||||||
|
++NumExtracted;
|
||||||
} else {
|
} else {
|
||||||
// Okay, this function is a minimal container around the specified loop.
|
// Okay, this function is a minimal container around the specified loop.
|
||||||
// If we extract the loop, we will continue to just keep extracting it
|
// If we extract the loop, we will continue to just keep extracting it
|
||||||
@ -108,6 +113,7 @@ bool LoopExtractor::runOnFunction(Function &F) {
|
|||||||
if (NumLoops == 0) return Changed;
|
if (NumLoops == 0) return Changed;
|
||||||
--NumLoops;
|
--NumLoops;
|
||||||
Changed |= ExtractLoop(DS, *i) != 0;
|
Changed |= ExtractLoop(DS, *i) != 0;
|
||||||
|
++NumExtracted;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user