[RISCV] Fix mgather -> riscv.masked.strided.load combine not extending indices (...
[llvm-project.git] / polly / test / ScopDetect / multidim_indirect_access.ll
blob3e06251f5fd157ba5750f5fdc2dbf37ca32cf026
1 ; RUN: opt %loadPolly -polly-print-detect -disable-output < %s | FileCheck %s
3 ; Check that we will recognize this SCoP.
5 ;    void f(int *A, long N) {
6 ;      int j = 0;
7 ;      while (N > j) {
8 ;        int x = A[0];
9 ;        int i = 1;
10 ;        do {
11 ;          A[x] = 42;
12 ;          A += x;
13 ;        } while (i++ < N);
14 ;      }
15 ;    }
17 ; CHECK: Valid Region for Scop: bb1 => bb0
19 target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
21 define void @f(ptr %A, i64 %N) {
22 bb:
23   br label %bb0
25 bb0:
26   %j = phi i64 [ %j.next, %bb1 ], [ 1, %bb ]
27   %tmp = load i32, ptr %A, align 4
28   %exitcond0 = icmp sgt i64 %N, %j
29   %j.next = add nuw nsw i64 %j, 1
30   br i1 %exitcond0, label %bb1, label %bb13
32 bb1:                                              ; preds = %bb7, %bb0
33   %i = phi i64 [ %i.next, %bb1 ], [ 1, %bb0 ]
34   %.0 = phi ptr [ %A, %bb0 ], [ %tmp12, %bb1 ]
35   %tmp8 = sext i32 %tmp to i64
36   %tmp9 = getelementptr inbounds i32, ptr %.0, i64 %tmp8
37   store i32 42, ptr %tmp9, align 4
38   %tmp11 = sext i32 %tmp to i64
39   %tmp12 = getelementptr inbounds i32, ptr %.0, i64 %tmp11
40   %i.next = add nuw nsw i64 %i, 1
41   %exitcond = icmp ne i64 %i, %N
42   br i1 %exitcond, label %bb1, label %bb0
44 bb13:                                             ; preds = %bb1
45   ret void