X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Fjournal%2Fmmap-cache.c;h=03b57beb046fc72019116ea368dc72ccc6cf0872;hb=442e00839e4fc3c11506f5c8a9477b465865aecc;hp=4be3f7e96608bcb947d27e13e7a7bc6a184d9f2f;hpb=f801968466fed39d50d410b30ac828c26722cc95;p=elogind.git diff --git a/src/journal/mmap-cache.c b/src/journal/mmap-cache.c index 4be3f7e96..03b57beb0 100644 --- a/src/journal/mmap-cache.c +++ b/src/journal/mmap-cache.c @@ -41,9 +41,9 @@ struct Window { bool keep_always; bool in_unused; + int prot; void *ptr; uint64_t offset; - int prot; size_t size; FileDescriptor *fd; @@ -70,12 +70,11 @@ struct FileDescriptor { struct MMapCache { int n_ref; + unsigned n_windows; Hashmap *fds; Hashmap *contexts; - unsigned n_windows; - LIST_HEAD(Window, unused); Window *last_unused; }; @@ -130,10 +129,11 @@ static void window_free(Window *w) { assert(w); window_unlink(w); + w->cache->n_windows--; free(w); } -static bool window_matches(Window *w, int fd, int prot, uint64_t offset, size_t size) { +_pure_ static bool window_matches(Window *w, int fd, int prot, uint64_t offset, size_t size) { assert(w); assert(fd >= 0); assert(size > 0); @@ -157,6 +157,7 @@ static Window *window_add(MMapCache *m) { w = new0(Window, 1); if (!w) return NULL; + m->n_windows++; } else { /* Reuse an existing one */ @@ -181,7 +182,7 @@ static void context_detach_window(Context *c) { c->window = NULL; LIST_REMOVE(Context, by_window, w->contexts, c); - if (!w->contexts) { + if (!w->contexts && !w->keep_always) { /* Not used anymore? */ LIST_PREPEND(Window, unused, c->cache->unused, w); if (!c->cache->last_unused) @@ -200,11 +201,11 @@ static void context_attach_window(Context *c, Window *w) { context_detach_window(c); - if (!w->contexts) { + if (w->in_unused) { /* Used again? */ LIST_REMOVE(Window, unused, c->cache->unused, w); - if (!c->cache->last_unused) - c->cache->last_unused = w; + if (c->cache->last_unused == w) + c->cache->last_unused = w->unused_prev; w->in_unused = false; } @@ -306,9 +307,13 @@ static void mmap_cache_free(MMapCache *m) { while ((c = hashmap_first(m->contexts))) context_free(c); + hashmap_free(m->contexts); + while ((f = hashmap_first(m->fds))) fd_free(f); + hashmap_free(m->fds); + while (m->unused) window_free(m->unused);