<div dir="ltr"><br><div class="gmail_extra"><br><br><div class="gmail_quote">On Thu, Jul 31, 2014 at 11:28 AM, Pete Cooper <span dir="ltr"><<a href="mailto:peter_cooper@apple.com" target="_blank">peter_cooper@apple.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div style="word-wrap:break-word"><br><div><div class=""><div>
On Jul 31, 2014, at 10:20 AM, Sean Silva <<a href="mailto:chisophugis@gmail.com" target="_blank">chisophugis@gmail.com</a>> wrote:</div><br><blockquote type="cite"><div dir="ltr"><br><div class="gmail_extra"><br><br>
<div class="gmail_quote">On Thu, Jul 31, 2014 at 10:08 AM, Pete Cooper <span dir="ltr"><<a href="mailto:peter_cooper@apple.com" target="_blank">peter_cooper@apple.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div style="word-wrap:break-word"><br><div><div><div>
On Jul 31, 2014, at 9:02 AM, Sean Silva <<a href="mailto:chisophugis@gmail.com" target="_blank">chisophugis@gmail.com</a>> wrote:</div><br><blockquote type="cite"><div style="font-family:Helvetica;font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;letter-spacing:normal;line-height:normal;text-align:start;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px">

I think it would make sense to change this behavior to follow the behavior that Pete describes. I don't have the code handy but my guess is that what the code is doing here is requesting each element in the braces of a bits<n> initializer to be casted to `bit`; in that case, we would want to change that code to first try casting to bits and give that preference (and issues relevant diagnostics). Pete, is that what your patch does? Can you attach your patches?</div>

</blockquote></div>Yeah, thats exactly it.  Here’s a WIP patch which fixes that particular issue.  I’m building the rest of the compiler now to see if anything breaks with that applied.</div><div><br></div><div></div></div>

<br><div style="word-wrap:break-word"><div><br><blockquote type="cite"><div style="font-family:Helvetica;font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;letter-spacing:normal;line-height:normal;text-align:start;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px">

<br></div><div style="font-family:Helvetica;font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;letter-spacing:normal;line-height:normal;text-align:start;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px">

Of course, before changing the behavior, we would probably want to place an assert on that codepath to catch all existing cases where the behavior would change.</div></blockquote>Sounds like a good plan.  I’ll try that and see what happens.<br>

<blockquote type="cite"><div style="font-family:Helvetica;font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;letter-spacing:normal;line-height:normal;text-align:start;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px">

Also it is important to scan all the docs in docs/TableGen/ and make any necessary updates (if there is nowhere that needs to be updated, then documentation needs to be *added* covering this behavior).</div></blockquote>
I haven’t done that yet, but good point.  Depending on what changes you all think are acceptable, i’ll update the documentation appropriately.<br>
<blockquote type="cite"><div style="font-family:Helvetica;font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;letter-spacing:normal;line-height:normal;text-align:start;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px">

Finally, we should post a notice to LLVMdev for out-of-tree maintainers including information about how to add the necessary assert to check for places where this behavior would change their .td files.</div></blockquote>
Sure thing.</div>
<div><br></div><div>And here’s the other 2 patches.  The first sizes binary literals.</div></div></blockquote><div><br></div><div>Regarding this patch, does it need to create a whole new Init class? I would try to avoid that if at all possible. Could we just have 0b0111 be a shorthand for a bits<4> BitsInit? Or maybe store some extra data in IntInit?</div>
</div></div></div></blockquote></div>I was worried that changing IntInit to store a size would have be too much of a change to existing behavior.  Perhaps thats wrong, as I only really need to check the size in a few limited circumstances.</div>
</div></blockquote><div><br></div><div>I'm personally much more in favor of the first option I suggested (0b0111 should be a bits<4>).</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
<div style="word-wrap:break-word"><div><div class=""><br><blockquote type="cite"><div dir="ltr"><div class="gmail_extra"><div class="gmail_quote">
<div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div style="word-wrap:break-word"><div>  The second allows them to initialize multiple bits inside { }.  Note that i’m only handling certain cases inside the { } initializer.  I’m happy to refactor the code and handle other cases if necessary.</div>

</div></blockquote><div><br></div><div>I don't like the special casing going on in this patch. Could we just switch BitsInit to store pointers to *both* BitInit and BitsInit (it actually can already sort of do that since it has a std::vector<Init*>)?</div>
</div></div></div></blockquote></div>Yeah, I think this could be improved.  How about instead of</div><div><br></div><div>Init *Bit = Vals[i]->convertInitializerTo(BitRecTy::get());</div><div><br></div><div>I do</div><div>
<br></div><div>Init *Bit = Vals[i]->convertInitializerTo(BitsRecTy::get());</div><div><br></div><div>Or perhaps attempt the Bits case first, and Bit as a fallback, or vice versa?</div></div></blockquote><div><br></div>
<div>Would the order of these checks cause any behavioral difference (besides one of the orders failing to produce the desired behavior)? I would hope not.</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
<div style="word-wrap:break-word"><div><br></div><div>The problem here is that I don’t necessarily want to allow { } to accept something like ‘-7’ because now I need to decide how many bits that is.</div></div></blockquote>
<div><br></div><div>Well, try placing a printf in `Init *BitsRecTy::convertValue(IntInit *II)` and see what you find. If it seems like nothing is crucially depending on this behavior, then it would probably make sense to completely eliminate this conversion.</div>
<div><br></div><div><br></div><div>-- Sean Silva</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
<div style="word-wrap:break-word"><div>  So i don’t want to allow anything to cast to Bits, but instead just anything with an exact size.  I’ll investigate the scope of this change and see what actually happens.  It might turn out ok.</div>
<div><br></div><div>Thanks for the feedback.</div><span class=""><font color="#888888"><div>Pete</div></font></span><div class=""><div><blockquote type="cite"><div dir="ltr"><div class="gmail_extra"><div class="gmail_quote">

<div><br></div><div>I just feel like this is adding a lot of complexity to TableGen where the behavior that you want could largely be accomplished by removing complexity.</div><div><br></div><div>-- Sean Silva</div><div>
 </div>
<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div style="word-wrap:break-word"><div><br></div><div></div>

</div><br><div style="word-wrap:break-word"><div></div></div>
<br><div style="word-wrap:break-word"><div></div><div><br></div><div>Thanks,</div><div>Pete<br><blockquote type="cite"><div style="font-family:Helvetica;font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;letter-spacing:normal;line-height:normal;text-align:start;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px">

<br></div><div style="font-family:Helvetica;font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;letter-spacing:normal;line-height:normal;text-align:start;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px">

-- Sean Silva</div></blockquote></div><br></div>
<br></blockquote></div><br></div></div>
</blockquote></div><br></div></div></blockquote></div><br></div></div>