From: Joern Engel Date: Sun, 20 Nov 2011 16:59:01 +0000 (+0530) Subject: logfs: Prevent memory corruption X-Git-Tag: v3.3-rc2~1^2~8 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=934eed395d201bf0901ca0c0cc3703b18729d0ce;p=users%2Fdwmw2%2Flinux.git logfs: Prevent memory corruption This is a bad one. I wonder whether we were so far protected by no_free_segments(sb) usually being smaller than LOGFS_NO_AREAS. Found by Dan Carpenter using smatch. Signed-off-by: Joern Engel Signed-off-by: Prasad Joshi --- diff --git a/fs/logfs/gc.c b/fs/logfs/gc.c index caa4419285dca..d4efb061bdc5d 100644 --- a/fs/logfs/gc.c +++ b/fs/logfs/gc.c @@ -367,7 +367,7 @@ static struct gc_candidate *get_candidate(struct super_block *sb) int i, max_dist; struct gc_candidate *cand = NULL, *this; - max_dist = min(no_free_segments(sb), LOGFS_NO_AREAS); + max_dist = min(no_free_segments(sb), LOGFS_NO_AREAS - 1); for (i = max_dist; i >= 0; i--) { this = first_in_list(&super->s_low_list[i]);