From: David Woodhouse Date: Mon, 7 May 2007 23:12:58 +0000 (+0100) Subject: [JFFS2] Fix potential memory leak of dead xattrs on unmount. X-Git-Tag: v2.6.22-rc4~1^2~3 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=2ad8ee713566671875216ebcec64f2eda47bd19d;p=users%2Fhch%2Fblock.git [JFFS2] Fix potential memory leak of dead xattrs on unmount. An xattr_datum which ends up orphaned should be freed by the GC thread. But if we umount before the GC thread is finished, or if we mount read-only and the GC thread never runs, they might never be freed. Clean them up during unmount, if there are any left. Signed-off-by: David Woodhouse --- diff --git a/fs/jffs2/xattr.c b/fs/jffs2/xattr.c index 073469856d4e..e48665984cb3 100644 --- a/fs/jffs2/xattr.c +++ b/fs/jffs2/xattr.c @@ -754,6 +754,10 @@ void jffs2_clear_xattr_subsystem(struct jffs2_sb_info *c) list_del(&xd->xindex); jffs2_free_xattr_datum(xd); } + list_for_each_entry_safe(xd, _xd, &c->xattr_unchecked, xindex) { + list_del(&xd->xindex); + jffs2_free_xattr_datum(xd); + } } #define XREF_TMPHASH_SIZE (128)