Unless destruction notification was added for packets since the last time I checked, setting up a pool system using the existing data pointer mechanism will be impossible. The data pointer mechanism is currently only useful if you have constant data somewhere that can be used by the packet, otherwise you have no way to know how long that packet will be alive for, and cannot safely deallocate the memory.
<br><br>However, since the custom allocation code is there, it should be fairly straightforward to dive into the codebase and tweak the allocation/deallocation code to support using a pool allocator, I think.<br><br><div>
<span class="gmail_quote">On 7/22/06, <b class="gmail_sendername">Beau Albiston</b> <<a href="mailto:albiston@cynergy.com">albiston@cynergy.com</a>> wrote:</span><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
The only time I have ever ran into a fragmentation problem with a memory<br>manager was when allocating very large, variable sized chunks of memory<br>(which is probably the worst case for most MMs). If your protocol<br>
consists of many small, same-size packet types, then it's probably<br>redundant to implement a pool system. However, there are other<br>instances where you may want the overhead in order to have some other<br>structural feature that the MM doesn't provide, like linked blocks
<br>(linked list, skip list, etc), and the one you mentioned (deallocating<br>large swaths of memory blocks at once--although, running a destructor<br>for each block is suspect).<br><br>Now that enet allows you to set the packet data pointer, hooking up a
<br>pool system should be really easy.<br><br>-Beau<br><br>Zola wrote:<br>> Hello,<br>><br>> I'm examining enet as a base of network code for a project which will<br>> have potentially hundreds of users in concentrated areas at certain
<br>> times; I have one concern here- fragmentation, and the servers should<br>> be able to keep long-running uptimes. I forsee a barrage of tiny<br>> allocations and frees happening, and I'm concerned about fragmentation.
<br>><br>> A pool allocator might solve this problem.<br>> Has anyone tried, or been successful in using enet with the boost pool<br>> allocator?<br>> It can be found here: <a href="http://www.boost.org/libs/pool/doc/index.html">
http://www.boost.org/libs/pool/doc/index.html</a><br>> <<a href="http://www.boost.org/libs/pool/doc/index.html">http://www.boost.org/libs/pool/doc/index.html</a>><br>><br>> As stated:<br>><br>> "Pools are generally used when there is a lot of allocation and
<br>> deallocation of small objects."<br>><br>> "Using Pools gives you more control over how memory is used in your<br>> program. For example, you could have a situation where you want to<br>> allocate a bunch of small objects at one point, and then reach a point
<br>> in your program where none of them are needed any more. Using pool<br>> interfaces, you can choose to run their destructors or just drop them<br>> off into oblivion; the pool interface will guarantee that there are no
<br>> system memory leaks."<br>><br>> Has anyone had experiences with this combination of enet and pool<br>> allocators, or boost's pool?<br>> And, is enet suited to be plugged into such a system?<br>>
<br>> - Zola<br>> ------------------------------------------------------------------------<br>><br>> _______________________________________________<br>> ENet-discuss mailing list<br>> <a href="mailto:ENet-discuss@cubik.org">
ENet-discuss@cubik.org</a><br>> <a href="http://lists.cubik.org/mailman/listinfo/enet-discuss">http://lists.cubik.org/mailman/listinfo/enet-discuss</a><br>><br><br>_______________________________________________<br>
ENet-discuss mailing list<br><a href="mailto:ENet-discuss@cubik.org">ENet-discuss@cubik.org</a><br><a href="http://lists.cubik.org/mailman/listinfo/enet-discuss">http://lists.cubik.org/mailman/listinfo/enet-discuss</a><br>
</blockquote></div><br>