Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
35dc1d74
K
Kernel
项目概览
openeuler
/
Kernel
1 年多 前同步成功
通知
8
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
Kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
35dc1d74
编写于
12月 05, 2009
作者:
T
Trond Myklebust
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
NFSv41: Fix up some bugs in the NFS4CLNT_SESSION_DRAINING code
Signed-off-by:
N
Trond Myklebust
<
Trond.Myklebust@netapp.com
>
上级
d61e612a
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
10 addition
and
11 deletion
+10
-11
fs/nfs/nfs4proc.c
fs/nfs/nfs4proc.c
+8
-9
fs/nfs/nfs4state.c
fs/nfs/nfs4state.c
+2
-2
未找到文件。
fs/nfs/nfs4proc.c
浏览文件 @
35dc1d74
...
...
@@ -318,13 +318,14 @@ static void renew_lease(const struct nfs_server *server, unsigned long timestamp
* so we need to scan down from highest_used_slotid to 0 looking for the now
* highest slotid in use.
* If none found, highest_used_slotid is set to -1.
*
* Must be called while holding tbl->slot_tbl_lock
*/
static
void
nfs4_free_slot
(
struct
nfs4_slot_table
*
tbl
,
u8
free_slotid
)
{
int
slotid
=
free_slotid
;
spin_lock
(
&
tbl
->
slot_tbl_lock
);
/* clear used bit in bitmap */
__clear_bit
(
slotid
,
tbl
->
used_slots
);
...
...
@@ -336,7 +337,6 @@ nfs4_free_slot(struct nfs4_slot_table *tbl, u8 free_slotid)
else
tbl
->
highest_used_slotid
=
-
1
;
}
spin_unlock
(
&
tbl
->
slot_tbl_lock
);
dprintk
(
"%s: free_slotid %u highest_used_slotid %d
\n
"
,
__func__
,
free_slotid
,
tbl
->
highest_used_slotid
);
}
...
...
@@ -351,22 +351,23 @@ static void nfs41_sequence_free_slot(const struct nfs_client *clp,
/* just wake up the next guy waiting since
* we may have not consumed a slot after all */
dprintk
(
"%s: No slot
\n
"
,
__func__
);
}
else
{
nfs4_free_slot
(
tbl
,
res
->
sr_slotid
);
res
->
sr_slotid
=
NFS4_MAX_SLOT_TABLE
;
return
;
}
spin_lock
(
&
tbl
->
slot_tbl_lock
);
nfs4_free_slot
(
tbl
,
res
->
sr_slotid
);
/* Signal state manager thread if session is drained */
if
(
test_bit
(
NFS4CLNT_SESSION_DRAINING
,
&
clp
->
cl_state
))
{
spin_lock
(
&
tbl
->
slot_tbl_lock
);
if
(
tbl
->
highest_used_slotid
==
-
1
)
{
dprintk
(
"%s COMPLETE: Session Drained
\n
"
,
__func__
);
complete
(
&
clp
->
cl_session
->
complete
);
}
spin_unlock
(
&
tbl
->
slot_tbl_lock
);
}
else
{
rpc_wake_up_next
(
&
tbl
->
slot_tbl_waitq
);
}
spin_unlock
(
&
tbl
->
slot_tbl_lock
);
res
->
sr_slotid
=
NFS4_MAX_SLOT_TABLE
;
}
static
void
nfs41_sequence_done
(
struct
nfs_client
*
clp
,
...
...
@@ -470,7 +471,6 @@ static int nfs41_setup_sequence(struct nfs4_session *session,
*/
dprintk
(
"%s Schedule Session Reset
\n
"
,
__func__
);
rpc_sleep_on
(
&
tbl
->
slot_tbl_waitq
,
task
,
NULL
);
nfs4_schedule_state_manager
(
session
->
clp
);
spin_unlock
(
&
tbl
->
slot_tbl_lock
);
return
-
EAGAIN
;
}
...
...
@@ -4489,7 +4489,6 @@ static int nfs4_reset_slot_tables(struct nfs4_session *session)
1
);
if
(
status
)
return
status
;
init_completion
(
&
session
->
complete
);
status
=
nfs4_reset_slot_table
(
&
session
->
bc_slot_table
,
session
->
bc_attrs
.
max_reqs
,
...
...
fs/nfs/nfs4state.c
浏览文件 @
35dc1d74
...
...
@@ -1220,10 +1220,10 @@ static int nfs4_reset_session(struct nfs_client *clp)
struct
nfs4_slot_table
*
tbl
=
&
ses
->
fc_slot_table
;
int
status
;
INIT_COMPLETION
(
ses
->
complete
);
spin_lock
(
&
tbl
->
slot_tbl_lock
);
set_bit
(
NFS4CLNT_SESSION_DRAINING
,
&
clp
->
cl_state
);
if
(
tbl
->
highest_used_slotid
!=
-
1
)
{
INIT_COMPLETION
(
ses
->
complete
);
spin_unlock
(
&
tbl
->
slot_tbl_lock
);
status
=
wait_for_completion_interruptible
(
&
ses
->
complete
);
if
(
status
)
/* -ERESTARTSYS */
...
...
@@ -1247,7 +1247,7 @@ static int nfs4_reset_session(struct nfs_client *clp)
out:
/* Wake up the next rpc task even on error */
clear_bit
(
NFS4CLNT_SESSION_DRAINING
,
&
clp
->
cl_state
);
rpc_wake_up
_next
(
&
clp
->
cl_session
->
fc_slot_table
.
slot_tbl_waitq
);
rpc_wake_up
(
&
clp
->
cl_session
->
fc_slot_table
.
slot_tbl_waitq
);
return
status
;
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录