Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
82d5b9a7
cloud-kernel
项目概览
openanolis
/
cloud-kernel
1 年多 前同步成功
通知
161
Star
36
Fork
7
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
10
列表
看板
标记
里程碑
合并请求
2
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
cloud-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
10
Issue
10
列表
看板
标记
里程碑
合并请求
2
合并请求
2
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
82d5b9a7
编写于
1月 09, 2007
作者:
D
Dave Kleikamp
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
JFS: Add lockdep annotations
Yeah, it's about time. Signed-off-by:
N
Dave Kleikamp
<
shaggy@austin.ibm.com
>
上级
17e6afc7
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
74 addition
and
41 deletion
+74
-41
fs/jfs/inode.c
fs/jfs/inode.c
+3
-3
fs/jfs/jfs_dmap.c
fs/jfs/jfs_dmap.c
+8
-8
fs/jfs/jfs_imap.c
fs/jfs/jfs_imap.c
+8
-8
fs/jfs/jfs_incore.h
fs/jfs/jfs_incore.h
+27
-2
fs/jfs/namei.c
fs/jfs/namei.c
+28
-20
未找到文件。
fs/jfs/inode.c
浏览文件 @
82d5b9a7
...
...
@@ -182,9 +182,9 @@ int jfs_get_block(struct inode *ip, sector_t lblock,
* Take appropriate lock on inode
*/
if
(
create
)
IWRITE_LOCK
(
ip
);
IWRITE_LOCK
(
ip
,
RDWRLOCK_NORMAL
);
else
IREAD_LOCK
(
ip
);
IREAD_LOCK
(
ip
,
RDWRLOCK_NORMAL
);
if
(((
lblock64
<<
ip
->
i_sb
->
s_blocksize_bits
)
<
ip
->
i_size
)
&&
(
!
xtLookup
(
ip
,
lblock64
,
xlen
,
&
xflag
,
&
xaddr
,
&
xlen
,
0
))
&&
...
...
@@ -359,7 +359,7 @@ void jfs_truncate(struct inode *ip)
nobh_truncate_page
(
ip
->
i_mapping
,
ip
->
i_size
);
IWRITE_LOCK
(
ip
);
IWRITE_LOCK
(
ip
,
RDWRLOCK_NORMAL
);
jfs_truncate_nolock
(
ip
,
ip
->
i_size
);
IWRITE_UNLOCK
(
ip
);
}
fs/jfs/jfs_dmap.c
浏览文件 @
82d5b9a7
...
...
@@ -337,7 +337,7 @@ int dbFree(struct inode *ip, s64 blkno, s64 nblocks)
struct
inode
*
ipbmap
=
JFS_SBI
(
ip
->
i_sb
)
->
ipbmap
;
struct
bmap
*
bmp
=
JFS_SBI
(
ip
->
i_sb
)
->
bmap
;
IREAD_LOCK
(
ipbmap
);
IREAD_LOCK
(
ipbmap
,
RDWRLOCK_DMAP
);
/* block to be freed better be within the mapsize. */
if
(
unlikely
((
blkno
==
0
)
||
(
blkno
+
nblocks
>
bmp
->
db_mapsize
)))
{
...
...
@@ -733,7 +733,7 @@ int dbAlloc(struct inode *ip, s64 hint, s64 nblocks, s64 * results)
* allocation group size, try to allocate anywhere.
*/
if
(
l2nb
>
bmp
->
db_agl2size
)
{
IWRITE_LOCK
(
ipbmap
);
IWRITE_LOCK
(
ipbmap
,
RDWRLOCK_DMAP
);
rc
=
dbAllocAny
(
bmp
,
nblocks
,
l2nb
,
results
);
...
...
@@ -774,7 +774,7 @@ int dbAlloc(struct inode *ip, s64 hint, s64 nblocks, s64 * results)
* the hint using a tiered strategy.
*/
if
(
nblocks
<=
BPERDMAP
)
{
IREAD_LOCK
(
ipbmap
);
IREAD_LOCK
(
ipbmap
,
RDWRLOCK_DMAP
);
/* get the buffer for the dmap containing the hint.
*/
...
...
@@ -844,7 +844,7 @@ int dbAlloc(struct inode *ip, s64 hint, s64 nblocks, s64 * results)
/* try to satisfy the allocation request with blocks within
* the same allocation group as the hint.
*/
IWRITE_LOCK
(
ipbmap
);
IWRITE_LOCK
(
ipbmap
,
RDWRLOCK_DMAP
);
if
((
rc
=
dbAllocAG
(
bmp
,
agno
,
nblocks
,
l2nb
,
results
))
!=
-
ENOSPC
)
goto
write_unlock
;
...
...
@@ -856,7 +856,7 @@ int dbAlloc(struct inode *ip, s64 hint, s64 nblocks, s64 * results)
* Let dbNextAG recommend a preferred allocation group
*/
agno
=
dbNextAG
(
ipbmap
);
IWRITE_LOCK
(
ipbmap
);
IWRITE_LOCK
(
ipbmap
,
RDWRLOCK_DMAP
);
/* Try to allocate within this allocation group. if that fails, try to
* allocate anywhere in the map.
...
...
@@ -900,7 +900,7 @@ int dbAllocExact(struct inode *ip, s64 blkno, int nblocks)
s64
lblkno
;
struct
metapage
*
mp
;
IREAD_LOCK
(
ipbmap
);
IREAD_LOCK
(
ipbmap
,
RDWRLOCK_DMAP
);
/*
* validate extent request:
...
...
@@ -1050,7 +1050,7 @@ static int dbExtend(struct inode *ip, s64 blkno, s64 nblocks, s64 addnblocks)
*/
extblkno
=
lastblkno
+
1
;
IREAD_LOCK
(
ipbmap
);
IREAD_LOCK
(
ipbmap
,
RDWRLOCK_DMAP
);
/* better be within the file system */
bmp
=
sbi
->
bmap
;
...
...
@@ -3116,7 +3116,7 @@ int dbAllocBottomUp(struct inode *ip, s64 blkno, s64 nblocks)
struct
inode
*
ipbmap
=
JFS_SBI
(
ip
->
i_sb
)
->
ipbmap
;
struct
bmap
*
bmp
=
JFS_SBI
(
ip
->
i_sb
)
->
bmap
;
IREAD_LOCK
(
ipbmap
);
IREAD_LOCK
(
ipbmap
,
RDWRLOCK_DMAP
);
/* block to be allocated better be within the mapsize. */
ASSERT
(
nblocks
<=
bmp
->
db_mapsize
-
blkno
);
...
...
fs/jfs/jfs_imap.c
浏览文件 @
82d5b9a7
...
...
@@ -331,7 +331,7 @@ int diRead(struct inode *ip)
/* read the iag */
imap
=
JFS_IP
(
ipimap
)
->
i_imap
;
IREAD_LOCK
(
ipimap
);
IREAD_LOCK
(
ipimap
,
RDWRLOCK_IMAP
);
rc
=
diIAGRead
(
imap
,
iagno
,
&
mp
);
IREAD_UNLOCK
(
ipimap
);
if
(
rc
)
{
...
...
@@ -920,7 +920,7 @@ int diFree(struct inode *ip)
/* Obtain read lock in imap inode. Don't release it until we have
* read all of the IAG's that we are going to.
*/
IREAD_LOCK
(
ipimap
);
IREAD_LOCK
(
ipimap
,
RDWRLOCK_IMAP
);
/* read the iag.
*/
...
...
@@ -1415,7 +1415,7 @@ int diAlloc(struct inode *pip, bool dir, struct inode *ip)
AG_LOCK
(
imap
,
agno
);
/* Get read lock on imap inode */
IREAD_LOCK
(
ipimap
);
IREAD_LOCK
(
ipimap
,
RDWRLOCK_IMAP
);
/* get the iag number and read the iag */
iagno
=
INOTOIAG
(
inum
);
...
...
@@ -1808,7 +1808,7 @@ static int diAllocIno(struct inomap * imap, int agno, struct inode *ip)
return
-
ENOSPC
;
/* obtain read lock on imap inode */
IREAD_LOCK
(
imap
->
im_ipimap
);
IREAD_LOCK
(
imap
->
im_ipimap
,
RDWRLOCK_IMAP
);
/* read the iag at the head of the list.
*/
...
...
@@ -1946,7 +1946,7 @@ static int diAllocExt(struct inomap * imap, int agno, struct inode *ip)
}
else
{
/* read the iag.
*/
IREAD_LOCK
(
imap
->
im_ipimap
);
IREAD_LOCK
(
imap
->
im_ipimap
,
RDWRLOCK_IMAP
);
if
((
rc
=
diIAGRead
(
imap
,
iagno
,
&
mp
)))
{
IREAD_UNLOCK
(
imap
->
im_ipimap
);
jfs_error
(
ip
->
i_sb
,
"diAllocExt: error reading iag"
);
...
...
@@ -2509,7 +2509,7 @@ diNewIAG(struct inomap * imap, int *iagnop, int agno, struct metapage ** mpp)
*/
/* acquire inode map lock */
IWRITE_LOCK
(
ipimap
);
IWRITE_LOCK
(
ipimap
,
RDWRLOCK_IMAP
);
if
(
ipimap
->
i_size
>>
L2PSIZE
!=
imap
->
im_nextiag
+
1
)
{
IWRITE_UNLOCK
(
ipimap
);
...
...
@@ -2648,7 +2648,7 @@ diNewIAG(struct inomap * imap, int *iagnop, int agno, struct metapage ** mpp)
}
/* obtain read lock on map */
IREAD_LOCK
(
ipimap
);
IREAD_LOCK
(
ipimap
,
RDWRLOCK_IMAP
);
/* read the iag */
if
((
rc
=
diIAGRead
(
imap
,
iagno
,
&
mp
)))
{
...
...
@@ -2779,7 +2779,7 @@ diUpdatePMap(struct inode *ipimap,
return
-
EIO
;
}
/* read the iag */
IREAD_LOCK
(
ipimap
);
IREAD_LOCK
(
ipimap
,
RDWRLOCK_IMAP
);
rc
=
diIAGRead
(
imap
,
iagno
,
&
mp
);
IREAD_UNLOCK
(
ipimap
);
if
(
rc
)
...
...
fs/jfs/jfs_incore.h
浏览文件 @
82d5b9a7
...
...
@@ -109,9 +109,11 @@ struct jfs_inode_info {
#define JFS_ACL_NOT_CACHED ((void *)-1)
#define IREAD_LOCK(ip) down_read(&JFS_IP(ip)->rdwrlock)
#define IREAD_LOCK(ip, subclass) \
down_read_nested(&JFS_IP(ip)->rdwrlock, subclass)
#define IREAD_UNLOCK(ip) up_read(&JFS_IP(ip)->rdwrlock)
#define IWRITE_LOCK(ip) down_write(&JFS_IP(ip)->rdwrlock)
#define IWRITE_LOCK(ip, subclass) \
down_write_nested(&JFS_IP(ip)->rdwrlock, subclass)
#define IWRITE_UNLOCK(ip) up_write(&JFS_IP(ip)->rdwrlock)
/*
...
...
@@ -127,6 +129,29 @@ enum cflags {
COMMIT_Synclist
,
/* metadata pages on group commit synclist */
};
/*
* commit_mutex nesting subclasses:
*/
enum
commit_mutex_class
{
COMMIT_MUTEX_PARENT
,
COMMIT_MUTEX_CHILD
,
COMMIT_MUTEX_SECOND_PARENT
,
/* Renaming */
COMMIT_MUTEX_VICTIM
/* Inode being unlinked due to rename */
};
/*
* rdwrlock subclasses:
* The dmap inode may be locked while a normal inode or the imap inode are
* locked.
*/
enum
rdwrlock_class
{
RDWRLOCK_NORMAL
,
RDWRLOCK_IMAP
,
RDWRLOCK_DMAP
};
#define set_cflag(flag, ip) set_bit(flag, &(JFS_IP(ip)->cflag))
#define clear_cflag(flag, ip) clear_bit(flag, &(JFS_IP(ip)->cflag))
#define test_cflag(flag, ip) test_bit(flag, &(JFS_IP(ip)->cflag))
...
...
fs/jfs/namei.c
浏览文件 @
82d5b9a7
...
...
@@ -104,8 +104,8 @@ static int jfs_create(struct inode *dip, struct dentry *dentry, int mode,
tid
=
txBegin
(
dip
->
i_sb
,
0
);
mutex_lock
(
&
JFS_IP
(
dip
)
->
commit_mutex
);
mutex_lock
(
&
JFS_IP
(
ip
)
->
commit_mutex
);
mutex_lock
_nested
(
&
JFS_IP
(
dip
)
->
commit_mutex
,
COMMIT_MUTEX_PARENT
);
mutex_lock
_nested
(
&
JFS_IP
(
ip
)
->
commit_mutex
,
COMMIT_MUTEX_CHILD
);
rc
=
jfs_init_acl
(
tid
,
ip
,
dip
);
if
(
rc
)
...
...
@@ -238,8 +238,8 @@ static int jfs_mkdir(struct inode *dip, struct dentry *dentry, int mode)
tid
=
txBegin
(
dip
->
i_sb
,
0
);
mutex_lock
(
&
JFS_IP
(
dip
)
->
commit_mutex
);
mutex_lock
(
&
JFS_IP
(
ip
)
->
commit_mutex
);
mutex_lock
_nested
(
&
JFS_IP
(
dip
)
->
commit_mutex
,
COMMIT_MUTEX_PARENT
);
mutex_lock
_nested
(
&
JFS_IP
(
ip
)
->
commit_mutex
,
COMMIT_MUTEX_CHILD
);
rc
=
jfs_init_acl
(
tid
,
ip
,
dip
);
if
(
rc
)
...
...
@@ -365,8 +365,8 @@ static int jfs_rmdir(struct inode *dip, struct dentry *dentry)
tid
=
txBegin
(
dip
->
i_sb
,
0
);
mutex_lock
(
&
JFS_IP
(
dip
)
->
commit_mutex
);
mutex_lock
(
&
JFS_IP
(
ip
)
->
commit_mutex
);
mutex_lock
_nested
(
&
JFS_IP
(
dip
)
->
commit_mutex
,
COMMIT_MUTEX_PARENT
);
mutex_lock
_nested
(
&
JFS_IP
(
ip
)
->
commit_mutex
,
COMMIT_MUTEX_CHILD
);
iplist
[
0
]
=
dip
;
iplist
[
1
]
=
ip
;
...
...
@@ -483,12 +483,12 @@ static int jfs_unlink(struct inode *dip, struct dentry *dentry)
if
((
rc
=
get_UCSname
(
&
dname
,
dentry
)))
goto
out
;
IWRITE_LOCK
(
ip
);
IWRITE_LOCK
(
ip
,
RDWRLOCK_NORMAL
);
tid
=
txBegin
(
dip
->
i_sb
,
0
);
mutex_lock
(
&
JFS_IP
(
dip
)
->
commit_mutex
);
mutex_lock
(
&
JFS_IP
(
ip
)
->
commit_mutex
);
mutex_lock
_nested
(
&
JFS_IP
(
dip
)
->
commit_mutex
,
COMMIT_MUTEX_PARENT
);
mutex_lock
_nested
(
&
JFS_IP
(
ip
)
->
commit_mutex
,
COMMIT_MUTEX_CHILD
);
iplist
[
0
]
=
dip
;
iplist
[
1
]
=
ip
;
...
...
@@ -802,8 +802,8 @@ static int jfs_link(struct dentry *old_dentry,
tid
=
txBegin
(
ip
->
i_sb
,
0
);
mutex_lock
(
&
JFS_IP
(
dir
)
->
commit_mutex
);
mutex_lock
(
&
JFS_IP
(
ip
)
->
commit_mutex
);
mutex_lock
_nested
(
&
JFS_IP
(
dir
)
->
commit_mutex
,
COMMIT_MUTEX_PARENT
);
mutex_lock
_nested
(
&
JFS_IP
(
ip
)
->
commit_mutex
,
COMMIT_MUTEX_CHILD
);
/*
* scan parent directory for entry/freespace
...
...
@@ -913,8 +913,8 @@ static int jfs_symlink(struct inode *dip, struct dentry *dentry,
tid
=
txBegin
(
dip
->
i_sb
,
0
);
mutex_lock
(
&
JFS_IP
(
dip
)
->
commit_mutex
);
mutex_lock
(
&
JFS_IP
(
ip
)
->
commit_mutex
);
mutex_lock
_nested
(
&
JFS_IP
(
dip
)
->
commit_mutex
,
COMMIT_MUTEX_PARENT
);
mutex_lock
_nested
(
&
JFS_IP
(
ip
)
->
commit_mutex
,
COMMIT_MUTEX_CHILD
);
rc
=
jfs_init_security
(
tid
,
ip
,
dip
);
if
(
rc
)
...
...
@@ -1127,7 +1127,7 @@ static int jfs_rename(struct inode *old_dir, struct dentry *old_dentry,
goto
out3
;
}
}
else
if
(
new_ip
)
{
IWRITE_LOCK
(
new_ip
);
IWRITE_LOCK
(
new_ip
,
RDWRLOCK_NORMAL
);
/* Init inode for quota operations. */
DQUOT_INIT
(
new_ip
);
}
...
...
@@ -1137,13 +1137,21 @@ static int jfs_rename(struct inode *old_dir, struct dentry *old_dentry,
*/
tid
=
txBegin
(
new_dir
->
i_sb
,
0
);
mutex_lock
(
&
JFS_IP
(
new_dir
)
->
commit_mutex
);
mutex_lock
(
&
JFS_IP
(
old_ip
)
->
commit_mutex
);
/*
* How do we know the locking is safe from deadlocks?
* The vfs does the hard part for us. Any time we are taking nested
* commit_mutexes, the vfs already has i_mutex held on the parent.
* Here, the vfs has already taken i_mutex on both old_dir and new_dir.
*/
mutex_lock_nested
(
&
JFS_IP
(
new_dir
)
->
commit_mutex
,
COMMIT_MUTEX_PARENT
);
mutex_lock_nested
(
&
JFS_IP
(
old_ip
)
->
commit_mutex
,
COMMIT_MUTEX_CHILD
);
if
(
old_dir
!=
new_dir
)
mutex_lock
(
&
JFS_IP
(
old_dir
)
->
commit_mutex
);
mutex_lock_nested
(
&
JFS_IP
(
old_dir
)
->
commit_mutex
,
COMMIT_MUTEX_SECOND_PARENT
);
if
(
new_ip
)
{
mutex_lock
(
&
JFS_IP
(
new_ip
)
->
commit_mutex
);
mutex_lock_nested
(
&
JFS_IP
(
new_ip
)
->
commit_mutex
,
COMMIT_MUTEX_VICTIM
);
/*
* Change existing directory entry to new inode number
*/
...
...
@@ -1357,8 +1365,8 @@ static int jfs_mknod(struct inode *dir, struct dentry *dentry,
tid
=
txBegin
(
dir
->
i_sb
,
0
);
mutex_lock
(
&
JFS_IP
(
dir
)
->
commit_mutex
);
mutex_lock
(
&
JFS_IP
(
ip
)
->
commit_mutex
);
mutex_lock
_nested
(
&
JFS_IP
(
dir
)
->
commit_mutex
,
COMMIT_MUTEX_PARENT
);
mutex_lock
_nested
(
&
JFS_IP
(
ip
)
->
commit_mutex
,
COMMIT_MUTEX_CHILD
);
rc
=
jfs_init_acl
(
tid
,
ip
,
dir
);
if
(
rc
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录