mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-19 17:33:29 +00:00
3f75c6cfb5
We are not working on a DAG and I ran into a number of problems when I enabled the vectorizations of 'diamond-trees' (trees that share leafs). * Imroved the numbering API. * Changed the placement of new instructions to the last root. * Fixed a bug with external tree users with non-zero lane. * Fixed a bug in the placement of in-tree users. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@182508 91177308-0d34-0410-b5e6-96231b3b80d8
35 lines
1.2 KiB
LLVM
35 lines
1.2 KiB
LLVM
; RUN: opt < %s -basicaa -slp-vectorizer -dce -S -mtriple=x86_64-apple-macosx10.8.0 -mcpu=corei7
|
|
|
|
target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64-S128"
|
|
target triple = "x86_64-apple-macosx10.8.0"
|
|
|
|
%struct.hoge = type { double, double, double}
|
|
|
|
define void @zot(%struct.hoge* %arg) {
|
|
bb:
|
|
%tmp = load double* undef, align 8
|
|
%tmp1 = fsub double %tmp, undef
|
|
%tmp2 = load double* undef, align 8
|
|
%tmp3 = fsub double %tmp2, undef
|
|
%tmp4 = fmul double %tmp3, undef
|
|
%tmp5 = fmul double %tmp3, undef
|
|
%tmp6 = fsub double %tmp5, undef
|
|
%tmp7 = getelementptr inbounds %struct.hoge* %arg, i64 0, i32 1
|
|
store double %tmp6, double* %tmp7, align 8
|
|
%tmp8 = fmul double %tmp1, undef
|
|
%tmp9 = fsub double %tmp8, undef
|
|
%tmp10 = getelementptr inbounds %struct.hoge* %arg, i64 0, i32 2
|
|
store double %tmp9, double* %tmp10, align 8
|
|
br i1 undef, label %bb11, label %bb12
|
|
|
|
bb11: ; preds = %bb
|
|
br label %bb14
|
|
|
|
bb12: ; preds = %bb
|
|
%tmp13 = fmul double undef, %tmp2
|
|
br label %bb14
|
|
|
|
bb14: ; preds = %bb12, %bb11
|
|
ret void
|
|
}
|