Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753731Ab2FMLgd (ORCPT ); Wed, 13 Jun 2012 07:36:33 -0400 Received: from mga09.intel.com ([134.134.136.24]:16557 "EHLO mga09.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753436Ab2FMLgc (ORCPT ); Wed, 13 Jun 2012 07:36:32 -0400 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="4.67,351,1309762800"; d="scan'208";a="157039697" From: Artem Bityutskiy To: Al Viro Cc: Linux FS Maling List , Linux Kernel Maling List Subject: [PATCH 0/4] hfsplus: stop using write_supers and s_dirt Date: Wed, 13 Jun 2012 14:37:47 +0300 Message-Id: <1339587471-2713-1-git-send-email-dedekind1@gmail.com> X-Mailer: git-send-email 1.7.7.6 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2642 Lines: 63 This patch-set makes HFSPLUS file-system stop using the VFS '->write_supers()' call-back and the '->s_dirt' superblock field because I plan to remove them once all users are gone. Like the other similar patch-sets, we switch to a delayed job for writing out the superblock instead of using the 's_dirt' flag. Additionally, this patch-set includes several clean-ups. Reminder: The goal is to get rid of the 'sync_supers()' kernel thread. This kernel thread wakes up every 5 seconds (by default) and calls '->write_super()' for all mounted file-systems. And the bad thing is that this is done even if all the superblocks are clean. Moreover, many file-systems do not even need this end they do not register the '->write_super()' method at all (e.g., btrfs). So 'sync_supers()' most often just generates useless wake-ups and wastes power. I am trying to make all file-systems independent of '->write_super()' and plan to remove 'sync_supers()' and '->write_super()' completely once there are no more users. Al, in the past I was trying to upstream patches which optimized 'sync_super()', but you wanted me to kill it completely instead, which I am trying to do now, see http://lkml.org/lkml/2010/7/22/96 Tested using the fsstress test from the LTP project. ====== Overall status: 1. ext4: patches submitted, waiting for review from Ted Ts'o: https://lkml.org/lkml/2012/4/2/111 2. hfs: patches submitted, see http://lkml.org/lkml/2012/6/12/82 3. hfsplus: this patch-set 4. udf: patch submitted, should be in Jan Kara's tree: https://lkml.org/lkml/2012/6/4/233 5. exofs: patch submitted, not sure if it will go to the exofs tree: https://lkml.org/lkml/2012/6/4/211 6. affs: patches submitted, should be in Al Viro's tree: https://lkml.org/lkml/2012/6/6/400 7. ext2: done, see commit f72cf5e223a28d3b3ea7dc9e40464fd534e359e8 8. vfat: done, see commit 78491189ddb6d84d4a4abae992ed891a236d0263 9. jffs2: done, see commit 208b14e507c00ff7f108e1a388dd3d8cc805a443 10. reiserfs: done, see commit 033369d1af1264abc23bea2e174aa47cdd212f6f TODO: sysv, ufs ====== fs/hfsplus/bitmap.c | 4 ++-- fs/hfsplus/dir.c | 2 +- fs/hfsplus/hfsplus_fs.h | 7 +++++-- fs/hfsplus/inode.c | 6 +++--- fs/hfsplus/super.c | 46 ++++++++++++++++++++++++++++++++++------------ 5 files changed, 45 insertions(+), 20 deletions(-) Thanks, Artem. -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/