Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
不穿格子衫的农民
TencentOS Tiny
提交
da61aa0a
T
TencentOS Tiny
项目概览
不穿格子衫的农民
/
TencentOS Tiny
通知
3
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
TencentOS Tiny
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
da61aa0a
编写于
3月 11, 2021
作者:
M
mculover666
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
add support for dynaminc sem and dynamic mutex
上级
54022c24
变更
8
隐藏空白更改
内联
并排
Showing
8 changed file
with
182 addition
and
7 deletion
+182
-7
board/TencentOS_tiny_EVB_MX_Plus/KEIL/test/TencentOS_tiny.uvprojx
...ncentOS_tiny_EVB_MX_Plus/KEIL/test/TencentOS_tiny.uvprojx
+20
-4
kernel/core/include/tos_kerr.h
kernel/core/include/tos_kerr.h
+4
-0
kernel/core/include/tos_mutex.h
kernel/core/include/tos_mutex.h
+13
-0
kernel/core/include/tos_sem.h
kernel/core/include/tos_sem.h
+29
-0
kernel/core/tos_mutex.c
kernel/core/tos_mutex.c
+32
-1
kernel/core/tos_sem.c
kernel/core/tos_sem.c
+40
-1
test/suit_mutex.c
test/suit_mutex.c
+15
-0
test/suit_sem.c
test/suit_sem.c
+29
-1
未找到文件。
board/TencentOS_tiny_EVB_MX_Plus/KEIL/test/TencentOS_tiny.uvprojx
浏览文件 @
da61aa0a
...
...
@@ -10,14 +10,14 @@
<TargetName>
TencentOS_tiny
</TargetName>
<ToolsetNumber>
0x4
</ToolsetNumber>
<ToolsetName>
ARM-ADS
</ToolsetName>
<pCCUsed>
5060750::V5.06 update 6 (build 750)::ARMCC
</pCCUsed>
<pCCUsed>
5060750::V5.06 update 6 (build 750)::
.\
ARMCC
</pCCUsed>
<uAC6>
0
</uAC6>
<TargetOption>
<TargetCommonOption>
<Device>
STM32L431RCTx
</Device>
<Vendor>
STMicroelectronics
</Vendor>
<PackID>
Keil.STM32L4xx_DFP.2.
2
.0
</PackID>
<PackURL>
http
://www.keil.com/pack
</PackURL>
<PackID>
Keil.STM32L4xx_DFP.2.
3
.0
</PackID>
<PackURL>
http
s://www.keil.com/pack/
</PackURL>
<Cpu>
IRAM(0x20000000-0x2000FFFF) IROM(0x8000000-0x803FFFF) CLOCK(8000000) FPU2 CPUTYPE("Cortex-M4")
</Cpu>
<FlashUtilSpec></FlashUtilSpec>
<StartupFile></StartupFile>
...
...
@@ -185,6 +185,7 @@
<uocXRam>
0
</uocXRam>
<RvdsVP>
2
</RvdsVP>
<RvdsMve>
0
</RvdsMve>
<RvdsCdeCp>
0
</RvdsCdeCp>
<hadIRAM2>
0
</hadIRAM2>
<hadIROM2>
0
</hadIROM2>
<StupSel>
8
</StupSel>
...
...
@@ -351,7 +352,7 @@
<NoWarn>
0
</NoWarn>
<uSurpInc>
0
</uSurpInc>
<useXO>
0
</useXO>
<
uClangAs>
0
</uClangAs
>
<
ClangAsOpt>
4
</ClangAsOpt
>
<VariousControls>
<MiscControls></MiscControls>
<Define></Define>
...
...
@@ -879,4 +880,19 @@
<files/>
</RTE>
<LayerInfo>
<Layers>
<Layer>
<LayName>
<
Project Info
>
</LayName>
<LayDesc></LayDesc>
<LayUrl></LayUrl>
<LayKeys></LayKeys>
<LayCat></LayCat>
<LayLic></LayLic>
<LayTarg>
0
</LayTarg>
<LayPrjMark>
1
</LayPrjMark>
</Layer>
</Layers>
</LayerInfo>
</Project>
kernel/core/include/tos_kerr.h
浏览文件 @
da61aa0a
...
...
@@ -124,6 +124,10 @@ typedef enum k_err_en {
K_ERR_TIMER_INVALID_OPT
,
K_ERR_TIMER_STOPPED
,
K_ERR_TIMER_RUNNING
,
K_ERR_SEM_OUT_OF_MEMORY
=
2200u
,
K_ERR_MUTEX_OUT_OF_MEMORY
=
2300u
,
}
k_err_t
;
#endif
/* _TOS_ERR_H_ */
...
...
kernel/core/include/tos_mutex.h
浏览文件 @
da61aa0a
...
...
@@ -47,6 +47,19 @@ typedef struct k_mutex_st {
*/
__API__
k_err_t
tos_mutex_create
(
k_mutex_t
*
mutex
);
/**
* @brief Create a dynamic mutex.
* create a dynamic mutex.
*
* @attention None
*
* @param[in] mutex pointer to the pointer of the mutex.
*
* @return errcode
* @retval #K_ERR_NONE return successfully.
*/
__API__
k_err_t
tos_mutex_create_dyn
(
k_mutex_t
**
mutex
);
/**
* @brief Destroy a mutex.
* destroy a mutex.
...
...
kernel/core/include/tos_sem.h
浏览文件 @
da61aa0a
...
...
@@ -61,6 +61,35 @@ __API__ k_err_t tos_sem_create_max(k_sem_t *sem, k_sem_cnt_t init_count, k_sem_c
*/
__API__
k_err_t
tos_sem_create
(
k_sem_t
*
sem
,
k_sem_cnt_t
init_count
);
/**
* @brief Create a dynamic semaphore with a limitation of maximum count.
* create a dynamic semaphore with a limitation of maximum count.
*
* @attention None
*
* @param[in] sem pointer to the pointer of the semaphore.
* @param[in] init_count initial count of the semaphore.
* @param[in] max_count maximum count of the semaphore.
*
* @return errcode
* @retval #K_ERR_NONE return successfully.
*/
__API__
k_err_t
tos_sem_create_max_dyn
(
k_sem_t
**
sem
,
k_sem_cnt_t
init_count
,
k_sem_cnt_t
max_count
);
/**
* @brief Create a dynamic semaphore.
* create a dynamic semaphore.
*
* @attention None
*
* @param[in] sem pointer to the pointer of the semaphore.
* @param[in] init_count initial count of the semaphore.
*
* @return errcode
* @retval #K_ERR_NONE return successfully.
*/
__API__
k_err_t
tos_sem_create_dyn
(
k_sem_t
**
sem
,
k_sem_cnt_t
init_count
);
/**
* @brief Destroy a semaphore.
* destroy a semaphore.
...
...
kernel/core/tos_mutex.c
浏览文件 @
da61aa0a
...
...
@@ -83,6 +83,32 @@ __API__ k_err_t tos_mutex_create(k_mutex_t *mutex)
return
K_ERR_NONE
;
}
__API__
k_err_t
tos_mutex_create_dyn
(
k_mutex_t
**
mutex
)
{
k_mutex_t
*
the_mutex
;
TOS_IN_IRQ_CHECK
();
TOS_PTR_SANITY_CHECK
(
mutex
);
the_mutex
=
tos_mmheap_calloc
(
1
,
sizeof
(
k_mutex_t
));
if
(
!
the_mutex
)
{
return
K_ERR_MUTEX_OUT_OF_MEMORY
;
}
pend_object_init
(
&
the_mutex
->
pend_obj
);
the_mutex
->
pend_nesting
=
(
k_nesting_t
)
0u
;
the_mutex
->
owner
=
K_NULL
;
the_mutex
->
owner_orig_prio
=
K_TASK_PRIO_INVALID
;
tos_list_init
(
&
the_mutex
->
owner_anchor
);
TOS_OBJ_INIT
(
the_mutex
,
KNL_OBJ_TYPE_MUTEX
);
knl_object_alloc_set_dynamic
(
&
the_mutex
->
knl_obj
);
*
mutex
=
the_mutex
;
return
K_ERR_NONE
;
}
__API__
k_err_t
tos_mutex_destroy
(
k_mutex_t
*
mutex
)
{
TOS_CPU_CPSR_ALLOC
();
...
...
@@ -101,7 +127,12 @@ __API__ k_err_t tos_mutex_destroy(k_mutex_t *mutex)
pend_object_deinit
(
&
mutex
->
pend_obj
);
TOS_OBJ_DEINIT
(
mutex
);
if
(
knl_object_alloc_is_dynamic
(
&
mutex
->
knl_obj
))
{
TOS_OBJ_DEINIT
(
mutex
);
tos_mmheap_free
(
mutex
);
}
else
{
TOS_OBJ_DEINIT
(
mutex
);
}
TOS_CPU_INT_ENABLE
();
knl_sched
();
...
...
kernel/core/tos_sem.c
浏览文件 @
da61aa0a
...
...
@@ -41,6 +41,40 @@ __API__ k_err_t tos_sem_create(k_sem_t *sem, k_sem_cnt_t init_count)
return
tos_sem_create_max
(
sem
,
init_count
,
(
k_sem_cnt_t
)
-
1
);
}
__API__
k_err_t
tos_sem_create_max_dyn
(
k_sem_t
**
sem
,
k_sem_cnt_t
init_count
,
k_sem_cnt_t
max_count
)
{
k_sem_t
*
the_sem
;
TOS_IN_IRQ_CHECK
();
TOS_PTR_SANITY_CHECK
(
sem
);
if
(
unlikely
(
init_count
>
max_count
))
{
init_count
=
max_count
;
}
the_sem
=
tos_mmheap_calloc
(
1
,
sizeof
(
k_sem_t
));
if
(
!
the_sem
)
{
return
K_ERR_SEM_OUT_OF_MEMORY
;
}
the_sem
->
count
=
init_count
;
the_sem
->
count_max
=
max_count
;
pend_object_init
(
&
the_sem
->
pend_obj
);
TOS_OBJ_INIT
(
the_sem
,
KNL_OBJ_TYPE_SEMAPHORE
);
knl_object_alloc_set_dynamic
(
&
the_sem
->
knl_obj
);
*
sem
=
the_sem
;
return
K_ERR_NONE
;
}
__API__
k_err_t
tos_sem_create_dyn
(
k_sem_t
**
sem
,
k_sem_cnt_t
init_count
)
{
return
tos_sem_create_max_dyn
(
sem
,
init_count
,
(
k_sem_cnt_t
)
-
1
);
}
__API__
k_err_t
tos_sem_destroy
(
k_sem_t
*
sem
)
{
TOS_CPU_CPSR_ALLOC
();
...
...
@@ -54,7 +88,12 @@ __API__ k_err_t tos_sem_destroy(k_sem_t *sem)
pend_object_deinit
(
&
sem
->
pend_obj
);
TOS_OBJ_DEINIT
(
sem
);
if
(
knl_object_alloc_is_dynamic
(
&
sem
->
knl_obj
))
{
TOS_OBJ_DEINIT
(
sem
);
tos_mmheap_free
(
sem
);
}
else
{
TOS_OBJ_DEINIT
(
sem
);
}
TOS_CPU_INT_ENABLE
();
knl_sched
();
...
...
test/suit_mutex.c
浏览文件 @
da61aa0a
...
...
@@ -10,6 +10,7 @@ SUITE(suit_mutex);
k_mutex_t
test_mutex_00
;
k_mutex_t
test_mutex_01
;
k_mutex_t
test_mutex_02
;
k_mutex_t
*
test_mutex_dyn_00
;
static
void
test_mutex_pend_task_entry
(
void
*
arg
)
{
...
...
@@ -127,6 +128,19 @@ TEST test_tos_mutex_create(void)
PASS
();
}
TEST
test_tos_mutex_create_dyn
(
void
)
{
k_err_t
err
;
err
=
tos_mutex_create_dyn
(
&
test_mutex_dyn_00
);
ASSERT_EQ
(
err
,
K_ERR_NONE
);
err
=
tos_mutex_destroy
(
test_mutex_dyn_00
);
ASSERT_EQ
(
err
,
K_ERR_NONE
);
PASS
();
}
TEST
test_tos_mutex_destroy
(
void
)
{
k_err_t
err
;
...
...
@@ -406,6 +420,7 @@ SUITE(suit_mutex)
{
RUN_TEST
(
test_tos_mutex_create
);
RUN_TEST
(
test_tos_mutex_destroy
);
RUN_TEST
(
test_tos_mutex_create_dyn
);
RUN_TEST
(
test_tos_mutex_pend
);
RUN_TEST
(
test_tos_mutex_pend_timed
);
RUN_TEST
(
test_tos_mutex_post
);
...
...
test/suit_sem.c
浏览文件 @
da61aa0a
...
...
@@ -10,7 +10,9 @@ SUITE(suit_sem);
k_sem_t
test_sem_00
;
k_sem_t
test_sem_01
;
k_sem_t
test_sem_02
;
k_sem_t
*
test_sem_dyn_00
;
k_sem_t
*
test_sem_dyn_01
;
k_sem_t
*
test_sem_dyn_02
;
static
void
test_sem_pend_task_entry
(
void
*
arg
)
{
k_err_t
err
;
...
...
@@ -81,6 +83,31 @@ TEST test_tos_sem_create(void)
PASS
();
}
TEST
test_tos_sem_create_dyn
(
void
)
{
k_err_t
err
;
err
=
tos_sem_create_dyn
(
&
test_sem_dyn_00
,
(
k_sem_cnt_t
)
0
);
ASSERT_EQ
(
err
,
K_ERR_NONE
);
err
=
tos_sem_create_dyn
(
&
test_sem_dyn_01
,
(
k_sem_cnt_t
)
0xFF
);
ASSERT_EQ
(
err
,
K_ERR_NONE
);
err
=
tos_sem_create_dyn
(
&
test_sem_dyn_02
,
(
k_sem_cnt_t
)
0xFFFF
);
ASSERT_EQ
(
err
,
K_ERR_NONE
);
err
=
tos_sem_destroy
(
test_sem_dyn_00
);
ASSERT_EQ
(
err
,
K_ERR_NONE
);
err
=
tos_sem_destroy
(
test_sem_dyn_01
);
ASSERT_EQ
(
err
,
K_ERR_NONE
);
err
=
tos_sem_destroy
(
test_sem_dyn_02
);
ASSERT_EQ
(
err
,
K_ERR_NONE
);
PASS
();
}
TEST
test_tos_sem_destroy
(
void
)
{
k_err_t
err
;
...
...
@@ -251,6 +278,7 @@ TEST test_tos_sem_post_all(void)
SUITE
(
suit_sem
)
{
RUN_TEST
(
test_tos_sem_create
);
RUN_TEST
(
test_tos_sem_create_dyn
);
RUN_TEST
(
test_tos_sem_destroy
);
RUN_TEST
(
test_tos_sem_pend
);
RUN_TEST
(
test_tos_sem_pend_timed
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录