diff options
| -rw-r--r-- | polly/lib/Analysis/ScopDetection.cpp | 12 | ||||
| -rw-r--r-- | polly/test/ScopDetection/single_function_only.ll | 122 | ||||
| -rw-r--r-- | polly/www/example_load_Polly_into_clang.html | 17 |
3 files changed, 149 insertions, 2 deletions
diff --git a/polly/lib/Analysis/ScopDetection.cpp b/polly/lib/Analysis/ScopDetection.cpp index 083ad439f84..ab9720c6741 100644 --- a/polly/lib/Analysis/ScopDetection.cpp +++ b/polly/lib/Analysis/ScopDetection.cpp @@ -63,6 +63,13 @@ using namespace llvm; using namespace polly; +static cl::opt<std::string> +OnlyFunction("polly-detect-only", + cl::desc("Only detect scops in function"), cl::Hidden, + cl::value_desc("The function name to detect scops in"), + cl::ValueRequired, cl::init("")); + + //===----------------------------------------------------------------------===// // Statistics. @@ -553,6 +560,11 @@ bool ScopDetection::runOnFunction(llvm::Function &F) { RI = &getAnalysis<RegionInfo>(); Region *TopRegion = RI->getTopLevelRegion(); + releaseMemory(); + + if (OnlyFunction != "" && F.getNameStr() != OnlyFunction) + return false; + if(!isValidFunction(F)) return false; diff --git a/polly/test/ScopDetection/single_function_only.ll b/polly/test/ScopDetection/single_function_only.ll new file mode 100644 index 00000000000..f80f3e6744b --- /dev/null +++ b/polly/test/ScopDetection/single_function_only.ll @@ -0,0 +1,122 @@ +; RUN: opt %loadPolly %defaultOpts -polly-cloog -analyze -polly-detect-only=bar %s | FileCheck %s +target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64" +target triple = "x86_64-unknown-linux-gnu" + +define i32 @foo() nounwind { +entry: + %A = alloca [1024 x i32], align 4 ; <[1024 x i32]*> [#uses=3] + %arraydecay = getelementptr inbounds [1024 x i32]* %A, i32 0, i32 0 ; <i32*> [#uses=1] + %conv = bitcast i32* %arraydecay to i8* ; <i8*> [#uses=1] + call void @llvm.memset.p0i8.i64(i8* %conv, i8 0, i64 4096, i32 1, i1 false) + br label %for.cond + +for.cond: ; preds = %for.inc, %entry + %indvar1 = phi i64 [ %indvar.next2, %for.inc ], [ 0, %entry ] ; <i64> [#uses=3] + %arrayidx = getelementptr [1024 x i32]* %A, i64 0, i64 %indvar1 ; <i32*> [#uses=1] + %exitcond = icmp ne i64 %indvar1, 1024 ; <i1> [#uses=1] + br i1 %exitcond, label %for.body, label %for.end + +for.body: ; preds = %for.cond + store i32 1, i32* %arrayidx + br label %for.inc + +for.inc: ; preds = %for.body + %indvar.next2 = add i64 %indvar1, 1 ; <i64> [#uses=1] + br label %for.cond + +for.end: ; preds = %for.cond + br label %for.cond5 + +for.cond5: ; preds = %for.inc17, %for.end + %indvar = phi i64 [ %indvar.next, %for.inc17 ], [ 0, %for.end ] ; <i64> [#uses=3] + %arrayidx13 = getelementptr [1024 x i32]* %A, i64 0, i64 %indvar ; <i32*> [#uses=1] + %i.1 = trunc i64 %indvar to i32 ; <i32> [#uses=1] + %cmp7 = icmp slt i32 %i.1, 1024 ; <i1> [#uses=1] + br i1 %cmp7, label %for.body9, label %for.end20 + +for.body9: ; preds = %for.cond5 + %tmp14 = load i32* %arrayidx13 ; <i32> [#uses=1] + %cmp15 = icmp ne i32 %tmp14, 1 ; <i1> [#uses=1] + br i1 %cmp15, label %if.then, label %if.end + +if.then: ; preds = %for.body9 + br label %return + +if.end: ; preds = %for.body9 + br label %for.inc17 + +for.inc17: ; preds = %if.end + %indvar.next = add i64 %indvar, 1 ; <i64> [#uses=1] + br label %for.cond5 + +for.end20: ; preds = %for.cond5 + br label %return + +return: ; preds = %for.end20, %if.then + %retval.0 = phi i32 [ 1, %if.then ], [ 0, %for.end20 ] ; <i32> [#uses=1] + ret i32 %retval.0 +} + +define i32 @bar() nounwind { +entry: + %A = alloca [1024 x i32], align 4 ; <[1024 x i32]*> [#uses=3] + %arraydecay = getelementptr inbounds [1024 x i32]* %A, i32 0, i32 0 ; <i32*> [#uses=1] + %conv = bitcast i32* %arraydecay to i8* ; <i8*> [#uses=1] + call void @llvm.memset.p0i8.i64(i8* %conv, i8 0, i64 4096, i32 1, i1 false) + br label %for.cond + +for.cond: ; preds = %for.inc, %entry + %indvar1 = phi i64 [ %indvar.next2, %for.inc ], [ 0, %entry ] ; <i64> [#uses=3] + %arrayidx = getelementptr [1024 x i32]* %A, i64 0, i64 %indvar1 ; <i32*> [#uses=1] + %exitcond = icmp ne i64 %indvar1, 1024 ; <i1> [#uses=1] + br i1 %exitcond, label %for.body, label %for.end + +for.body: ; preds = %for.cond + store i32 1, i32* %arrayidx + br label %for.inc + +for.inc: ; preds = %for.body + %indvar.next2 = add i64 %indvar1, 1 ; <i64> [#uses=1] + br label %for.cond + +for.end: ; preds = %for.cond + br label %for.cond5 + +for.cond5: ; preds = %for.inc17, %for.end + %indvar = phi i64 [ %indvar.next, %for.inc17 ], [ 0, %for.end ] ; <i64> [#uses=3] + %arrayidx13 = getelementptr [1024 x i32]* %A, i64 0, i64 %indvar ; <i32*> [#uses=1] + %i.1 = trunc i64 %indvar to i32 ; <i32> [#uses=1] + %cmp7 = icmp slt i32 %i.1, 1024 ; <i1> [#uses=1] + br i1 %cmp7, label %for.body9, label %for.end20 + +for.body9: ; preds = %for.cond5 + %tmp14 = load i32* %arrayidx13 ; <i32> [#uses=1] + %cmp15 = icmp ne i32 %tmp14, 1 ; <i1> [#uses=1] + br i1 %cmp15, label %if.then, label %if.end + +if.then: ; preds = %for.body9 + br label %return + +if.end: ; preds = %for.body9 + br label %for.inc17 + +for.inc17: ; preds = %if.end + %indvar.next = add i64 %indvar, 1 ; <i64> [#uses=1] + br label %for.cond5 + +for.end20: ; preds = %for.cond5 + br label %return + +return: ; preds = %for.end20, %if.then + %retval.0 = phi i32 [ 1, %if.then ], [ 0, %for.end20 ] ; <i32> [#uses=1] + ret i32 %retval.0 +} + + +declare void @llvm.memset.p0i8.i64(i8* nocapture, i8, i64, i32, i1) nounwind + +; CHECK-NOT: foo() +; CHECK:bar() +; CHECK:for (c2=0;c2<=1023;c2++) { +; CHECK: Stmt_for_body(c2); +; CHECK:} diff --git a/polly/www/example_load_Polly_into_clang.html b/polly/www/example_load_Polly_into_clang.html index 2fc504b78db..877d96e341b 100644 --- a/polly/www/example_load_Polly_into_clang.html +++ b/polly/www/example_load_Polly_into_clang.html @@ -20,7 +20,7 @@ that Polly is a young research project. It is expected to crash, produce invalid code or to hang in complex calculations even for simple examples. In case you see such a problem, please check the <a href="bugs.html">Bug database</a> and consider reporting the bug. -<h4>Compiling code with Polly</h4> +<h2>Compiling code with Polly</h2> To compile code with Polly you only need to add '-load ${POLLY_BUILD_DIR}/lib/LLVMPolly.so' to your command line or your CFLAGS and @@ -28,12 +28,25 @@ Polly is automatically executed at -O3. <pre class="code">clang -load ${POLLY_BUILD_DIR}/lib/LLVMPolly.so -O3 file.c</pre> -<h4>Automatic OpenMP code generation</h4> +<h2>Automatic OpenMP code generation</h2> To automatically detect parallel loops and generate OpenMP code for them you also need to add '-mllvm -enable-polly-openmp -lgomp' to your CFLAGS. <pre class="code">clang -load ${POLLY_BUILD_DIR}/lib/LLVMPolly.so -O3 -mllvm -enable-polly-openmp -lgomp file.c</pre> + +<h2>Further options</h2> + +Polly supports further options that are mainly useful for the development or +the +analysis of Polly. The relevant options can be +added to clang by appending '-mllvm -option-name' to the CFLAGS or the clang +command line. + +<h3>Limit Polly to a single function</h3> +To limit the execution of Polly to a single function, use the option +'-polly-detect-only=functionname'. + </div> </body> </html> |

