Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
PHPmihuan
rt-thread
提交
b4e57db1
R
rt-thread
项目概览
PHPmihuan
/
rt-thread
与 Fork 源项目一致
Fork自
RT-Thread / rt-thread
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
rt-thread
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
b4e57db1
编写于
12月 31, 2020
作者:
B
bernard
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[kernel] Use object_find to implement thread_find/device_find
上级
a1292576
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
2 addition
and
64 deletion
+2
-64
src/device.c
src/device.c
+1
-32
src/thread.c
src/thread.c
+1
-32
未找到文件。
src/device.c
浏览文件 @
b4e57db1
...
...
@@ -111,38 +111,7 @@ rt_err_t rt_device_init_all(void)
*/
rt_device_t
rt_device_find
(
const
char
*
name
)
{
struct
rt_object
*
object
;
struct
rt_list_node
*
node
;
struct
rt_object_information
*
information
;
/* enter critical */
if
(
rt_thread_self
()
!=
RT_NULL
)
rt_enter_critical
();
/* try to find device object */
information
=
rt_object_get_information
(
RT_Object_Class_Device
);
RT_ASSERT
(
information
!=
RT_NULL
);
for
(
node
=
information
->
object_list
.
next
;
node
!=
&
(
information
->
object_list
);
node
=
node
->
next
)
{
object
=
rt_list_entry
(
node
,
struct
rt_object
,
list
);
if
(
rt_strncmp
(
object
->
name
,
name
,
RT_NAME_MAX
)
==
0
)
{
/* leave critical */
if
(
rt_thread_self
()
!=
RT_NULL
)
rt_exit_critical
();
return
(
rt_device_t
)
object
;
}
}
/* leave critical */
if
(
rt_thread_self
()
!=
RT_NULL
)
rt_exit_critical
();
/* not found */
return
RT_NULL
;
return
(
rt_device_t
)
rt_object_find
(
name
,
RT_Object_Class_Device
);
}
RTM_EXPORT
(
rt_device_find
);
...
...
src/thread.c
浏览文件 @
b4e57db1
...
...
@@ -862,38 +862,7 @@ RTM_EXPORT(rt_thread_timeout);
*/
rt_thread_t
rt_thread_find
(
char
*
name
)
{
struct
rt_object_information
*
information
;
struct
rt_object
*
object
;
struct
rt_list_node
*
node
;
/* enter critical */
if
(
rt_thread_self
()
!=
RT_NULL
)
rt_enter_critical
();
/* try to find device object */
information
=
rt_object_get_information
(
RT_Object_Class_Thread
);
RT_ASSERT
(
information
!=
RT_NULL
);
for
(
node
=
information
->
object_list
.
next
;
node
!=
&
(
information
->
object_list
);
node
=
node
->
next
)
{
object
=
rt_list_entry
(
node
,
struct
rt_object
,
list
);
if
(
rt_strncmp
(
object
->
name
,
name
,
RT_NAME_MAX
)
==
0
)
{
/* leave critical */
if
(
rt_thread_self
()
!=
RT_NULL
)
rt_exit_critical
();
return
(
rt_thread_t
)
object
;
}
}
/* leave critical */
if
(
rt_thread_self
()
!=
RT_NULL
)
rt_exit_critical
();
/* not found */
return
RT_NULL
;
return
(
rt_thread_t
)
rt_object_find
(
name
,
RT_Object_Class_Thread
);
}
RTM_EXPORT
(
rt_thread_find
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录