<div dir="ltr"><div dir="ltr"><br></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Fri, Mar 12, 2021 at 2:30 AM Trifunovic, Konrad via llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-style:solid;border-left-color:rgb(204,204,204);padding-left:1ex">Hi,<br>
<br>
Thank you all for a very in-depth discussion so far.<br>
Besides the major topic of MLIR and LLVM-IR coexistence, are there any other comments, especially regarding 'Open questions' section that we proposed?<br>
<br>
My recap so far is:<br>
        * There is a good reception from the community that is interested in LLVM-IR path (a classical FE/opt/code-generation path, clang community)<br>
        * There is a concern on maintenance cost if we have two solutions in parallel: MLIR based, and LLVM-IR based. We will look for the ways to address this, one investigation point would be generating MLIR 'spv' dialect from the target backend infrastructure (GlobalISel)<br>
        * We also need to iron out the details of the semantics and capabilities of SPIR-V that we would like to expose: 1) which exact subset of LLVM-IR is acceptable by the backend, 2) how do we expose the extensions and core builtins, 3) how do we map a memory model to LLVM-IR (especially if we think about adding Vulkan compute memory model) etc.<br>
<br>
Based on the feedback so far, that would be roughly my plan:<br>
        * Go ahead with a SPIR-V backend in LLVM-IR, as planned. Look for clang integration.<br>
        * Midterm: investigate MLIR 'spv' dialect generation from GlobalISel (or other means) as an unifying solution<br></blockquote><div><br></div><div>To me this is something to look at in the very short term: I'm wary of investment in duplicated infrastructure for SPIRV binary serialization/deserialization in-tree. I.e. this covers the path from MIR (post-GlobalISel)->SPIRV (and potentially any MIR-level transformations).</div><div>To be clear: this does not block landing parts of the backend (all the GlobalISel specification for instance), but I suspect you'll want to get something end-to-end.</div><div><br></div><div>The two points below are indeed more long-term / hypothetical in my opinion: good to keep in mind but clearly off the table right now.</div><div><br></div><div><br></div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-style:solid;border-left-color:rgb(204,204,204);padding-left:1ex">
        * Long-term: come up with a single, MLIR based backend (which is going to take care of serialization, deserialization, automatic specification updates and all the rest of the infrastructure work). This still means we will have two entry points: directly through MLIR 'spv' dialect or through LLVM-IR with intrinsics/metadata. Will support both Vulkan compute and OpenCL compute models.<br>
        * When/if clang eventually switches to MLIR code generation, that would be eventually the end of LLVM-IR path :)<br>
<br>
For the first point, we need a close collaboration with GlobalISel and clang communities. For the last three points, we will work closely with MLIR community on engineering and IR specification.<br>
<br>
What do You think? Does this sound like a reasonable plan?<br>
<br>
thanks,<br>
konrad<br>
<br>
> -----Original Message-----<br>
> From: Ronan KERYELL <<a href="mailto:ronan@keryell.fr" target="_blank">ronan@keryell.fr</a>><br>
> Sent: Wednesday, March 3, 2021 8:55 PM<br>
> To: Renato Golin <<a href="mailto:rengolin@gmail.com" target="_blank">rengolin@gmail.com</a>><br>
> Cc: Renato Golin via llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>>; Trifunovic, Konrad<br>
> <<a href="mailto:konrad.trifunovic@intel.com" target="_blank">konrad.trifunovic@intel.com</a>><br>
> Subject: Re: [llvm-dev] [RFC] Upstreaming a proper SPIR-V backend<br>
> <br>
> >>>>> On Wed, 3 Mar 2021 18:57:33 +0000, Renato Golin<br>
> <<a href="mailto:rengolin@gmail.com" target="_blank">rengolin@gmail.com</a>> said:<br>
> <br>
>     Renato> Just thinking out loud if clang couldn't be a hybrid<br>
>     Renato> front-end, emitting LLVM IR and MLIR for different parts of<br>
>     Renato> the program (for example, accelerators), and either use<br>
>     Renato> SPIRV (for supported accelerators) or lower to LLVM IR (for<br>
>     Renato> the rest).<br>
> <br>
> At some point everything is possible.<br>
> <br>
>     Renato> This would allow us to use MLIR directly in hybrid<br>
>     Renato> programming models (like OpenMP, OpenCL) and make real use<br>
>     Renato> of the high-level optimisations in MLIR. Perhaps SYCL<br>
>     Renato> wouldn't fit here.<br>
> <br>
> I guess you have exchanged the words OpenCL and SYCL in this sentence.<br>
> OpenCL is like graphics shader languages: a foreign language to the host.<br>
> From the host point-of-view it is just a host foreign API managing memory<br>
> allocation on the device and controlling kernel execution on some devices<br>
> (think RPC). The advantage is that you can use OpenCL from a COBOL host<br>
> program if you want but this is another story... :-)<br>
> --<br>
>   Ronan KERYELL<br>
_______________________________________________<br>
LLVM Developers mailing list<br>
<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a><br>
<a href="https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev" rel="noreferrer" target="_blank">https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev</a><br>
</blockquote></div></div>