blob: f9e849ec1026e494804bbf1717b3127b99cd4f38 [file] [log] [blame]
Roman Gareevd7754a12016-07-30 09:25:51 +00001; RUN: opt %loadPolly -polly-scops -analyze -polly-import-jscop-dir=%S -polly-import-jscop -polly-import-jscop-postfix=transformed < %s 2>&1 | FileCheck %s
2; RUN: opt %loadPolly -polly-import-jscop-dir=%S -polly-import-jscop -polly-import-jscop-postfix=transformed -polly-codegen -S < %s 2>&1 | FileCheck %s --check-prefix=CODEGEN
3;
4; for (i = 0; i < _PB_NI; i++)
5; for (j = 0; j < _PB_NJ; j++)
6; for (k = 0; k < _PB_NK; ++k)
7; B[i][j] = beta * A[i][k];
8;
9;
10; CHECK: Arrays {
11; CHECK: double MemRef_B[*][1024]; // Element size 8
12; CHECK: double MemRef_beta; // Element size 8
13; CHECK: double MemRef_A[*][1056]; // Element size 8
14; CHECK: double D[*][270336]; // Element size 8
15; CHECK: double E[*][270336][200000]; // Element size 8
16; CHECK: i64 F[*][270336]; // Element size 8
17;
Roman Gareev44aeef72016-08-26 13:41:53 +000018; CHECK:New access function '{ Stmt_bb12[i0, i1, i2] -> E[0, i2, i0] }'detected in JSCOP file
Roman Gareevd7754a12016-07-30 09:25:51 +000019;
Roman Gareev0c09a3a2016-07-30 11:15:00 +000020; CODEGEN:define internal void @create_arrays(i32 %arg, i32 %arg1, i32 %arg2, double %arg3, double %beta, [1056 x double]* %A, [1024 x double]* %B, [1056 x double]* %arg7) #0 {
21; CODEGEN:bb:
22; CODEGEN: %beta.s2a = alloca double
23; CODEGEN: %D = alloca [270336 x double]
24; CODEGEN: %E = alloca [270336 x [200000 x double]]
25; CODEGEN: %F = alloca [270336 x i64]
26; CODEGEN: br label %bb8
Roman Gareevd7754a12016-07-30 09:25:51 +000027;
Roman Gareev44aeef72016-08-26 13:41:53 +000028; CODEGEN: %beta.s2a.reload = load double, double* %beta.s2a
Roman Gareevd7754a12016-07-30 09:25:51 +000029; CODEGEN: %polly.access.cast.E = bitcast [270336 x [200000 x double]]* %E to double*
Roman Gareev44aeef72016-08-26 13:41:53 +000030; CODEGEN: %polly.access.add.E = add nsw i64 0, %polly.indvar33
31; CODEGEN: %polly.access.mul.E = mul nsw i64 %polly.access.add.E, 200000
32; CODEGEN: %polly.access.add.E36 = add nsw i64 %polly.access.mul.E, %polly.indvar
Roman Gareevd7754a12016-07-30 09:25:51 +000033;
34target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
35target triple = "x86_64-unknown-unknown"
36
37; Function Attrs: nounwind uwtable
38define internal void @create_arrays(i32 %arg, i32 %arg1, i32 %arg2, double %arg3, double %beta, [1056 x double]* %A, [1024 x double]* %B, [1056 x double]* %arg7) #0 {
39bb:
40 br label %bb8
41
42bb8: ; preds = %bb
43 br label %bb9
44
45bb9: ; preds = %bb23, %bb8
46 %tmp = phi i64 [ 0, %bb8 ], [ %tmp24, %bb23 ]
47 br label %bb10
48
49bb10: ; preds = %bb20, %bb9
50 %tmp11 = phi i64 [ 0, %bb9 ], [ %tmp21, %bb20 ]
51 br label %bb12
52
53bb12: ; preds = %bb12, %bb10
54 %tmp13 = phi i64 [ 0, %bb10 ], [ %tmp18, %bb12 ]
55 %tmp14 = getelementptr inbounds [1024 x double], [1024 x double]* %B, i64 %tmp, i64 %tmp13
56 %tmp15 = load double, double* %tmp14, align 8
57 %tmp16 = fmul double %tmp15, %beta
58 %tmp17 = getelementptr inbounds [1056 x double], [1056 x double]* %A, i64 %tmp, i64 %tmp11
59 store double %tmp16, double* %tmp17, align 8
60 %tmp18 = add nuw nsw i64 %tmp13, 1
61 %tmp19 = icmp ne i64 %tmp18, 1024
62 br i1 %tmp19, label %bb12, label %bb20
63
64bb20: ; preds = %bb12
65 %tmp21 = add nuw nsw i64 %tmp11, 1
66 %tmp22 = icmp ne i64 %tmp21, 1056
67 br i1 %tmp22, label %bb10, label %bb23
68
69bb23: ; preds = %bb20
70 %tmp24 = add nuw nsw i64 %tmp, 1
71 %tmp25 = icmp ne i64 %tmp24, 1056
72 br i1 %tmp25, label %bb9, label %bb26
73
74bb26: ; preds = %bb23
75 ret void
76}
77
78attributes #0 = { nounwind uwtable "target-cpu"="x86-64" "target-features"="+aes,+avx,+cmov,+cx16,+fxsr,+mmx,+pclmul,+popcnt,+sse,+sse2,+sse3,+sse4.1,+sse4.2,+ssse3,+x87,+xsave,+xsaveopt" }