SmallVector and SmallPtrSet allocations not power-of-two aligned

Michael Ilseman milseman at apple.com
Thu Mar 28 10:31:42 PDT 2013


On Mar 27, 2013, at 5:44 PM, Sean Silva <silvas at purdue.edu> wrote:

> On Wed, Mar 27, 2013 at 5:42 PM, Jean-Luc Duprat <jduprat at apple.com> wrote:
> 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.
> 
> 
> 
> Have you dug into why the existing code is written so that the end iterator always points at valid memory? That is mentioned in multiple comments. It seems weird to do that, but I wouldn't change it without investigating why that was done in the first place.
> 

The iterators have to step over tombstones/empty slots, so when ++ advances from the last set entry to a place that will compare equal with end(), it needed somewhere to land. By having an extra null entry that end() pointed to, that allowed it to stop and then compare equal. If not for that null entry, it wouldn't know it has left the data structure and might just march through memory arbitrarily. However, Jean-Luc's patch passes in end() to the iterator, so it can now behave correctly without needing the extra space.

> -- Sean Silva
> _______________________________________________
> llvm-commits mailing list
> llvm-commits at cs.uiuc.edu
> http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20130328/2b322c3c/attachment.html>


More information about the llvm-commits mailing list