annotate libgomp/oacc-parallel.c @ 138:fc828634a951

merge
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Thu, 08 Nov 2018 14:17:14 +0900
parents 84e7813d76e9
children 1830386684a0
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1 /* Copyright (C) 2013-2018 Free Software Foundation, Inc.
111
kono
parents:
diff changeset
2
kono
parents:
diff changeset
3 Contributed by Mentor Embedded.
kono
parents:
diff changeset
4
kono
parents:
diff changeset
5 This file is part of the GNU Offloading and Multi Processing Library
kono
parents:
diff changeset
6 (libgomp).
kono
parents:
diff changeset
7
kono
parents:
diff changeset
8 Libgomp is free software; you can redistribute it and/or modify it
kono
parents:
diff changeset
9 under the terms of the GNU General Public License as published by
kono
parents:
diff changeset
10 the Free Software Foundation; either version 3, or (at your option)
kono
parents:
diff changeset
11 any later version.
kono
parents:
diff changeset
12
kono
parents:
diff changeset
13 Libgomp is distributed in the hope that it will be useful, but WITHOUT ANY
kono
parents:
diff changeset
14 WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
kono
parents:
diff changeset
15 FOR A PARTICULAR PURPOSE. See the GNU General Public License for
kono
parents:
diff changeset
16 more details.
kono
parents:
diff changeset
17
kono
parents:
diff changeset
18 Under Section 7 of GPL version 3, you are granted additional
kono
parents:
diff changeset
19 permissions described in the GCC Runtime Library Exception, version
kono
parents:
diff changeset
20 3.1, as published by the Free Software Foundation.
kono
parents:
diff changeset
21
kono
parents:
diff changeset
22 You should have received a copy of the GNU General Public License and
kono
parents:
diff changeset
23 a copy of the GCC Runtime Library Exception along with this program;
kono
parents:
diff changeset
24 see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
kono
parents:
diff changeset
25 <http://www.gnu.org/licenses/>. */
kono
parents:
diff changeset
26
kono
parents:
diff changeset
27 /* This file handles OpenACC constructs. */
kono
parents:
diff changeset
28
kono
parents:
diff changeset
29 #include "openacc.h"
kono
parents:
diff changeset
30 #include "libgomp.h"
kono
parents:
diff changeset
31 #include "libgomp_g.h"
kono
parents:
diff changeset
32 #include "gomp-constants.h"
kono
parents:
diff changeset
33 #include "oacc-int.h"
kono
parents:
diff changeset
34 #ifdef HAVE_INTTYPES_H
kono
parents:
diff changeset
35 # include <inttypes.h> /* For PRIu64. */
kono
parents:
diff changeset
36 #endif
kono
parents:
diff changeset
37 #include <string.h>
kono
parents:
diff changeset
38 #include <stdarg.h>
kono
parents:
diff changeset
39 #include <assert.h>
kono
parents:
diff changeset
40
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
41 /* Returns the number of mappings associated with the pointer or pset. PSET
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
42 have three mappings, whereas pointer have two. */
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
43
111
kono
parents:
diff changeset
44 static int
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
45 find_pointer (int pos, size_t mapnum, unsigned short *kinds)
111
kono
parents:
diff changeset
46 {
kono
parents:
diff changeset
47 if (pos + 1 >= mapnum)
kono
parents:
diff changeset
48 return 0;
kono
parents:
diff changeset
49
kono
parents:
diff changeset
50 unsigned char kind = kinds[pos+1] & 0xff;
kono
parents:
diff changeset
51
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
52 if (kind == GOMP_MAP_TO_PSET)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
53 return 3;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
54 else if (kind == GOMP_MAP_POINTER)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
55 return 2;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
56
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
57 return 0;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
58 }
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
59
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
60 /* Handle the mapping pair that are presented when a
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
61 deviceptr clause is used with Fortran. */
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
62
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
63 static void
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
64 handle_ftn_pointers (size_t mapnum, void **hostaddrs, size_t *sizes,
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
65 unsigned short *kinds)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
66 {
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
67 int i;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
68
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
69 for (i = 0; i < mapnum; i++)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
70 {
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
71 unsigned short kind1 = kinds[i] & 0xff;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
72
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
73 /* Handle Fortran deviceptr clause. */
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
74 if (kind1 == GOMP_MAP_FORCE_DEVICEPTR)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
75 {
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
76 unsigned short kind2;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
77
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
78 if (i < (signed)mapnum - 1)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
79 kind2 = kinds[i + 1] & 0xff;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
80 else
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
81 kind2 = 0xffff;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
82
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
83 if (sizes[i] == sizeof (void *))
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
84 continue;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
85
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
86 /* At this point, we're dealing with a Fortran deviceptr.
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
87 If the next element is not what we're expecting, then
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
88 this is an instance of where the deviceptr variable was
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
89 not used within the region and the pointer was removed
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
90 by the gimplifier. */
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
91 if (kind2 == GOMP_MAP_POINTER
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
92 && sizes[i + 1] == 0
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
93 && hostaddrs[i] == *(void **)hostaddrs[i + 1])
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
94 {
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
95 kinds[i+1] = kinds[i];
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
96 sizes[i+1] = sizeof (void *);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
97 }
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
98
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
99 /* Invalidate the entry. */
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
100 hostaddrs[i] = NULL;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
101 }
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
102 }
111
kono
parents:
diff changeset
103 }
kono
parents:
diff changeset
104
kono
parents:
diff changeset
105 static void goacc_wait (int async, int num_waits, va_list *ap);
kono
parents:
diff changeset
106
kono
parents:
diff changeset
107
kono
parents:
diff changeset
108 /* Launch a possibly offloaded function on DEVICE. FN is the host fn
kono
parents:
diff changeset
109 address. MAPNUM, HOSTADDRS, SIZES & KINDS describe the memory
kono
parents:
diff changeset
110 blocks to be copied to/from the device. Varadic arguments are
kono
parents:
diff changeset
111 keyed optional parameters terminated with a zero. */
kono
parents:
diff changeset
112
kono
parents:
diff changeset
113 void
kono
parents:
diff changeset
114 GOACC_parallel_keyed (int device, void (*fn) (void *),
kono
parents:
diff changeset
115 size_t mapnum, void **hostaddrs, size_t *sizes,
kono
parents:
diff changeset
116 unsigned short *kinds, ...)
kono
parents:
diff changeset
117 {
kono
parents:
diff changeset
118 bool host_fallback = device == GOMP_DEVICE_HOST_FALLBACK;
kono
parents:
diff changeset
119 va_list ap;
kono
parents:
diff changeset
120 struct goacc_thread *thr;
kono
parents:
diff changeset
121 struct gomp_device_descr *acc_dev;
kono
parents:
diff changeset
122 struct target_mem_desc *tgt;
kono
parents:
diff changeset
123 void **devaddrs;
kono
parents:
diff changeset
124 unsigned int i;
kono
parents:
diff changeset
125 struct splay_tree_key_s k;
kono
parents:
diff changeset
126 splay_tree_key tgt_fn_key;
kono
parents:
diff changeset
127 void (*tgt_fn);
kono
parents:
diff changeset
128 int async = GOMP_ASYNC_SYNC;
kono
parents:
diff changeset
129 unsigned dims[GOMP_DIM_MAX];
kono
parents:
diff changeset
130 unsigned tag;
kono
parents:
diff changeset
131
kono
parents:
diff changeset
132 #ifdef HAVE_INTTYPES_H
kono
parents:
diff changeset
133 gomp_debug (0, "%s: mapnum=%"PRIu64", hostaddrs=%p, size=%p, kinds=%p\n",
kono
parents:
diff changeset
134 __FUNCTION__, (uint64_t) mapnum, hostaddrs, sizes, kinds);
kono
parents:
diff changeset
135 #else
kono
parents:
diff changeset
136 gomp_debug (0, "%s: mapnum=%lu, hostaddrs=%p, sizes=%p, kinds=%p\n",
kono
parents:
diff changeset
137 __FUNCTION__, (unsigned long) mapnum, hostaddrs, sizes, kinds);
kono
parents:
diff changeset
138 #endif
kono
parents:
diff changeset
139 goacc_lazy_initialize ();
kono
parents:
diff changeset
140
kono
parents:
diff changeset
141 thr = goacc_thread ();
kono
parents:
diff changeset
142 acc_dev = thr->dev;
kono
parents:
diff changeset
143
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
144 handle_ftn_pointers (mapnum, hostaddrs, sizes, kinds);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
145
111
kono
parents:
diff changeset
146 /* Host fallback if "if" clause is false or if the current device is set to
kono
parents:
diff changeset
147 the host. */
kono
parents:
diff changeset
148 if (host_fallback)
kono
parents:
diff changeset
149 {
kono
parents:
diff changeset
150 goacc_save_and_set_bind (acc_device_host);
kono
parents:
diff changeset
151 fn (hostaddrs);
kono
parents:
diff changeset
152 goacc_restore_bind ();
kono
parents:
diff changeset
153 return;
kono
parents:
diff changeset
154 }
kono
parents:
diff changeset
155 else if (acc_device_type (acc_dev->type) == acc_device_host)
kono
parents:
diff changeset
156 {
kono
parents:
diff changeset
157 fn (hostaddrs);
kono
parents:
diff changeset
158 return;
kono
parents:
diff changeset
159 }
kono
parents:
diff changeset
160
kono
parents:
diff changeset
161 /* Default: let the runtime choose. */
kono
parents:
diff changeset
162 for (i = 0; i != GOMP_DIM_MAX; i++)
kono
parents:
diff changeset
163 dims[i] = 0;
kono
parents:
diff changeset
164
kono
parents:
diff changeset
165 va_start (ap, kinds);
kono
parents:
diff changeset
166 /* TODO: This will need amending when device_type is implemented. */
kono
parents:
diff changeset
167 while ((tag = va_arg (ap, unsigned)) != 0)
kono
parents:
diff changeset
168 {
kono
parents:
diff changeset
169 if (GOMP_LAUNCH_DEVICE (tag))
kono
parents:
diff changeset
170 gomp_fatal ("device_type '%d' offload parameters, libgomp is too old",
kono
parents:
diff changeset
171 GOMP_LAUNCH_DEVICE (tag));
kono
parents:
diff changeset
172
kono
parents:
diff changeset
173 switch (GOMP_LAUNCH_CODE (tag))
kono
parents:
diff changeset
174 {
kono
parents:
diff changeset
175 case GOMP_LAUNCH_DIM:
kono
parents:
diff changeset
176 {
kono
parents:
diff changeset
177 unsigned mask = GOMP_LAUNCH_OP (tag);
kono
parents:
diff changeset
178
kono
parents:
diff changeset
179 for (i = 0; i != GOMP_DIM_MAX; i++)
kono
parents:
diff changeset
180 if (mask & GOMP_DIM_MASK (i))
kono
parents:
diff changeset
181 dims[i] = va_arg (ap, unsigned);
kono
parents:
diff changeset
182 }
kono
parents:
diff changeset
183 break;
kono
parents:
diff changeset
184
kono
parents:
diff changeset
185 case GOMP_LAUNCH_ASYNC:
kono
parents:
diff changeset
186 {
kono
parents:
diff changeset
187 /* Small constant values are encoded in the operand. */
kono
parents:
diff changeset
188 async = GOMP_LAUNCH_OP (tag);
kono
parents:
diff changeset
189
kono
parents:
diff changeset
190 if (async == GOMP_LAUNCH_OP_MAX)
kono
parents:
diff changeset
191 async = va_arg (ap, unsigned);
kono
parents:
diff changeset
192 break;
kono
parents:
diff changeset
193 }
kono
parents:
diff changeset
194
kono
parents:
diff changeset
195 case GOMP_LAUNCH_WAIT:
kono
parents:
diff changeset
196 {
kono
parents:
diff changeset
197 unsigned num_waits = GOMP_LAUNCH_OP (tag);
kono
parents:
diff changeset
198
kono
parents:
diff changeset
199 if (num_waits)
kono
parents:
diff changeset
200 goacc_wait (async, num_waits, &ap);
kono
parents:
diff changeset
201 break;
kono
parents:
diff changeset
202 }
kono
parents:
diff changeset
203
kono
parents:
diff changeset
204 default:
kono
parents:
diff changeset
205 gomp_fatal ("unrecognized offload code '%d',"
kono
parents:
diff changeset
206 " libgomp is too old", GOMP_LAUNCH_CODE (tag));
kono
parents:
diff changeset
207 }
kono
parents:
diff changeset
208 }
kono
parents:
diff changeset
209 va_end (ap);
kono
parents:
diff changeset
210
kono
parents:
diff changeset
211 acc_dev->openacc.async_set_async_func (async);
kono
parents:
diff changeset
212
kono
parents:
diff changeset
213 if (!(acc_dev->capabilities & GOMP_OFFLOAD_CAP_NATIVE_EXEC))
kono
parents:
diff changeset
214 {
kono
parents:
diff changeset
215 k.host_start = (uintptr_t) fn;
kono
parents:
diff changeset
216 k.host_end = k.host_start + 1;
kono
parents:
diff changeset
217 gomp_mutex_lock (&acc_dev->lock);
kono
parents:
diff changeset
218 tgt_fn_key = splay_tree_lookup (&acc_dev->mem_map, &k);
kono
parents:
diff changeset
219 gomp_mutex_unlock (&acc_dev->lock);
kono
parents:
diff changeset
220
kono
parents:
diff changeset
221 if (tgt_fn_key == NULL)
kono
parents:
diff changeset
222 gomp_fatal ("target function wasn't mapped");
kono
parents:
diff changeset
223
kono
parents:
diff changeset
224 tgt_fn = (void (*)) tgt_fn_key->tgt_offset;
kono
parents:
diff changeset
225 }
kono
parents:
diff changeset
226 else
kono
parents:
diff changeset
227 tgt_fn = (void (*)) fn;
kono
parents:
diff changeset
228
kono
parents:
diff changeset
229 tgt = gomp_map_vars (acc_dev, mapnum, hostaddrs, NULL, sizes, kinds, true,
kono
parents:
diff changeset
230 GOMP_MAP_VARS_OPENACC);
kono
parents:
diff changeset
231
kono
parents:
diff changeset
232 devaddrs = gomp_alloca (sizeof (void *) * mapnum);
kono
parents:
diff changeset
233 for (i = 0; i < mapnum; i++)
kono
parents:
diff changeset
234 devaddrs[i] = (void *) (tgt->list[i].key->tgt->tgt_start
kono
parents:
diff changeset
235 + tgt->list[i].key->tgt_offset);
kono
parents:
diff changeset
236
kono
parents:
diff changeset
237 acc_dev->openacc.exec_func (tgt_fn, mapnum, hostaddrs, devaddrs,
kono
parents:
diff changeset
238 async, dims, tgt);
kono
parents:
diff changeset
239
kono
parents:
diff changeset
240 /* If running synchronously, unmap immediately. */
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
241 bool copyfrom = true;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
242 if (async_synchronous_p (async))
111
kono
parents:
diff changeset
243 gomp_unmap_vars (tgt, true);
kono
parents:
diff changeset
244 else
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
245 {
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
246 bool async_unmap = false;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
247 for (size_t i = 0; i < tgt->list_count; i++)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
248 {
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
249 splay_tree_key k = tgt->list[i].key;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
250 if (k && k->refcount == 1)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
251 {
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
252 async_unmap = true;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
253 break;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
254 }
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
255 }
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
256 if (async_unmap)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
257 tgt->device_descr->openacc.register_async_cleanup_func (tgt, async);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
258 else
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
259 {
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
260 copyfrom = false;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
261 gomp_unmap_vars (tgt, copyfrom);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
262 }
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
263 }
111
kono
parents:
diff changeset
264
kono
parents:
diff changeset
265 acc_dev->openacc.async_set_async_func (acc_async_sync);
kono
parents:
diff changeset
266 }
kono
parents:
diff changeset
267
kono
parents:
diff changeset
268 /* Legacy entry point, only provide host execution. */
kono
parents:
diff changeset
269
kono
parents:
diff changeset
270 void
kono
parents:
diff changeset
271 GOACC_parallel (int device, void (*fn) (void *),
kono
parents:
diff changeset
272 size_t mapnum, void **hostaddrs, size_t *sizes,
kono
parents:
diff changeset
273 unsigned short *kinds,
kono
parents:
diff changeset
274 int num_gangs, int num_workers, int vector_length,
kono
parents:
diff changeset
275 int async, int num_waits, ...)
kono
parents:
diff changeset
276 {
kono
parents:
diff changeset
277 goacc_save_and_set_bind (acc_device_host);
kono
parents:
diff changeset
278 fn (hostaddrs);
kono
parents:
diff changeset
279 goacc_restore_bind ();
kono
parents:
diff changeset
280 }
kono
parents:
diff changeset
281
kono
parents:
diff changeset
282 void
kono
parents:
diff changeset
283 GOACC_data_start (int device, size_t mapnum,
kono
parents:
diff changeset
284 void **hostaddrs, size_t *sizes, unsigned short *kinds)
kono
parents:
diff changeset
285 {
kono
parents:
diff changeset
286 bool host_fallback = device == GOMP_DEVICE_HOST_FALLBACK;
kono
parents:
diff changeset
287 struct target_mem_desc *tgt;
kono
parents:
diff changeset
288
kono
parents:
diff changeset
289 #ifdef HAVE_INTTYPES_H
kono
parents:
diff changeset
290 gomp_debug (0, "%s: mapnum=%"PRIu64", hostaddrs=%p, size=%p, kinds=%p\n",
kono
parents:
diff changeset
291 __FUNCTION__, (uint64_t) mapnum, hostaddrs, sizes, kinds);
kono
parents:
diff changeset
292 #else
kono
parents:
diff changeset
293 gomp_debug (0, "%s: mapnum=%lu, hostaddrs=%p, sizes=%p, kinds=%p\n",
kono
parents:
diff changeset
294 __FUNCTION__, (unsigned long) mapnum, hostaddrs, sizes, kinds);
kono
parents:
diff changeset
295 #endif
kono
parents:
diff changeset
296
kono
parents:
diff changeset
297 goacc_lazy_initialize ();
kono
parents:
diff changeset
298
kono
parents:
diff changeset
299 struct goacc_thread *thr = goacc_thread ();
kono
parents:
diff changeset
300 struct gomp_device_descr *acc_dev = thr->dev;
kono
parents:
diff changeset
301
kono
parents:
diff changeset
302 /* Host fallback or 'do nothing'. */
kono
parents:
diff changeset
303 if ((acc_dev->capabilities & GOMP_OFFLOAD_CAP_SHARED_MEM)
kono
parents:
diff changeset
304 || host_fallback)
kono
parents:
diff changeset
305 {
kono
parents:
diff changeset
306 tgt = gomp_map_vars (NULL, 0, NULL, NULL, NULL, NULL, true,
kono
parents:
diff changeset
307 GOMP_MAP_VARS_OPENACC);
kono
parents:
diff changeset
308 tgt->prev = thr->mapped_data;
kono
parents:
diff changeset
309 thr->mapped_data = tgt;
kono
parents:
diff changeset
310
kono
parents:
diff changeset
311 return;
kono
parents:
diff changeset
312 }
kono
parents:
diff changeset
313
kono
parents:
diff changeset
314 gomp_debug (0, " %s: prepare mappings\n", __FUNCTION__);
kono
parents:
diff changeset
315 tgt = gomp_map_vars (acc_dev, mapnum, hostaddrs, NULL, sizes, kinds, true,
kono
parents:
diff changeset
316 GOMP_MAP_VARS_OPENACC);
kono
parents:
diff changeset
317 gomp_debug (0, " %s: mappings prepared\n", __FUNCTION__);
kono
parents:
diff changeset
318 tgt->prev = thr->mapped_data;
kono
parents:
diff changeset
319 thr->mapped_data = tgt;
kono
parents:
diff changeset
320 }
kono
parents:
diff changeset
321
kono
parents:
diff changeset
322 void
kono
parents:
diff changeset
323 GOACC_data_end (void)
kono
parents:
diff changeset
324 {
kono
parents:
diff changeset
325 struct goacc_thread *thr = goacc_thread ();
kono
parents:
diff changeset
326 struct target_mem_desc *tgt = thr->mapped_data;
kono
parents:
diff changeset
327
kono
parents:
diff changeset
328 gomp_debug (0, " %s: restore mappings\n", __FUNCTION__);
kono
parents:
diff changeset
329 thr->mapped_data = tgt->prev;
kono
parents:
diff changeset
330 gomp_unmap_vars (tgt, true);
kono
parents:
diff changeset
331 gomp_debug (0, " %s: mappings restored\n", __FUNCTION__);
kono
parents:
diff changeset
332 }
kono
parents:
diff changeset
333
kono
parents:
diff changeset
334 void
kono
parents:
diff changeset
335 GOACC_enter_exit_data (int device, size_t mapnum,
kono
parents:
diff changeset
336 void **hostaddrs, size_t *sizes, unsigned short *kinds,
kono
parents:
diff changeset
337 int async, int num_waits, ...)
kono
parents:
diff changeset
338 {
kono
parents:
diff changeset
339 struct goacc_thread *thr;
kono
parents:
diff changeset
340 struct gomp_device_descr *acc_dev;
kono
parents:
diff changeset
341 bool host_fallback = device == GOMP_DEVICE_HOST_FALLBACK;
kono
parents:
diff changeset
342 bool data_enter = false;
kono
parents:
diff changeset
343 size_t i;
kono
parents:
diff changeset
344
kono
parents:
diff changeset
345 goacc_lazy_initialize ();
kono
parents:
diff changeset
346
kono
parents:
diff changeset
347 thr = goacc_thread ();
kono
parents:
diff changeset
348 acc_dev = thr->dev;
kono
parents:
diff changeset
349
kono
parents:
diff changeset
350 if ((acc_dev->capabilities & GOMP_OFFLOAD_CAP_SHARED_MEM)
kono
parents:
diff changeset
351 || host_fallback)
kono
parents:
diff changeset
352 return;
kono
parents:
diff changeset
353
kono
parents:
diff changeset
354 if (num_waits)
kono
parents:
diff changeset
355 {
kono
parents:
diff changeset
356 va_list ap;
kono
parents:
diff changeset
357
kono
parents:
diff changeset
358 va_start (ap, num_waits);
kono
parents:
diff changeset
359 goacc_wait (async, num_waits, &ap);
kono
parents:
diff changeset
360 va_end (ap);
kono
parents:
diff changeset
361 }
kono
parents:
diff changeset
362
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
363 /* Determine whether "finalize" semantics apply to all mappings of this
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
364 OpenACC directive. */
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
365 bool finalize = false;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
366 if (mapnum > 0)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
367 {
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
368 unsigned char kind = kinds[0] & 0xff;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
369 if (kind == GOMP_MAP_DELETE
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
370 || kind == GOMP_MAP_FORCE_FROM)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
371 finalize = true;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
372 }
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
373
111
kono
parents:
diff changeset
374 acc_dev->openacc.async_set_async_func (async);
kono
parents:
diff changeset
375
kono
parents:
diff changeset
376 /* Determine if this is an "acc enter data". */
kono
parents:
diff changeset
377 for (i = 0; i < mapnum; ++i)
kono
parents:
diff changeset
378 {
kono
parents:
diff changeset
379 unsigned char kind = kinds[i] & 0xff;
kono
parents:
diff changeset
380
kono
parents:
diff changeset
381 if (kind == GOMP_MAP_POINTER || kind == GOMP_MAP_TO_PSET)
kono
parents:
diff changeset
382 continue;
kono
parents:
diff changeset
383
kono
parents:
diff changeset
384 if (kind == GOMP_MAP_FORCE_ALLOC
kono
parents:
diff changeset
385 || kind == GOMP_MAP_FORCE_PRESENT
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
386 || kind == GOMP_MAP_FORCE_TO
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
387 || kind == GOMP_MAP_TO
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
388 || kind == GOMP_MAP_ALLOC)
111
kono
parents:
diff changeset
389 {
kono
parents:
diff changeset
390 data_enter = true;
kono
parents:
diff changeset
391 break;
kono
parents:
diff changeset
392 }
kono
parents:
diff changeset
393
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
394 if (kind == GOMP_MAP_RELEASE
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
395 || kind == GOMP_MAP_DELETE
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
396 || kind == GOMP_MAP_FROM
111
kono
parents:
diff changeset
397 || kind == GOMP_MAP_FORCE_FROM)
kono
parents:
diff changeset
398 break;
kono
parents:
diff changeset
399
kono
parents:
diff changeset
400 gomp_fatal (">>>> GOACC_enter_exit_data UNHANDLED kind 0x%.2x",
kono
parents:
diff changeset
401 kind);
kono
parents:
diff changeset
402 }
kono
parents:
diff changeset
403
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
404 /* In c, non-pointers and arrays are represented by a single data clause.
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
405 Dynamically allocated arrays and subarrays are represented by a data
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
406 clause followed by an internal GOMP_MAP_POINTER.
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
407
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
408 In fortran, scalars and not allocated arrays are represented by a
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
409 single data clause. Allocated arrays and subarrays have three mappings:
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
410 1) the original data clause, 2) a PSET 3) a pointer to the array data.
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
411 */
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
412
111
kono
parents:
diff changeset
413 if (data_enter)
kono
parents:
diff changeset
414 {
kono
parents:
diff changeset
415 for (i = 0; i < mapnum; i++)
kono
parents:
diff changeset
416 {
kono
parents:
diff changeset
417 unsigned char kind = kinds[i] & 0xff;
kono
parents:
diff changeset
418
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
419 /* Scan for pointers and PSETs. */
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
420 int pointer = find_pointer (i, mapnum, kinds);
111
kono
parents:
diff changeset
421
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
422 if (!pointer)
111
kono
parents:
diff changeset
423 {
kono
parents:
diff changeset
424 switch (kind)
kono
parents:
diff changeset
425 {
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
426 case GOMP_MAP_ALLOC:
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
427 acc_present_or_create (hostaddrs[i], sizes[i]);
111
kono
parents:
diff changeset
428 break;
kono
parents:
diff changeset
429 case GOMP_MAP_FORCE_ALLOC:
kono
parents:
diff changeset
430 acc_create (hostaddrs[i], sizes[i]);
kono
parents:
diff changeset
431 break;
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
432 case GOMP_MAP_TO:
111
kono
parents:
diff changeset
433 acc_present_or_copyin (hostaddrs[i], sizes[i]);
kono
parents:
diff changeset
434 break;
kono
parents:
diff changeset
435 case GOMP_MAP_FORCE_TO:
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
436 acc_copyin (hostaddrs[i], sizes[i]);
111
kono
parents:
diff changeset
437 break;
kono
parents:
diff changeset
438 default:
kono
parents:
diff changeset
439 gomp_fatal (">>>> GOACC_enter_exit_data UNHANDLED kind 0x%.2x",
kono
parents:
diff changeset
440 kind);
kono
parents:
diff changeset
441 break;
kono
parents:
diff changeset
442 }
kono
parents:
diff changeset
443 }
kono
parents:
diff changeset
444 else
kono
parents:
diff changeset
445 {
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
446 gomp_acc_insert_pointer (pointer, &hostaddrs[i],
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
447 &sizes[i], &kinds[i]);
111
kono
parents:
diff changeset
448 /* Increment 'i' by two because OpenACC requires fortran
kono
parents:
diff changeset
449 arrays to be contiguous, so each PSET is associated with
kono
parents:
diff changeset
450 one of MAP_FORCE_ALLOC/MAP_FORCE_PRESET/MAP_FORCE_TO, and
kono
parents:
diff changeset
451 one MAP_POINTER. */
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
452 i += pointer - 1;
111
kono
parents:
diff changeset
453 }
kono
parents:
diff changeset
454 }
kono
parents:
diff changeset
455 }
kono
parents:
diff changeset
456 else
kono
parents:
diff changeset
457 for (i = 0; i < mapnum; ++i)
kono
parents:
diff changeset
458 {
kono
parents:
diff changeset
459 unsigned char kind = kinds[i] & 0xff;
kono
parents:
diff changeset
460
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
461 int pointer = find_pointer (i, mapnum, kinds);
111
kono
parents:
diff changeset
462
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
463 if (!pointer)
111
kono
parents:
diff changeset
464 {
kono
parents:
diff changeset
465 switch (kind)
kono
parents:
diff changeset
466 {
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
467 case GOMP_MAP_RELEASE:
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
468 case GOMP_MAP_DELETE:
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
469 if (acc_is_present (hostaddrs[i], sizes[i]))
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
470 {
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
471 if (finalize)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
472 acc_delete_finalize (hostaddrs[i], sizes[i]);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
473 else
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
474 acc_delete (hostaddrs[i], sizes[i]);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
475 }
111
kono
parents:
diff changeset
476 break;
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
477 case GOMP_MAP_FROM:
111
kono
parents:
diff changeset
478 case GOMP_MAP_FORCE_FROM:
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
479 if (finalize)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
480 acc_copyout_finalize (hostaddrs[i], sizes[i]);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
481 else
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
482 acc_copyout (hostaddrs[i], sizes[i]);
111
kono
parents:
diff changeset
483 break;
kono
parents:
diff changeset
484 default:
kono
parents:
diff changeset
485 gomp_fatal (">>>> GOACC_enter_exit_data UNHANDLED kind 0x%.2x",
kono
parents:
diff changeset
486 kind);
kono
parents:
diff changeset
487 break;
kono
parents:
diff changeset
488 }
kono
parents:
diff changeset
489 }
kono
parents:
diff changeset
490 else
kono
parents:
diff changeset
491 {
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
492 bool copyfrom = (kind == GOMP_MAP_FORCE_FROM
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
493 || kind == GOMP_MAP_FROM);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
494 gomp_acc_remove_pointer (hostaddrs[i], sizes[i], copyfrom, async,
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
495 finalize, pointer);
111
kono
parents:
diff changeset
496 /* See the above comment. */
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
497 i += pointer - 1;
111
kono
parents:
diff changeset
498 }
kono
parents:
diff changeset
499 }
kono
parents:
diff changeset
500
kono
parents:
diff changeset
501 acc_dev->openacc.async_set_async_func (acc_async_sync);
kono
parents:
diff changeset
502 }
kono
parents:
diff changeset
503
kono
parents:
diff changeset
504 static void
kono
parents:
diff changeset
505 goacc_wait (int async, int num_waits, va_list *ap)
kono
parents:
diff changeset
506 {
kono
parents:
diff changeset
507 struct goacc_thread *thr = goacc_thread ();
kono
parents:
diff changeset
508 struct gomp_device_descr *acc_dev = thr->dev;
kono
parents:
diff changeset
509
kono
parents:
diff changeset
510 while (num_waits--)
kono
parents:
diff changeset
511 {
kono
parents:
diff changeset
512 int qid = va_arg (*ap, int);
kono
parents:
diff changeset
513
kono
parents:
diff changeset
514 if (acc_async_test (qid))
kono
parents:
diff changeset
515 continue;
kono
parents:
diff changeset
516
kono
parents:
diff changeset
517 if (async == acc_async_sync)
kono
parents:
diff changeset
518 acc_wait (qid);
kono
parents:
diff changeset
519 else if (qid == async)
kono
parents:
diff changeset
520 ;/* If we're waiting on the same asynchronous queue as we're
kono
parents:
diff changeset
521 launching on, the queue itself will order work as
kono
parents:
diff changeset
522 required, so there's no need to wait explicitly. */
kono
parents:
diff changeset
523 else
kono
parents:
diff changeset
524 acc_dev->openacc.async_wait_async_func (qid, async);
kono
parents:
diff changeset
525 }
kono
parents:
diff changeset
526 }
kono
parents:
diff changeset
527
kono
parents:
diff changeset
528 void
kono
parents:
diff changeset
529 GOACC_update (int device, size_t mapnum,
kono
parents:
diff changeset
530 void **hostaddrs, size_t *sizes, unsigned short *kinds,
kono
parents:
diff changeset
531 int async, int num_waits, ...)
kono
parents:
diff changeset
532 {
kono
parents:
diff changeset
533 bool host_fallback = device == GOMP_DEVICE_HOST_FALLBACK;
kono
parents:
diff changeset
534 size_t i;
kono
parents:
diff changeset
535
kono
parents:
diff changeset
536 goacc_lazy_initialize ();
kono
parents:
diff changeset
537
kono
parents:
diff changeset
538 struct goacc_thread *thr = goacc_thread ();
kono
parents:
diff changeset
539 struct gomp_device_descr *acc_dev = thr->dev;
kono
parents:
diff changeset
540
kono
parents:
diff changeset
541 if ((acc_dev->capabilities & GOMP_OFFLOAD_CAP_SHARED_MEM)
kono
parents:
diff changeset
542 || host_fallback)
kono
parents:
diff changeset
543 return;
kono
parents:
diff changeset
544
kono
parents:
diff changeset
545 if (num_waits)
kono
parents:
diff changeset
546 {
kono
parents:
diff changeset
547 va_list ap;
kono
parents:
diff changeset
548
kono
parents:
diff changeset
549 va_start (ap, num_waits);
kono
parents:
diff changeset
550 goacc_wait (async, num_waits, &ap);
kono
parents:
diff changeset
551 va_end (ap);
kono
parents:
diff changeset
552 }
kono
parents:
diff changeset
553
kono
parents:
diff changeset
554 acc_dev->openacc.async_set_async_func (async);
kono
parents:
diff changeset
555
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
556 bool update_device = false;
111
kono
parents:
diff changeset
557 for (i = 0; i < mapnum; ++i)
kono
parents:
diff changeset
558 {
kono
parents:
diff changeset
559 unsigned char kind = kinds[i] & 0xff;
kono
parents:
diff changeset
560
kono
parents:
diff changeset
561 switch (kind)
kono
parents:
diff changeset
562 {
kono
parents:
diff changeset
563 case GOMP_MAP_POINTER:
kono
parents:
diff changeset
564 case GOMP_MAP_TO_PSET:
kono
parents:
diff changeset
565 break;
kono
parents:
diff changeset
566
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
567 case GOMP_MAP_ALWAYS_POINTER:
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
568 if (update_device)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
569 {
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
570 /* Save the contents of the host pointer. */
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
571 void *dptr = acc_deviceptr (hostaddrs[i-1]);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
572 uintptr_t t = *(uintptr_t *) hostaddrs[i];
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
573
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
574 /* Update the contents of the host pointer to reflect
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
575 the value of the allocated device memory in the
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
576 previous pointer. */
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
577 *(uintptr_t *) hostaddrs[i] = (uintptr_t)dptr;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
578 acc_update_device (hostaddrs[i], sizeof (uintptr_t));
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
579
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
580 /* Restore the host pointer. */
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
581 *(uintptr_t *) hostaddrs[i] = t;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
582 update_device = false;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
583 }
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
584 break;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
585
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
586 case GOMP_MAP_TO:
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
587 if (!acc_is_present (hostaddrs[i], sizes[i]))
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
588 {
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
589 update_device = false;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
590 break;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
591 }
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
592 /* Fallthru */
111
kono
parents:
diff changeset
593 case GOMP_MAP_FORCE_TO:
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
594 update_device = true;
111
kono
parents:
diff changeset
595 acc_update_device (hostaddrs[i], sizes[i]);
kono
parents:
diff changeset
596 break;
kono
parents:
diff changeset
597
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
598 case GOMP_MAP_FROM:
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
599 if (!acc_is_present (hostaddrs[i], sizes[i]))
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
600 {
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
601 update_device = false;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
602 break;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
603 }
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
604 /* Fallthru */
111
kono
parents:
diff changeset
605 case GOMP_MAP_FORCE_FROM:
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
606 update_device = false;
111
kono
parents:
diff changeset
607 acc_update_self (hostaddrs[i], sizes[i]);
kono
parents:
diff changeset
608 break;
kono
parents:
diff changeset
609
kono
parents:
diff changeset
610 default:
kono
parents:
diff changeset
611 gomp_fatal (">>>> GOACC_update UNHANDLED kind 0x%.2x", kind);
kono
parents:
diff changeset
612 break;
kono
parents:
diff changeset
613 }
kono
parents:
diff changeset
614 }
kono
parents:
diff changeset
615
kono
parents:
diff changeset
616 acc_dev->openacc.async_set_async_func (acc_async_sync);
kono
parents:
diff changeset
617 }
kono
parents:
diff changeset
618
kono
parents:
diff changeset
619 void
kono
parents:
diff changeset
620 GOACC_wait (int async, int num_waits, ...)
kono
parents:
diff changeset
621 {
kono
parents:
diff changeset
622 if (num_waits)
kono
parents:
diff changeset
623 {
kono
parents:
diff changeset
624 va_list ap;
kono
parents:
diff changeset
625
kono
parents:
diff changeset
626 va_start (ap, num_waits);
kono
parents:
diff changeset
627 goacc_wait (async, num_waits, &ap);
kono
parents:
diff changeset
628 va_end (ap);
kono
parents:
diff changeset
629 }
kono
parents:
diff changeset
630 else if (async == acc_async_sync)
kono
parents:
diff changeset
631 acc_wait_all ();
kono
parents:
diff changeset
632 else if (async == acc_async_noval)
kono
parents:
diff changeset
633 goacc_thread ()->dev->openacc.async_wait_all_async_func (acc_async_noval);
kono
parents:
diff changeset
634 }
kono
parents:
diff changeset
635
kono
parents:
diff changeset
636 int
kono
parents:
diff changeset
637 GOACC_get_num_threads (void)
kono
parents:
diff changeset
638 {
kono
parents:
diff changeset
639 return 1;
kono
parents:
diff changeset
640 }
kono
parents:
diff changeset
641
kono
parents:
diff changeset
642 int
kono
parents:
diff changeset
643 GOACC_get_thread_num (void)
kono
parents:
diff changeset
644 {
kono
parents:
diff changeset
645 return 0;
kono
parents:
diff changeset
646 }
kono
parents:
diff changeset
647
kono
parents:
diff changeset
648 void
kono
parents:
diff changeset
649 GOACC_declare (int device, size_t mapnum,
kono
parents:
diff changeset
650 void **hostaddrs, size_t *sizes, unsigned short *kinds)
kono
parents:
diff changeset
651 {
kono
parents:
diff changeset
652 int i;
kono
parents:
diff changeset
653
kono
parents:
diff changeset
654 for (i = 0; i < mapnum; i++)
kono
parents:
diff changeset
655 {
kono
parents:
diff changeset
656 unsigned char kind = kinds[i] & 0xff;
kono
parents:
diff changeset
657
kono
parents:
diff changeset
658 if (kind == GOMP_MAP_POINTER || kind == GOMP_MAP_TO_PSET)
kono
parents:
diff changeset
659 continue;
kono
parents:
diff changeset
660
kono
parents:
diff changeset
661 switch (kind)
kono
parents:
diff changeset
662 {
kono
parents:
diff changeset
663 case GOMP_MAP_FORCE_ALLOC:
kono
parents:
diff changeset
664 case GOMP_MAP_FORCE_FROM:
kono
parents:
diff changeset
665 case GOMP_MAP_FORCE_TO:
kono
parents:
diff changeset
666 case GOMP_MAP_POINTER:
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
667 case GOMP_MAP_RELEASE:
111
kono
parents:
diff changeset
668 case GOMP_MAP_DELETE:
kono
parents:
diff changeset
669 GOACC_enter_exit_data (device, 1, &hostaddrs[i], &sizes[i],
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
670 &kinds[i], GOMP_ASYNC_SYNC, 0);
111
kono
parents:
diff changeset
671 break;
kono
parents:
diff changeset
672
kono
parents:
diff changeset
673 case GOMP_MAP_FORCE_DEVICEPTR:
kono
parents:
diff changeset
674 break;
kono
parents:
diff changeset
675
kono
parents:
diff changeset
676 case GOMP_MAP_ALLOC:
kono
parents:
diff changeset
677 if (!acc_is_present (hostaddrs[i], sizes[i]))
kono
parents:
diff changeset
678 GOACC_enter_exit_data (device, 1, &hostaddrs[i], &sizes[i],
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
679 &kinds[i], GOMP_ASYNC_SYNC, 0);
111
kono
parents:
diff changeset
680 break;
kono
parents:
diff changeset
681
kono
parents:
diff changeset
682 case GOMP_MAP_TO:
kono
parents:
diff changeset
683 GOACC_enter_exit_data (device, 1, &hostaddrs[i], &sizes[i],
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
684 &kinds[i], GOMP_ASYNC_SYNC, 0);
111
kono
parents:
diff changeset
685
kono
parents:
diff changeset
686 break;
kono
parents:
diff changeset
687
kono
parents:
diff changeset
688 case GOMP_MAP_FROM:
kono
parents:
diff changeset
689 GOACC_enter_exit_data (device, 1, &hostaddrs[i], &sizes[i],
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
690 &kinds[i], GOMP_ASYNC_SYNC, 0);
111
kono
parents:
diff changeset
691 break;
kono
parents:
diff changeset
692
kono
parents:
diff changeset
693 case GOMP_MAP_FORCE_PRESENT:
kono
parents:
diff changeset
694 if (!acc_is_present (hostaddrs[i], sizes[i]))
kono
parents:
diff changeset
695 gomp_fatal ("[%p,%ld] is not mapped", hostaddrs[i],
kono
parents:
diff changeset
696 (unsigned long) sizes[i]);
kono
parents:
diff changeset
697 break;
kono
parents:
diff changeset
698
kono
parents:
diff changeset
699 default:
kono
parents:
diff changeset
700 assert (0);
kono
parents:
diff changeset
701 break;
kono
parents:
diff changeset
702 }
kono
parents:
diff changeset
703 }
kono
parents:
diff changeset
704 }