1 ; RUN: opt %loadNPMPolly '-passes=print<polly-detect>' -disable-output < %s 2>&1 | FileCheck %s
3 ; CHECK: Valid Region for Scop:
5 ; void jd(int *A, int *B, int c) {
6 ; for (int i = 0; i < 1024; i++)
7 ; A[i] = B[c - 10] + B[5];
10 target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
12 define void @jd(ptr %A, ptr %B, i32 %c) {
16 for.cond: ; preds = %for.inc, %entry
17 %indvars.iv = phi i64 [ %indvars.iv.next, %for.inc ], [ 0, %entry ]
18 %exitcond = icmp ne i64 %indvars.iv, 1024
19 br i1 %exitcond, label %for.body, label %for.end
21 for.body: ; preds = %for.cond
22 %sub = add nsw i32 %c, -10
23 %idxprom = sext i32 %sub to i64
24 %arrayidx = getelementptr inbounds i32, ptr %B, i64 %idxprom
25 %tmp = load i32, ptr %arrayidx, align 4
26 %arrayidx1 = getelementptr inbounds i32, ptr %B, i64 5
27 %tmp1 = load i32, ptr %arrayidx1, align 4
28 %add = add nsw i32 %tmp, %tmp1
29 %arrayidx3 = getelementptr inbounds i32, ptr %A, i64 %indvars.iv
30 store i32 %add, ptr %arrayidx3, align 4
33 for.inc: ; preds = %for.body
34 %indvars.iv.next = add nuw nsw i64 %indvars.iv, 1
37 for.end: ; preds = %for.cond