Skip to content

Commit

Permalink
hfs: convert bitmap_lock in a mutex
Browse files Browse the repository at this point in the history
Apple Macintosh file system: The semaphore bitmap_lock is used as a mutex.
Convert it to the mutex API

Signed-off-by: Matthias Kaehlcke <[email protected]>
Cc: Roman Zippel <[email protected]>
Signed-off-by: Andrew Morton <[email protected]>
Signed-off-by: Linus Torvalds <[email protected]>
  • Loading branch information
mkaehlcke authored and torvalds committed Jul 25, 2008
1 parent de0ca06 commit 3084b72
Show file tree
Hide file tree
Showing 3 changed files with 7 additions and 6 deletions.
8 changes: 4 additions & 4 deletions fs/hfs/bitmap.c
Original file line number Diff line number Diff line change
Expand Up @@ -145,7 +145,7 @@ u32 hfs_vbm_search_free(struct super_block *sb, u32 goal, u32 *num_bits)
if (!*num_bits)
return 0;

down(&HFS_SB(sb)->bitmap_lock);
mutex_lock(&HFS_SB(sb)->bitmap_lock);
bitmap = HFS_SB(sb)->bitmap;

pos = hfs_find_set_zero_bits(bitmap, HFS_SB(sb)->fs_ablocks, goal, num_bits);
Expand All @@ -162,7 +162,7 @@ u32 hfs_vbm_search_free(struct super_block *sb, u32 goal, u32 *num_bits)
HFS_SB(sb)->free_ablocks -= *num_bits;
hfs_bitmap_dirty(sb);
out:
up(&HFS_SB(sb)->bitmap_lock);
mutex_unlock(&HFS_SB(sb)->bitmap_lock);
return pos;
}

Expand Down Expand Up @@ -205,7 +205,7 @@ int hfs_clear_vbm_bits(struct super_block *sb, u16 start, u16 count)
if ((start + count) > HFS_SB(sb)->fs_ablocks)
return -2;

down(&HFS_SB(sb)->bitmap_lock);
mutex_lock(&HFS_SB(sb)->bitmap_lock);
/* bitmap is always on a 32-bit boundary */
curr = HFS_SB(sb)->bitmap + (start / 32);
len = count;
Expand Down Expand Up @@ -236,7 +236,7 @@ int hfs_clear_vbm_bits(struct super_block *sb, u16 start, u16 count)
}
out:
HFS_SB(sb)->free_ablocks += len;
up(&HFS_SB(sb)->bitmap_lock);
mutex_unlock(&HFS_SB(sb)->bitmap_lock);
hfs_bitmap_dirty(sb);

return 0;
Expand Down
3 changes: 2 additions & 1 deletion fs/hfs/hfs_fs.h
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@

#include <linux/slab.h>
#include <linux/types.h>
#include <linux/mutex.h>
#include <linux/buffer_head.h>
#include <linux/fs.h>

Expand Down Expand Up @@ -139,7 +140,7 @@ struct hfs_sb_info {

struct nls_table *nls_io, *nls_disk;

struct semaphore bitmap_lock;
struct mutex bitmap_lock;

unsigned long flags;

Expand Down
2 changes: 1 addition & 1 deletion fs/hfs/super.c
Original file line number Diff line number Diff line change
Expand Up @@ -372,7 +372,7 @@ static int hfs_fill_super(struct super_block *sb, void *data, int silent)

sb->s_op = &hfs_super_operations;
sb->s_flags |= MS_NODIRATIME;
init_MUTEX(&sbi->bitmap_lock);
mutex_init(&sbi->bitmap_lock);

res = hfs_mdb_get(sb);
if (res) {
Expand Down

0 comments on commit 3084b72

Please sign in to comment.