Minimal LDA interface, maximally conservative tester.
authorAndreas Bolka <a@bolka.at>
Sun, 28 Jun 2009 00:21:21 +0000 (00:21 +0000)
committerAndreas Bolka <a@bolka.at>
Sun, 28 Jun 2009 00:21:21 +0000 (00:21 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@74401 91177308-0d34-0410-b5e6-96231b3b80d8

include/llvm/Analysis/LoopDependenceAnalysis.h
lib/Analysis/LoopDependenceAnalysis.cpp

index 0c3dadea75fcae03acac898892901910510ff3ff..bde426ba9a880bca3860bc1a4242b6f6e976c405 100644 (file)
@@ -28,6 +28,7 @@ namespace llvm {
 
   class AnalysisUsage;
   class ScalarEvolution;
+  class Value;
 
   class LoopDependenceAnalysis : public LoopPass {
     Loop *L;
@@ -37,6 +38,10 @@ namespace llvm {
     static char ID; // Class identification, replacement for typeinfo
     LoopDependenceAnalysis() : LoopPass(&ID) {}
 
+    /// TODO: docs
+    bool isDependencePair(const Value*, const Value*) const;
+    bool depends(Value*, Value*);
+
     bool runOnLoop(Loop*, LPPassManager&);
 
     virtual void getAnalysisUsage(AnalysisUsage&) const;
index 8f3e6baf5c57596f06ec714dfcb8928a71aed996..b23459e81ac76086a95167a6f7d3c63cca70cff8 100644 (file)
@@ -21,6 +21,7 @@
 #include "llvm/Analysis/LoopDependenceAnalysis.h"
 #include "llvm/Analysis/LoopPass.h"
 #include "llvm/Analysis/ScalarEvolution.h"
+#include "llvm/Instructions.h"
 using namespace llvm;
 
 LoopPass *llvm::createLoopDependenceAnalysisPass() {
@@ -31,6 +32,29 @@ static RegisterPass<LoopDependenceAnalysis>
 R("lda", "Loop Dependence Analysis", false, true);
 char LoopDependenceAnalysis::ID = 0;
 
+//===----------------------------------------------------------------------===//
+//                             Utility Functions
+//===----------------------------------------------------------------------===//
+
+static inline bool isMemRefInstr(const Value *I) {
+  return isa<LoadInst>(I) || isa<StoreInst>(I);
+}
+
+//===----------------------------------------------------------------------===//
+//                             Dependence Testing
+//===----------------------------------------------------------------------===//
+
+bool LoopDependenceAnalysis::isDependencePair(const Value *x,
+                                              const Value *y) const {
+  return isMemRefInstr(x) && isMemRefInstr(y)
+      && (isa<StoreInst>(x) || isa<StoreInst>(y));
+}
+
+bool LoopDependenceAnalysis::depends(Value *src, Value *dst) {
+  assert(isDependencePair(src, dst) && "Values form no dependence pair!");
+  return true;
+}
+
 //===----------------------------------------------------------------------===//
 //                   LoopDependenceAnalysis Implementation
 //===----------------------------------------------------------------------===//