| ; RUN: opt %loadPolly -pass-remarks-analysis="polly-scops" -polly-scops \ |
| ; RUN: -polly-invariant-load-hoisting=true -disable-output < %s 2>&1 | FileCheck %s |
| ; |
| ; CHECK: remark: test/ScopInfo/remarks.c:4:7: SCoP begins here. |
| ; CHECK: remark: test/ScopInfo/remarks.c:9:15: Inbounds assumption: [N, M, Debug] -> { : M <= 100 } |
| ; CHECK: remark: test/ScopInfo/remarks.c:13:7: No-error restriction: [N, M, Debug] -> { : N > 0 and M >= 0 and (Debug < 0 or Debug > 0) } |
| ; CHECK: remark: test/ScopInfo/remarks.c:8:5: Finite loop restriction: [N, M, Debug] -> { : N > 0 and M < 0 } |
| ; CHECK: remark: test/ScopInfo/remarks.c:4:7: No-overflows restriction: [N, M, Debug] -> { : M <= -2147483649 - N or M >= 2147483648 - N } |
| ; CHECK: remark: test/ScopInfo/remarks.c:9:18: Possibly aliasing pointer, use restrict keyword. |
| ; CHECK: remark: test/ScopInfo/remarks.c:9:33: Possibly aliasing pointer, use restrict keyword. |
| ; CHECK: remark: test/ScopInfo/remarks.c:9:15: Possibly aliasing pointer, use restrict keyword. |
| ; CHECK: remark: test/ScopInfo/remarks.c:14:3: SCoP ends here. |
| ; CHECK: remark: test/ScopInfo/remarks.c:19:3: SCoP begins here. |
| ; CHECK: remark: test/ScopInfo/remarks.c:21:11: Invariant load restriction: [tmp] -> { : tmp < 0 or tmp > 0 } |
| ; CHECK: remark: test/ScopInfo/remarks.c:22:16: SCoP ends here but was dismissed. |
| ; |
| ; #include <stdio.h> |
| ; |
| ; void valid(int *A, int *B, int N, int M, int C[100][100], int Debug) { |
| ; if (N + M == -1) |
| ; C[0][0] = 0; |
| ; |
| ; for (int i = 0; i < N; i++) { |
| ; for (int j = 0; j != M; j++) { |
| ; C[i][j] += A[i * M + j] + B[i + j]; |
| ; } |
| ; |
| ; if (Debug) |
| ; printf("Printf!"); |
| ; } |
| ; } |
| ; |
| ; void invalid0(int *A) { |
| ; for (int i = 0; i < 10; i++) |
| ; for (int j = 0; j < 10; j++) |
| ; if (A[0]) |
| ; A[0] = 0; |
| ; } |
| ; |
| target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128" |
| |
| @.str = private unnamed_addr constant [8 x i8] c"Printf!\00", align 1 |
| |
| define void @valid(i32* %A, i32* %B, i32 %N, i32 %M, [100 x i32]* %C, i32 %Debug) #0 !dbg !4 { |
| entry: |
| call void @llvm.dbg.value(metadata i32* %A, i64 0, metadata !23, metadata !24), !dbg !25 |
| call void @llvm.dbg.value(metadata i32* %B, i64 0, metadata !26, metadata !24), !dbg !27 |
| call void @llvm.dbg.value(metadata i32 %N, i64 0, metadata !28, metadata !24), !dbg !29 |
| call void @llvm.dbg.value(metadata i32 %M, i64 0, metadata !30, metadata !24), !dbg !31 |
| call void @llvm.dbg.value(metadata [100 x i32]* %C, i64 0, metadata !32, metadata !24), !dbg !33 |
| call void @llvm.dbg.value(metadata i32 %Debug, i64 0, metadata !34, metadata !24), !dbg !35 |
| br label %entry.split |
| |
| entry.split: |
| %add = add i32 %N, %M, !dbg !36 |
| %cmp = icmp eq i32 %add, -1, !dbg !38 |
| br i1 %cmp, label %if.then, label %if.end, !dbg !39 |
| |
| if.then: ; preds = %entry |
| %arrayidx1 = getelementptr inbounds [100 x i32], [100 x i32]* %C, i64 0, i64 0, !dbg !40 |
| store i32 0, i32* %arrayidx1, align 4, !dbg !41 |
| br label %if.end, !dbg !40 |
| |
| if.end: ; preds = %if.then, %entry |
| call void @llvm.dbg.value(metadata i32 0, i64 0, metadata !42, metadata !24), !dbg !44 |
| %N64 = sext i32 %N to i64, !dbg !45 |
| %M64 = sext i32 %M to i64, !dbg !45 |
| br label %for.cond, !dbg !45 |
| |
| for.cond: ; preds = %for.inc.19, %if.end |
| %indvars.iv3 = phi i64 [ %indvars.iv.next4, %for.inc.19 ], [ 0, %if.end ] |
| %cmp2 = icmp slt i64 %indvars.iv3, %N64, !dbg !46 |
| br i1 %cmp2, label %for.body, label %for.end.21, !dbg !49 |
| |
| for.body: ; preds = %for.cond |
| call void @llvm.dbg.value(metadata i32 0, i64 0, metadata !50, metadata !24), !dbg !53 |
| br label %for.cond.3, !dbg !54 |
| |
| for.cond.3: ; preds = %for.inc, %for.body |
| %indvars.iv = phi i64 [ %indvars.iv.next, %for.inc ], [ 0, %for.body ] |
| %cmp4 = icmp eq i64 %indvars.iv, %M64, !dbg !55 |
| br i1 %cmp4, label %for.end, label %for.body.5, !dbg !58 |
| |
| for.body.5: ; preds = %for.cond.3 |
| %tmp8 = mul i64 %indvars.iv3, %M64, !dbg !59 |
| %tmp9 = add i64 %tmp8, %indvars.iv, !dbg !61 |
| %arrayidx7 = getelementptr inbounds i32, i32* %A, i64 %tmp9, !dbg !62 |
| %tmp10 = load i32, i32* %arrayidx7, align 4, !dbg !62 |
| %tmp11 = add i64 %indvars.iv3, %indvars.iv, !dbg !63 |
| %arrayidx10 = getelementptr inbounds i32, i32* %B, i64 %tmp11, !dbg !64 |
| %tmp12 = load i32, i32* %arrayidx10, align 4, !dbg !64 |
| %add11 = add i32 %tmp10, %tmp12, !dbg !65 |
| %arrayidx15 = getelementptr inbounds [100 x i32], [100 x i32]* %C, i64 %indvars.iv3, i64 %indvars.iv, !dbg !66 |
| %tmp13 = load i32, i32* %arrayidx15, align 4, !dbg !67 |
| %add16 = add i32 %tmp13, %add11, !dbg !67 |
| store i32 %add16, i32* %arrayidx15, align 4, !dbg !67 |
| br label %for.inc, !dbg !68 |
| |
| for.inc: ; preds = %for.body.5 |
| %indvars.iv.next = add i64 %indvars.iv, 1, !dbg !69 |
| call void @llvm.dbg.value(metadata !2, i64 0, metadata !50, metadata !24), !dbg !53 |
| br label %for.cond.3, !dbg !69 |
| |
| for.end: ; preds = %for.cond.3 |
| %tobool = icmp eq i32 %Debug, 0, !dbg !70 |
| br i1 %tobool, label %if.end.18, label %if.then.17, !dbg !72 |
| |
| if.then.17: ; preds = %for.end |
| %call = call i32 (i8*, ...) @printf(i8* nonnull getelementptr inbounds ([8 x i8], [8 x i8]* @.str, i64 0, i64 0)) #3, !dbg !73 |
| br label %if.end.18, !dbg !73 |
| |
| if.end.18: ; preds = %for.end, %if.then.17 |
| br label %for.inc.19, !dbg !74 |
| |
| for.inc.19: ; preds = %if.end.18 |
| %indvars.iv.next4 = add nuw nsw i64 %indvars.iv3, 1, !dbg !75 |
| call void @llvm.dbg.value(metadata !2, i64 0, metadata !42, metadata !24), !dbg !44 |
| br label %for.cond, !dbg !75 |
| |
| for.end.21: ; preds = %for.cond |
| ret void, !dbg !76 |
| } |
| |
| declare void @llvm.dbg.declare(metadata, metadata, metadata) #1 |
| |
| declare i32 @printf(i8*, ...) #2 |
| |
| define void @invalid0(i32* %A) #0 !dbg !13 { |
| entry: |
| call void @llvm.dbg.value(metadata i32* %A, i64 0, metadata !77, metadata !24), !dbg !78 |
| call void @llvm.dbg.value(metadata i32 0, i64 0, metadata !79, metadata !24), !dbg !81 |
| br label %for.cond, !dbg !82 |
| |
| for.cond: ; preds = %for.inc.5, %entry |
| %i.0 = phi i32 [ 0, %entry ], [ %inc6, %for.inc.5 ] |
| %exitcond1 = icmp ne i32 %i.0, 10, !dbg !83 |
| br i1 %exitcond1, label %for.body, label %for.end.7, !dbg !83 |
| |
| for.body: ; preds = %for.cond |
| call void @llvm.dbg.value(metadata i32 0, i64 0, metadata !86, metadata !24), !dbg !88 |
| br label %for.cond.1, !dbg !89 |
| |
| for.cond.1: ; preds = %for.inc, %for.body |
| %j.0 = phi i32 [ 0, %for.body ], [ %inc, %for.inc ] |
| %exitcond = icmp ne i32 %j.0, 10, !dbg !90 |
| br i1 %exitcond, label %for.body.3, label %for.end, !dbg !90 |
| |
| for.body.3: ; preds = %for.cond.1 |
| %tmp = load i32, i32* %A, align 4, !dbg !93 |
| %tobool = icmp eq i32 %tmp, 0, !dbg !93 |
| br i1 %tobool, label %if.end, label %if.then, !dbg !95 |
| |
| if.then: ; preds = %for.body.3 |
| store i32 0, i32* %A, align 4, !dbg !96 |
| br label %if.end, !dbg !97 |
| |
| if.end: ; preds = %for.body.3, %if.then |
| br label %for.inc, !dbg !98 |
| |
| for.inc: ; preds = %if.end |
| %inc = add nuw nsw i32 %j.0, 1, !dbg !100 |
| call void @llvm.dbg.value(metadata i32 %inc, i64 0, metadata !86, metadata !24), !dbg !88 |
| br label %for.cond.1, !dbg !101 |
| |
| for.end: ; preds = %for.cond.1 |
| br label %for.inc.5, !dbg !102 |
| |
| for.inc.5: ; preds = %for.end |
| %inc6 = add nuw nsw i32 %i.0, 1, !dbg !103 |
| call void @llvm.dbg.value(metadata i32 %inc6, i64 0, metadata !79, metadata !24), !dbg !81 |
| br label %for.cond, !dbg !104 |
| |
| for.end.7: ; preds = %for.cond |
| ret void, !dbg !105 |
| } |
| |
| declare void @llvm.dbg.value(metadata, i64, metadata, metadata) #1 |
| |
| attributes #0 = { nounwind uwtable "disable-tail-calls"="false" "less-precise-fpmad"="false" "no-frame-pointer-elim"="true" "no-frame-pointer-elim-non-leaf" "no-infs-fp-math"="false" "no-nans-fp-math"="false" "stack-protector-buffer-size"="8" "target-cpu"="x86-64" "target-features"="+fxsr,+mmx,+sse,+sse2" "unsafe-fp-math"="false" "use-soft-float"="false" } |
| attributes #1 = { nounwind readnone } |
| attributes #2 = { "disable-tail-calls"="false" "less-precise-fpmad"="false" "no-frame-pointer-elim"="true" "no-frame-pointer-elim-non-leaf" "no-infs-fp-math"="false" "no-nans-fp-math"="false" "stack-protector-buffer-size"="8" "target-cpu"="x86-64" "target-features"="+fxsr,+mmx,+sse,+sse2" "unsafe-fp-math"="false" "use-soft-float"="false" } |
| attributes #3 = { nounwind } |
| |
| !llvm.dbg.cu = !{!0} |
| !llvm.module.flags = !{!20, !21} |
| !llvm.ident = !{!22} |
| |
| !0 = distinct !DICompileUnit(language: DW_LANG_C99, file: !1, producer: "clang version 3.8.0 (http://llvm.org/git/clang.git 65eeefc97d2eee4d075ec7d9ed56b5f0786b6421)", isOptimized: false, runtimeVersion: 0, emissionKind: 1, enums: !2) |
| !1 = !DIFile(filename: "test/ScopInfo/remarks.c", directory: "/home/johannes/repos/llvm-polly/tools/polly") |
| !2 = !{} |
| !4 = distinct !DISubprogram(name: "valid", scope: !1, file: !1, line: 3, type: !5, isLocal: false, isDefinition: true, scopeLine: 3, flags: DIFlagPrototyped, isOptimized: false, unit: !0, retainedNodes: !2) |
| !5 = !DISubroutineType(types: !6) |
| !6 = !{null, !7, !7, !8, !8, !9, !8} |
| !7 = !DIDerivedType(tag: DW_TAG_pointer_type, baseType: !8, size: 64, align: 64) |
| !8 = !DIBasicType(name: "int", size: 32, align: 32, encoding: DW_ATE_signed) |
| !9 = !DIDerivedType(tag: DW_TAG_pointer_type, baseType: !10, size: 64, align: 64) |
| !10 = !DICompositeType(tag: DW_TAG_array_type, baseType: !8, size: 3200, align: 32, elements: !11) |
| !11 = !{!12} |
| !12 = !DISubrange(count: 100) |
| !13 = distinct !DISubprogram(name: "invalid0", scope: !1, file: !1, line: 18, type: !14, isLocal: false, isDefinition: true, scopeLine: 18, flags: DIFlagPrototyped, isOptimized: false, unit: !0, retainedNodes: !2) |
| !14 = !DISubroutineType(types: !15) |
| !15 = !{null, !7} |
| !16 = distinct !DISubprogram(name: "invalid1", scope: !1, file: !1, line: 25, type: !17, isLocal: false, isDefinition: true, scopeLine: 25, flags: DIFlagPrototyped, isOptimized: false, unit: !0, retainedNodes: !2) |
| !17 = !DISubroutineType(types: !18) |
| !18 = !{null, !19, !19} |
| !19 = !DIDerivedType(tag: DW_TAG_pointer_type, baseType: !7, size: 64, align: 64) |
| !20 = !{i32 2, !"Dwarf Version", i32 4} |
| !21 = !{i32 2, !"Debug Info Version", i32 3} |
| !22 = !{!"clang version 3.8.0 (http://llvm.org/git/clang.git 65eeefc97d2eee4d075ec7d9ed56b5f0786b6421)"} |
| !23 = !DILocalVariable(name: "A", arg: 1, scope: !4, file: !1, line: 3, type: !7) |
| !24 = !DIExpression() |
| !25 = !DILocation(line: 3, column: 17, scope: !4) |
| !26 = !DILocalVariable(name: "B", arg: 2, scope: !4, file: !1, line: 3, type: !7) |
| !27 = !DILocation(line: 3, column: 25, scope: !4) |
| !28 = !DILocalVariable(name: "N", arg: 3, scope: !4, file: !1, line: 3, type: !8) |
| !29 = !DILocation(line: 3, column: 32, scope: !4) |
| !30 = !DILocalVariable(name: "M", arg: 4, scope: !4, file: !1, line: 3, type: !8) |
| !31 = !DILocation(line: 3, column: 39, scope: !4) |
| !32 = !DILocalVariable(name: "C", arg: 5, scope: !4, file: !1, line: 3, type: !9) |
| !33 = !DILocation(line: 3, column: 46, scope: !4) |
| !34 = !DILocalVariable(name: "Debug", arg: 6, scope: !4, file: !1, line: 3, type: !8) |
| !35 = !DILocation(line: 3, column: 63, scope: !4) |
| !36 = !DILocation(line: 4, column: 9, scope: !37) |
| !37 = distinct !DILexicalBlock(scope: !4, file: !1, line: 4, column: 7) |
| !38 = !DILocation(line: 4, column: 13, scope: !37) |
| !39 = !DILocation(line: 4, column: 7, scope: !4) |
| !40 = !DILocation(line: 5, column: 5, scope: !37) |
| !41 = !DILocation(line: 5, column: 13, scope: !37) |
| !42 = !DILocalVariable(name: "i", scope: !43, file: !1, line: 7, type: !8) |
| !43 = distinct !DILexicalBlock(scope: !4, file: !1, line: 7, column: 3) |
| !44 = !DILocation(line: 7, column: 12, scope: !43) |
| !45 = !DILocation(line: 7, column: 8, scope: !43) |
| !46 = !DILocation(line: 7, column: 21, scope: !47) |
| !47 = !DILexicalBlockFile(scope: !48, file: !1, discriminator: 1) |
| !48 = distinct !DILexicalBlock(scope: !43, file: !1, line: 7, column: 3) |
| !49 = !DILocation(line: 7, column: 3, scope: !47) |
| !50 = !DILocalVariable(name: "j", scope: !51, file: !1, line: 8, type: !8) |
| !51 = distinct !DILexicalBlock(scope: !52, file: !1, line: 8, column: 5) |
| !52 = distinct !DILexicalBlock(scope: !48, file: !1, line: 7, column: 31) |
| !53 = !DILocation(line: 8, column: 14, scope: !51) |
| !54 = !DILocation(line: 8, column: 10, scope: !51) |
| !55 = !DILocation(line: 8, column: 23, scope: !56) |
| !56 = !DILexicalBlockFile(scope: !57, file: !1, discriminator: 1) |
| !57 = distinct !DILexicalBlock(scope: !51, file: !1, line: 8, column: 5) |
| !58 = !DILocation(line: 8, column: 5, scope: !56) |
| !59 = !DILocation(line: 9, column: 22, scope: !60) |
| !60 = distinct !DILexicalBlock(scope: !57, file: !1, line: 8, column: 34) |
| !61 = !DILocation(line: 9, column: 26, scope: !60) |
| !62 = !DILocation(line: 9, column: 18, scope: !60) |
| !63 = !DILocation(line: 9, column: 37, scope: !60) |
| !64 = !DILocation(line: 9, column: 33, scope: !60) |
| !65 = !DILocation(line: 9, column: 31, scope: !60) |
| !66 = !DILocation(line: 9, column: 7, scope: !60) |
| !67 = !DILocation(line: 9, column: 15, scope: !60) |
| !68 = !DILocation(line: 10, column: 5, scope: !60) |
| !69 = !DILocation(line: 8, column: 5, scope: !57) |
| !70 = !DILocation(line: 12, column: 9, scope: !71) |
| !71 = distinct !DILexicalBlock(scope: !52, file: !1, line: 12, column: 9) |
| !72 = !DILocation(line: 12, column: 9, scope: !52) |
| !73 = !DILocation(line: 13, column: 7, scope: !71) |
| !74 = !DILocation(line: 14, column: 3, scope: !52) |
| !75 = !DILocation(line: 7, column: 3, scope: !48) |
| !76 = !DILocation(line: 16, column: 1, scope: !4) |
| !77 = !DILocalVariable(name: "A", arg: 1, scope: !13, file: !1, line: 18, type: !7) |
| !78 = !DILocation(line: 18, column: 20, scope: !13) |
| !79 = !DILocalVariable(name: "i", scope: !80, file: !1, line: 19, type: !8) |
| !80 = distinct !DILexicalBlock(scope: !13, file: !1, line: 19, column: 3) |
| !81 = !DILocation(line: 19, column: 12, scope: !80) |
| !82 = !DILocation(line: 19, column: 8, scope: !80) |
| !83 = !DILocation(line: 19, column: 3, scope: !84) |
| !84 = !DILexicalBlockFile(scope: !85, file: !1, discriminator: 1) |
| !85 = distinct !DILexicalBlock(scope: !80, file: !1, line: 19, column: 3) |
| !86 = !DILocalVariable(name: "j", scope: !87, file: !1, line: 20, type: !8) |
| !87 = distinct !DILexicalBlock(scope: !85, file: !1, line: 20, column: 5) |
| !88 = !DILocation(line: 20, column: 14, scope: !87) |
| !89 = !DILocation(line: 20, column: 10, scope: !87) |
| !90 = !DILocation(line: 20, column: 5, scope: !91) |
| !91 = !DILexicalBlockFile(scope: !92, file: !1, discriminator: 1) |
| !92 = distinct !DILexicalBlock(scope: !87, file: !1, line: 20, column: 5) |
| !93 = !DILocation(line: 21, column: 11, scope: !94) |
| !94 = distinct !DILexicalBlock(scope: !92, file: !1, line: 21, column: 11) |
| !95 = !DILocation(line: 21, column: 11, scope: !92) |
| !96 = !DILocation(line: 22, column: 14, scope: !94) |
| !97 = !DILocation(line: 22, column: 9, scope: !94) |
| !98 = !DILocation(line: 21, column: 14, scope: !99) |
| !99 = !DILexicalBlockFile(scope: !94, file: !1, discriminator: 1) |
| !100 = !DILocation(line: 20, column: 30, scope: !92) |
| !101 = !DILocation(line: 20, column: 5, scope: !92) |
| !102 = !DILocation(line: 22, column: 16, scope: !87) |
| !103 = !DILocation(line: 19, column: 28, scope: !85) |
| !104 = !DILocation(line: 19, column: 3, scope: !85) |
| !105 = !DILocation(line: 23, column: 1, scope: !13) |
| !106 = !DILocalVariable(name: "A", arg: 1, scope: !16, file: !1, line: 25, type: !19) |
| !107 = !DILocation(line: 25, column: 21, scope: !16) |
| !108 = !DILocalVariable(name: "B", arg: 2, scope: !16, file: !1, line: 25, type: !19) |
| !109 = !DILocation(line: 25, column: 30, scope: !16) |
| !110 = !DILocalVariable(name: "i", scope: !111, file: !1, line: 26, type: !8) |
| !111 = distinct !DILexicalBlock(scope: !16, file: !1, line: 26, column: 3) |
| !112 = !DILocation(line: 26, column: 12, scope: !111) |
| !113 = !DILocation(line: 26, column: 8, scope: !111) |
| !114 = !DILocation(line: 26, column: 3, scope: !115) |
| !115 = !DILexicalBlockFile(scope: !116, file: !1, discriminator: 1) |
| !116 = distinct !DILexicalBlock(scope: !111, file: !1, line: 26, column: 3) |
| !117 = !DILocalVariable(name: "j", scope: !118, file: !1, line: 27, type: !8) |
| !118 = distinct !DILexicalBlock(scope: !116, file: !1, line: 27, column: 5) |
| !119 = !DILocation(line: 27, column: 14, scope: !118) |
| !120 = !DILocation(line: 27, column: 10, scope: !118) |
| !121 = !DILocation(line: 27, column: 5, scope: !122) |
| !122 = !DILexicalBlockFile(scope: !123, file: !1, discriminator: 1) |
| !123 = distinct !DILexicalBlock(scope: !118, file: !1, line: 27, column: 5) |
| !124 = !DILocation(line: 28, column: 17, scope: !123) |
| !125 = !DILocation(line: 28, column: 7, scope: !123) |
| !126 = !DILocation(line: 28, column: 15, scope: !123) |
| !127 = !DILocation(line: 27, column: 5, scope: !123) |
| !128 = !DILocation(line: 28, column: 23, scope: !118) |
| !129 = !DILocation(line: 26, column: 3, scope: !116) |
| !130 = !DILocation(line: 29, column: 1, scope: !16) |