From: Lennart Poettering Date: Wed, 17 Oct 2012 19:23:52 +0000 (+0200) Subject: journal: fix potential integer overflow X-Git-Tag: v195~80 X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=commitdiff_plain;h=4fa25d62bd586b56fa6a30009f41ce6dbc5fdd54 journal: fix potential integer overflow --- diff --git a/src/journal/journal-vacuum.c b/src/journal/journal-vacuum.c index 22c9cfcd5..731f6c770 100644 --- a/src/journal/journal-vacuum.c +++ b/src/journal/journal-vacuum.c @@ -243,6 +243,7 @@ int journal_directory_vacuum( have_seqnum = false; } else + /* We do not vacuum active files or unknown files! */ continue; patch_realtime(directory, de->d_name, &st, &realtime); @@ -291,7 +292,12 @@ int journal_directory_vacuum( if (unlinkat(dirfd(d), list[i].filename, 0) >= 0) { log_debug("Deleted archived journal %s/%s.", directory, list[i].filename); - sum -= list[i].usage; + + if ((uint64_t) list[i].usage > sum) + sum -= list[i].usage; + else + sum = 0; + } else if (errno != ENOENT) log_warning("Failed to delete %s/%s: %m", directory, list[i].filename); }