diff options
author | Eric Sandeen <sandeen@redhat.com> | 2009-12-23 07:57:07 -0500 |
---|---|---|
committer | Theodore Ts'o <tytso@mit.edu> | 2009-12-23 07:57:07 -0500 |
commit | 17bd55d037a02b04d9119511cfd1a4b985d20f63 (patch) | |
tree | ddbc227fffb84d1b95f5f8c48b627f88f3fd56ed /fs/fs-writeback.c | |
parent | d3533d72e7478a61a3e1936956fc825289a2acf4 (diff) |
fs-writeback: Add helper function to start writeback if idle
ext4, at least, would like to start pushing on writeback if it starts
to get close to ENOSPC when reserving worst-case blocks for delalloc
writes. Writing out delalloc data will convert those worst-case
predictions into usually smaller actual usage, freeing up space
before we hit ENOSPC based on this speculation.
Thanks to Jens for the suggestion for the helper function,
& the naming help.
I've made the helper return status on whether writeback was
started even though I don't plan to use it in the ext4 patch;
it seems like it would be potentially useful to test this
in some cases.
Signed-off-by: Eric Sandeen <sandeen@redhat.com>
Acked-by: Jan Kara <jack@suse.cz>
Diffstat (limited to 'fs/fs-writeback.c')
-rw-r--r-- | fs/fs-writeback.c | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/fs/fs-writeback.c b/fs/fs-writeback.c index 49bc1b8e8f19..f6c2155e0026 100644 --- a/fs/fs-writeback.c +++ b/fs/fs-writeback.c | |||
@@ -1187,6 +1187,23 @@ void writeback_inodes_sb(struct super_block *sb) | |||
1187 | EXPORT_SYMBOL(writeback_inodes_sb); | 1187 | EXPORT_SYMBOL(writeback_inodes_sb); |
1188 | 1188 | ||
1189 | /** | 1189 | /** |
1190 | * writeback_inodes_sb_if_idle - start writeback if none underway | ||
1191 | * @sb: the superblock | ||
1192 | * | ||
1193 | * Invoke writeback_inodes_sb if no writeback is currently underway. | ||
1194 | * Returns 1 if writeback was started, 0 if not. | ||
1195 | */ | ||
1196 | int writeback_inodes_sb_if_idle(struct super_block *sb) | ||
1197 | { | ||
1198 | if (!writeback_in_progress(sb->s_bdi)) { | ||
1199 | writeback_inodes_sb(sb); | ||
1200 | return 1; | ||
1201 | } else | ||
1202 | return 0; | ||
1203 | } | ||
1204 | EXPORT_SYMBOL(writeback_inodes_sb_if_idle); | ||
1205 | |||
1206 | /** | ||
1190 | * sync_inodes_sb - sync sb inode pages | 1207 | * sync_inodes_sb - sync sb inode pages |
1191 | * @sb: the superblock | 1208 | * @sb: the superblock |
1192 | * | 1209 | * |