File: openmp-omp.private-dealloc.mlir

package info (click to toggle)
swiftlang 6.1.3-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 2,791,604 kB
  • sloc: cpp: 9,901,740; ansic: 2,201,431; asm: 1,091,827; python: 308,252; objc: 82,166; f90: 80,126; lisp: 38,358; pascal: 25,559; sh: 20,429; ml: 5,058; perl: 4,745; makefile: 4,484; awk: 3,535; javascript: 3,018; xml: 918; fortran: 664; cs: 573; ruby: 396
file content (53 lines) | stat: -rw-r--r-- 1,640 bytes parent folder | download | duplicates (6)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
// RUN: mlir-translate -mlir-to-llvmir -split-input-file %s | FileCheck %s

llvm.func @free(!llvm.ptr)

llvm.func @parallel_op_dealloc(%arg0: !llvm.ptr) {
  omp.parallel private(@x.privatizer %arg0 -> %arg2 : !llvm.ptr) {
    %0 = llvm.load %arg2 : !llvm.ptr -> f32
    omp.terminator
  }
  llvm.return
}

omp.private {type = firstprivate} @x.privatizer : !llvm.ptr alloc {
^bb0(%arg0: !llvm.ptr):
  %c1 = llvm.mlir.constant(1 : i32) : i32
  %0 = llvm.alloca %c1 x f32 : (i32) -> !llvm.ptr
  omp.yield(%0 : !llvm.ptr)
} copy {
^bb0(%arg0: !llvm.ptr, %arg1: !llvm.ptr):
  %0 = llvm.load %arg0 : !llvm.ptr -> f32
  llvm.store %0, %arg1 : f32, !llvm.ptr
  omp.yield(%arg1 : !llvm.ptr)
} dealloc {
^bb0(%arg0: !llvm.ptr):
  %0 = llvm.ptrtoint %arg0 : !llvm.ptr to i64
  %c0 = llvm.mlir.constant(0 : i64) : i64
  %1 = llvm.icmp "ne" %0, %c0 : i64
  llvm.cond_br %1, ^bb1, ^bb2

^bb1:
  llvm.call @free(%arg0) : (!llvm.ptr) -> ()
  llvm.br ^bb2

^bb2:
  omp.yield
}

// CHECK-LABEL: define internal void @parallel_op_dealloc..omp_par
// CHECK:         %[[LOCAL_ALLOC:.*]] = alloca float, align 4

// CHECK:      omp.par.pre_finalize:
// CHECK:        br label %[[DEALLOC_REG_START:.*]]

// CHECK:      [[DEALLOC_REG_START]]:
// CHECK:        %[[LOCAL_ALLOC_CONV:.*]] = ptrtoint ptr %[[LOCAL_ALLOC]] to i64
// CHECK:        %[[COND:.*]] = icmp ne i64 %[[LOCAL_ALLOC_CONV]], 0
// CHECK:        br i1 %[[COND]], label %[[DEALLOC_REG_BB1:.*]], label %[[DEALLOC_REG_BB2:.*]]

// CHECK:      [[DEALLOC_REG_BB2]]:

// CHECK:      [[DEALLOC_REG_BB1]]:
// CHECK-NEXT:   call void @free(ptr %[[LOCAL_ALLOC]])
// CHECK-NEXT:   br label %[[DEALLOC_REG_BB2]]