<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
<style type="text/css" style="display:none;"><!-- P {margin-top:0;margin-bottom:0;} --></style>
</head>
<body dir="ltr">
<div id="divtagdefaultwrapper" style="font-size:12pt;color:#000000;font-family:Calibri,Helvetica,sans-serif;" dir="ltr">
<div id="divtagdefaultwrapper" style="font-size: 12pt; color: rgb(0, 0, 0); font-family: Calibri, Helvetica, sans-serif, "EmojiFont", "Apple Color Emoji", "Segoe UI Emoji", NotoColorEmoji, "Segoe UI Symbol", "Android Emoji", EmojiSymbols;" dir="ltr">
<p style="margin-top:0;margin-bottom:0">Hi Alexey,</p>
<p style="margin-top:0;margin-bottom:0"><br>
</p>
<span class="transaction-comment" data-sigil="transaction-comment" data-meta="0_29">
<p>Sorry for the delay. It took me sometime to look at your prototype in github. It seems quite a substantial amount of work!</p>
<p><br>
</p>
<p>I have provided my feedback on your review already <a href="https://reviews.llvm.org/D57768" class="OWAAutoLink">
https://reviews.llvm.org/D57768</a> but I think the topics mainly belong here.<br>
</p>
<p><br>
</p>
<p>There are a number of big architectural aspects of Clang that this work affects. My personal feeling is that some more senior developers in Clang architecture should provide feedback.</p>
<p><br>
</p>
<p>Particularly, the following aspects require more attention:</p>
<ul class="remarkup-list">
<li class="remarkup-list-item">SYCL seems to require adding tight dependencies from the standard libraries into the compiler because many language features are hidden behind library classes. This is not common for Clang. We had a discussion about this issue
during the implementation of OpenCL C++ and it was decided not to go this route for upstream Clang. Can you explain your current approach to implement this?</li></ul>
<ul class="remarkup-list">
<li class="remarkup-list-item">I am not sure how the change of direction for OpenCL C++ to just enabling C++ in OpenCL would affect your work now? Particularly we are establishing a lot of rules in the areas of interplay between OpenCL features and C++. Address
space handling is one example here. As far as I am aware SYCL doesn't detail many of these rules either. So I am wondering how it would work... would you just inherit the same rules? Also keep in mind they are not documented anywhere yet other than the source
code. Additionally for the address spaces we are trying to generalize the rules as much as possible rather than just adding separate language checks all over. It would be nice if you adhere to this approach too!</li></ul>
</span><span class="transaction-comment" data-sigil="transaction-comment" data-meta="0_29">
<ul class="remarkup-list">
<li class="remarkup-list-item">What is your solution for integration with SPIR-V and how does it relate to our previous discussions in October:
<a href="http://lists.llvm.org/pipermail/cfe-dev/2018-October/059974.html" class="remarkup-link" target="_blank" rel="noreferrer">
http://lists.llvm.org/pipermail/cfe-dev/2018-October/059974.html</a></li></ul>
<ul class="remarkup-list">
<li class="remarkup-list-item">Can you explain the purpose of <a href="https://github.com/intel/llvm/tree/sycl/clang/lib/CodeGen/OclCxxRewrite" class="remarkup-link" target="_blank" rel="noreferrer">
https://github.com/intel/llvm/tree/sycl/clang/lib/CodeGen/OclCxxRewrite</a> that you are adding to Clang?</li></ul>
Cheers,</span></div>
<div style="font-size: 12pt; color: rgb(0, 0, 0); font-family: Calibri, Helvetica, sans-serif, "EmojiFont", "Apple Color Emoji", "Segoe UI Emoji", NotoColorEmoji, "Segoe UI Symbol", "Android Emoji", EmojiSymbols;" dir="ltr">
<span class="transaction-comment" data-sigil="transaction-comment" data-meta="0_29">Anastasia<br>
</span><br>
<br>
<div style="color: rgb(0, 0, 0);">
<hr style="display:inline-block;width:98%" tabindex="-1">
<div id="divRplyFwdMsg" dir="ltr"><font style="font-size:11pt" face="Calibri, sans-serif" color="#000000"><b>From:</b> cfe-dev <cfe-dev-bounces@lists.llvm.org> on behalf of Bader, Alexey via cfe-dev <cfe-dev@lists.llvm.org><br>
<b>Sent:</b> 30 January 2019 22:06<br>
<b>To:</b> David Airlie<br>
<b>Cc:</b> cfe-dev (cfe-dev@lists.llvm.org)<br>
<b>Subject:</b> Re: [cfe-dev] [RFC] Add SYCL programming model support.</font>
<div> </div>
</div>
<div class="BodyFragment"><font size="2"><span style="font-size:11pt;">
<div class="PlainText">Hi Dave,<br>
<br>
Thanks for your comments.<br>
We definitely will integrate address spaces support required for SYCL into ToT. The code currently uploaded to the GitHub is our first approach to implement SYCL address spaces inference rules, but we found that it is not robust and difficult to maintain. We
are working on alternative implementation emitting "raw" pointers (i.e. w/o specified address space) in "generic" address space and later re-using existing LLVM pass to inference address space.<br>
This approach should be aligned with existing implementation of address spaces for OpenCL C++.<br>
<br>
Thanks,<br>
Alexey<br>
<br>
-----Original Message-----<br>
From: David Airlie [<a href="mailto:airlied@redhat.com">mailto:airlied@redhat.com</a>]
<br>
Sent: Monday, January 28, 2019 9:45 PM<br>
To: Bader, Alexey <alexey.bader@intel.com><br>
Cc: cfe-dev (cfe-dev@lists.llvm.org) <cfe-dev@lists.llvm.org><br>
Subject: Re: [cfe-dev] [RFC] Add SYCL programming model support.<br>
<br>
On Sat, Jan 26, 2019 at 6:11 AM Bader, Alexey via cfe-dev <cfe-dev@lists.llvm.org> wrote:<br>
><br>
> Hi,<br>
><br>
><br>
><br>
> A short update: we uploaded SYCL compiler and runtime sources to the GitHub <a href="https://github.com/intel/llvm/tree/sycl">
https://github.com/intel/llvm/tree/sycl</a>.<br>
><br>
><br>
><br>
> Thanks to all who provided feedback and expressed interest in this project (mostly off the clang mailing list).<br>
><br>
> If there are no objections, we are going to start sending patches for review in a week or two.<br>
<br>
Hi Alexey,<br>
<br>
I've just started looking over this, and first of all great work! I'm not directly the best person yet to review all of this, but I'm starting to look over it and one thing stood out:<br>
<br>
There seems to be some interaction or reliance on old address space behaviour,<br>
<br>
I don't think (maybe I'm wrong) that upstream will want to accept:<br>
[SYCL] Revert "[OpenCL] Enable address spaces for references in C++"<br>
or at least the OpenCL C++ people need to be talked to.<br>
<br>
Is there some more work that could be done in these to avoid the revert?<br>
[SYCL] Implement SYCL address-space rules.<br>
- do we have to use separate sycl address spaces as at all here btw?<br>
or are the opencl ones defined already not sufficient?<br>
[SYCL] Add SYCL-specific address spaces fixer pass.<br>
<br>
Dave.<br>
<br>
--------------------------------------------------------------------<br>
Joint Stock Company Intel A/O<br>
Registered legal address: Krylatsky Hills Business Park,<br>
17 Krylatskaya Str., Bldg 4, Moscow 121614,<br>
Russian Federation<br>
<br>
This e-mail and any attachments may contain confidential material for<br>
the sole use of the intended recipient(s). Any review or distribution<br>
by others is strictly prohibited. If you are not the intended<br>
recipient, please contact the sender and delete all copies.<br>
_______________________________________________<br>
cfe-dev mailing list<br>
cfe-dev@lists.llvm.org<br>
<a href="https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-dev">https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-dev</a><br>
</div>
</span></font></div>
</div>
</div>
</div>
</body>
</html>