re PR libgomp/92028 (OpenACC 'host_data' execution test regressions with nvptx offloa...
authorJakub Jelinek <jakub@redhat.com>
Wed, 9 Oct 2019 07:33:02 +0000 (09:33 +0200)
committerJakub Jelinek <jakub@gcc.gnu.org>
Wed, 9 Oct 2019 07:33:02 +0000 (09:33 +0200)
PR libgomp/92028
* target.c (gomp_map_vars_internal): Readd the previous
GOMP_MAP_USE_DEVICE_PTR handling code in the first loop,
though do that just in the !not_found_cnt case.

From-SVN: r276753

libgomp/ChangeLog
libgomp/target.c

index 67d5737e5e8bb9e57a06bfcdd953a9f5c67c4ded..dcd57cfd57098bf5668e30d14e9c7f853ca8a279 100644 (file)
@@ -1,3 +1,10 @@
+2019-10-09  Jakub Jelinek  <jakub@redhat.com>
+
+       PR libgomp/92028
+       * target.c (gomp_map_vars_internal): Readd the previous
+       GOMP_MAP_USE_DEVICE_PTR handling code in the first loop,
+       though do that just in the !not_found_cnt case.
+
 2019-10-08  Tobias Burnus  <tobias@codesourcery.com>
 
        * gfortran.dg/gomp/target-simd.f90: New.
index a83cb48108a9c5b7c71aef9b051957628e965fa3..84d6daa76ca87b968f7ddbba18daded5e7ab505a 100644 (file)
@@ -593,6 +593,30 @@ gomp_map_vars_internal (struct gomp_device_descr *devicep,
          tgt->list[i].key = NULL;
          if (!not_found_cnt)
            {
+             /* In OpenMP < 5.0 and OpenACC the mapping has to be done
+                on a separate construct prior to using use_device_{addr,ptr}.
+                In OpenMP 5.0, map directives need to be ordered by the
+                middle-end before the use_device_* clauses.  If
+                !not_found_cnt, all mappings requested (if any) are already
+                mapped, so use_device_{addr,ptr} can be resolved right away.
+                Otherwise, if not_found_cnt, gomp_map_lookup might fail
+                now but would succeed after performing the mappings in the
+                following loop.  We can't defer this always to the second
+                loop, because it is not even invoked when !not_found_cnt
+                after the first loop.  */
+             cur_node.host_start = (uintptr_t) hostaddrs[i];
+             cur_node.host_end = cur_node.host_start;
+             splay_tree_key n = gomp_map_lookup (mem_map, &cur_node);
+             if (n == NULL)
+               {
+                 gomp_mutex_unlock (&devicep->lock);
+                 gomp_fatal ("use_device_ptr pointer wasn't mapped");
+               }
+             cur_node.host_start -= n->host_start;
+             hostaddrs[i]
+               = (void *) (n->tgt->tgt_start + n->tgt_offset
+                           + cur_node.host_start);
+             tgt->list[i].offset = ~(uintptr_t) 0;
            }
          else
            tgt->list[i].offset = 0;