annotate polly/test/GPGPU/managed-memory-rewrite-malloc-free-inside-constexpr.ll @ 252:1f2b6ac9f198 llvm-original

LLVM16-1
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Fri, 18 Aug 2023 09:04:13 +0900
parents c4bab56944e8
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
236
c4bab56944e8 LLVM 16
kono
parents: 150
diff changeset
1 ; RUN: opt %loadPolly -polly-print-scops -disable-output < %s | FileCheck %s --check-prefix=SCOP
150
anatofuz
parents:
diff changeset
2
anatofuz
parents:
diff changeset
3 ; RUN: opt %loadPolly -polly-codegen-ppcg \
anatofuz
parents:
diff changeset
4 ; RUN: -S -polly-acc-codegen-managed-memory \
anatofuz
parents:
diff changeset
5 ; RUN: -polly-acc-rewrite-managed-memory < %s | FileCheck %s --check-prefix=HOST-IR
anatofuz
parents:
diff changeset
6 ;
anatofuz
parents:
diff changeset
7 ; REQUIRES: pollyacc
anatofuz
parents:
diff changeset
8 ;
anatofuz
parents:
diff changeset
9 ; Check that we can correctly rewrite `malloc` to `polly_mallocManaged`, and
anatofuz
parents:
diff changeset
10 ; `free` to `polly_freeManaged` with the `polly-acc-rewrite-managed-memory`
anatofuz
parents:
diff changeset
11 ; pass, even inside `constantExpr`. This is necessary because a cookie cutter
anatofuz
parents:
diff changeset
12 ; Inst->replaceUsesOfWith(...) call does not actually work, because this does
anatofuz
parents:
diff changeset
13 ; not replace the instruction within a ConstantExpr.
anatofuz
parents:
diff changeset
14 ;
anatofuz
parents:
diff changeset
15 ; #include <memory.h>
anatofuz
parents:
diff changeset
16 ;
anatofuz
parents:
diff changeset
17 ; static const int N = 100;
anatofuz
parents:
diff changeset
18 ; int* f(int *ToFree) {
anatofuz
parents:
diff changeset
19 ; free(ToFree);
anatofuz
parents:
diff changeset
20 ; int *A = (int *)malloc(sizeof(int) * N);
anatofuz
parents:
diff changeset
21 ; for(int i = 0; i < N; i++) {
anatofuz
parents:
diff changeset
22 ; A[i] = 42;
anatofuz
parents:
diff changeset
23 ; }
anatofuz
parents:
diff changeset
24 ; return A;
anatofuz
parents:
diff changeset
25 ;
anatofuz
parents:
diff changeset
26 ; }
anatofuz
parents:
diff changeset
27
anatofuz
parents:
diff changeset
28 ; SCOP: Function: f
anatofuz
parents:
diff changeset
29 ; SCOP-NEXT: Region: %for.body---%for.end
anatofuz
parents:
diff changeset
30 ; SCOP-NEXT: Max Loop Depth: 1
anatofuz
parents:
diff changeset
31
anatofuz
parents:
diff changeset
32 ; SCOP: Arrays {
anatofuz
parents:
diff changeset
33 ; SCOP-NEXT: i32 MemRef_tmp[*]; // Element size 4
anatofuz
parents:
diff changeset
34 ; SCOP-NEXT: }
anatofuz
parents:
diff changeset
35
anatofuz
parents:
diff changeset
36 ; // Check that polly_mallocManaged is declared and used correctly.
anatofuz
parents:
diff changeset
37 ; HOST-IR: %1 = bitcast i8* (i64)* @polly_mallocManaged to i32* (i64)*
anatofuz
parents:
diff changeset
38 ; HOST-IR: declare i8* @polly_mallocManaged(i64)
anatofuz
parents:
diff changeset
39
anatofuz
parents:
diff changeset
40 ; // Check that polly_freeManaged is declared and used correctly.
anatofuz
parents:
diff changeset
41 ; HOST-IR call void @polly_freeManaged(i8* %toFree)
anatofuz
parents:
diff changeset
42 ; HOST-IR: declare void @polly_freeManaged(i8*)
anatofuz
parents:
diff changeset
43
anatofuz
parents:
diff changeset
44 ; // Check that we remove the original malloc,free
anatofuz
parents:
diff changeset
45 ; HOST-IR-NOT: declare i8* @malloc(i64)
anatofuz
parents:
diff changeset
46 ; HOST-IR-NOT: declare void @free(i8*)
anatofuz
parents:
diff changeset
47
anatofuz
parents:
diff changeset
48 target datalayout = "e-m:o-i64:64-f80:128-n8:16:32:64-S128"
anatofuz
parents:
diff changeset
49 target triple = "x86_64-apple-macosx10.12.0"
anatofuz
parents:
diff changeset
50
anatofuz
parents:
diff changeset
51 define i32* @f(i32 *%toFree) {
anatofuz
parents:
diff changeset
52 entry:
anatofuz
parents:
diff changeset
53 ; Free inside bitcast
anatofuz
parents:
diff changeset
54 call void bitcast (void (i8*)* @free to void (i32 *)*) (i32 * %toFree)
anatofuz
parents:
diff changeset
55 br label %entry.split
anatofuz
parents:
diff changeset
56
anatofuz
parents:
diff changeset
57 entry.split: ; preds = %entry
anatofuz
parents:
diff changeset
58 ; malloc inside bitcast.
anatofuz
parents:
diff changeset
59 %tmp = call i32* bitcast (i8* (i64)* @malloc to i32* (i64)*) (i64 400)
anatofuz
parents:
diff changeset
60 br label %for.body
anatofuz
parents:
diff changeset
61
anatofuz
parents:
diff changeset
62 for.body: ; preds = %entry.split, %for.body
anatofuz
parents:
diff changeset
63 %indvars.iv1 = phi i64 [ 0, %entry.split ], [ %indvars.iv.next, %for.body ]
anatofuz
parents:
diff changeset
64 %arrayidx = getelementptr inbounds i32, i32* %tmp, i64 %indvars.iv1
anatofuz
parents:
diff changeset
65 store i32 42, i32* %arrayidx, align 4, !tbaa !3
anatofuz
parents:
diff changeset
66 %indvars.iv.next = add nuw nsw i64 %indvars.iv1, 1
anatofuz
parents:
diff changeset
67 %exitcond = icmp eq i64 %indvars.iv.next, 100
anatofuz
parents:
diff changeset
68 br i1 %exitcond, label %for.end, label %for.body
anatofuz
parents:
diff changeset
69
anatofuz
parents:
diff changeset
70 for.end: ; preds = %for.body
anatofuz
parents:
diff changeset
71 ret i32* %tmp
anatofuz
parents:
diff changeset
72 }
anatofuz
parents:
diff changeset
73
anatofuz
parents:
diff changeset
74 ; Function Attrs: argmemonly nounwind
anatofuz
parents:
diff changeset
75 declare void @llvm.lifetime.start.p0i8(i64, i8* nocapture) #0
anatofuz
parents:
diff changeset
76
anatofuz
parents:
diff changeset
77 declare i8* @malloc(i64)
anatofuz
parents:
diff changeset
78 declare void @free(i8*)
anatofuz
parents:
diff changeset
79
anatofuz
parents:
diff changeset
80 ; Function Attrs: argmemonly nounwind
anatofuz
parents:
diff changeset
81 declare void @llvm.lifetime.end.p0i8(i64, i8* nocapture) #0
anatofuz
parents:
diff changeset
82
anatofuz
parents:
diff changeset
83 attributes #0 = { argmemonly nounwind }
anatofuz
parents:
diff changeset
84
anatofuz
parents:
diff changeset
85 !llvm.module.flags = !{!0, !1}
anatofuz
parents:
diff changeset
86 !llvm.ident = !{!2}
anatofuz
parents:
diff changeset
87
anatofuz
parents:
diff changeset
88 !0 = !{i32 1, !"wchar_size", i32 4}
anatofuz
parents:
diff changeset
89 !1 = !{i32 7, !"PIC Level", i32 2}
anatofuz
parents:
diff changeset
90 !2 = !{!"clang version 6.0.0"}
anatofuz
parents:
diff changeset
91 !3 = !{!4, !4, i64 0}
anatofuz
parents:
diff changeset
92 !4 = !{!"int", !5, i64 0}
anatofuz
parents:
diff changeset
93 !5 = !{!"omnipotent char", !6, i64 0}
anatofuz
parents:
diff changeset
94 !6 = !{!"Simple C/C++ TBAA"}