Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
34006cee
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看板
提交
34006cee
编写于
7月 17, 2011
作者:
T
Trond Myklebust
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
SUNRPC: Replace xprt->resend and xprt->sending with a priority queue
Signed-off-by:
N
Trond Myklebust
<
Trond.Myklebust@netapp.com
>
上级
3b27bad7
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
21 addition
and
22 deletion
+21
-22
include/linux/sunrpc/xprt.h
include/linux/sunrpc/xprt.h
+0
-1
net/sunrpc/xprt.c
net/sunrpc/xprt.c
+21
-21
未找到文件。
include/linux/sunrpc/xprt.h
浏览文件 @
34006cee
...
...
@@ -165,7 +165,6 @@ struct rpc_xprt {
struct
rpc_wait_queue
binding
;
/* requests waiting on rpcbind */
struct
rpc_wait_queue
sending
;
/* requests waiting to send */
struct
rpc_wait_queue
resend
;
/* requests waiting to resend */
struct
rpc_wait_queue
pending
;
/* requests in flight */
struct
rpc_wait_queue
backlog
;
/* waiting for slot */
struct
list_head
free
;
/* free slots */
...
...
net/sunrpc/xprt.c
浏览文件 @
34006cee
...
...
@@ -195,6 +195,7 @@ EXPORT_SYMBOL_GPL(xprt_load_transport);
int
xprt_reserve_xprt
(
struct
rpc_xprt
*
xprt
,
struct
rpc_task
*
task
)
{
struct
rpc_rqst
*
req
=
task
->
tk_rqstp
;
int
priority
;
if
(
test_and_set_bit
(
XPRT_LOCKED
,
&
xprt
->
state
))
{
if
(
task
==
xprt
->
snd_task
)
...
...
@@ -214,10 +215,13 @@ int xprt_reserve_xprt(struct rpc_xprt *xprt, struct rpc_task *task)
task
->
tk_pid
,
xprt
);
task
->
tk_timeout
=
0
;
task
->
tk_status
=
-
EAGAIN
;
if
(
req
!=
NULL
&&
req
->
rq_ntrans
)
rpc_sleep_on
(
&
xprt
->
resend
,
task
,
NULL
);
if
(
req
==
NULL
)
priority
=
RPC_PRIORITY_LOW
;
else
if
(
!
req
->
rq_ntrans
)
priority
=
RPC_PRIORITY_NORMAL
;
else
rpc_sleep_on
(
&
xprt
->
sending
,
task
,
NULL
);
priority
=
RPC_PRIORITY_HIGH
;
rpc_sleep_on_priority
(
&
xprt
->
sending
,
task
,
NULL
,
priority
);
return
0
;
}
EXPORT_SYMBOL_GPL
(
xprt_reserve_xprt
);
...
...
@@ -244,6 +248,7 @@ static void xprt_clear_locked(struct rpc_xprt *xprt)
int
xprt_reserve_xprt_cong
(
struct
rpc_xprt
*
xprt
,
struct
rpc_task
*
task
)
{
struct
rpc_rqst
*
req
=
task
->
tk_rqstp
;
int
priority
;
if
(
test_and_set_bit
(
XPRT_LOCKED
,
&
xprt
->
state
))
{
if
(
task
==
xprt
->
snd_task
)
...
...
@@ -265,10 +270,13 @@ int xprt_reserve_xprt_cong(struct rpc_xprt *xprt, struct rpc_task *task)
dprintk
(
"RPC: %5u failed to lock transport %p
\n
"
,
task
->
tk_pid
,
xprt
);
task
->
tk_timeout
=
0
;
task
->
tk_status
=
-
EAGAIN
;
if
(
req
!=
NULL
&&
req
->
rq_ntrans
)
rpc_sleep_on
(
&
xprt
->
resend
,
task
,
NULL
);
if
(
req
==
NULL
)
priority
=
RPC_PRIORITY_LOW
;
else
if
(
!
req
->
rq_ntrans
)
priority
=
RPC_PRIORITY_NORMAL
;
else
rpc_sleep_on
(
&
xprt
->
sending
,
task
,
NULL
);
priority
=
RPC_PRIORITY_HIGH
;
rpc_sleep_on_priority
(
&
xprt
->
sending
,
task
,
NULL
,
priority
);
return
0
;
}
EXPORT_SYMBOL_GPL
(
xprt_reserve_xprt_cong
);
...
...
@@ -291,12 +299,9 @@ static void __xprt_lock_write_next(struct rpc_xprt *xprt)
if
(
test_and_set_bit
(
XPRT_LOCKED
,
&
xprt
->
state
))
return
;
task
=
rpc_wake_up_next
(
&
xprt
->
resend
);
if
(
!
task
)
{
task
=
rpc_wake_up_next
(
&
xprt
->
sending
);
if
(
task
==
NULL
)
goto
out_unlock
;
}
task
=
rpc_wake_up_next
(
&
xprt
->
sending
);
if
(
task
==
NULL
)
goto
out_unlock
;
req
=
task
->
tk_rqstp
;
xprt
->
snd_task
=
task
;
...
...
@@ -319,12 +324,9 @@ static void __xprt_lock_write_next_cong(struct rpc_xprt *xprt)
return
;
if
(
RPCXPRT_CONGESTED
(
xprt
))
goto
out_unlock
;
task
=
rpc_wake_up_next
(
&
xprt
->
resend
);
if
(
!
task
)
{
task
=
rpc_wake_up_next
(
&
xprt
->
sending
);
if
(
task
==
NULL
)
goto
out_unlock
;
}
task
=
rpc_wake_up_next
(
&
xprt
->
sending
);
if
(
task
==
NULL
)
goto
out_unlock
;
req
=
task
->
tk_rqstp
;
if
(
req
==
NULL
)
{
...
...
@@ -1177,8 +1179,7 @@ static void xprt_init(struct rpc_xprt *xprt, struct net *net)
rpc_init_wait_queue
(
&
xprt
->
binding
,
"xprt_binding"
);
rpc_init_wait_queue
(
&
xprt
->
pending
,
"xprt_pending"
);
rpc_init_wait_queue
(
&
xprt
->
sending
,
"xprt_sending"
);
rpc_init_wait_queue
(
&
xprt
->
resend
,
"xprt_resend"
);
rpc_init_priority_wait_queue
(
&
xprt
->
sending
,
"xprt_sending"
);
rpc_init_priority_wait_queue
(
&
xprt
->
backlog
,
"xprt_backlog"
);
xprt_init_xid
(
xprt
);
...
...
@@ -1240,7 +1241,6 @@ static void xprt_destroy(struct rpc_xprt *xprt)
rpc_destroy_wait_queue
(
&
xprt
->
binding
);
rpc_destroy_wait_queue
(
&
xprt
->
pending
);
rpc_destroy_wait_queue
(
&
xprt
->
sending
);
rpc_destroy_wait_queue
(
&
xprt
->
resend
);
rpc_destroy_wait_queue
(
&
xprt
->
backlog
);
cancel_work_sync
(
&
xprt
->
task_cleanup
);
/*
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录