<div dir="ltr"><br><div class="gmail_extra"><br><br><div class="gmail_quote">On Tue, Nov 26, 2013 at 6:31 AM, Bill Wendling <span dir="ltr"><<a href="mailto:isanbard@gmail.com" target="_blank">isanbard@gmail.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="HOEnZb"><div class="h5">On Nov 25, 2013, at 4:40 PM, Dan Gohman <<a href="mailto:dan433584@gmail.com">dan433584@gmail.com</a>> wrote:<br>

<br>
> Hello llvm-dev,<br>
><br>
> Following up on the "CodeGen Context" discussion that was started, attached is patch which implements a pretty minimal skeleton of a CGContext implementation. The goal is to allow the newly added subtarget attributes on functions to be made available to codegen so that codegen can actually switch subtargets within a Module.<br>

><br>
> Comments and questions are invited herewith.<br>
><br>
> There has been some disagreement as to what to name this class. I have stuck with "CGContext" for now, though I'm absolutely not attached to that name.<br>
><br>
> It demonstrates where the CGContext state lives, how code can access it (in X86ISelLowering.cpp), how it reads the attributes from the IR, and how it gets cached.<br>
><br>
> One thing that it doesn't yet do is hook up to the target-specific subtarget feature interpretation. For example, it would need to hook up to the x86 subtarget code which knows that, for example, sse4.2 implies sse4.1, and so on. However, I'm sending this out now so that the other parts of the patch can get some feedback.<br>

><br>
</div></div>Hi Dan,<br></blockquote><div><br></div><div>Hi Bill,<br> <br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
Thanks for working on this! I like the direction this is going. One thing though, the function attributes no longer have “target-cpu” and “target-features” in them. I opted to separate out all of the different flags into separate attributes, instead of relying upon a single feature string. So the caching key would need to be modified here. Or do you think we should go back to adding back those attributes?<br>
</blockquote><div><br></div><div>One of the advantages os using a single target-features string is that it's easy to extend; there's no need for the CGContext code to know which attributes it should care about and which it should ignore, unless we introduce a naming convention. Alternatively, we could just have it read *all* the attributes all the time. What do you think?<br>
</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
One thing to be addressed is when one function has attributes but the next function lacks them. Some type of default value needs to be assumed for the function lacking an attribute, and the context cached accordingly.</blockquote>
<div><br></div><div>Yes, that's a good point. I'll update my patch to include code to handle that case.<br><br>Dan<br> <br></div></div></div></div>