OK committed. Let the shaving begin! :)<br><br><div class="gmail_quote">On Sat, Feb 18, 2012 at 3:20 AM, Chris Lattner <span dir="ltr"><<a href="mailto:clattner@apple.com">clattner@apple.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">

<div style="word-wrap:break-word"><div><div class="im"><div>On Feb 18, 2012, at 1:11 AM, Talin wrote:</div><blockquote type="cite"><div class="gmail_quote"><blockquote class="gmail_quote" style="margin-top:0px;margin-right:0px;margin-bottom:0px;margin-left:0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">

+  /// Add an ArrayRef of arbitrary data.<br>
+  template<typename T><br>
+  GeneralHash& add(ArrayRef<T> ArrayVal) {<br>
+    addBits(ArrayVal.begin(), ArrayVal.end());<br>
+    return *this;<br>
+  }<br>
<br>
Doesn't this have the same host-specificity problem, except that it will cause things that *are* stable to vary, such as arrays of char, or is the alignment check enough?<br>
<br></blockquote><div>I thought about whether it would be possible to prevent people from passing in ArrayRefs with unstable things, and I came to the conclusion that there's no simple way to distinguish between stable and unstable ArrayRefs. This is why I decided not to make a special "addPointer" method for pointers, because you could easily subvert it by wrapping it in a singleton ArrayRef.</div>

</div></blockquote><div><br></div></div>Ok.</div><div><div class="im"><br><blockquote type="cite"><div class="gmail_quote">

<blockquote class="gmail_quote" style="margin-top:0px;margin-right:0px;margin-bottom:0px;margin-left:0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
+  /// Add a float<br>
+  GeneralHash& add(float Data) {<br>
<br>
It is worth adding a comment here that this does a bitwise hash, so -0.0 and +0.0 will hash to different values even though they compare equal and two identical NaN's will hash to the same value even though they compare unequal.<br>




<br></blockquote><div>BTW, are there in fact any maps in LLVM that use floats as keys, other than uniquing of constants? And in the latter case, would you not want to distinguish between a -0.0 and +0.0 constant?</div></div>

</blockquote><div><br></div></div><div>I don't know of any.  I think that the ConstantFP uniquing code specifically has to unique things as integers to avoid problems with FP comparisons.   In any case, I'm sure that the desired behavior is client specific - adding the comment just makes it obvious what the semantics are.  </div>

<div class="im"><br><blockquote type="cite"><div class="gmail_quote"><div>   Actually, how much do we care about host instability here?  If this is used by hashing containers, we can just declare that iteration order is undefined even for non-pointer values.  The real problem I guess is that we'd have to go check out all the existing DenseMap's etc to make sure people aren't doing well-defined iteration right now and fixing the code.  What do you think?</div>

<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">


<div><br></div></blockquote><div>I think that you are thinking that existing uses of DenseMap and other ADT containers will be affected by this. That wasn't my plan - I was going to basically use the hashing class to create a custom DenseMapInfo for specific maps which could benefit from the optimization. Other DenseMaps would remain as they are.</div>

</div></blockquote><div><br></div></div>Ok.</div><div><div class="im"><br><blockquote type="cite"><div class="gmail_quote">

<blockquote class="gmail_quote" style="margin-top:0px;margin-right:0px;margin-bottom:0px;margin-left:0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><br>Is there a specific observed concern here (e.g. when built with Clang) or is this a historical problem?  Compilers have gotten much better about inlining stuff that is actually small, if Clang handles it then I think we're good.  Marking these attribute(always_inline) is massive overkill.<br>




<br></blockquote><div>Well, it is historical from about 5 years ago when I was working on EASTL. The compilers we were using at the time were gcc and MSVC. We found cases in the standard STL where inlines were nested up to 10 levels deep, and in some of those cases the compiler just gave up trying to inline things that deeply.</div>



</div></blockquote><div><br></div></div><div>Ok, LLVM uses a completely different (bottom-up, incremental, simplifying as it goes) approach to inlining.  I wouldn't worry about it.  Please just remove the always inline markers and if it is a measured performance problem later we can add them back.</div>

<div class="im"><br><blockquote type="cite"><div class="gmail_quote"><div> </div><blockquote class="gmail_quote" style="margin-top:0px;margin-right:0px;margin-bottom:0px;margin-left:0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">


Overall the code is looking great.  I'd recommend checking in the new API separately from switching Constants.cpp to use it though (just so that any problems doesn't cause both to get reverted).<br>
<font color="#888888"><br></font></blockquote><div>OK. I'm still working on getting a consensus from the hashing experts :)</div></div></blockquote><br></div></div><div>My advise is to check in when you have to make forward progress.  If people want to reshave your yak into another hairdo, then then can do that at some later time.  No reason to block your progress as long as the API is good.</div>

<div><br></div><div>Thanks again for working on this!</div><div><br></div><font color="#888888"><div>-Chris</div><br></font></div></blockquote></div><br><br clear="all"><div><br></div>-- <br>-- Talin<br>