diff options
author | Philippe De Swert <philippedeswert@gmail.com> | 2014-09-10 12:20:41 +0300 |
---|---|---|
committer | David Herrmann <dh.herrmann@gmail.com> | 2014-09-11 17:27:44 +0200 |
commit | b67ddc7bbe31cde7f69f9814204d9bb1d4623c47 (patch) | |
tree | f6fe799504e198ff5071592c128f0e82f7e75c4c /src/journal/mmap-cache.c | |
parent | 21978bc3c90ec192130a9ea9df62a75d1262b80c (diff) |
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
Diffstat (limited to 'src/journal/mmap-cache.c')
-rw-r--r-- | src/journal/mmap-cache.c | 10 |
1 files changed, 7 insertions, 3 deletions
diff --git a/src/journal/mmap-cache.c b/src/journal/mmap-cache.c index 7dbbb5ef38..908562da27 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( |