From mboxrd@z Thu Jan 1 00:00:00 1970 From: Christoph Lameter Subject: [patch 12/21] Filesystem: Ext2 filesystem defrag Date: Fri, 09 May 2008 20:08:43 -0700 Message-ID: <20080510030917.436927236@sgi.com> References: <20080510030831.796641881@sgi.com> Cc: linux-kernel@vger.kernel.org To: akpm@linux-foundation.org Return-path: Received: from netops-testserver-3-out.sgi.com ([192.48.171.28]:55032 "EHLO relay.sgi.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1751654AbYEJDJS (ORCPT ); Fri, 9 May 2008 23:09:18 -0400 CC: linux-fsdevel@vger.kernel.org Cc: Mel Gorman Cc: andi@firstfloor.org Cc: Rik van Riel Cc: Pekka Enberg Cc: mpm@selenic.com Content-Disposition: inline; filename=ext2-defrag Sender: linux-fsdevel-owner@vger.kernel.org List-ID: Support defragmentation for ext2 filesystem inodes Reviewed-by: Rik van Riel Signed-off-by: Christoph Lameter --- fs/ext2/super.c | 9 +++++++++ 1 file changed, 9 insertions(+) Index: linux-2.6/fs/ext2/super.c =================================================================== --- linux-2.6.orig/fs/ext2/super.c 2008-05-07 21:23:41.931409650 -0700 +++ linux-2.6/fs/ext2/super.c 2008-05-07 21:24:42.951410526 -0700 @@ -170,6 +170,12 @@ static void init_once(struct kmem_cache inode_init_once(&ei->vfs_inode); } +static void *ext2_get_inodes(struct kmem_cache *s, int nr, void **v) +{ + return fs_get_inodes(s, nr, v, + offsetof(struct ext2_inode_info, vfs_inode)); +} + static int init_inodecache(void) { ext2_inode_cachep = kmem_cache_create("ext2_inode_cache", @@ -179,6 +185,9 @@ static int init_inodecache(void) init_once); if (ext2_inode_cachep == NULL) return -ENOMEM; + + kmem_cache_setup_defrag(ext2_inode_cachep, + ext2_get_inodes, kick_inodes); return 0; } --