<div dir="ltr">Formatting nit:<div><br></div><div><div><div>- explicit SmallPtrSetIterator(const void *const *BP)</div><div>- : SmallPtrSetIteratorImpl(BP) {}</div><div>+ explicit SmallPtrSetIterator(const void *const *BP, const void *const *E)</div>
<div>+ : SmallPtrSetIteratorImpl(BP, E) {}</div></div></div><div><br></div><div style>Indenting.</div><div style><br></div><div style>-eric</div><div style><br></div><div style><br></div></div><div class="gmail_extra">
<br><br><div class="gmail_quote">On Wed, Mar 27, 2013 at 4:00 PM, Jean-Luc Duprat <span dir="ltr"><<a href="mailto:jduprat@apple.com" target="_blank">jduprat@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">Now with unit tests…<span class="HOEnZb"><font color="#888888"><div><br></div><div>JL</div><div></div></font></span></div><br><div style="word-wrap:break-word"><div></div><div><br></div><div>
<br><div><div>On Mar 27, 2013, at 15:16 , Nadav Rotem <<a href="mailto:nrotem@apple.com" target="_blank">nrotem@apple.com</a>> wrote:</div><br><blockquote type="cite">LGTM. <div><br><br><span>On 03/27/13, <b>Jean-Luc Duprat </b> <<a href="mailto:jduprat@apple.com" target="_blank">jduprat@apple.com</a>> wrote:</span><blockquote style="border-left:1px solid #00f;padding-left:13px;margin-left:0" type="cite">
<div>While running dtrace on a large compile, focusing on memory usage, I found several strange allocations on x64.<br>Here is the trimmed output of my dtrace run---these read: allocation size\t number of such allocations<br>
<br>[snip: trimmed, leaving only allocation that seemed odd]<br> 32776 156<br> 16392 446<br> 8200 604<br> 4104 605<br> 2056 614<br>
1032 1212<br><br>Note that these allocations are 1032 bytes (1024+8), 2056 bytes (2048+8), 4104 bytes (4096+8), etc.<br><br>These were tracked down to SmallVector and SmallPtrSet, and the way they grow when no longer "small".<br>
For SmallVector the fix is pretty minimal, just using better logic to compute the size of the next allocation. For SmallPtrSet the fix involved getting the allocator to track the end of the set, growing the size of the allocator itself rather than growing the set.<br>
<br>These changes moved all the allocations identified above to proper power-of-two allocations. These changes have no impact on performance, but will help pool memory allocations together if needed.<br><br>Please provide feedback on the attached change.<br>
Thank you,<br><br>JL<br><br><br><br><div><br></div><hr size="2"><p><br><br></p><hr size="2"><p>_______________________________________________<br>llvm-commits mailing list<br><a href="mailto:llvm-commits@cs.uiuc.edu" target="_blank">llvm-commits@cs.uiuc.edu</a><br>
<a href="http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits</a><br></p></div></blockquote></div>
</blockquote></div><br></div></div><br>_______________________________________________<br>
llvm-commits mailing list<br>
<a href="mailto:llvm-commits@cs.uiuc.edu">llvm-commits@cs.uiuc.edu</a><br>
<a href="http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits</a><br>
<br></blockquote></div><br></div>