<div dir="ltr">The description you had is basically how and why this stuff works. Just switch "older cpu" for "minimum gpu" and I think all of this should still make sense?</div><br><div class="gmail_quote"><div dir="ltr">On Tue, Jun 12, 2018 at 9:57 AM Artem Belevich via Phabricator <<a href="mailto:reviews@reviews.llvm.org">reviews@reviews.llvm.org</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">tra added a comment.<br>
<br>
In <a href="https://reviews.llvm.org/D47691#1123513" rel="noreferrer" target="_blank">https://reviews.llvm.org/D47691#1123513</a>, @hfinkel wrote:<br>
<br>
> > Bottom line -- the situation is far from perfect, but IMO the patch does sensible thing if we're compiling IR with mixed target-cpu and target-features attributes using NVPTX.<br>
><br>
> In summary, I think that's okay so long as there aren't intrinsics that depend on target features.<br>
<br>
<br>
There are intrinsics that have *minimum* requirements for GPU variant (SM_XX) and PTX version.<br>
So it is possible to generate instructions for a wrong GPU variant which will cause PTXAS to fail.<br>
AFAICT, we have no good way to implement intended semantics of target-gpu and target-feature in NVPTX because it just does not allow mixing instructions from different GPU variants in the same TU. Well, you can have *older* SM/PTX entities in the IR, but all of them will be compiled for the most recent variant. IMO we can either ignore the attributes (and leave PTXAS deal with potentially invalid instructions) or error out during compilation (which LLVM does not handle particularly well, either).<br>
<br>
Whether inline functions with mismatched attributes is actually orthogonal to that. It's the presence of the mismatched attributes that's the problem. Whether we inline those functions or not does not change the situation much. I.e. if mismatched function requires older SM/PTX, it will compile and work just fine, whether it's inlined or not. If the function requires newer SM/PTX, it will fail PTXAS compilation if not inlined and may or may not fail is it is inlined as it may end up not generating anything that would need new functionality. In the end inlining mismatched functions in NVPTX does not make the situation worse than it would be if inlining was not allowed.<br>
<br>
The issue with handling target-cpu and target-features in NVPTX in principle does remain open. This patch should let things work the way they did before my clang patch ended up generating the attributes and exposed this issue.<br>
<br>
<br>
Repository:<br>
  rL LLVM<br>
<br>
<a href="https://reviews.llvm.org/D47691" rel="noreferrer" target="_blank">https://reviews.llvm.org/D47691</a><br>
<br>
<br>
<br>
</blockquote></div>