Michael Kruse | 5c02808 | 2022-03-14 08:39:25 -0500 | [diff] [blame] | 1 | ; RUN: opt %loadPolly -polly-reschedule=0 -polly-loopfusion-greedy=1 -polly-postopts=0 -polly-print-opt-isl -disable-output < %s | FileCheck %s --check-prefixes=CHECK,RAW |
| 2 | ; RUN: opt %loadPolly -polly-reschedule=1 -polly-loopfusion-greedy=1 -polly-postopts=0 -polly-print-opt-isl -disable-output < %s | FileCheck %s --check-prefixes=CHECK |
Michael Kruse | 6448925 | 2021-10-08 19:49:40 -0500 | [diff] [blame] | 3 | |
Nikita Popov | b332499 | 2023-01-17 10:12:02 +0100 | [diff] [blame^] | 4 | define void @func(i32 %n, ptr noalias nonnull %A, ptr noalias nonnull %B, i32 %k) { |
Michael Kruse | 6448925 | 2021-10-08 19:49:40 -0500 | [diff] [blame] | 5 | entry: |
| 6 | br label %for1 |
| 7 | |
| 8 | |
| 9 | for1: |
| 10 | %j1 = phi i32 [0, %entry], [%j1.inc, %inc1] |
| 11 | %j1.cmp = icmp slt i32 %j1, %n |
| 12 | br i1 %j1.cmp, label %body1, label %exit1 |
| 13 | |
| 14 | body1: |
Nikita Popov | b332499 | 2023-01-17 10:12:02 +0100 | [diff] [blame^] | 15 | %arrayidx1 = getelementptr inbounds double, ptr %A, i32 %j1 |
| 16 | store double 21.0, ptr %arrayidx1 |
Michael Kruse | 6448925 | 2021-10-08 19:49:40 -0500 | [diff] [blame] | 17 | br label %inc1 |
| 18 | |
| 19 | inc1: |
| 20 | %j1.inc = add nuw nsw i32 %j1, 1 |
| 21 | br label %for1 |
| 22 | |
| 23 | exit1: |
| 24 | br label %for2 |
| 25 | |
| 26 | |
| 27 | for2: |
| 28 | %j2 = phi i32 [0, %exit1], [%j2.inc, %inc2] |
| 29 | %j2.cmp = icmp slt i32 %j2, %n |
| 30 | br i1 %j2.cmp, label %body2, label %exit2 |
| 31 | |
| 32 | body2: |
Nikita Popov | b332499 | 2023-01-17 10:12:02 +0100 | [diff] [blame^] | 33 | %arrayidx2 = getelementptr inbounds double, ptr %B, i32 %j2 |
| 34 | store double 42.0, ptr %arrayidx2 |
Michael Kruse | 6448925 | 2021-10-08 19:49:40 -0500 | [diff] [blame] | 35 | br label %inc2 |
| 36 | |
| 37 | inc2: |
| 38 | %j2.inc = add nuw nsw i32 %j2, 1 |
| 39 | br label %for2 |
| 40 | |
| 41 | exit2: |
| 42 | br label %for3 |
| 43 | |
| 44 | |
| 45 | for3: |
| 46 | %j3 = phi i32 [0, %exit2], [%j3.inc, %inc3] |
| 47 | %j3.cmp = icmp slt i32 %j3, %n |
| 48 | br i1 %j3.cmp, label %body3, label %exit3 |
| 49 | |
| 50 | body3: |
| 51 | %idx3 = add i32 %j3, %k |
Nikita Popov | b332499 | 2023-01-17 10:12:02 +0100 | [diff] [blame^] | 52 | %arrayidx3 = getelementptr inbounds double, ptr %B, i32 %idx3 |
| 53 | store double 84.0, ptr %arrayidx3 |
Michael Kruse | 6448925 | 2021-10-08 19:49:40 -0500 | [diff] [blame] | 54 | br label %inc3 |
| 55 | |
| 56 | inc3: |
| 57 | %j3.inc = add nuw nsw i32 %j3, 1 |
| 58 | br label %for3, !llvm.loop !1 |
| 59 | |
| 60 | exit3: |
| 61 | br label %return |
| 62 | |
| 63 | |
| 64 | return: |
| 65 | ret void |
| 66 | } |
| 67 | |
| 68 | |
| 69 | !1 = distinct !{!1, !2} |
| 70 | !2 = !{!"llvm.loop.id", !"Hello World!"} |
| 71 | |
| 72 | |
| 73 | ; CHECK: Calculated schedule: |
| 74 | ; CHECK-NEXT: domain: "[n, k] -> { Stmt_body2[i0] : 0 <= i0 < n; Stmt_body1[i0] : 0 <= i0 < n; Stmt_body3[i0] : 0 <= i0 < n }" |
| 75 | ; CHECK-NEXT: child: |
| 76 | ; CHECK-NEXT: sequence: |
| 77 | ; CHECK-NEXT: - filter: "[n, k] -> { Stmt_body2[i0]; Stmt_body1[i0] }" |
| 78 | ; CHECK-NEXT: child: |
| 79 | ; CHECK-NEXT: schedule: "[n, k] -> [{ Stmt_body2[i0] -> [(i0)]; Stmt_body1[i0] -> [(i0)] }]" |
| 80 | ; CHECK-NEXT: child: |
| 81 | ; CHECK-NEXT: sequence: |
| 82 | ; CHECK-NEXT: - filter: "[n, k] -> { Stmt_body1[i0] }" |
| 83 | ; CHECK-NEXT: - filter: "[n, k] -> { Stmt_body2[i0] }" |
| 84 | ; CHECK-NEXT: - filter: "[n, k] -> { Stmt_body3[i0] }" |
| 85 | ; CHECK-NEXT: child: |
| 86 | ; RAW-NEXT: mark: "Loop with Metadata" |
| 87 | ; RAW-NEXT: child: |
| 88 | ; CHECK-NEXT: schedule: "[n, k] -> [{ Stmt_body3[i0] -> [(i0)] }]" |