1 ; RUN: opt %loadPolly %defaultOpts -polly-codegen -enable-polly-vector -dce -S %s | FileCheck %s
2 ; ModuleID = 'pr33860a.s'
3 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"
4 target triple = "x86_64-unknown-linux-gnu"
6 %class.Matrix = type { [4 x [4 x float]] }
8 define void @_ZN6Matrix23makeRotationAboutVectorEv(%class.Matrix* %this) uwtable align 2 {
10 %irx = alloca %class.Matrix, align 16
11 %ref.tmp = alloca %class.Matrix, align 16
12 %agg.tmp = alloca %class.Matrix, align 16
13 %tmp = bitcast %class.Matrix* %agg.tmp to i8*
14 %tmp2 = bitcast %class.Matrix* %this to i8*
15 call void @llvm.memcpy.p0i8.p0i8.i64(i8* %tmp, i8* %tmp2, i64 64, i32 16, i1 false)
16 call void @_ZNK6MatrixmlES_(%class.Matrix* sret %ref.tmp, %class.Matrix* %irx, %class.Matrix* byval align 16 %agg.tmp)
17 %tmp3 = bitcast %class.Matrix* %this to i8*
18 %tmp4 = bitcast %class.Matrix* %ref.tmp to i8*
19 call void @llvm.memcpy.p0i8.p0i8.i64(i8* %tmp3, i8* %tmp4, i64 64, i32 16, i1 false)
23 define void @_ZNK6MatrixmlES_(%class.Matrix* sret %agg.result, %class.Matrix* %this, %class.Matrix* byval align 16 %matrix) nounwind uwtable align 2 {
27 for.cond: ; preds = %for.inc24, %entry
28 %indvar1 = phi i64 [ %indvar.next2, %for.inc24 ], [ 0, %entry ]
29 %exitcond3 = icmp ne i64 %indvar1, 4
30 br i1 %exitcond3, label %for.body, label %for.end27
32 for.body: ; preds = %for.cond
35 for.cond3: ; preds = %for.inc, %for.body
36 %indvar = phi i64 [ %indvar.next, %for.inc ], [ 0, %for.body ]
37 %arrayidx22 = getelementptr %class.Matrix* %agg.result, i64 0, i32 0, i64 %indvar, i64 %indvar1
38 %arrayidx14 = getelementptr %class.Matrix* %matrix, i64 0, i32 0, i64 %indvar, i64 3
39 %arrayidx8 = getelementptr %class.Matrix* %matrix, i64 0, i32 0, i64 %indvar, i64 2
40 %exitcond = icmp ne i64 %indvar, 4
41 br i1 %exitcond, label %for.body6, label %for.end
43 for.body6: ; preds = %for.cond3
44 %tmp9 = load float* %arrayidx8, align 8
45 %tmp15 = load float* %arrayidx14, align 4
46 %add = fadd float %tmp9, %tmp15
47 store float %add, float* %arrayidx22, align 4
50 for.inc: ; preds = %for.body6
51 %indvar.next = add i64 %indvar, 1
54 for.end: ; preds = %for.cond3
57 for.inc24: ; preds = %for.end
58 %indvar.next2 = add i64 %indvar1, 1
61 for.end27: ; preds = %for.cond
65 declare void @llvm.memcpy.p0i8.p0i8.i64(i8* nocapture, i8* nocapture, i64, i32, i1) nounwind