From: Anders Carlsson Date: Sat, 25 Jan 2003 00:11:41 +0000 (+0000) Subject: 2003-01-25 Anders Carlsson X-Git-Tag: dbus-0.3~53 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=a284b8071436e02064074e08d56dfcc6702c5250;p=platform%2Fupstream%2Fdbus.git 2003-01-25 Anders Carlsson * dbus/dbus-list.c: (alloc_link), (free_link): Use a memory pool for the links. --- diff --git a/ChangeLog b/ChangeLog index 3961e97..2fedb45 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,5 +1,10 @@ 2003-01-25 Anders Carlsson + * dbus/dbus-list.c: (alloc_link), (free_link): + Use a memory pool for the links. + +2003-01-25 Anders Carlsson + * bus/connection.c: (bus_connection_foreach): * bus/connection.h: Add new bus_connection_foreach function. diff --git a/dbus/dbus-list.c b/dbus/dbus-list.c index c36246c..42fc79b 100644 --- a/dbus/dbus-list.c +++ b/dbus/dbus-list.c @@ -23,6 +23,7 @@ #include "dbus-internals.h" #include "dbus-list.h" +#include "dbus-mempool.h" /** * @defgroup DBusList Linked list @@ -32,6 +33,8 @@ * Types and functions related to DBusList. */ +static DBusMemPool *list_pool; + /** * @defgroup DBusListInternals Linked list implementation details * @ingroup DBusInternals @@ -39,8 +42,6 @@ * * The guts of DBusList. * - * @todo should use a memory pool for the list nodes, to avoid - * a memory allocation for every link. * @{ */ @@ -49,7 +50,10 @@ alloc_link (void *data) { DBusList *link; - link = dbus_new0 (DBusList, 1); + if (!list_pool) + list_pool = _dbus_mem_pool_new (sizeof (DBusList), TRUE); + + link = _dbus_mem_pool_alloc (list_pool); link->data = data; return link; @@ -58,7 +62,7 @@ alloc_link (void *data) static void free_link (DBusList *link) { - dbus_free (link); + _dbus_mem_pool_dealloc (list_pool, link); } static void