Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
36f20c6d
cloud-kernel
项目概览
openanolis
/
cloud-kernel
大约 1 年 前同步成功
通知
154
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看板
体验新版 GitCode,发现更多精彩内容 >>
提交
36f20c6d
编写于
11月 25, 2005
作者:
T
Trond Myklebust
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
NFSv4: Fix buggy nfs_wait_on_sequence()
Signed-off-by:
N
Trond Myklebust
<
Trond.Myklebust@netapp.com
>
上级
af955987
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
10 addition
and
10 deletion
+10
-10
fs/nfs/nfs4state.c
fs/nfs/nfs4state.c
+10
-10
未找到文件。
fs/nfs/nfs4state.c
浏览文件 @
36f20c6d
...
...
@@ -644,12 +644,15 @@ void nfs4_copy_stateid(nfs4_stateid *dst, struct nfs4_state *state, fl_owner_t f
struct
nfs_seqid
*
nfs_alloc_seqid
(
struct
nfs_seqid_counter
*
counter
)
{
struct
rpc_sequence
*
sequence
=
counter
->
sequence
;
struct
nfs_seqid
*
new
;
new
=
kmalloc
(
sizeof
(
*
new
),
GFP_KERNEL
);
if
(
new
!=
NULL
)
{
new
->
sequence
=
counter
;
INIT_LIST_HEAD
(
&
new
->
list
);
spin_lock
(
&
sequence
->
lock
);
list_add_tail
(
&
new
->
list
,
&
sequence
->
list
);
spin_unlock
(
&
sequence
->
lock
);
}
return
new
;
}
...
...
@@ -658,12 +661,10 @@ void nfs_free_seqid(struct nfs_seqid *seqid)
{
struct
rpc_sequence
*
sequence
=
seqid
->
sequence
->
sequence
;
if
(
!
list_empty
(
&
seqid
->
list
))
{
spin_lock
(
&
sequence
->
lock
);
list_del
(
&
seqid
->
list
);
spin_unlock
(
&
sequence
->
lock
);
}
rpc_wake_up_next
(
&
sequence
->
wait
);
rpc_wake_up
(
&
sequence
->
wait
);
kfree
(
seqid
);
}
...
...
@@ -722,11 +723,10 @@ int nfs_wait_on_sequence(struct nfs_seqid *seqid, struct rpc_task *task)
if
(
sequence
->
list
.
next
==
&
seqid
->
list
)
goto
out
;
spin_lock
(
&
sequence
->
lock
);
if
(
!
list_empty
(
&
sequence
->
list
)
)
{
if
(
sequence
->
list
.
next
!=
&
seqid
->
list
)
{
rpc_sleep_on
(
&
sequence
->
wait
,
task
,
NULL
,
NULL
);
status
=
-
EAGAIN
;
}
else
list_add
(
&
seqid
->
list
,
&
sequence
->
list
);
}
spin_unlock
(
&
sequence
->
lock
);
out:
return
status
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录