|
@@ -54,7 +54,7 @@ void ufs_free_fragments(struct inode *inode, u64 fragment, unsigned count)
|
|
|
if (ufs_fragnum(fragment) + count > uspi->s_fpg)
|
|
|
ufs_error (sb, "ufs_free_fragments", "internal error");
|
|
|
|
|
|
- lock_super(sb);
|
|
|
+ mutex_lock(&UFS_SB(sb)->s_lock);
|
|
|
|
|
|
cgno = ufs_dtog(uspi, fragment);
|
|
|
bit = ufs_dtogd(uspi, fragment);
|
|
@@ -118,12 +118,12 @@ void ufs_free_fragments(struct inode *inode, u64 fragment, unsigned count)
|
|
|
ubh_sync_block(UCPI_UBH(ucpi));
|
|
|
ufs_mark_sb_dirty(sb);
|
|
|
|
|
|
- unlock_super (sb);
|
|
|
+ mutex_unlock(&UFS_SB(sb)->s_lock);
|
|
|
UFSD("EXIT\n");
|
|
|
return;
|
|
|
|
|
|
failed:
|
|
|
- unlock_super (sb);
|
|
|
+ mutex_unlock(&UFS_SB(sb)->s_lock);
|
|
|
UFSD("EXIT (FAILED)\n");
|
|
|
return;
|
|
|
}
|
|
@@ -155,7 +155,7 @@ void ufs_free_blocks(struct inode *inode, u64 fragment, unsigned count)
|
|
|
goto failed;
|
|
|
}
|
|
|
|
|
|
- lock_super(sb);
|
|
|
+ mutex_lock(&UFS_SB(sb)->s_lock);
|
|
|
|
|
|
do_more:
|
|
|
overflow = 0;
|
|
@@ -215,12 +215,12 @@ do_more:
|
|
|
}
|
|
|
|
|
|
ufs_mark_sb_dirty(sb);
|
|
|
- unlock_super (sb);
|
|
|
+ mutex_unlock(&UFS_SB(sb)->s_lock);
|
|
|
UFSD("EXIT\n");
|
|
|
return;
|
|
|
|
|
|
failed_unlock:
|
|
|
- unlock_super (sb);
|
|
|
+ mutex_unlock(&UFS_SB(sb)->s_lock);
|
|
|
failed:
|
|
|
UFSD("EXIT (FAILED)\n");
|
|
|
return;
|
|
@@ -361,7 +361,7 @@ u64 ufs_new_fragments(struct inode *inode, void *p, u64 fragment,
|
|
|
usb1 = ubh_get_usb_first(uspi);
|
|
|
*err = -ENOSPC;
|
|
|
|
|
|
- lock_super (sb);
|
|
|
+ mutex_lock(&UFS_SB(sb)->s_lock);
|
|
|
tmp = ufs_data_ptr_to_cpu(sb, p);
|
|
|
|
|
|
if (count + ufs_fragnum(fragment) > uspi->s_fpb) {
|
|
@@ -382,19 +382,19 @@ u64 ufs_new_fragments(struct inode *inode, void *p, u64 fragment,
|
|
|
"fragment %llu, tmp %llu\n",
|
|
|
(unsigned long long)fragment,
|
|
|
(unsigned long long)tmp);
|
|
|
- unlock_super(sb);
|
|
|
+ mutex_unlock(&UFS_SB(sb)->s_lock);
|
|
|
return INVBLOCK;
|
|
|
}
|
|
|
if (fragment < UFS_I(inode)->i_lastfrag) {
|
|
|
UFSD("EXIT (ALREADY ALLOCATED)\n");
|
|
|
- unlock_super (sb);
|
|
|
+ mutex_unlock(&UFS_SB(sb)->s_lock);
|
|
|
return 0;
|
|
|
}
|
|
|
}
|
|
|
else {
|
|
|
if (tmp) {
|
|
|
UFSD("EXIT (ALREADY ALLOCATED)\n");
|
|
|
- unlock_super(sb);
|
|
|
+ mutex_unlock(&UFS_SB(sb)->s_lock);
|
|
|
return 0;
|
|
|
}
|
|
|
}
|
|
@@ -403,7 +403,7 @@ u64 ufs_new_fragments(struct inode *inode, void *p, u64 fragment,
|
|
|
* There is not enough space for user on the device
|
|
|
*/
|
|
|
if (!capable(CAP_SYS_RESOURCE) && ufs_freespace(uspi, UFS_MINFREE) <= 0) {
|
|
|
- unlock_super (sb);
|
|
|
+ mutex_unlock(&UFS_SB(sb)->s_lock);
|
|
|
UFSD("EXIT (FAILED)\n");
|
|
|
return 0;
|
|
|
}
|
|
@@ -428,7 +428,7 @@ u64 ufs_new_fragments(struct inode *inode, void *p, u64 fragment,
|
|
|
ufs_clear_frags(inode, result + oldcount,
|
|
|
newcount - oldcount, locked_page != NULL);
|
|
|
}
|
|
|
- unlock_super(sb);
|
|
|
+ mutex_unlock(&UFS_SB(sb)->s_lock);
|
|
|
UFSD("EXIT, result %llu\n", (unsigned long long)result);
|
|
|
return result;
|
|
|
}
|
|
@@ -443,7 +443,7 @@ u64 ufs_new_fragments(struct inode *inode, void *p, u64 fragment,
|
|
|
fragment + count);
|
|
|
ufs_clear_frags(inode, result + oldcount, newcount - oldcount,
|
|
|
locked_page != NULL);
|
|
|
- unlock_super(sb);
|
|
|
+ mutex_unlock(&UFS_SB(sb)->s_lock);
|
|
|
UFSD("EXIT, result %llu\n", (unsigned long long)result);
|
|
|
return result;
|
|
|
}
|
|
@@ -481,7 +481,7 @@ u64 ufs_new_fragments(struct inode *inode, void *p, u64 fragment,
|
|
|
*err = 0;
|
|
|
UFS_I(inode)->i_lastfrag = max(UFS_I(inode)->i_lastfrag,
|
|
|
fragment + count);
|
|
|
- unlock_super(sb);
|
|
|
+ mutex_unlock(&UFS_SB(sb)->s_lock);
|
|
|
if (newcount < request)
|
|
|
ufs_free_fragments (inode, result + newcount, request - newcount);
|
|
|
ufs_free_fragments (inode, tmp, oldcount);
|
|
@@ -489,7 +489,7 @@ u64 ufs_new_fragments(struct inode *inode, void *p, u64 fragment,
|
|
|
return result;
|
|
|
}
|
|
|
|
|
|
- unlock_super(sb);
|
|
|
+ mutex_unlock(&UFS_SB(sb)->s_lock);
|
|
|
UFSD("EXIT (FAILED)\n");
|
|
|
return 0;
|
|
|
}
|