From: Philippe De Swert Date: Wed, 10 Sep 2014 09:20:41 +0000 (+0300) Subject: journal: do not leak mmaps on OOM X-Git-Tag: v217~596 X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=commitdiff_plain;h=b67ddc7bbe31cde7f69f9814204d9bb1d4623c47 journal: do not leak mmaps on OOM After a section of memory is succesfully allocated, some of the following actions can still fail due to lack of memory. In this case -ENOMEM is returned without actually freeing the already mapped memory. Found with coverity. Fixes: CID#1237762 --- diff --git a/src/journal/mmap-cache.c b/src/journal/mmap-cache.c index 7dbbb5ef3..908562da2 100644 --- a/src/journal/mmap-cache.c +++ b/src/journal/mmap-cache.c @@ -496,15 +496,15 @@ static int add_mmap( c = context_add(m, context); if (!c) - return -ENOMEM; + goto outofmem; f = fd_add(m, fd); if (!f) - return -ENOMEM; + goto outofmem; w = window_add(m); if (!w) - return -ENOMEM; + goto outofmem; w->keep_always = keep_always; w->ptr = d; @@ -522,6 +522,10 @@ static int add_mmap( if (ret) *ret = (uint8_t*) w->ptr + (offset - w->offset); return 1; + +outofmem: + munmap(d, wsize); + return -ENOMEM; } int mmap_cache_get(