[Author Prev][Author Next][Thread Prev][Thread Next][Author Index][Thread Index]
[or-cvs] r14319: Use a freelist to hold a few recent memarea chunks. We do a (in tor/trunk: . src/common src/or)
Author: nickm
Date: 2008-04-08 13:29:05 -0400 (Tue, 08 Apr 2008)
New Revision: 14319
Modified:
tor/trunk/
tor/trunk/src/common/memarea.c
tor/trunk/src/common/memarea.h
tor/trunk/src/or/main.c
Log:
r19243@catbus: nickm | 2008-04-08 13:28:59 -0400
Use a freelist to hold a few recent memarea chunks. We do a kazillion memarea allocs and frees; that cant be good for us.
Property changes on: tor/trunk
___________________________________________________________________
svk:merge ticket from /tor/trunk [r19243] on 8246c3cf-6607-4228-993b-4d95d33730f1
Modified: tor/trunk/src/common/memarea.c
===================================================================
--- tor/trunk/src/common/memarea.c 2008-04-08 17:06:41 UTC (rev 14318)
+++ tor/trunk/src/common/memarea.c 2008-04-08 17:29:05 UTC (rev 14319)
@@ -53,6 +53,8 @@
#define CHUNK_HEADER_SIZE STRUCT_OFFSET(memarea_chunk_t, u)
+#define CHUNK_SIZE 8192
+
/** A memarea_t is an allocation region for a set of small memory requests
* that will all be freed at once. */
struct memarea_t {
@@ -60,25 +62,49 @@
size_t chunk_size; /**<Size to use when allocating chunks.*/
};
+#define MAX_FREELIST_LEN 4
+int freelist_len=0;
+static memarea_chunk_t *freelist = NULL;
+
/** Helper: allocate a new memarea chunk of around <b>chunk_size</b> bytes. */
static memarea_chunk_t *
-alloc_chunk(size_t chunk_size)
+alloc_chunk(size_t sz)
{
- memarea_chunk_t *res = tor_malloc_roundup(&chunk_size);
- res->next_chunk = NULL;
- res->mem_size = chunk_size - CHUNK_HEADER_SIZE;
- res->next_mem = res->u.mem;
- return res;
+ (void)sz; /*XXXX021 remove this argument. */
+ if (freelist) {
+ memarea_chunk_t *res = freelist;
+ freelist = res->next_chunk;
+ --freelist_len;
+ return res;
+ } else {
+ size_t chunk_size = CHUNK_SIZE;
+ memarea_chunk_t *res = tor_malloc_roundup(&chunk_size);
+ res->next_chunk = NULL;
+ res->mem_size = chunk_size - CHUNK_HEADER_SIZE;
+ res->next_mem = res->u.mem;
+ return res;
+ }
}
-/** Allocate and return new memarea, with chunks of approximately
- * <b>chunk_size</b> bytes. (There is indeed some overhead.) */
+static void
+chunk_free(memarea_chunk_t *chunk)
+{
+ if (freelist_len >= MAX_FREELIST_LEN) {
+ ++freelist_len;
+ chunk->next_chunk = freelist;
+ freelist = chunk;
+ } else {
+ tor_free(chunk);
+ }
+}
+
+/** Allocate and return new memarea. */
memarea_t *
-memarea_new(size_t chunk_size)
+memarea_new(size_t chunk_size)/*XXXX021 remove this argument.*/
{
memarea_t *head = tor_malloc(sizeof(memarea_t));
head->first = alloc_chunk(chunk_size);
- head->chunk_size = chunk_size;
+ (void)chunk_size;
return head;
}
@@ -90,7 +116,7 @@
memarea_chunk_t *chunk, *next;
for (chunk = area->first; chunk; chunk = next) {
next = chunk->next_chunk;
- tor_free(chunk);
+ chunk_free(chunk);
}
area->first = NULL; /*fail fast on */
tor_free(area);
@@ -106,13 +132,26 @@
if (area->first->next_chunk) {
for (chunk = area->first->next_chunk; chunk; chunk = next) {
next = chunk->next_chunk;
- tor_free(chunk);
+ chunk_free(chunk);
}
area->first->next_chunk = NULL;
}
area->first->next_mem = area->first->u.mem;
}
+/** DOCDOC */
+void
+memarea_clear_freelist(void)
+{
+ memarea_chunk_t *chunk, *next;
+ freelist_len = 0;
+ for (chunk = freelist; chunk; chunk = next) {
+ next = chunk->next_chunk;
+ tor_free(chunk);
+ }
+ freelist = NULL;
+}
+
/** Return true iff <b>p</b> is in a range that has been returned by an
* allocation from <b>area</b>. */
int
Modified: tor/trunk/src/common/memarea.h
===================================================================
--- tor/trunk/src/common/memarea.h 2008-04-08 17:06:41 UTC (rev 14318)
+++ tor/trunk/src/common/memarea.h 2008-04-08 17:29:05 UTC (rev 14319)
@@ -19,6 +19,7 @@
char *memarea_strndup(memarea_t *area, const char *s, size_t n);
void memarea_get_stats(memarea_t *area,
size_t *allocated_out, size_t *used_out);
+void memarea_clear_freelist(void);
void memarea_assert_ok(memarea_t *area);
#endif
Modified: tor/trunk/src/or/main.c
===================================================================
--- tor/trunk/src/or/main.c 2008-04-08 17:06:41 UTC (rev 14318)
+++ tor/trunk/src/or/main.c 2008-04-08 17:29:05 UTC (rev 14319)
@@ -18,6 +18,7 @@
#ifdef USE_DMALLOC
#include <dmalloc.h>
#endif
+#include "memarea.h"
void evdns_shutdown(int);
@@ -1858,6 +1859,7 @@
entry_guards_free_all();
connection_free_all();
buf_shrink_freelists(1);
+ memarea_clear_freelist();
if (!postfork) {
config_free_all();
router_free_all();