1*269d5c16SJoseph Huber //===-------- LegacyAPI.cpp - Target independent OpenMP target RTL --------===//
2*269d5c16SJoseph Huber //
3*269d5c16SJoseph Huber // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4*269d5c16SJoseph Huber // See https://llvm.org/LICENSE.txt for license information.
5*269d5c16SJoseph Huber // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6*269d5c16SJoseph Huber //
7*269d5c16SJoseph Huber //===----------------------------------------------------------------------===//
8*269d5c16SJoseph Huber //
9*269d5c16SJoseph Huber // Legacy interfaces for libomptarget used to maintain backwards-compatibility.
10*269d5c16SJoseph Huber //
11*269d5c16SJoseph Huber //===----------------------------------------------------------------------===//
12*269d5c16SJoseph Huber
13*269d5c16SJoseph Huber #include "omptarget.h"
14*269d5c16SJoseph Huber #include "private.h"
15*269d5c16SJoseph Huber
__tgt_target_data_begin(int64_t DeviceId,int32_t ArgNum,void ** ArgsBase,void ** Args,int64_t * ArgSizes,int64_t * ArgTypes)16*269d5c16SJoseph Huber EXTERN void __tgt_target_data_begin(int64_t DeviceId, int32_t ArgNum,
17*269d5c16SJoseph Huber void **ArgsBase, void **Args,
18*269d5c16SJoseph Huber int64_t *ArgSizes, int64_t *ArgTypes) {
19*269d5c16SJoseph Huber TIMESCOPE();
20*269d5c16SJoseph Huber __tgt_target_data_begin_mapper(nullptr, DeviceId, ArgNum, ArgsBase, Args,
21*269d5c16SJoseph Huber ArgSizes, ArgTypes, nullptr, nullptr);
22*269d5c16SJoseph Huber }
23*269d5c16SJoseph Huber
__tgt_target_data_begin_nowait(int64_t DeviceId,int32_t ArgNum,void ** ArgsBase,void ** Args,int64_t * ArgSizes,int64_t * ArgTypes,int32_t DepNum,void * DepList,int32_t NoAliasDepNum,void * NoAliasDepList)24*269d5c16SJoseph Huber EXTERN void __tgt_target_data_begin_nowait(int64_t DeviceId, int32_t ArgNum,
25*269d5c16SJoseph Huber void **ArgsBase, void **Args,
26*269d5c16SJoseph Huber int64_t *ArgSizes, int64_t *ArgTypes,
27*269d5c16SJoseph Huber int32_t DepNum, void *DepList,
28*269d5c16SJoseph Huber int32_t NoAliasDepNum,
29*269d5c16SJoseph Huber void *NoAliasDepList) {
30*269d5c16SJoseph Huber TIMESCOPE();
31*269d5c16SJoseph Huber
32*269d5c16SJoseph Huber __tgt_target_data_begin_mapper(nullptr, DeviceId, ArgNum, ArgsBase, Args,
33*269d5c16SJoseph Huber ArgSizes, ArgTypes, nullptr, nullptr);
34*269d5c16SJoseph Huber }
35*269d5c16SJoseph Huber
__tgt_target_data_end(int64_t DeviceId,int32_t ArgNum,void ** ArgsBase,void ** Args,int64_t * ArgSizes,int64_t * ArgTypes)36*269d5c16SJoseph Huber EXTERN void __tgt_target_data_end(int64_t DeviceId, int32_t ArgNum,
37*269d5c16SJoseph Huber void **ArgsBase, void **Args,
38*269d5c16SJoseph Huber int64_t *ArgSizes, int64_t *ArgTypes) {
39*269d5c16SJoseph Huber TIMESCOPE();
40*269d5c16SJoseph Huber __tgt_target_data_end_mapper(nullptr, DeviceId, ArgNum, ArgsBase, Args,
41*269d5c16SJoseph Huber ArgSizes, ArgTypes, nullptr, nullptr);
42*269d5c16SJoseph Huber }
43*269d5c16SJoseph Huber
__tgt_target_data_update(int64_t DeviceId,int32_t ArgNum,void ** ArgsBase,void ** Args,int64_t * ArgSizes,int64_t * ArgTypes)44*269d5c16SJoseph Huber EXTERN void __tgt_target_data_update(int64_t DeviceId, int32_t ArgNum,
45*269d5c16SJoseph Huber void **ArgsBase, void **Args,
46*269d5c16SJoseph Huber int64_t *ArgSizes, int64_t *ArgTypes) {
47*269d5c16SJoseph Huber TIMESCOPE();
48*269d5c16SJoseph Huber __tgt_target_data_update_mapper(nullptr, DeviceId, ArgNum, ArgsBase, Args,
49*269d5c16SJoseph Huber ArgSizes, ArgTypes, nullptr, nullptr);
50*269d5c16SJoseph Huber }
51*269d5c16SJoseph Huber
__tgt_target_data_update_nowait(int64_t DeviceId,int32_t ArgNum,void ** ArgsBase,void ** Args,int64_t * ArgSizes,int64_t * ArgTypes,int32_t DepNum,void * DepList,int32_t NoAliasDepNum,void * NoAliasDepList)52*269d5c16SJoseph Huber EXTERN void __tgt_target_data_update_nowait(
53*269d5c16SJoseph Huber int64_t DeviceId, int32_t ArgNum, void **ArgsBase, void **Args,
54*269d5c16SJoseph Huber int64_t *ArgSizes, int64_t *ArgTypes, int32_t DepNum, void *DepList,
55*269d5c16SJoseph Huber int32_t NoAliasDepNum, void *NoAliasDepList) {
56*269d5c16SJoseph Huber TIMESCOPE();
57*269d5c16SJoseph Huber
58*269d5c16SJoseph Huber __tgt_target_data_update_mapper(nullptr, DeviceId, ArgNum, ArgsBase, Args,
59*269d5c16SJoseph Huber ArgSizes, ArgTypes, nullptr, nullptr);
60*269d5c16SJoseph Huber }
61*269d5c16SJoseph Huber
__tgt_target_data_end_nowait(int64_t DeviceId,int32_t ArgNum,void ** ArgsBase,void ** Args,int64_t * ArgSizes,int64_t * ArgTypes,int32_t DepNum,void * DepList,int32_t NoAliasDepNum,void * NoAliasDepList)62*269d5c16SJoseph Huber EXTERN void __tgt_target_data_end_nowait(int64_t DeviceId, int32_t ArgNum,
63*269d5c16SJoseph Huber void **ArgsBase, void **Args,
64*269d5c16SJoseph Huber int64_t *ArgSizes, int64_t *ArgTypes,
65*269d5c16SJoseph Huber int32_t DepNum, void *DepList,
66*269d5c16SJoseph Huber int32_t NoAliasDepNum,
67*269d5c16SJoseph Huber void *NoAliasDepList) {
68*269d5c16SJoseph Huber TIMESCOPE();
69*269d5c16SJoseph Huber
70*269d5c16SJoseph Huber __tgt_target_data_end_mapper(nullptr, DeviceId, ArgNum, ArgsBase, Args,
71*269d5c16SJoseph Huber ArgSizes, ArgTypes, nullptr, nullptr);
72*269d5c16SJoseph Huber }
73*269d5c16SJoseph Huber
__tgt_target_mapper(ident_t * Loc,int64_t DeviceId,void * HostPtr,int32_t ArgNum,void ** ArgsBase,void ** Args,int64_t * ArgSizes,int64_t * ArgTypes,map_var_info_t * ArgNames,void ** ArgMappers)74*269d5c16SJoseph Huber EXTERN int __tgt_target_mapper(ident_t *Loc, int64_t DeviceId, void *HostPtr,
75*269d5c16SJoseph Huber int32_t ArgNum, void **ArgsBase, void **Args,
76*269d5c16SJoseph Huber int64_t *ArgSizes, int64_t *ArgTypes,
77*269d5c16SJoseph Huber map_var_info_t *ArgNames, void **ArgMappers) {
78*269d5c16SJoseph Huber TIMESCOPE_WITH_IDENT(Loc);
79*269d5c16SJoseph Huber __tgt_kernel_arguments KernelArgs{
80*269d5c16SJoseph Huber 1, ArgNum, ArgsBase, Args, ArgSizes, ArgTypes, ArgNames, ArgMappers, -1};
81*269d5c16SJoseph Huber return __tgt_target_kernel(Loc, DeviceId, -1, -1, HostPtr, &KernelArgs);
82*269d5c16SJoseph Huber }
83*269d5c16SJoseph Huber
__tgt_target(int64_t DeviceId,void * HostPtr,int32_t ArgNum,void ** ArgsBase,void ** Args,int64_t * ArgSizes,int64_t * ArgTypes)84*269d5c16SJoseph Huber EXTERN int __tgt_target(int64_t DeviceId, void *HostPtr, int32_t ArgNum,
85*269d5c16SJoseph Huber void **ArgsBase, void **Args, int64_t *ArgSizes,
86*269d5c16SJoseph Huber int64_t *ArgTypes) {
87*269d5c16SJoseph Huber TIMESCOPE();
88*269d5c16SJoseph Huber return __tgt_target_mapper(nullptr, DeviceId, HostPtr, ArgNum, ArgsBase, Args,
89*269d5c16SJoseph Huber ArgSizes, ArgTypes, nullptr, nullptr);
90*269d5c16SJoseph Huber }
91*269d5c16SJoseph Huber
__tgt_target_nowait(int64_t DeviceId,void * HostPtr,int32_t ArgNum,void ** ArgsBase,void ** Args,int64_t * ArgSizes,int64_t * ArgTypes,int32_t DepNum,void * DepList,int32_t NoAliasDepNum,void * NoAliasDepList)92*269d5c16SJoseph Huber EXTERN int __tgt_target_nowait(int64_t DeviceId, void *HostPtr, int32_t ArgNum,
93*269d5c16SJoseph Huber void **ArgsBase, void **Args, int64_t *ArgSizes,
94*269d5c16SJoseph Huber int64_t *ArgTypes, int32_t DepNum, void *DepList,
95*269d5c16SJoseph Huber int32_t NoAliasDepNum, void *NoAliasDepList) {
96*269d5c16SJoseph Huber TIMESCOPE();
97*269d5c16SJoseph Huber
98*269d5c16SJoseph Huber return __tgt_target_mapper(nullptr, DeviceId, HostPtr, ArgNum, ArgsBase, Args,
99*269d5c16SJoseph Huber ArgSizes, ArgTypes, nullptr, nullptr);
100*269d5c16SJoseph Huber }
101*269d5c16SJoseph Huber
__tgt_target_nowait_mapper(ident_t * Loc,int64_t DeviceId,void * HostPtr,int32_t ArgNum,void ** ArgsBase,void ** Args,int64_t * ArgSizes,int64_t * ArgTypes,map_var_info_t * ArgNames,void ** ArgMappers,int32_t DepNum,void * DepList,int32_t NoAliasDepNum,void * NoAliasDepList)102*269d5c16SJoseph Huber EXTERN int __tgt_target_nowait_mapper(
103*269d5c16SJoseph Huber ident_t *Loc, int64_t DeviceId, void *HostPtr, int32_t ArgNum,
104*269d5c16SJoseph Huber void **ArgsBase, void **Args, int64_t *ArgSizes, int64_t *ArgTypes,
105*269d5c16SJoseph Huber map_var_info_t *ArgNames, void **ArgMappers, int32_t DepNum, void *DepList,
106*269d5c16SJoseph Huber int32_t NoAliasDepNum, void *NoAliasDepList) {
107*269d5c16SJoseph Huber TIMESCOPE_WITH_IDENT(Loc);
108*269d5c16SJoseph Huber
109*269d5c16SJoseph Huber return __tgt_target_mapper(Loc, DeviceId, HostPtr, ArgNum, ArgsBase, Args,
110*269d5c16SJoseph Huber ArgSizes, ArgTypes, ArgNames, ArgMappers);
111*269d5c16SJoseph Huber }
112*269d5c16SJoseph Huber
__tgt_target_teams_mapper(ident_t * Loc,int64_t DeviceId,void * HostPtr,int32_t ArgNum,void ** ArgsBase,void ** Args,int64_t * ArgSizes,int64_t * ArgTypes,map_var_info_t * ArgNames,void ** ArgMappers,int32_t NumTeams,int32_t ThreadLimit)113*269d5c16SJoseph Huber EXTERN int __tgt_target_teams_mapper(ident_t *Loc, int64_t DeviceId,
114*269d5c16SJoseph Huber void *HostPtr, int32_t ArgNum,
115*269d5c16SJoseph Huber void **ArgsBase, void **Args,
116*269d5c16SJoseph Huber int64_t *ArgSizes, int64_t *ArgTypes,
117*269d5c16SJoseph Huber map_var_info_t *ArgNames,
118*269d5c16SJoseph Huber void **ArgMappers, int32_t NumTeams,
119*269d5c16SJoseph Huber int32_t ThreadLimit) {
120*269d5c16SJoseph Huber TIMESCOPE_WITH_IDENT(Loc);
121*269d5c16SJoseph Huber
122*269d5c16SJoseph Huber __tgt_kernel_arguments KernelArgs{
123*269d5c16SJoseph Huber 1, ArgNum, ArgsBase, Args, ArgSizes, ArgTypes, ArgNames, ArgMappers, -1};
124*269d5c16SJoseph Huber return __tgt_target_kernel(Loc, DeviceId, NumTeams, ThreadLimit, HostPtr,
125*269d5c16SJoseph Huber &KernelArgs);
126*269d5c16SJoseph Huber }
127*269d5c16SJoseph Huber
__tgt_target_teams(int64_t DeviceId,void * HostPtr,int32_t ArgNum,void ** ArgsBase,void ** Args,int64_t * ArgSizes,int64_t * ArgTypes,int32_t NumTeams,int32_t ThreadLimit)128*269d5c16SJoseph Huber EXTERN int __tgt_target_teams(int64_t DeviceId, void *HostPtr, int32_t ArgNum,
129*269d5c16SJoseph Huber void **ArgsBase, void **Args, int64_t *ArgSizes,
130*269d5c16SJoseph Huber int64_t *ArgTypes, int32_t NumTeams,
131*269d5c16SJoseph Huber int32_t ThreadLimit) {
132*269d5c16SJoseph Huber TIMESCOPE();
133*269d5c16SJoseph Huber return __tgt_target_teams_mapper(nullptr, DeviceId, HostPtr, ArgNum, ArgsBase,
134*269d5c16SJoseph Huber Args, ArgSizes, ArgTypes, nullptr, nullptr,
135*269d5c16SJoseph Huber NumTeams, ThreadLimit);
136*269d5c16SJoseph Huber }
137*269d5c16SJoseph Huber
__tgt_target_teams_nowait(int64_t DeviceId,void * HostPtr,int32_t ArgNum,void ** ArgsBase,void ** Args,int64_t * ArgSizes,int64_t * ArgTypes,int32_t NumTeams,int32_t ThreadLimit,int32_t DepNum,void * DepList,int32_t NoAliasDepNum,void * NoAliasDepList)138*269d5c16SJoseph Huber EXTERN int __tgt_target_teams_nowait(int64_t DeviceId, void *HostPtr,
139*269d5c16SJoseph Huber int32_t ArgNum, void **ArgsBase,
140*269d5c16SJoseph Huber void **Args, int64_t *ArgSizes,
141*269d5c16SJoseph Huber int64_t *ArgTypes, int32_t NumTeams,
142*269d5c16SJoseph Huber int32_t ThreadLimit, int32_t DepNum,
143*269d5c16SJoseph Huber void *DepList, int32_t NoAliasDepNum,
144*269d5c16SJoseph Huber void *NoAliasDepList) {
145*269d5c16SJoseph Huber TIMESCOPE();
146*269d5c16SJoseph Huber
147*269d5c16SJoseph Huber return __tgt_target_teams_mapper(nullptr, DeviceId, HostPtr, ArgNum, ArgsBase,
148*269d5c16SJoseph Huber Args, ArgSizes, ArgTypes, nullptr, nullptr,
149*269d5c16SJoseph Huber NumTeams, ThreadLimit);
150*269d5c16SJoseph Huber }
151*269d5c16SJoseph Huber
__tgt_target_teams_nowait_mapper(ident_t * Loc,int64_t DeviceId,void * HostPtr,int32_t ArgNum,void ** ArgsBase,void ** Args,int64_t * ArgSizes,int64_t * ArgTypes,map_var_info_t * ArgNames,void ** ArgMappers,int32_t NumTeams,int32_t ThreadLimit,int32_t DepNum,void * DepList,int32_t NoAliasDepNum,void * NoAliasDepList)152*269d5c16SJoseph Huber EXTERN int __tgt_target_teams_nowait_mapper(
153*269d5c16SJoseph Huber ident_t *Loc, int64_t DeviceId, void *HostPtr, int32_t ArgNum,
154*269d5c16SJoseph Huber void **ArgsBase, void **Args, int64_t *ArgSizes, int64_t *ArgTypes,
155*269d5c16SJoseph Huber map_var_info_t *ArgNames, void **ArgMappers, int32_t NumTeams,
156*269d5c16SJoseph Huber int32_t ThreadLimit, int32_t DepNum, void *DepList, int32_t NoAliasDepNum,
157*269d5c16SJoseph Huber void *NoAliasDepList) {
158*269d5c16SJoseph Huber TIMESCOPE_WITH_IDENT(Loc);
159*269d5c16SJoseph Huber
160*269d5c16SJoseph Huber return __tgt_target_teams_mapper(Loc, DeviceId, HostPtr, ArgNum, ArgsBase,
161*269d5c16SJoseph Huber Args, ArgSizes, ArgTypes, ArgNames,
162*269d5c16SJoseph Huber ArgMappers, NumTeams, ThreadLimit);
163*269d5c16SJoseph Huber }
164*269d5c16SJoseph Huber
__kmpc_push_target_tripcount_mapper(ident_t * Loc,int64_t DeviceId,uint64_t LoopTripcount)165*269d5c16SJoseph Huber EXTERN void __kmpc_push_target_tripcount_mapper(ident_t *Loc, int64_t DeviceId,
166*269d5c16SJoseph Huber uint64_t LoopTripcount) {
167*269d5c16SJoseph Huber TIMESCOPE_WITH_IDENT(Loc);
168*269d5c16SJoseph Huber if (checkDeviceAndCtors(DeviceId, Loc)) {
169*269d5c16SJoseph Huber DP("Not offloading to device %" PRId64 "\n", DeviceId);
170*269d5c16SJoseph Huber return;
171*269d5c16SJoseph Huber }
172*269d5c16SJoseph Huber
173*269d5c16SJoseph Huber DP("__kmpc_push_target_tripcount(%" PRId64 ", %" PRIu64 ")\n", DeviceId,
174*269d5c16SJoseph Huber LoopTripcount);
175*269d5c16SJoseph Huber PM->TblMapMtx.lock();
176*269d5c16SJoseph Huber PM->Devices[DeviceId]->LoopTripCnt.emplace(__kmpc_global_thread_num(NULL),
177*269d5c16SJoseph Huber LoopTripcount);
178*269d5c16SJoseph Huber PM->TblMapMtx.unlock();
179*269d5c16SJoseph Huber }
180*269d5c16SJoseph Huber
__kmpc_push_target_tripcount(int64_t DeviceId,uint64_t LoopTripcount)181*269d5c16SJoseph Huber EXTERN void __kmpc_push_target_tripcount(int64_t DeviceId,
182*269d5c16SJoseph Huber uint64_t LoopTripcount) {
183*269d5c16SJoseph Huber __kmpc_push_target_tripcount_mapper(nullptr, DeviceId, LoopTripcount);
184*269d5c16SJoseph Huber }
185