RaviNarayanaswamy added inline comments.

================
Comment at: openmp/libomptarget/src/interop.cpp:198-201
+  if (interop_type == kmp_interop_type_tasksync) {
+    __kmpc_omp_wait_deps(loc_ref, gtid, ndeps, dep_list, ndeps_noalias,
+                         noalias_dep_list);
+  }
----------------
jdoerfert wrote:
> RaviNarayanaswamy wrote:
> > jdoerfert wrote:
> > > RaviNarayanaswamy wrote:
> > > > jdoerfert wrote:
> > > > > RaviNarayanaswamy wrote:
> > > > > > Interop object does not wait for any task from libomp.  
> > > > > > Init just initializes the interop object.
> > > > > > The initialization of interop object should  be done by the plugin 
> > > > > > as only the plugin knows what properties are supported
> > > > > > Interop object does not wait for any task from libomp. 
> > > > > 
> > > > > I don't know why you think we would not wait for libomp tasks. If we 
> > > > > have dependences we need to wait for them.
> > > > > 
> > > > > > The initialization of interop object should be done by the plugin 
> > > > > > as only the plugin knows what properties are supported.
> > > > > 
> > > > > It is, below. This is the generic part that then redirects to the 
> > > > > plugin.
> > > > Libomp would have not invoked the task which calls this routine if 
> > > > there are dependences.   They must be executed before the task 
> > > > containing  the interop creation is scheduled.
> > > > 
> > > > The interop_type should be passed to plugin and let it initialize the 
> > > > common for all interop-types and then add based on the interop_type 
> > > > Libomp would have not invoked the task which calls this routine if 
> > > > there are dependences. They must be executed before the task containing 
> > > > the interop creation is scheduled.
> > > 
> > > To me it seems you are assuming that we create a task in which this 
> > > routine is called. We do not, as far as I can tell. See D105876.
> > > 
> > > > The interop_type should be passed to plugin and let it initialize the 
> > > > common for all interop-types and then add based on the interop_type
> > > 
> > > So what you are trying to say is that `init_device_info` should take the 
> > > `interop_type` too? That makes sense to me. But as discussed in other 
> > > reviews recently, we should not extend the API for "future use cases" but 
> > > extend it as use cases become relevant. For now it seems we can simply 
> > > set up the `tgt_device_info` part of the `omp_interop_val_t` without 
> > > knowing the `interop_type`.
> > Then need to change this code since the interop_type  can be both 
> > target_sync and  target which will not be handled correctly.  target_sync 
> > and target have common initialization + additional  property base don the 
> > interop_type requested
> > Then need to change this code since the interop_type can be both 
> > target_sync and target which will not be handled correctly. target_sync and 
> > target have common initialization + additional property base don the 
> > interop_type requested
> 
> Could you please elaborate what needs to be changed exactly. What information 
> is currently not available in the setup as is? What properties would be 
> different?
Should be something like this

// NEED to add _kmp_interop_type_target  to represent interop target
//  interop_ptr->device_info would initialize the following: device handle, 
device_context, platform.
if (interop_type == kmp_interop_type_target) { 
 if (!Device.RTL || !Device.RTL->init_device_info ||
        Device.RTL->init_device_info(device_id, &(interop_ptr)->device_info,
                                     &(interop_ptr)->err_str)) {
      delete interop_ptr;
      interop_ptr = omp_interop_none;
 }
// Add target sync if  request.
if (interop_type == kmp_interop_type_tasksync) {
    if (!Device.RTL || !Device.RTL->init_async_info ||
        Device.RTL->init_async_info(device_id, &(interop_ptr)->async_info)) {
      delete interop_ptr;
      interop_ptr = omp_interop_none;
  }





Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D106674/new/

https://reviews.llvm.org/D106674

_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to