<div dir="ltr"><div>Hi Johannes,</div><div><br></div><div>Thanks for working on this.  A brief question inline....<br></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Thu, Aug 1, 2019 at 5:47 PM Doerfert, Johannes via Openmp-dev <<a href="mailto:openmp-dev@lists.llvm.org">openmp-dev@lists.llvm.org</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">Short summary of the phone call we had Wednesday for people that<br>
couldn't make it, are not aware of the phone calls, or simply forgot:<br>
  - We do split the requested changes into three different activities,<br>
    thus separate patch sets:<br>
    1) splitting common logic and target specific code<br>
    2) improving documentation<br>
    3) unifying coding style<br>
  - We need to improve the testing situation, both CI testing and test<br>
    coverage. Task include:<br>
    * Setup buildbots that run OpenMP tests and report the results,<br>
      detect failure, maybe later measure performance, etc.<br>
    * Add OpenMP execution tests, both host and device, to the OpenMP<br>
      subproject (see also below) and the LLVM Test Suite.<br>
  - We need to agree on a directory structure and build model for the<br>
    device runtime library or better libomptarget (potentially later<br>
    also for other parts). As discussed, I outline what I think is a<br>
    good solution below.<br>
<br>
<br>
-------------------------------------------------------------------------------<br>
<br>
<br>
libomptarget* directory structure<br>
=================================<br>
* everything currently contained in "openmp/libomptarget/"<br>
<br>
Folder and file names (including file extensions) are subject to the<br>
usual bikeshedding. Let's agree on the idea first and the color of the<br>
shed later.<br>
<br>
<br>
Sources<br>
-------<br>
For the device RTL it currently looks like this:<br>
  openmp/libomptarget/deviceRTLs/nvptx/{docs,src,test,CMakeLists.txt}<br>
The test structure is discussed later. docs is pretty much empty and it<br>
should probably live with the common logic. src is discussed now:<br>
<br>
I now assume we will have a common core (probably header only), and<br>
device specific code that may or may not use common core parts. The<br>
structure I imagine looks like this:<br>
  openmp/libomptarget/deviceRTLs/common/include/{queue.h, target_impl.h,...}<br>
  openmp/libomptarget/deviceRTLs/nvptx/{<a href="http://libomptarget.cu" rel="noreferrer" target="_blank">libomptarget.cu</a>,CMakeLists.txt,...,include/target_impl.h,...}<br>
  openmp/libomptarget/deviceRTLs/amdgpu/{libomptarget.hip,CMakeLists.txt,...,include/target_impl.h,...}<br>
  openmp/libomptarget/deviceRTLs/CPU/{libomptarget.XYZ,CMakeLists.txt,...,include/target_impl.h,...}<br>
  openmp/libomptarget/deviceRTLs/.../{libomptarget.XYZ,CMakeLists.txt,...,include/target_impl.h,...}<br>
I added a CPU version above to ease testing (see below) and to provide a<br>
target_impl.h declaration for better IDE support.<br>
<br>
- The common files could be header only (debatable and not strictly necessary).<br>
- All source files that need to be compiled and linked into a library<br>
  for this device (as IR or object files) are listed in the device<br>
  CMakeLists.txt file. This can include common source files if the<br>
  common files are not header only. There is no need to include any<br>
  common files if the device implementation is self-contained.<br>
- To make target definitions available to common files we would:<br></blockquote><div><br></div><div>Why do target definitions need to be made available to common files?  Is it only for the case that common has source not just headers, and that source must be compiled per device?</div><div><br></div><div>Thanks.</div><div><br></div><div>Joel<br></div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
    * put target specific function declarations, e.g.,<br>
       `template <typename T> T __kmpc_impl_atomic_add(T *Ptr, T Val)`<br>
      in common/include/target_impl.h.<br>
    * put implementations in {nvptx,amdgpu,...}/include/target_impl.h.<br>
    * have a `#include_next "target_impl.h"` in common/include/target_impl.h.<br>
    * have the common/include and one device include folder in the<br>
      include path (in this order) when we compile any file.<br></blockquote><div></div></div><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<br>
<br>
Tests<br>
-----<br>
So far, there are tests in<br>
  openmp/libomptarget/test<br>
and<br>
  openmp/libomptarget/deviceRTLs/nvptx/test<br>
<br>
I think we should reorganize this such that we have three distinct<br>
kinds of tests living in distinct places:<br>
  1) Functional/Execution tests written in C/C++/Fortran + OpenMP, living in<br>
     openmp/libomptarget/test/{api,env,mapping,offloading,...}<br>
  2) Unit tests for the common logic, living in<br>
     openmp/libomptarget/unittests/{api,env,mapping,offloading,...}<br>
  3) Unit tests for the device specific code, living in<br>
     openmp/libomptarget/deviceRTLs/{nvptx,amdgpu,...}/unittests/{api,env,mapping,offloading,...}<br>
