Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
452e9352
cloud-kernel
项目概览
openanolis
/
cloud-kernel
大约 1 年 前同步成功
通知
158
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,发现更多精彩内容 >>
提交
452e9352
编写于
7月 31, 2010
作者:
T
Trond Myklebust
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
NFSv4: Clean up the process of renewing the NFSv4 lease
Signed-off-by:
N
Trond Myklebust
<
Trond.Myklebust@netapp.com
>
上级
14516c3a
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
9 addition
and
14 deletion
+9
-14
fs/nfs/nfs4proc.c
fs/nfs/nfs4proc.c
+9
-14
未找到文件。
fs/nfs/nfs4proc.c
浏览文件 @
452e9352
...
...
@@ -303,15 +303,19 @@ static int nfs4_handle_exception(const struct nfs_server *server, int errorcode,
}
static
void
renew_lease
(
const
struct
nfs_server
*
server
,
unsigned
long
timestamp
)
static
void
do_renew_lease
(
struct
nfs_client
*
clp
,
unsigned
long
timestamp
)
{
struct
nfs_client
*
clp
=
server
->
nfs_client
;
spin_lock
(
&
clp
->
cl_lock
);
if
(
time_before
(
clp
->
cl_last_renewal
,
timestamp
))
clp
->
cl_last_renewal
=
timestamp
;
spin_unlock
(
&
clp
->
cl_lock
);
}
static
void
renew_lease
(
const
struct
nfs_server
*
server
,
unsigned
long
timestamp
)
{
do_renew_lease
(
server
->
nfs_client
,
timestamp
);
}
#if defined(CONFIG_NFS_V4_1)
/*
...
...
@@ -419,10 +423,7 @@ static int nfs41_sequence_done(struct rpc_task *task, struct nfs4_sequence_res *
++
slot
->
seq_nr
;
timestamp
=
res
->
sr_renewal_time
;
clp
=
res
->
sr_session
->
clp
;
spin_lock
(
&
clp
->
cl_lock
);
if
(
time_before
(
clp
->
cl_last_renewal
,
timestamp
))
clp
->
cl_last_renewal
=
timestamp
;
spin_unlock
(
&
clp
->
cl_lock
);
do_renew_lease
(
clp
,
timestamp
);
/* Check sequence flags */
if
(
atomic_read
(
&
clp
->
cl_count
)
>
1
)
nfs41_handle_sequence_flag_errors
(
clp
,
res
->
sr_status_flags
);
...
...
@@ -3219,10 +3220,7 @@ static void nfs4_renew_done(struct rpc_task *task, void *calldata)
nfs4_schedule_state_recovery
(
clp
);
return
;
}
spin_lock
(
&
clp
->
cl_lock
);
if
(
time_before
(
clp
->
cl_last_renewal
,
timestamp
))
clp
->
cl_last_renewal
=
timestamp
;
spin_unlock
(
&
clp
->
cl_lock
);
do_renew_lease
(
clp
,
timestamp
);
}
static
const
struct
rpc_call_ops
nfs4_renew_ops
=
{
...
...
@@ -3263,10 +3261,7 @@ int nfs4_proc_renew(struct nfs_client *clp, struct rpc_cred *cred)
status
=
rpc_call_sync
(
clp
->
cl_rpcclient
,
&
msg
,
0
);
if
(
status
<
0
)
return
status
;
spin_lock
(
&
clp
->
cl_lock
);
if
(
time_before
(
clp
->
cl_last_renewal
,
now
))
clp
->
cl_last_renewal
=
now
;
spin_unlock
(
&
clp
->
cl_lock
);
do_renew_lease
(
clp
,
now
);
return
0
;
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录