diff options
author | Mark Fasheh <mfasheh@suse.com> | 2010-03-12 03:31:09 +0100 |
---|---|---|
committer | Joel Becker <joel.becker@oracle.com> | 2010-03-24 02:22:40 +0100 |
commit | b4414eea0e7b9c134262c801a87e338bf675962c (patch) | |
tree | 09829d99527f1da69cc19074a2d3baef1195955e /fs/ocfs2/suballoc.h | |
parent | ocfs2: Init meta_ac properly in ocfs2_create_empty_xattr_block. (diff) | |
download | linux-b4414eea0e7b9c134262c801a87e338bf675962c.tar.xz linux-b4414eea0e7b9c134262c801a87e338bf675962c.zip |
ocfs2: Clear undo bits when local alloc is freed
When the local alloc file changes windows, unused bits are freed back to the
global bitmap. By defnition, those bits can not be in use by any file. Also,
the local alloc will never have been able to allocate those bits if they
were part of a previous truncate. Therefore it makes sense that we should
clear unused local alloc bits in the undo buffer so that they can be used
immediatly.
[ Modified to call it ocfs2_release_clusters() -- Joel ]
Signed-off-by: Mark Fasheh <mfasheh@suse.com>
Signed-off-by: Joel Becker <joel.becker@oracle.com>
Diffstat (limited to '')
-rw-r--r-- | fs/ocfs2/suballoc.h | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/fs/ocfs2/suballoc.h b/fs/ocfs2/suballoc.h index fa60723c43e8..e0f46df357e6 100644 --- a/fs/ocfs2/suballoc.h +++ b/fs/ocfs2/suballoc.h @@ -127,6 +127,11 @@ int ocfs2_free_clusters(handle_t *handle, struct buffer_head *bitmap_bh, u64 start_blk, unsigned int num_clusters); +int ocfs2_release_clusters(handle_t *handle, + struct inode *bitmap_inode, + struct buffer_head *bitmap_bh, + u64 start_blk, + unsigned int num_clusters); static inline u64 ocfs2_which_suballoc_group(u64 block, unsigned int bit) { |