]> git.ipfire.org Git - thirdparty/bird.git/commitdiff
Linpool flush drops all the allocated pages but one
authorMaria Matejka <mq@ucw.cz>
Wed, 22 Feb 2023 13:45:20 +0000 (14:45 +0100)
committerMaria Matejka <mq@ucw.cz>
Wed, 22 Feb 2023 13:54:09 +0000 (14:54 +0100)
When a linpool is used to allocate a one-off big load of memory, it
makes no sense to keep that amount of memory for future use inside the
linpool. Contrary to previous implementations where the memory was
directly free()d, we now use the page allocator which has an internal
cache which keeps the released pages for us and subsequent allocations
simply get these released pages back.

And even if the page cleanup routine kicks in inbetween, the pages get
only madvise()d, not munmap()ed so performance aspects are negligible.

This may fix some memory usage peaks in extreme cases.

lib/mempool.c

index 325b1ecfccba14f130ee18e79f0176bd8aeadeb0..7c306e991b7ec0204882d971471d963a5c83e1f1 100644 (file)
@@ -187,11 +187,18 @@ lp_flush(linpool *m)
 {
   struct lp_chunk *c;
 
-  /* Move ptr to the first chunk and free all large chunks */
+  /* Move ptr to the first chunk and free all other chunks */
   m->current = c = m->first;
   m->ptr = c ? c->data : NULL;
   m->end = c ? c->data + LP_DATA_SIZE : NULL;
 
+  while (c && c->next)
+  {
+    struct lp_chunk *d = c->next;
+    c->next = d->next;
+    free_page(d);
+  }
+
   while (c = m->first_large)
     {
       m->first_large = c->next;