Skip to content

Commit

Permalink
sysv: drop lock/unlock super
Browse files Browse the repository at this point in the history
Removed lock/unlock super. Added a new private s_lock mutex.

Signed-off-by: Marco Stornelli <marco.stornelli@gmail.com>
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
  • Loading branch information
Marco Stornelli authored and Al Viro committed Oct 10, 2012
1 parent f6e12dc commit c07cb01
Show file tree
Hide file tree
Showing 5 changed files with 20 additions and 18 deletions.
18 changes: 9 additions & 9 deletions fs/sysv/balloc.c
Original file line number Diff line number Diff line change
Expand Up @@ -60,12 +60,12 @@ void sysv_free_block(struct super_block * sb, sysv_zone_t nr)
return;
}

lock_super(sb);
mutex_lock(&sbi->s_lock);
count = fs16_to_cpu(sbi, *sbi->s_bcache_count);

if (count > sbi->s_flc_size) {
printk("sysv_free_block: flc_count > flc_size\n");
unlock_super(sb);
mutex_unlock(&sbi->s_lock);
return;
}
/* If the free list head in super-block is full, it is copied
Expand All @@ -77,7 +77,7 @@ void sysv_free_block(struct super_block * sb, sysv_zone_t nr)
bh = sb_getblk(sb, block);
if (!bh) {
printk("sysv_free_block: getblk() failed\n");
unlock_super(sb);
mutex_unlock(&sbi->s_lock);
return;
}
memset(bh->b_data, 0, sb->s_blocksize);
Expand All @@ -93,7 +93,7 @@ void sysv_free_block(struct super_block * sb, sysv_zone_t nr)
*sbi->s_bcache_count = cpu_to_fs16(sbi, count);
fs32_add(sbi, sbi->s_free_blocks, 1);
dirty_sb(sb);
unlock_super(sb);
mutex_unlock(&sbi->s_lock);
}

sysv_zone_t sysv_new_block(struct super_block * sb)
Expand All @@ -104,7 +104,7 @@ sysv_zone_t sysv_new_block(struct super_block * sb)
struct buffer_head * bh;
unsigned count;

lock_super(sb);
mutex_lock(&sbi->s_lock);
count = fs16_to_cpu(sbi, *sbi->s_bcache_count);

if (count == 0) /* Applies only to Coherent FS */
Expand Down Expand Up @@ -147,11 +147,11 @@ sysv_zone_t sysv_new_block(struct super_block * sb)
/* Now the free list head in the superblock is valid again. */
fs32_add(sbi, sbi->s_free_blocks, -1);
dirty_sb(sb);
unlock_super(sb);
mutex_unlock(&sbi->s_lock);
return nr;

Enospc:
unlock_super(sb);
mutex_unlock(&sbi->s_lock);
return 0;
}

Expand All @@ -173,7 +173,7 @@ unsigned long sysv_count_free_blocks(struct super_block * sb)
if (sbi->s_type == FSTYPE_AFS)
return 0;

lock_super(sb);
mutex_lock(&sbi->s_lock);
sb_count = fs32_to_cpu(sbi, *sbi->s_free_blocks);

if (0)
Expand Down Expand Up @@ -211,7 +211,7 @@ unsigned long sysv_count_free_blocks(struct super_block * sb)
if (count != sb_count)
goto Ecount;
done:
unlock_super(sb);
mutex_unlock(&sbi->s_lock);
return count;

Einval:
Expand Down
14 changes: 7 additions & 7 deletions fs/sysv/ialloc.c
Original file line number Diff line number Diff line change
Expand Up @@ -118,7 +118,7 @@ void sysv_free_inode(struct inode * inode)
"%s\n", inode->i_sb->s_id);
return;
}
lock_super(sb);
mutex_lock(&sbi->s_lock);
count = fs16_to_cpu(sbi, *sbi->s_sb_fic_count);
if (count < sbi->s_fic_size) {
*sv_sb_fic_inode(sb,count++) = cpu_to_fs16(sbi, ino);
Expand All @@ -128,7 +128,7 @@ void sysv_free_inode(struct inode * inode)
dirty_sb(sb);
memset(raw_inode, 0, sizeof(struct sysv_inode));
mark_buffer_dirty(bh);
unlock_super(sb);
mutex_unlock(&sbi->s_lock);
brelse(bh);
}

Expand All @@ -147,13 +147,13 @@ struct inode * sysv_new_inode(const struct inode * dir, umode_t mode)
if (!inode)
return ERR_PTR(-ENOMEM);

lock_super(sb);
mutex_lock(&sbi->s_lock);
count = fs16_to_cpu(sbi, *sbi->s_sb_fic_count);
if (count == 0 || (*sv_sb_fic_inode(sb,count-1) == 0)) {
count = refill_free_cache(sb);
if (count == 0) {
iput(inode);
unlock_super(sb);
mutex_unlock(&sbi->s_lock);
return ERR_PTR(-ENOSPC);
}
}
Expand All @@ -174,7 +174,7 @@ struct inode * sysv_new_inode(const struct inode * dir, umode_t mode)
sysv_write_inode(inode, &wbc); /* ensure inode not allocated again */
mark_inode_dirty(inode); /* cleared by sysv_write_inode() */
/* That's it. */
unlock_super(sb);
mutex_unlock(&sbi->s_lock);
return inode;
}

Expand All @@ -185,7 +185,7 @@ unsigned long sysv_count_free_inodes(struct super_block * sb)
struct sysv_inode * raw_inode;
int ino, count, sb_count;

lock_super(sb);
mutex_lock(&sbi->s_lock);

sb_count = fs16_to_cpu(sbi, *sbi->s_sb_total_free_inodes);

Expand Down Expand Up @@ -213,7 +213,7 @@ unsigned long sysv_count_free_inodes(struct super_block * sb)
if (count != sb_count)
goto Einval;
out:
unlock_super(sb);
mutex_unlock(&sbi->s_lock);
return count;

Einval:
Expand Down
4 changes: 2 additions & 2 deletions fs/sysv/inode.c
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,7 @@ static int sysv_sync_fs(struct super_block *sb, int wait)
struct sysv_sb_info *sbi = SYSV_SB(sb);
unsigned long time = get_seconds(), old_time;

lock_super(sb);
mutex_lock(&sbi->s_lock);

/*
* If we are going to write out the super block,
Expand All @@ -51,7 +51,7 @@ static int sysv_sync_fs(struct super_block *sb, int wait)
mark_buffer_dirty(sbi->s_bh2);
}

unlock_super(sb);
mutex_unlock(&sbi->s_lock);

return 0;
}
Expand Down
1 change: 1 addition & 0 deletions fs/sysv/super.c
Original file line number Diff line number Diff line change
Expand Up @@ -368,6 +368,7 @@ static int sysv_fill_super(struct super_block *sb, void *data, int silent)

sbi->s_sb = sb;
sbi->s_block_base = 0;
mutex_init(&sbi->s_lock);
sb->s_fs_info = sbi;

sb_set_blocksize(sb, BLOCK_SIZE);
Expand Down
1 change: 1 addition & 0 deletions fs/sysv/sysv.h
Original file line number Diff line number Diff line change
Expand Up @@ -58,6 +58,7 @@ struct sysv_sb_info {
u32 s_nzones; /* same as s_sbd->s_fsize */
u16 s_namelen; /* max length of dir entry */
int s_forced_ro;
struct mutex s_lock;
};

/*
Expand Down

0 comments on commit c07cb01

Please sign in to comment.