<div dir="ltr"><div>Hi Andrew,</div><div><br></div><div>I am very sorry for replying late. I had to just clean up some things before I pushed the code.</div><div><br></div><div>You can find it here: <a href="https://github.com/nvg24/llvm-project" target="_blank">https://github.com/nvg24/llvm-project</a><br><br></div><div>It's not a big change. But the main assumption my change has it that the tests respect the OMP_NUM_THREADS environment variable. The current tests(eg. XSBench) in the LLVM test-suite use
<span style="font-family:monospace">omp_get_num_procs() <font face="arial,sans-serif">to get the number of threads, which is a problem.</font></span></div><div><span style="font-family:monospace"><font face="arial,sans-serif"><br></font></span></div><div><span style="font-family:monospace"><font face="arial,sans-serif">You can contact me if you have any questions.</font></span></div><div><span style="font-family:monospace"><font face="arial,sans-serif"><br></font></span></div><div><span style="font-family:monospace"><font face="arial,sans-serif">Thank you,</font></span></div><div><span style="font-family:monospace"><font face="arial,sans-serif">Neeraj Ganu<br></font>
</span></div><div><br></div><div><br></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Wed, Jun 10, 2020 at 3:20 PM Kaylor, Andrew <<a href="mailto:andrew.kaylor@intel.com" target="_blank">andrew.kaylor@intel.com</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">
<div lang="EN-US">
<div>
<p class="MsoNormal">Hi Neeraj,<u></u><u></u></p>
<p class="MsoNormal"><u></u> <u></u></p>
<p class="MsoNormal">Are your changes available somewhere that I could see them?<u></u><u></u></p>
<p class="MsoNormal"><u></u> <u></u></p>
<p class="MsoNormal">It sounds like a useful feature, and I’d like to see how you have implemented it.<u></u><u></u></p>
<p class="MsoNormal"><u></u> <u></u></p>
<p class="MsoNormal">Thanks,<u></u><u></u></p>
<p class="MsoNormal">Andy<u></u><u></u></p>
<p class="MsoNormal"><u></u> <u></u></p>
<p class="MsoNormal"><u></u> <u></u></p>
<p class="MsoNormal"><b>From:</b> Neeraj Ganu <<a href="mailto:neeraj.ganu@stonybrook.edu" target="_blank">neeraj.ganu@stonybrook.edu</a>> <br>
<b>Sent:</b> Wednesday, June 10, 2020 9:12 AM<br>
<b>To:</b> Kaylor, Andrew <<a href="mailto:andrew.kaylor@intel.com" target="_blank">andrew.kaylor@intel.com</a>>; Johannes Doerfert <<a href="mailto:johannesdoerfert@gmail.com" target="_blank">johannesdoerfert@gmail.com</a>><br>
<b>Cc:</b> Lazarev, Vladimir <<a href="mailto:vladimir.lazarev@intel.com" target="_blank">vladimir.lazarev@intel.com</a>>; LLVM Developers <<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>>; <a href="mailto:bhomerding@anl.gov" target="_blank">bhomerding@anl.gov</a>; Finkel, Hal J. <<a href="mailto:hfinkel@anl.gov" target="_blank">hfinkel@anl.gov</a>>; Kruse, Michael <<a href="mailto:michael.kruse@anl.gov" target="_blank">michael.kruse@anl.gov</a>>; Malik,Abid <<a href="mailto:amalik@bnl.gov" target="_blank">amalik@bnl.gov</a>>; Clement, Valentin <<a href="mailto:clementv@ornl.gov" target="_blank">clementv@ornl.gov</a>><br>
<b>Subject:</b> Re: [cfe-dev] Adding SYCL tests in test-suite<u></u><u></u></p>
<p class="MsoNormal"><u></u> <u></u></p>
<div>
<div>
<p class="MsoNormal">Hi Johannes and Andrew,<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
<div>
<p class="MsoNormal">1) I agree with the structure suggested by Johannes for the test-suite, it will make things easier.<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
<div>
<p class="MsoNormal">2) Regarding the lit changes that I made : <u></u><u></u></p>
</div>
<div>
<p class="MsoNormal">I made changes to the <b>lit utility </b>that can be used to execute the tests in the LLVM test-suite. I enabled an option for tests that run with multiple threads using OpenMP, that allows you to control how many threads you will like
to assign to the tests. So by default, a test will run with 1 thread unless you mention otherwise.<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
<div>
<p class="MsoNormal">This was done as the tests in consideration could do both(parallel and serial execution). But if we make the directory structure as suggested above then we can even have control over if we want to run parallel tests or just the serial ones
without much changes.<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
<div>
<p class="MsoNormal">These changes are not included in the current TOT.<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
<div>
<p class="MsoNormal">Let me know if you have any questions. <u></u><u></u></p>
</div>
</div>
<p class="MsoNormal"><u></u> <u></u></p>
<div>
<div>
<p class="MsoNormal">On Mon, Jun 8, 2020 at 8:04 PM Kaylor, Andrew <<a href="mailto:andrew.kaylor@intel.com" target="_blank">andrew.kaylor@intel.com</a>> wrote:<u></u><u></u></p>
</div>
<blockquote style="border-color:currentcolor currentcolor currentcolor rgb(204,204,204);border-style:none none none solid;border-width:medium medium medium 1pt;padding:0in 0in 0in 6pt;margin-left:4.8pt;margin-right:0in">
<div>
<div>
<p class="MsoNormal">That’s a good question. I’m afraid I don’t know how/if that’s controlled in these tests.<u></u><u></u></p>
<p class="MsoNormal"> <u></u><u></u></p>
<div>
<div style="border-style:solid none none;border-width:1pt medium medium;padding:3pt 0in 0in;border-color:currentcolor">
<p class="MsoNormal"><b>From:</b> Johannes Doerfert <<a href="mailto:johannesdoerfert@gmail.com" target="_blank">johannesdoerfert@gmail.com</a>>
<br>
<b>Sent:</b> Monday, June 08, 2020 3:05 PM<br>
<b>To:</b> Kaylor, Andrew <<a href="mailto:andrew.kaylor@intel.com" target="_blank">andrew.kaylor@intel.com</a>>; Lazarev, Vladimir <<a href="mailto:vladimir.lazarev@intel.com" target="_blank">vladimir.lazarev@intel.com</a>><br>
<b>Cc:</b> LLVM Developers <<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>>;
<a href="mailto:bhomerding@anl.gov" target="_blank">bhomerding@anl.gov</a>; Finkel, Hal J. <<a href="mailto:hfinkel@anl.gov" target="_blank">hfinkel@anl.gov</a>>; Kruse, Michael <<a href="mailto:michael.kruse@anl.gov" target="_blank">michael.kruse@anl.gov</a>>;
Malik,Abid <<a href="mailto:amalik@bnl.gov" target="_blank">amalik@bnl.gov</a>>; Clement, Valentin <<a href="mailto:clementv@ornl.gov" target="_blank">clementv@ornl.gov</a>>; Neeraj Ganu <<a href="mailto:neeraj.ganu@stonybrook.edu" target="_blank">neeraj.ganu@stonybrook.edu</a>><br>
<b>Subject:</b> Re: [cfe-dev] Adding SYCL tests in test-suite<u></u><u></u></p>
</div>
</div>
<p class="MsoNormal"> <u></u><u></u></p>
<p><span style="font-family:"Hack Nerd Font Mono",serif">Sounds great. Did he also put in nobs to limit parallelism, make sure not to oversubscribe the system, etc. ?</span><u></u><u></u></p>
<p> <u></u><u></u></p>
<div>
<p class="MsoNormal">On 6/8/20 4:53 PM, Kaylor, Andrew wrote:<u></u><u></u></p>
</div>
<blockquote style="margin-top:5pt;margin-bottom:5pt">
<pre>Hi Johannes,<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>The structure you suggested makes sense to me.<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>Vladimir Lazarev has been working on moving some end-to-end tests out of the source tree (in the intel/llvm GitHub branch where the parts of our SYCL development that aren’t ready to be included in the main LLVM repo are being shared). He has a local working copy that can run the tests with various hardware and device runtimes. The last version of this that I saw put the tests in llvm-test-suite/SYCL, but it should be easy enough to move them another level deeper to create a parallel structure to be shared with OpenMP. Vladimir is on vacation right now, but I believe he’ll be preparing a patch for review shortly after he returns.<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>Thanks,<u></u><u></u></pre>
<pre>Andy<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>From: Johannes Doerfert <a href="mailto:johannesdoerfert@gmail.com" target="_blank"><johannesdoerfert@gmail.com></a><u></u><u></u></pre>
<pre>Sent: Monday, June 08, 2020 2:00 PM<u></u><u></u></pre>
<pre>To: Kaylor, Andrew <a href="mailto:andrew.kaylor@intel.com" target="_blank"><andrew.kaylor@intel.com></a><u></u><u></u></pre>
<pre>Cc: LLVM Developers <a href="mailto:llvm-dev@lists.llvm.org" target="_blank"><llvm-dev@lists.llvm.org></a>; <a href="mailto:bhomerding@anl.gov" target="_blank">bhomerding@anl.gov</a>; Finkel, Hal J. <a href="mailto:hfinkel@anl.gov" target="_blank"><hfinkel@anl.gov></a>; Kruse, Michael <a href="mailto:michael.kruse@anl.gov" target="_blank"><michael.kruse@anl.gov></a>; Malik,Abid <a href="mailto:amalik@bnl.gov" target="_blank"><amalik@bnl.gov></a>; Clement, Valentin <a href="mailto:clementv@ornl.gov" target="_blank"><clementv@ornl.gov></a>; Neeraj Ganu <a href="mailto:neeraj.ganu@stonybrook.edu" target="_blank"><neeraj.ganu@stonybrook.edu></a><u></u><u></u></pre>
<pre>Subject: Re: [cfe-dev] Adding SYCL tests in test-suite<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>Hi Andy,<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>[-cfe-dev, llvm-dev seems sufficient for this]<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>First, apologies for not responding earlier.<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>I CC'ed a few people that might be interested in this (or at least in the path we'll take).<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>On 4/16/20 5:44 PM, Kaylor, Andrew wrote:<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>Thanks, Johannes!<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>It would be nice to have some additional infrastructure to control execution of tests that have special resource requirements like this. We've seen some problems in our internal testing with parallel test execution causing system gridlock. Having a common way to address that would be great.<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>@Neeraj started to work on this, I'm not sure where exactly we are though.<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>One reason I thought separate SYCL folders (either at the top level or elsewhere in the tree) would be useful is that I think we'll probably want a single option to turn these tests on or off as a group. A "parallel" folder may make sense for the same reason. I see your point about mixed languages, but perhaps we could add a "parallel/mixed" subfolder if/when such a test is added.<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>Agreed, something like this would make sense to me:<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>llvm-test-suite/SingleSource/...<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>llvm-test-suite/parallel/SYCL/...<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>llvm-test-suite/parallel/OpenMP/...<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>llvm-test-suite/parallel/multiple/proxyapps/...<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>llvm-test-suite/parallel/multiple/cloverleaf/...<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>Thoughts?<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>Cheers,<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> Johannes<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>Any other opinions?<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>-Andy<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>-----Original Message-----<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>From: Johannes Doerfert <a href="mailto:johannesdoerfert@gmail.com" target="_blank"><johannesdoerfert@gmail.com></a><a href="mailto:johannesdoerfert@gmail.com" target="_blank"><mailto:johannesdoerfert@gmail.com></a><u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>Sent: Wednesday, April 15, 2020 11:45 PM<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>To: Kaylor, Andrew <a href="mailto:andrew.kaylor@intel.com" target="_blank"><andrew.kaylor@intel.com></a><a href="mailto:andrew.kaylor@intel.com" target="_blank"><mailto:andrew.kaylor@intel.com></a><u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>Cc: LLVM Developers <a href="mailto:llvm-dev@lists.llvm.org" target="_blank"><llvm-dev@lists.llvm.org></a><a href="mailto:llvm-dev@lists.llvm.org" target="_blank"><mailto:llvm-dev@lists.llvm.org></a>; <a href="mailto:cfe-dev@lists.llvm.org" target="_blank">cfe-dev@lists.llvm.org</a><a href="mailto:cfe-dev@lists.llvm.org" target="_blank"><mailto:cfe-dev@lists.llvm.org></a><u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>Subject: Re: [cfe-dev] Adding SYCL tests in test-suite<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>Hi Andy,<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>On 4/15/20 7:17 PM, Kaylor, Andrew via cfe-dev wrote:<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> > We'd like to some SYCL tests to LLVM's test suite. The SYCL support in > the LLVM repo is still very much a work-in-progress, but since the > test-suite is supposed to be able to support compilers other than > clang, I thought it would be reasonable to start adding the tests > there now, disabled by default, rather than maintaining a fork of the > test-suite repo until SYCL support is fully in place in the main repo.<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>I think adding such tests is generally a good idea and I do think we could have them in the test suite while SYCL support in clang is still maturing.<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> > These tests would involve compiling one or more source files > containing SYCL kernels and then executing the resulting binaries > using either host, CPU, or accelerator devices, based on the user's > configuration. Running these tests in some configurations would > require an OpenCL runtime and, of course, the chosen hardware.<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>Now this is where the dicey part begins. The test suite, as of now, is not well equipped for tests "competing for shared resources". I mean, parallel tests or tests running on accelerators. To be fair, I am assuming we don't want the test suite to be run completely sequential if the SYCL parts are run, potentially with the non-SYCL parts. I'm saying this because OpenMP is in a similar position right now.<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>Our goal is to run OpenMP tests as part of the test suite but that requires infrastructure we only started to build (downstream so far). I think the goals of basically all parallel (and offloading) extensions are pretty much the same so we should work together on them.<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> > Am I over-reaching?<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>No.<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> > If not, I'd like some feedback on where the tests should go. For the > most part, I think these will be correctness tests, though I expect > we'll want to add benchmarks at some point. For the correctness tests, > I thought it would make sense to either (a) create a top-level SYCL > folder with SingleSource and MultiSource folders under it, or (b) > create SYCL folders in appropriate locations under the existing > SingleSource and MultiSource folders (e.g.<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> > llvm-test-suite/SingleSource/UnitTests/SYCL). I would favor (b) but I > wasn't sure if SYCL is enough of a departure from the normal C/C++ > tests to push it into its own location.<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>Option (c) would be an parallel or accelerator subfolder in which we nest things. Howe we nest things is again the question you asked. While I can see the appeal of a (almost) top-level SYCL folder it also has drawbacks, mostly when it comes to these really cool applications that come in 2+ different languages. Keeping these sources together as they are seems pretty important. In that spirit, I am unsure why we should do any of the options (a-c) at all. We could just put a test, let's say XYZ, into the existing structure SingleSource/Benchmarks/XYZ regardless of the language XYZ is written in. We mixed C and C++, why stop there.<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>To be honest, I don't really care too much and the above is mostly to start a discussion on the pros and cons of the different options.<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> > I haven't added anything to test-suite before, so if I'm approaching > this in completely the wrong way don't be shy about telling me so.<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>I think writing an email like this is exactly the right way :)<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre>Cheers,<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> Johannes<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> > Thanks,<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> > Andy<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> ><u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> ><u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> ><u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> > _______________________________________________<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> > cfe-dev mailing list<u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> > <a href="mailto:cfe-dev@lists.llvm.org" target="_blank">cfe-dev@lists.llvm.org</a><a href="mailto:cfe-dev@lists.llvm.org" target="_blank"><mailto:cfe-dev@lists.llvm.org></a><u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> > <a href="https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-dev" target="_blank">https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-dev</a><u></u><u></u></pre>
<pre> <u></u><u></u></pre>
<pre> <u></u><u></u></pre>
</blockquote>
</div>
</div>
</blockquote>
</div>
</div>
</div>
</blockquote></div>