[llvm] r214494 - SLPVectorizer: improved scheduling algorithm.

Joerg Sonnenberger joerg at britannica.bec.de
Tue Aug 26 15:31:38 PDT 2014


On Fri, Aug 01, 2014 at 09:20:43AM -0000, Erik Eckstein wrote:
> Author: eeckstein
> Date: Fri Aug  1 04:20:42 2014
> New Revision: 214494
> 
> URL: http://llvm.org/viewvc/llvm-project?rev=214494&view=rev
> Log:
> SLPVectorizer: improved scheduling algorithm.

This crashes on the attached input. Can you fix or revert please?

Joerg
-------------- next part --------------
; ModuleID = 'auth_poly1305_53-33b314.bc'
target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
target triple = "x86_64--netbsd"

@b = common global double 0.000000e+00, align 8
@c = common global i32 0, align 4
@e = common global double 0.000000e+00, align 8
@a = common global double 0.000000e+00, align 8
@d = common global double 0.000000e+00, align 8
@g = common global double 0.000000e+00, align 8
@f = common global double 0.000000e+00, align 8
@h = common global double 0.000000e+00, align 8
@i = common global double 0.000000e+00, align 8

; Function Attrs: nounwind uwtable
define i32 @fn1() #0 {
entry:
  %j = alloca double, align 8
  br label %multiplyaddatleast16bytes

multiplyaddatleast16bytes:                        ; preds = %if.end, %entry
  %0 = load double* @b, align 8
  %1 = load i32* @c, align 4
  %conv = sitofp i32 %1 to double
  %sub = fsub double %0, %conv
  store double %sub, double* @e, align 8
  %2 = load double* @a, align 8
  %3 = load double* @d, align 8
  %sub1 = fsub double %2, %3
  store double %sub1, double* @g, align 8
  %4 = load double* @e, align 8
  %5 = load double* @f, align 8
  %add = fadd double %5, %4
  store double %add, double* @f, align 8
  %6 = load double* @g, align 8
  %7 = load double* %j, align 8
  %add2 = fadd double %7, %6
  store double %add2, double* %j, align 8
  %8 = load double* @f, align 8
  %mul = fmul double 0.000000e+00, %8
  store double %mul, double* @h, align 8
  %9 = load double* @b, align 8
  %add3 = fadd double %9, 0.000000e+00
  store double %add3, double* @b, align 8
  %10 = load double* @h, align 8
  %11 = load double* @a, align 8
  %add4 = fadd double %11, %10
  store double %add4, double* @a, align 8
  %12 = load double* %j, align 8
  %mul5 = fmul double 0.000000e+00, %12
  store double %mul5, double* @i, align 8
  %13 = load double* @i, align 8
  %14 = load double* @a, align 8
  %add6 = fadd double %14, %13
  store double %add6, double* @a, align 8
  %15 = load double* @b, align 8
  %inc = fadd double %15, 1.000000e+00
  store double %inc, double* @b, align 8
  %16 = load double* @a, align 8
  %add7 = fadd double %16, 0.000000e+00
  store double %add7, double* @a, align 8
  %17 = load double* @a, align 8
  %tobool = fcmp une double %17, 0.000000e+00
  br i1 %tobool, label %if.then, label %if.end

if.then:                                          ; preds = %multiplyaddatleast16bytes
  ret i32 1

if.end:                                           ; preds = %multiplyaddatleast16bytes
  br label %multiplyaddatleast16bytes
}

attributes #0 = { nounwind uwtable "less-precise-fpmad"="false" "no-frame-pointer-elim"="true" "no-frame-pointer-elim-non-leaf" "no-infs-fp-math"="false" "no-nans-fp-math"="false" "stack-protector-buffer-size"="8" "unsafe-fp-math"="false" "use-soft-float"="false" }

!llvm.ident = !{!0}

!0 = metadata !{metadata !"clang version 3.6.0 (216456)"}


More information about the llvm-commits mailing list