1 ; RUN: opt -S -slp-vectorizer < %s | FileCheck %s 2 3 target datalayout = "e-m:e-i64:64-i128:128-n32:64-S128" 4 target triple = "aarch64--linux-gnu" 5 6 ; This test ensures that we do not regress due to PR26364. The vectorizer 7 ; should not compute a smaller size for %k.13 since it is in a use-def cycle 8 ; and cannot be demoted. 9 ; 10 ; CHECK-LABEL: @PR26364 11 ; CHECK: %k.13 = phi i32 12 ; 13 define fastcc void @PR26364() { 14 entry: 15 br i1 undef, label %for.end11, label %for.cond4 16 17 for.cond4: 18 %k.13 = phi i32 [ undef, %entry ], [ %k.3, %for.cond4 ] 19 %e.02 = phi i32 [ 1, %entry ], [ 0, %for.cond4 ] 20 %e.1 = select i1 undef, i32 %e.02, i32 0 21 %k.3 = select i1 undef, i32 %k.13, i32 undef 22 br label %for.cond4 23 24 for.end11: 25 ret void 26 } 27 28 ; This test ensures that we do not regress due to PR26629. We must look at 29 ; every root in the vectorizable tree when computing minimum sizes since one 30 ; root may require fewer bits than another. 31 ; 32 ; CHECK-LABEL: @PR26629 33 ; CHECK-NOT: {{.*}} and <2 x i72> 34 ; 35 define void @PR26629(i32* %c) { 36 entry: 37 br i1 undef, label %for.ph, label %for.end 38 39 for.ph: 40 %0 = load i32, i32* %c, align 4 41 br label %for.body 42 43 for.body: 44 %d = phi i72 [ 576507472957710340, %for.ph ], [ %bf.set17, %for.body ] 45 %sub = sub i32 %0, undef 46 %bf.clear13 = and i72 %d, -576460748008464384 47 %1 = zext i32 %sub to i72 48 %bf.value15 = and i72 %1, 8191 49 %bf.clear16 = or i72 %bf.value15, %bf.clear13 50 %bf.set17 = or i72 %bf.clear16, undef 51 br label %for.body 52 53 for.end: 54 ret void 55 } 56