| OLD | NEW |
| (Empty) |
| 1 ; RUN: opt < %s -loop-vectorize -force-vector-unroll=2 -force-vector-width=4 -S
| FileCheck %s | |
| 2 | |
| 3 target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f3
2:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:6
4-S128" | |
| 4 | |
| 5 ; Make sure consecutive vector generates correct negative indices. | |
| 6 ; PR15882 | |
| 7 | |
| 8 ; CHECK: reverse_induction_i64 | |
| 9 ; CHECK: add <4 x i64> %[[SPLAT:.*]], <i64 0, i64 -1, i64 -2, i64 -3> | |
| 10 ; CHECK: add <4 x i64> %[[SPLAT]], <i64 -4, i64 -5, i64 -6, i64 -7> | |
| 11 | |
| 12 define i32 @reverse_induction_i64(i64 %startval, i32 * %ptr) { | |
| 13 entry: | |
| 14 br label %for.body | |
| 15 | |
| 16 for.body: | |
| 17 %add.i7 = phi i64 [ %startval, %entry ], [ %add.i, %for.body ] | |
| 18 %i.06 = phi i32 [ 0, %entry ], [ %inc4, %for.body ] | |
| 19 %redux5 = phi i32 [ 0, %entry ], [ %inc.redux, %for.body ] | |
| 20 %add.i = add i64 %add.i7, -1 | |
| 21 %kind_.i = getelementptr inbounds i32* %ptr, i64 %add.i | |
| 22 %tmp.i1 = load i32* %kind_.i, align 4 | |
| 23 %inc.redux = add i32 %tmp.i1, %redux5 | |
| 24 %inc4 = add i32 %i.06, 1 | |
| 25 %exitcond = icmp ne i32 %inc4, 1024 | |
| 26 br i1 %exitcond, label %for.body, label %loopend | |
| 27 | |
| 28 loopend: | |
| 29 ret i32 %inc.redux | |
| 30 } | |
| 31 | |
| 32 ; CHECK: reverse_induction_i128 | |
| 33 ; CHECK: add <4 x i128> %[[SPLAT:.*]], <i128 0, i128 -1, i128 -2, i128 -3> | |
| 34 ; CHECK: add <4 x i128> %[[SPLAT]], <i128 -4, i128 -5, i128 -6, i128 -7> | |
| 35 define i32 @reverse_induction_i128(i128 %startval, i32 * %ptr) { | |
| 36 entry: | |
| 37 br label %for.body | |
| 38 | |
| 39 for.body: | |
| 40 %add.i7 = phi i128 [ %startval, %entry ], [ %add.i, %for.body ] | |
| 41 %i.06 = phi i32 [ 0, %entry ], [ %inc4, %for.body ] | |
| 42 %redux5 = phi i32 [ 0, %entry ], [ %inc.redux, %for.body ] | |
| 43 %add.i = add i128 %add.i7, -1 | |
| 44 %kind_.i = getelementptr inbounds i32* %ptr, i128 %add.i | |
| 45 %tmp.i1 = load i32* %kind_.i, align 4 | |
| 46 %inc.redux = add i32 %tmp.i1, %redux5 | |
| 47 %inc4 = add i32 %i.06, 1 | |
| 48 %exitcond = icmp ne i32 %inc4, 1024 | |
| 49 br i1 %exitcond, label %for.body, label %loopend | |
| 50 | |
| 51 loopend: | |
| 52 ret i32 %inc.redux | |
| 53 } | |
| 54 | |
| 55 ; CHECK: reverse_induction_i16 | |
| 56 ; CHECK: add <4 x i16> %[[SPLAT:.*]], <i16 0, i16 -1, i16 -2, i16 -3> | |
| 57 ; CHECK: add <4 x i16> %[[SPLAT]], <i16 -4, i16 -5, i16 -6, i16 -7> | |
| 58 | |
| 59 define i32 @reverse_induction_i16(i16 %startval, i32 * %ptr) { | |
| 60 entry: | |
| 61 br label %for.body | |
| 62 | |
| 63 for.body: | |
| 64 %add.i7 = phi i16 [ %startval, %entry ], [ %add.i, %for.body ] | |
| 65 %i.06 = phi i32 [ 0, %entry ], [ %inc4, %for.body ] | |
| 66 %redux5 = phi i32 [ 0, %entry ], [ %inc.redux, %for.body ] | |
| 67 %add.i = add i16 %add.i7, -1 | |
| 68 %kind_.i = getelementptr inbounds i32* %ptr, i16 %add.i | |
| 69 %tmp.i1 = load i32* %kind_.i, align 4 | |
| 70 %inc.redux = add i32 %tmp.i1, %redux5 | |
| 71 %inc4 = add i32 %i.06, 1 | |
| 72 %exitcond = icmp ne i32 %inc4, 1024 | |
| 73 br i1 %exitcond, label %for.body, label %loopend | |
| 74 | |
| 75 loopend: | |
| 76 ret i32 %inc.redux | |
| 77 } | |
| 78 | |
| 79 | |
| OLD | NEW |