<div dir="ltr">LGTM</div><div class="gmail_extra"><br><br><div class="gmail_quote">On Wed, Mar 26, 2014 at 4:24 PM, Eli Bendersky <span dir="ltr"><<a href="mailto:eliben@google.com" target="_blank">eliben@google.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr">Hello,<div><br></div><div>As discussed in PR19099, the solution in r203483 was imperfect. While we could fix global names when they are emitted in directives, this does not work for their usage within instructions. Instruction emission is hard-coded through MI and NVPTX does not control this.</div>


<div><br></div><div>A more thorough solution is a target-specific IR pass that replaces all invalid characters in symbol names before they go into codegen. This makes sure that invalid characters will never appear in symbols in PTX.</div>


<div><br></div><div>An added benefit is that this avoids collisions because Value->setName does automatic collision resolution.</div><div><br></div><div>Once this goes in, most of r203483 can be reverted (I'll take care of that).</div>


<div><br></div><div>PTAL,</div><div>Eli</div><div><br></div></div>
</blockquote></div><br></div>