Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
4d71ab87
K
Kernel
项目概览
openeuler
/
Kernel
大约 1 年 前同步成功
通知
5
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看板
体验新版 GitCode,发现更多精彩内容 >>
提交
4d71ab87
编写于
9月 06, 2011
作者:
J
J. Bruce Fields
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
nfsd4: split up find_stateid
Minor cleanup. Signed-off-by:
N
J. Bruce Fields
<
bfields@redhat.com
>
上级
4581d140
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
21 addition
and
13 deletion
+21
-13
fs/nfsd/nfs4state.c
fs/nfsd/nfs4state.c
+21
-13
未找到文件。
fs/nfsd/nfs4state.c
浏览文件 @
4d71ab87
...
...
@@ -1068,21 +1068,29 @@ same_stateid(stateid_t *id_one, stateid_t *id_two)
return
id_one
->
si_fileid
==
id_two
->
si_fileid
;
}
static
struct
nfs4_stateid
*
find_stateid
(
stateid_t
*
t
,
int
flags
)
static
struct
nfs4_stateid
*
find_stateid
(
stateid_t
*
t
)
{
struct
nfs4_stateid
*
s
;
unsigned
int
hashval
;
hashval
=
stateid_hashval
(
t
->
si_stateownerid
,
t
->
si_fileid
);
list_for_each_entry
(
s
,
&
stateid_hashtbl
[
hashval
],
st_hash
)
{
if
(
!
same_stateid
(
&
s
->
st_stateid
,
t
))
continue
;
if
(
flags
&
LOCK_STATE
&&
s
->
st_type
!=
NFS4_LOCK_STID
)
return
NULL
;
if
(
flags
&
OPEN_STATE
&&
s
->
st_type
!=
NFS4_OPEN_STID
)
return
NULL
;
list_for_each_entry
(
s
,
&
stateid_hashtbl
[
hashval
],
st_hash
)
if
(
same_stateid
(
&
s
->
st_stateid
,
t
))
return
s
;
return
NULL
;
}
static
struct
nfs4_stateid
*
find_stateid_by_type
(
stateid_t
*
t
,
int
flags
)
{
struct
nfs4_stateid
*
s
;
s
=
find_stateid
(
t
);
if
(
!
s
)
return
NULL
;
if
(
flags
&
LOCK_STATE
&&
s
->
st_type
==
NFS4_LOCK_STID
)
return
s
;
if
(
flags
&
OPEN_STATE
&&
s
->
st_type
==
NFS4_OPEN_STID
)
return
s
;
}
return
NULL
;
}
...
...
@@ -3241,7 +3249,7 @@ __be32 nfs4_validate_stateid(stateid_t *stateid, bool has_session)
goto
out
;
status
=
nfserr_expired
;
stp
=
find_stateid
(
stateid
,
0
);
stp
=
find_stateid
(
stateid
);
if
(
!
stp
)
goto
out
;
status
=
nfserr_bad_stateid
;
...
...
@@ -3306,7 +3314,7 @@ nfs4_preprocess_stateid_op(struct nfsd4_compound_state *cstate,
BUG_ON
(
!*
filpp
);
}
}
else
{
/* open or lock stateid */
stp
=
find_stateid
(
stateid
,
flags
);
stp
=
find_stateid
(
stateid
);
if
(
!
stp
)
goto
out
;
status
=
nfserr_bad_stateid
;
...
...
@@ -3381,7 +3389,7 @@ nfsd4_free_stateid(struct svc_rqst *rqstp, struct nfsd4_compound_state *cstate,
goto
out
;
}
stp
=
find_stateid
(
stateid
,
0
);
stp
=
find_stateid
(
stateid
);
if
(
!
stp
)
{
ret
=
nfserr_bad_stateid
;
goto
out
;
...
...
@@ -3440,7 +3448,7 @@ nfs4_preprocess_seqid_op(struct nfsd4_compound_state *cstate, u32 seqid,
* the confirmed flag is incorrecly set, or the generation
* number is incorrect.
*/
*
stpp
=
find_stateid
(
stateid
,
flags
);
*
stpp
=
find_stateid
_by_type
(
stateid
,
flags
);
if
(
*
stpp
==
NULL
)
return
nfserr_expired
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录