Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Achou.Wang
accel-ppp
提交
111e1bee
A
accel-ppp
项目概览
Achou.Wang
/
accel-ppp
通知
6
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
A
accel-ppp
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
111e1bee
编写于
5月 20, 2014
作者:
D
Dmitry Kozlov
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
triton: fix possible race
上级
f7b2b5c9
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
8 addition
and
7 deletion
+8
-7
accel-pppd/triton/triton.c
accel-pppd/triton/triton.c
+8
-7
未找到文件。
accel-pppd/triton/triton.c
浏览文件 @
111e1bee
...
...
@@ -148,24 +148,23 @@ static void* triton_thread(struct _triton_thread_t *thread)
spin_unlock
(
&
threads_lock
);
}
cont:
log_debug2
(
"thread %p: ctx=%p %p
\n
"
,
thread
,
thread
->
ctx
,
thread
->
ctx
?
thread
->
ctx
->
thread
:
NULL
);
this_ctx
=
thread
->
ctx
->
ud
;
if
(
thread
->
ctx
->
ud
->
before_switch
)
thread
->
ctx
->
ud
->
before_switch
(
thread
->
ctx
->
ud
,
thread
->
ctx
->
bf_arg
);
cont:
log_debug2
(
"thread %p: switch to %p
\n
"
,
thread
,
thread
->
ctx
);
ctx_thread
(
thread
->
ctx
);
log_debug2
(
"thread %p: switch from %p %p
\n
"
,
thread
,
thread
->
ctx
,
thread
->
ctx
->
thread
);
spin_lock
(
&
thread
->
ctx
->
lock
);
spin_lock
(
&
thread
s_
lock
);
if
(
thread
->
ctx
->
pending
)
{
spin_unlock
(
&
thread
->
ctx
->
lock
);
spin_unlock
(
&
thread
s_
lock
);
goto
cont
;
}
thread
->
ctx
->
thread
=
NULL
;
spin_unlock
(
&
thread
->
ctx
->
lock
);
spin_unlock
(
&
threads_lock
);
if
(
thread
->
ctx
->
need_free
)
{
log_debug2
(
"- context %p removed
\n
"
,
thread
->
ctx
);
...
...
@@ -269,11 +268,13 @@ struct _triton_thread_t *create_thread()
int
triton_queue_ctx
(
struct
_triton_context_t
*
ctx
)
{
spin_lock
(
&
threads_lock
);
ctx
->
pending
=
1
;
if
(
ctx
->
thread
||
ctx
->
queued
||
ctx
->
init
)
if
(
ctx
->
thread
||
ctx
->
queued
||
ctx
->
init
)
{
spin_unlock
(
&
threads_lock
);
return
0
;
}
spin_lock
(
&
threads_lock
);
if
(
list_empty
(
&
sleep_threads
)
||
need_config_reload
||
triton_stat
.
thread_active
>
thread_count
||
(
ctx
->
priority
==
0
&&
triton_stat
.
thread_count
>
thread_count_max
))
{
if
(
ctx
->
priority
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录