Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / openmp / libomptarget / test / offloading / info.c
blobecb5efb9b257e1a57e6dc891a8069c1c6f719def
1 // RUN: %libomptarget-compile-generic \
2 // RUN: -gline-tables-only -fopenmp-extensions
3 // RUN: env LIBOMPTARGET_INFO=63 %libomptarget-run-generic 2>&1 | \
4 // RUN: %fcheck-generic -allow-empty -check-prefixes=INFO
5 // RUN: env LIBOMPTARGET_INFO=63 %libomptarget-run-amdgcn-amd-amdhsa 2>&1 | \
6 // RUN: %fcheck-amdgcn-amd-amdhsa -allow-empty -check-prefixes=INFO,AMDGPU
8 #include <omp.h>
9 #include <stdio.h>
11 #define N 64
13 #pragma omp declare target
14 int global;
15 #pragma omp end declare target
17 extern void __tgt_set_info_flag(unsigned);
19 int main() {
20 int A[N];
21 int B[N];
22 int C[N];
23 int val = 1;
25 // clang-format off
26 // INFO: info: Entering OpenMP data region with being_mapper at info.c:{{[0-9]+}}:{{[0-9]+}} with 3 arguments:
27 // INFO: info: alloc(A[0:64])[256]
28 // INFO: info: tofrom(B[0:64])[256]
29 // INFO: info: to(C[0:64])[256]
30 // INFO: info: Creating new map entry with HstPtrBase={{.*}}, HstPtrBegin={{.*}}, TgtPtrBegin={{.*}}, Size=256, DynRefCount=1, HoldRefCount=0, Name=A[0:64]
31 // INFO: info: Creating new map entry with HstPtrBase={{.*}}, HstPtrBegin={{.*}}, TgtPtrBegin={{.*}}, Size=256, DynRefCount=0, HoldRefCount=1, Name=B[0:64]
32 // INFO: info: Copying data from host to device, HstPtr={{.*}}, TgtPtr={{.*}}, Size=256, Name=B[0:64]
33 // INFO: info: Creating new map entry with HstPtrBase={{.*}}, HstPtrBegin={{.*}}, TgtPtrBegin={{.*}}, Size=256, DynRefCount=1, HoldRefCount=0, Name=C[0:64]
34 // INFO: info: Copying data from host to device, HstPtr={{.*}}, TgtPtr={{.*}}, Size=256, Name=C[0:64]
35 // INFO: info: OpenMP Host-Device pointer mappings after block at info.c:{{[0-9]+}}:{{[0-9]+}}:
36 // INFO: info: Host Ptr Target Ptr Size (B) DynRefCount HoldRefCount Declaration
37 // INFO: info: {{.*}} {{.*}} 256 1 0 C[0:64] at info.c:{{[0-9]+}}:{{[0-9]+}}
38 // INFO: info: {{.*}} {{.*}} 256 0 1 B[0:64] at info.c:{{[0-9]+}}:{{[0-9]+}}
39 // INFO: info: {{.*}} {{.*}} 256 1 0 A[0:64] at info.c:{{[0-9]+}}:{{[0-9]+}}
40 // INFO: info: Entering OpenMP kernel at info.c:{{[0-9]+}}:{{[0-9]+}} with 1 arguments:
41 // INFO: info: firstprivate(val)[4]
42 // INFO: info: Launching kernel __omp_offloading_{{.*}}main{{.*}} with {{[0-9]+}} blocks and {{[0-9]+}} threads in Generic mode
43 // AMDGPU: AMDGPU device {{[0-9]}} info: #Args: {{[0-9]}} Teams x Thrds: {{[0-9]+}}x {{[0-9]+}} (MaxFlatWorkGroupSize: {{[0-9]+}}) LDS Usage: {{[0-9]+}}B #SGPRs/VGPRs: {{[0-9]+}}/{{[0-9]+}} #SGPR/VGPR Spills: {{[0-9]+}}/{{[0-9]+}} Tripcount: {{[0-9]+}}
44 // INFO: info: OpenMP Host-Device pointer mappings after block at info.c:{{[0-9]+}}:{{[0-9]+}}:
45 // INFO: info: Host Ptr Target Ptr Size (B) DynRefCount HoldRefCount Declaration
46 // INFO: info: {{.*}} {{.*}} 256 1 0 C[0:64] at info.c:{{[0-9]+}}:{{[0-9]+}}
47 // INFO: info: {{.*}} {{.*}} 256 0 1 B[0:64] at info.c:{{[0-9]+}}:{{[0-9]+}}
48 // INFO: info: {{.*}} {{.*}} 256 1 0 A[0:64] at info.c:{{[0-9]+}}:{{[0-9]+}}
49 // INFO: info: Exiting OpenMP data region with end_mapper at info.c:{{[0-9]+}}:{{[0-9]+}} with 3 arguments:
50 // INFO: info: alloc(A[0:64])[256]
51 // INFO: info: tofrom(B[0:64])[256]
52 // INFO: info: to(C[0:64])[256]
53 // INFO: info: Copying data from device to host, TgtPtr={{.*}}, HstPtr={{.*}}, Size=256, Name=B[0:64]
54 // INFO: info: Removing map entry with HstPtrBegin={{.*}}, TgtPtrBegin={{.*}}, Size=256, Name=C[0:64]
55 // INFO: info: Removing map entry with HstPtrBegin={{.*}}, TgtPtrBegin={{.*}}, Size=256, Name=B[0:64]
56 // INFO: info: Removing map entry with HstPtrBegin={{.*}}, TgtPtrBegin={{.*}}, Size=256, Name=A[0:64]
57 // INFO: info: OpenMP Host-Device pointer mappings after block at info.c:[[#%u,]]:[[#%u,]]:
58 // INFO: info: Host Ptr Target Ptr Size (B) DynRefCount HoldRefCount Declaration
59 // INFO: info: [[#%#x,]] [[#%#x,]] 4 INF 0 global at unknown:0:0
60 // clang-format on
61 #pragma omp target data map(alloc : A[0 : N]) \
62 map(ompx_hold, tofrom : B[0 : N]) map(to : C[0 : N])
63 #pragma omp target firstprivate(val)
64 { val = 1; }
66 __tgt_set_info_flag(0x0);
67 // INFO-NOT: Libomptarget device 0 info: {{.*}}
68 #pragma omp target
71 return 0;