Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
27b3f949
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看板
提交
27b3f949
编写于
7月 02, 2007
作者:
T
Trond Myklebust
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
NFSv4: Fix a credential reference leak in nfs4_get_state_owner()
Signed-off-by:
N
Trond Myklebust
<
Trond.Myklebust@netapp.com
>
上级
587142f8
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
2 addition
and
4 deletion
+2
-4
fs/nfs/nfs4state.c
fs/nfs/nfs4state.c
+2
-4
未找到文件。
fs/nfs/nfs4state.c
浏览文件 @
27b3f949
...
@@ -83,7 +83,7 @@ nfs4_client_grab_unused(struct nfs_client *clp, struct rpc_cred *cred)
...
@@ -83,7 +83,7 @@ nfs4_client_grab_unused(struct nfs_client *clp, struct rpc_cred *cred)
if
(
!
list_empty
(
&
clp
->
cl_unused
))
{
if
(
!
list_empty
(
&
clp
->
cl_unused
))
{
sp
=
list_entry
(
clp
->
cl_unused
.
next
,
struct
nfs4_state_owner
,
so_list
);
sp
=
list_entry
(
clp
->
cl_unused
.
next
,
struct
nfs4_state_owner
,
so_list
);
atomic_inc
(
&
sp
->
so_count
);
atomic_inc
(
&
sp
->
so_count
);
sp
->
so_cred
=
cred
;
sp
->
so_cred
=
get_rpccred
(
cred
)
;
list_move
(
&
sp
->
so_list
,
&
clp
->
cl_state_owners
);
list_move
(
&
sp
->
so_list
,
&
clp
->
cl_state_owners
);
clp
->
cl_nunused
--
;
clp
->
cl_nunused
--
;
}
}
...
@@ -175,7 +175,6 @@ struct nfs4_state_owner *nfs4_get_state_owner(struct nfs_server *server, struct
...
@@ -175,7 +175,6 @@ struct nfs4_state_owner *nfs4_get_state_owner(struct nfs_server *server, struct
struct
nfs_client
*
clp
=
server
->
nfs_client
;
struct
nfs_client
*
clp
=
server
->
nfs_client
;
struct
nfs4_state_owner
*
sp
,
*
new
;
struct
nfs4_state_owner
*
sp
,
*
new
;
get_rpccred
(
cred
);
new
=
nfs4_alloc_state_owner
();
new
=
nfs4_alloc_state_owner
();
spin_lock
(
&
clp
->
cl_lock
);
spin_lock
(
&
clp
->
cl_lock
);
sp
=
nfs4_find_state_owner
(
clp
,
cred
);
sp
=
nfs4_find_state_owner
(
clp
,
cred
);
...
@@ -185,7 +184,7 @@ struct nfs4_state_owner *nfs4_get_state_owner(struct nfs_server *server, struct
...
@@ -185,7 +184,7 @@ struct nfs4_state_owner *nfs4_get_state_owner(struct nfs_server *server, struct
list_add
(
&
new
->
so_list
,
&
clp
->
cl_state_owners
);
list_add
(
&
new
->
so_list
,
&
clp
->
cl_state_owners
);
new
->
so_client
=
clp
;
new
->
so_client
=
clp
;
new
->
so_id
=
nfs4_alloc_lockowner_id
(
clp
);
new
->
so_id
=
nfs4_alloc_lockowner_id
(
clp
);
new
->
so_cred
=
cred
;
new
->
so_cred
=
get_rpccred
(
cred
)
;
sp
=
new
;
sp
=
new
;
new
=
NULL
;
new
=
NULL
;
}
}
...
@@ -193,7 +192,6 @@ struct nfs4_state_owner *nfs4_get_state_owner(struct nfs_server *server, struct
...
@@ -193,7 +192,6 @@ struct nfs4_state_owner *nfs4_get_state_owner(struct nfs_server *server, struct
kfree
(
new
);
kfree
(
new
);
if
(
sp
!=
NULL
)
if
(
sp
!=
NULL
)
return
sp
;
return
sp
;
put_rpccred
(
cred
);
return
NULL
;
return
NULL
;
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录