Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
raspberrypi-kernel
提交
83e08fd4
R
raspberrypi-kernel
项目概览
openeuler
/
raspberrypi-kernel
通知
13
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
raspberrypi-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
83e08fd4
编写于
5月 14, 2012
作者:
J
J. Bruce Fields
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
nfsd4: exchange_id cleanup: local shorthands for repeated tests
Signed-off-by:
N
J. Bruce Fields
<
bfields@redhat.com
>
上级
1a308118
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
10 addition
and
6 deletion
+10
-6
fs/nfsd/nfs4state.c
fs/nfsd/nfs4state.c
+10
-6
未找到文件。
fs/nfsd/nfs4state.c
浏览文件 @
83e08fd4
...
@@ -1520,6 +1520,7 @@ nfsd4_exchange_id(struct svc_rqst *rqstp,
...
@@ -1520,6 +1520,7 @@ nfsd4_exchange_id(struct svc_rqst *rqstp,
char
addr_str
[
INET6_ADDRSTRLEN
];
char
addr_str
[
INET6_ADDRSTRLEN
];
nfs4_verifier
verf
=
exid
->
verifier
;
nfs4_verifier
verf
=
exid
->
verifier
;
struct
sockaddr
*
sa
=
svc_addr
(
rqstp
);
struct
sockaddr
*
sa
=
svc_addr
(
rqstp
);
bool
update
=
exid
->
flags
&
EXCHGID4_FLAG_UPD_CONFIRMED_REC_A
;
rpc_ntop
(
sa
,
addr_str
,
sizeof
(
addr_str
));
rpc_ntop
(
sa
,
addr_str
,
sizeof
(
addr_str
));
dprintk
(
"%s rqstp=%p exid=%p clname.len=%u clname.data=%p "
dprintk
(
"%s rqstp=%p exid=%p clname.len=%u clname.data=%p "
...
@@ -1552,23 +1553,26 @@ nfsd4_exchange_id(struct svc_rqst *rqstp,
...
@@ -1552,23 +1553,26 @@ nfsd4_exchange_id(struct svc_rqst *rqstp,
nfs4_lock_state
();
nfs4_lock_state
();
conf
=
find_confirmed_client_by_str
(
dname
,
strhashval
);
conf
=
find_confirmed_client_by_str
(
dname
,
strhashval
);
if
(
conf
)
{
if
(
conf
)
{
bool
creds_match
=
same_creds
(
&
conf
->
cl_cred
,
&
rqstp
->
rq_cred
);
bool
verfs_match
=
same_verf
(
&
verf
,
&
conf
->
cl_verifier
);
if
(
!
clp_used_exchangeid
(
conf
))
{
if
(
!
clp_used_exchangeid
(
conf
))
{
if
(
exid
->
flags
&
EXCHGID4_FLAG_UPD_CONFIRMED_REC_A
)
{
if
(
update
)
{
status
=
nfserr_inval
;
/* buggy client */
status
=
nfserr_inval
;
/* buggy client */
goto
out
;
goto
out
;
}
}
}
}
if
(
!
same_creds
(
&
conf
->
cl_cred
,
&
rqstp
->
rq_cred
)
)
{
if
(
!
creds_match
)
{
/* 18.35.4 case 9 */
/* 18.35.4 case 9 */
if
(
exid
->
flags
&
EXCHGID4_FLAG_UPD_CONFIRMED_REC_A
)
if
(
update
)
status
=
nfserr_perm
;
status
=
nfserr_perm
;
else
/* case 3 */
else
/* case 3 */
status
=
nfserr_clid_inuse
;
status
=
nfserr_clid_inuse
;
goto
out
;
goto
out
;
}
}
if
(
!
same_verf
(
&
verf
,
&
conf
->
cl_verifier
)
)
{
if
(
!
verfs_match
)
{
/* 18.35.4 case 8 */
/* 18.35.4 case 8 */
if
(
exid
->
flags
&
EXCHGID4_FLAG_UPD_CONFIRMED_REC_A
)
{
if
(
update
)
{
status
=
nfserr_not_same
;
status
=
nfserr_not_same
;
goto
out
;
goto
out
;
}
}
...
@@ -1595,7 +1599,7 @@ nfsd4_exchange_id(struct svc_rqst *rqstp,
...
@@ -1595,7 +1599,7 @@ nfsd4_exchange_id(struct svc_rqst *rqstp,
}
}
/* 18.35.4 case 7 */
/* 18.35.4 case 7 */
if
(
exid
->
flags
&
EXCHGID4_FLAG_UPD_CONFIRMED_REC_A
)
{
if
(
update
)
{
status
=
nfserr_noent
;
status
=
nfserr_noent
;
goto
out
;
goto
out
;
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录