Existing tests will be categorized accordingly and put into their<br>
respective place.<br>
<br>
To allow testing of common logic without offloading we can have a "CPU"<br>
deviceRTL that implements the declarations in target_impl.h. It could<br>
even offer us a way to vary the system parameters easily over vast<br>
ranges not necessarily supported by existing hardware. This should be<br>
discussed separately though.<br>
<br>
<br>
-------------------------------------------------------------------------------<br>
<br>
Comments welcome!<br>
<br>
Thanks,<br>
  Johannes<br>
<br>
<br>
<br>
On 07/05, Doerfert, Johannes via Openmp-dev wrote:<br>
> Tl;dr<br>
>   We should extract device specific code out of the OpenMP deviceRTL such that we can reuse the common logic (>90%) for all devices.<br>
>   We also need to improve the documentation and we should think about bringing the code into the LLVM coding style.<br>
> <br>
> <br>
> Requested changes:<br>
> I would like is to change the OpenMP device runtime library design (openmp/libomptarget/deviceRTLs) towards the following goals:<br>
>  1) Allow reuse of common logic between different devices in a clean and extensible way.<br>
>  2) Improve the documentation, e.g., doxygen comments and code comments, for the code.<br>
>  3) Follow the same coding style as LLVM core.<br>
> <br>
> Disclaimer:<br>
> First, I do not want to say it currently is impossible the reuse the code for other devices or the code is not documented at all. What I<br>
> think is that we can improve both substantially if we choose to do so. Also, a change in coding style is easier now than later, so if we<br>
> decide to do refactoring, that can be included without adding to much churn.<br>
> <br>
> Motivation:<br>
> Now we can discuss if we should do any of the proposed changes but I guess most of them have clear benefits. I am also not the first<br>
> to suggest them. Point 1 was mentioned with the initial drop of the device runtime [0], but it was rejected for time reasons. Point 2<br>
> was recently discussed as a pressing issue in multiple reviews. Point 3 is a general observation as writing and reviewing code for the<br>
> openmp sub project is unnecessarily hard for LLVM developers due to the different coding style.<br>
> <br>
> Proposed structure:<br>
> In order to ease the reuse by new devices we should have a common core with device independent logic, e.g., in<br>
>   openmp/ibomptarget/deviceRTLs/common<br>
> including an interface that declares all device specific methods needed by the core logic. The interface is then the<br>
> only thing implemented in the device subfolders, e.g., <br>
>    openmp/ibomptarget/deviceRTLs/nvptx,   openmp/ibomptarget/deviceRTLs/amdgpu, ...<br>
> To get to this goal, all device specific code has to be extracted from the core logic. The prototypes below show that this<br>
> is fairly easy to do.<br>
> <br>
> <br>
> Feasibility and prototypes:<br>
> To showcase the direction I would like is to move to I "redesigned" three files (out of ~20) with the above goals in mind. The patches<br>
> can be found here:<br>
>   <a href="https://reviews.llvm.org/D64217" rel="noreferrer" target="_blank">https://reviews.llvm.org/D64217</a><br>
>   <a href="https://reviews.llvm.org/D64218" rel="noreferrer" target="_blank">https://reviews.llvm.org/D64218</a><br>
>   <a href="https://reviews.llvm.org/D64219" rel="noreferrer" target="_blank">https://reviews.llvm.org/D64219</a><br>
> Note that there is a vast design space even if we agree to the above three goals. As a consequence, I'd like us to use the patches to<br>
> discuss general design decisions not specific ones until we agreed on a path forward.<br>
>  <br>
> <br>
> Please let me know what you think,<br>
>   Johannes<br>
> <br>
> <br>
> <br>
> [0] <a href="https://reviews.llvm.org/D14254#949985" rel="noreferrer" target="_blank">https://reviews.llvm.org/D14254#949985</a><br>
> <br>
> <br>
> ---------------------------------------<br>
> Johannes Doerfert<br>
> Researcher<br>
> <br>
> Argonne National Laboratory<br>
> Lemont, IL 60439, USA<br>
> <br>
> <a href="mailto:jdoerfert@anl.gov" target="_blank">jdoerfert@anl.gov</a><br>
> _______________________________________________<br>
> Openmp-dev mailing list<br>
> <a href="mailto:Openmp-dev@lists.llvm.org" target="_blank">Openmp-dev@lists.llvm.org</a><br>
> <a href="https://lists.llvm.org/cgi-bin/mailman/listinfo/openmp-dev" rel="noreferrer" target="_blank">https://lists.llvm.org/cgi-bin/mailman/listinfo/openmp-dev</a><br>
<br>
-- <br>
<br>
Johannes Doerfert<br>
Researcher<br>
<br>
Argonne National Laboratory<br>
Lemont, IL 60439, USA<br>
<br>
<a href="mailto:jdoerfert@anl.gov" target="_blank">jdoerfert@anl.gov</a><br>
_______________________________________________<br>
Openmp-dev mailing list<br>
<a href="mailto:Openmp-dev@lists.llvm.org" target="_blank">Openmp-dev@lists.llvm.org</a><br>
<a href="https://lists.llvm.org/cgi-bin/mailman/listinfo/openmp-dev" rel="noreferrer" target="_blank">https://lists.llvm.org/cgi-bin/mailman/listinfo/openmp-dev</a><br>
</blockquote></div></div>