Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
bbd5a1f9
cloud-kernel
项目概览
openanolis
/
cloud-kernel
1 年多 前同步成功
通知
161
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看板
提交
bbd5a1f9
编写于
10月 18, 2006
作者:
T
Trond Myklebust
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
SUNRPC: Fix up missing BKL in asynchronous RPC callback functions
Signed-off-by:
N
Trond Myklebust
<
Trond.Myklebust@netapp.com
>
上级
3e32a5d9
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
13 addition
and
6 deletion
+13
-6
include/linux/sunrpc/sched.h
include/linux/sunrpc/sched.h
+1
-0
net/sunrpc/clnt.c
net/sunrpc/clnt.c
+1
-2
net/sunrpc/sched.c
net/sunrpc/sched.c
+11
-4
未找到文件。
include/linux/sunrpc/sched.h
浏览文件 @
bbd5a1f9
...
...
@@ -252,6 +252,7 @@ void rpc_init_task(struct rpc_task *task, struct rpc_clnt *clnt,
void
rpc_put_task
(
struct
rpc_task
*
);
void
rpc_release_task
(
struct
rpc_task
*
);
void
rpc_exit_task
(
struct
rpc_task
*
);
void
rpc_release_calldata
(
const
struct
rpc_call_ops
*
,
void
*
);
void
rpc_killall_tasks
(
struct
rpc_clnt
*
);
int
rpc_execute
(
struct
rpc_task
*
);
void
rpc_init_priority_wait_queue
(
struct
rpc_wait_queue
*
,
const
char
*
);
...
...
net/sunrpc/clnt.c
浏览文件 @
bbd5a1f9
...
...
@@ -541,8 +541,7 @@ rpc_call_async(struct rpc_clnt *clnt, struct rpc_message *msg, int flags,
rpc_restore_sigmask
(
&
oldset
);
return
status
;
out_release:
if
(
tk_ops
->
rpc_release
!=
NULL
)
tk_ops
->
rpc_release
(
data
);
rpc_release_calldata
(
tk_ops
,
data
);
return
status
;
}
...
...
net/sunrpc/sched.c
浏览文件 @
bbd5a1f9
...
...
@@ -608,6 +608,15 @@ void rpc_exit_task(struct rpc_task *task)
}
EXPORT_SYMBOL
(
rpc_exit_task
);
void
rpc_release_calldata
(
const
struct
rpc_call_ops
*
ops
,
void
*
calldata
)
{
if
(
ops
->
rpc_release
!=
NULL
)
{
lock_kernel
();
ops
->
rpc_release
(
calldata
);
unlock_kernel
();
}
}
/*
* This is the RPC `scheduler' (or rather, the finite state machine).
*/
...
...
@@ -883,8 +892,7 @@ void rpc_put_task(struct rpc_task *task)
}
if
(
task
->
tk_flags
&
RPC_TASK_DYNAMIC
)
call_rcu_bh
(
&
task
->
u
.
tk_rcu
,
rpc_free_task
);
if
(
tk_ops
->
rpc_release
)
tk_ops
->
rpc_release
(
calldata
);
rpc_release_calldata
(
tk_ops
,
calldata
);
}
EXPORT_SYMBOL
(
rpc_put_task
);
...
...
@@ -928,8 +936,7 @@ struct rpc_task *rpc_run_task(struct rpc_clnt *clnt, int flags,
struct
rpc_task
*
task
;
task
=
rpc_new_task
(
clnt
,
flags
,
ops
,
data
);
if
(
task
==
NULL
)
{
if
(
ops
->
rpc_release
!=
NULL
)
ops
->
rpc_release
(
data
);
rpc_release_calldata
(
ops
,
data
);
return
ERR_PTR
(
-
ENOMEM
);
}
atomic_inc
(
&
task
->
tk_count
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录