Skip to content

Commit

Permalink
nilfs2: add free entries count only if clear bit operation succeeded
Browse files Browse the repository at this point in the history
Three functions of the current persistent object allocator,
nilfs_palloc_commit_free_entry, nilfs_palloc_abort_alloc_entry, and
nilfs_palloc_freev functions unconditionally add a counter after doing
clear bit operation on a bitmap block.

If the clear bit operation overlapped, the counter will not add up.
This fixes the issue by making the counter operations conditional.

Signed-off-by: Ryusuke Konishi <[email protected]>
  • Loading branch information
konis committed Mar 8, 2011
1 parent 25b18d3 commit 9954e7a
Showing 1 changed file with 7 additions and 5 deletions.
12 changes: 7 additions & 5 deletions fs/nilfs2/alloc.c
Original file line number Diff line number Diff line change
Expand Up @@ -521,8 +521,8 @@ void nilfs_palloc_commit_free_entry(struct inode *inode,
group_offset, bitmap))
printk(KERN_WARNING "%s: entry number %llu already freed\n",
__func__, (unsigned long long)req->pr_entry_nr);

nilfs_palloc_group_desc_add_entries(inode, group, desc, 1);
else
nilfs_palloc_group_desc_add_entries(inode, group, desc, 1);

kunmap(req->pr_bitmap_bh->b_page);
kunmap(req->pr_desc_bh->b_page);
Expand Down Expand Up @@ -558,8 +558,8 @@ void nilfs_palloc_abort_alloc_entry(struct inode *inode,
group_offset, bitmap))
printk(KERN_WARNING "%s: entry number %llu already freed\n",
__func__, (unsigned long long)req->pr_entry_nr);

nilfs_palloc_group_desc_add_entries(inode, group, desc, 1);
else
nilfs_palloc_group_desc_add_entries(inode, group, desc, 1);

kunmap(req->pr_bitmap_bh->b_page);
kunmap(req->pr_desc_bh->b_page);
Expand Down Expand Up @@ -665,7 +665,7 @@ int nilfs_palloc_freev(struct inode *inode, __u64 *entry_nrs, size_t nitems)
for (j = i, n = 0;
(j < nitems) && nilfs_palloc_group_is_in(inode, group,
entry_nrs[j]);
j++, n++) {
j++) {
nilfs_palloc_group(inode, entry_nrs[j], &group_offset);
if (!nilfs_clear_bit_atomic(
nilfs_mdt_bgl_lock(inode, group),
Expand All @@ -674,6 +674,8 @@ int nilfs_palloc_freev(struct inode *inode, __u64 *entry_nrs, size_t nitems)
"%s: entry number %llu already freed\n",
__func__,
(unsigned long long)entry_nrs[j]);
} else {
n++;
}
}
nilfs_palloc_group_desc_add_entries(inode, group, desc, n);
Expand Down

0 comments on commit 9954e7a

Please sign in to comment.