diff options
Diffstat (limited to 'fs/ufs/super.c')
| -rw-r--r-- | fs/ufs/super.c | 37 | 
1 files changed, 12 insertions, 25 deletions
diff --git a/fs/ufs/super.c b/fs/ufs/super.c index 329f2f53b7e..b879f1ba343 100644 --- a/fs/ufs/super.c +++ b/fs/ufs/super.c @@ -524,11 +524,9 @@ static int ufs_read_cylinder_structures(struct super_block *sb)  	struct ufs_buffer_head * ubh;  	unsigned char * base, * space;  	unsigned size, blks, i; -	struct ufs_super_block_third *usb3;  	UFSD("ENTER\n"); -	usb3 = ubh_get_usb_third(uspi);  	/*  	 * Read cs structures from (usually) first data block  	 * on the device.  @@ -699,7 +697,6 @@ static int ufs_sync_fs(struct super_block *sb, int wait)  	unsigned flags;  	lock_ufs(sb); -	mutex_lock(&UFS_SB(sb)->s_lock);  	UFSD("ENTER\n"); @@ -717,7 +714,6 @@ static int ufs_sync_fs(struct super_block *sb, int wait)  	ufs_put_cstotal(sb);  	UFSD("EXIT\n"); -	mutex_unlock(&UFS_SB(sb)->s_lock);  	unlock_ufs(sb);  	return 0; @@ -762,6 +758,7 @@ static void ufs_put_super(struct super_block *sb)  	ubh_brelse_uspi (sbi->s_uspi);  	kfree (sbi->s_uspi); +	mutex_destroy(&sbi->mutex);  	kfree (sbi);  	sb->s_fs_info = NULL;  	UFSD("EXIT\n"); @@ -788,6 +785,14 @@ static int ufs_fill_super(struct super_block *sb, void *data, int silent)  	flags = 0;  	UFSD("ENTER\n"); + +#ifndef CONFIG_UFS_FS_WRITE +	if (!(sb->s_flags & MS_RDONLY)) { +		printk("ufs was compiled with read-only support, " +		       "can't be mounted as read-write\n"); +		return -EROFS; +	} +#endif  	sbi = kzalloc(sizeof(struct ufs_sb_info), GFP_KERNEL);  	if (!sbi) @@ -797,15 +802,7 @@ static int ufs_fill_super(struct super_block *sb, void *data, int silent)  	UFSD("flag %u\n", (int)(sb->s_flags & MS_RDONLY)); -#ifndef CONFIG_UFS_FS_WRITE -	if (!(sb->s_flags & MS_RDONLY)) { -		printk("ufs was compiled with read-only support, " -		"can't be mounted as read-write\n"); -		goto failed; -	} -#endif  	mutex_init(&sbi->mutex); -	mutex_init(&sbi->s_lock);  	spin_lock_init(&sbi->work_lock);  	INIT_DELAYED_WORK(&sbi->sync_work, delayed_sync_fs);  	/* @@ -1259,6 +1256,7 @@ magic_found:  	return 0;  failed: +	mutex_destroy(&sbi->mutex);  	if (ubh)  		ubh_brelse_uspi (uspi);  	kfree (uspi); @@ -1280,8 +1278,8 @@ static int ufs_remount (struct super_block *sb, int *mount_flags, char *data)  	unsigned new_mount_opt, ufstype;  	unsigned flags; +	sync_filesystem(sb);  	lock_ufs(sb); -	mutex_lock(&UFS_SB(sb)->s_lock);  	uspi = UFS_SB(sb)->s_uspi;  	flags = UFS_SB(sb)->s_flags;  	usb1 = ubh_get_usb_first(uspi); @@ -1295,7 +1293,6 @@ static int ufs_remount (struct super_block *sb, int *mount_flags, char *data)  	new_mount_opt = 0;  	ufs_set_opt (new_mount_opt, ONERROR_LOCK);  	if (!ufs_parse_options (data, &new_mount_opt)) { -		mutex_unlock(&UFS_SB(sb)->s_lock);  		unlock_ufs(sb);  		return -EINVAL;  	} @@ -1303,14 +1300,12 @@ static int ufs_remount (struct super_block *sb, int *mount_flags, char *data)  		new_mount_opt |= ufstype;  	} else if ((new_mount_opt & UFS_MOUNT_UFSTYPE) != ufstype) {  		printk("ufstype can't be changed during remount\n"); -		mutex_unlock(&UFS_SB(sb)->s_lock);  		unlock_ufs(sb);  		return -EINVAL;  	}  	if ((*mount_flags & MS_RDONLY) == (sb->s_flags & MS_RDONLY)) {  		UFS_SB(sb)->s_mount_opt = new_mount_opt; -		mutex_unlock(&UFS_SB(sb)->s_lock);  		unlock_ufs(sb);  		return 0;  	} @@ -1335,7 +1330,6 @@ static int ufs_remount (struct super_block *sb, int *mount_flags, char *data)  #ifndef CONFIG_UFS_FS_WRITE  		printk("ufs was compiled with read-only support, "  		"can't be mounted as read-write\n"); -		mutex_unlock(&UFS_SB(sb)->s_lock);  		unlock_ufs(sb);  		return -EINVAL;  #else @@ -1345,13 +1339,11 @@ static int ufs_remount (struct super_block *sb, int *mount_flags, char *data)  		    ufstype != UFS_MOUNT_UFSTYPE_SUNx86 &&  		    ufstype != UFS_MOUNT_UFSTYPE_UFS2) {  			printk("this ufstype is read-only supported\n"); -			mutex_unlock(&UFS_SB(sb)->s_lock);  			unlock_ufs(sb);  			return -EINVAL;  		}  		if (!ufs_read_cylinder_structures(sb)) {  			printk("failed during remounting\n"); -			mutex_unlock(&UFS_SB(sb)->s_lock);  			unlock_ufs(sb);  			return -EPERM;  		} @@ -1359,7 +1351,6 @@ static int ufs_remount (struct super_block *sb, int *mount_flags, char *data)  #endif  	}  	UFS_SB(sb)->s_mount_opt = new_mount_opt; -	mutex_unlock(&UFS_SB(sb)->s_lock);  	unlock_ufs(sb);  	return 0;  } @@ -1389,15 +1380,11 @@ static int ufs_statfs(struct dentry *dentry, struct kstatfs *buf)  	struct super_block *sb = dentry->d_sb;  	struct ufs_sb_private_info *uspi= UFS_SB(sb)->s_uspi;  	unsigned  flags = UFS_SB(sb)->s_flags; -	struct ufs_super_block_first *usb1; -	struct ufs_super_block_second *usb2;  	struct ufs_super_block_third *usb3;  	u64 id = huge_encode_dev(sb->s_bdev->bd_dev);  	lock_ufs(sb); -	usb1 = ubh_get_usb_first(uspi); -	usb2 = ubh_get_usb_second(uspi);  	usb3 = ubh_get_usb_third(uspi);  	if ((flags & UFS_TYPE_MASK) == UFS_TYPE_UFS2) { @@ -1453,7 +1440,7 @@ static void init_once(void *foo)  	inode_init_once(&ei->vfs_inode);  } -static int init_inodecache(void) +static int __init init_inodecache(void)  {  	ufs_inode_cachep = kmem_cache_create("ufs_inode_cache",  					     sizeof(struct ufs_inode_info),  | 
