Add compile command to each testcase
[gcc-vect-testsuite.git] / pr33860.ll
blob55d021684ac91255dc553f15199bf1b39c4a8c49
1 ; RUN: opt %loadPolly %defaultOpts -polly-codegen -enable-polly-vector -dce -S %s | FileCheck %s
2 ; ModuleID = 'pr33860.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 double]] }
8 define void @_ZN6Matrix23makeRotationAboutVectorEv(%class.Matrix* %this) uwtable align 2 {
9 entry:
10   %irx = alloca %class.Matrix, align 8
11   %ref.tmp = alloca %class.Matrix, align 8
12   %agg.tmp = alloca %class.Matrix, align 8
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 128, i32 8, i1 false)
16   call void @_ZNK6MatrixmlES_(%class.Matrix* sret %ref.tmp, %class.Matrix* %irx, %class.Matrix* byval align 8 %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 128, i32 8, i1 false)
20   ret void
23 define void @_ZNK6MatrixmlES_(%class.Matrix* sret %agg.result, %class.Matrix* %this, %class.Matrix* byval align 8 %matrix) nounwind uwtable align 2 {
24 entry:
25   br label %for.cond
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
33   br label %for.cond3
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 double* %arrayidx8, align 8
45   %tmp15 = load double* %arrayidx14, align 8
46   %add = fadd double %tmp9, %tmp15
47   store double %add, double* %arrayidx22, align 8
48   br label %for.inc
50 for.inc:                                          ; preds = %for.body6
51   %indvar.next = add i64 %indvar, 1
52   br label %for.cond3
54 for.end:                                          ; preds = %for.cond3
55   br label %for.inc24
57 for.inc24:                                        ; preds = %for.end
58   %indvar.next2 = add i64 %indvar1, 1
59   br label %for.cond
61 for.end27:                                        ; preds = %for.cond
62   ret void
65 declare void @llvm.memcpy.p0i8.p0i8.i64(i8* nocapture, i8* nocapture, i64, i32, i1) nounwind
66 ; CHECK: define