reduction2.ll 1.2 KB

12345678910111213141516171819202122232425262728293031323334
  1. ; RUN: opt < %s -basicaa -slp-vectorizer -dce -S -mtriple=i386-apple-macosx10.8.0 -mcpu=corei7-avx | FileCheck %s
  2. target datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f32:32:32-f64:32:64-v64:64:64-v128:128:128-a0:0:64-f80:128:128-n8:16:32-S128"
  3. target triple = "i386-apple-macosx10.8.0"
  4. ;CHECK-LABEL: @foo(
  5. ;CHECK: load <2 x double>
  6. ;CHECK: ret
  7. define double @foo(double* nocapture %D) {
  8. br label %1
  9. ; <label>:1 ; preds = %1, %0
  10. %i.02 = phi i32 [ 0, %0 ], [ %10, %1 ]
  11. %sum.01 = phi double [ 0.000000e+00, %0 ], [ %9, %1 ]
  12. %2 = shl nsw i32 %i.02, 1
  13. %3 = getelementptr inbounds double, double* %D, i32 %2
  14. %4 = load double, double* %3, align 4
  15. %A4 = fmul double %4, %4
  16. %A42 = fmul double %A4, %A4
  17. %5 = or i32 %2, 1
  18. %6 = getelementptr inbounds double, double* %D, i32 %5
  19. %7 = load double, double* %6, align 4
  20. %A7 = fmul double %7, %7
  21. %A72 = fmul double %A7, %A7
  22. %8 = fadd double %A42, %A72
  23. %9 = fadd double %sum.01, %8
  24. %10 = add nsw i32 %i.02, 1
  25. %exitcond = icmp eq i32 %10, 100
  26. br i1 %exitcond, label %11, label %1
  27. ; <label>:11 ; preds = %1
  28. ret double %9
  29. }