Merge pull request #375 from szlr/fix-memory-leak-and-type-conversion

[HUST CSE] Fix memory leak and type conversion
This commit is contained in:
Supowang
2023-04-25 14:14:06 +08:00
committed by GitHub

View File

@@ -122,36 +122,36 @@ void sys_sem_set_invalid(sys_sem_t *sem)
} }
/* /*
<EFBFBD><EFBFBD><EFBFBD><EFBFBD>timeout<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ϊ<EFBFBD><EFBFBD>򷵻<EFBFBD>ֵΪ 如果timeout参数不为零,则返回值为
<EFBFBD>ȴ<EFBFBD><EFBFBD>ź<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ѵĺ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> 等待信号量所花费的毫秒数。如果
<EFBFBD>ź<EFBFBD><EFBFBD><EFBFBD>δ<EFBFBD><EFBFBD>ָ<EFBFBD><EFBFBD>ʱ<EFBFBD><EFBFBD><EFBFBD>ڷ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>źţ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ֵΪ 信号量未在指定时间内发出信号,返回值为
SYS_ARCH_TIMEOUT<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>̲߳<EFBFBD><EFBFBD>صȴ<EFBFBD><EFBFBD>ź<EFBFBD><EFBFBD><EFBFBD> SYS_ARCH_TIMEOUT。如果线程不必等待信号量
<EFBFBD>ú<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> */ 该函数返回零。 */
u32_t sys_arch_sem_wait(sys_sem_t *sem, u32_t timeout) u32_t sys_arch_sem_wait(sys_sem_t *sem, u32_t timeout)
{ {
k_tick_t wait_tick = 0; k_tick_t wait_tick = 0;
k_tick_t start_tick = 0; k_tick_t start_tick = 0;
//<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ź<EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ƿ<EFBFBD><EFBFBD><EFBFBD>Ч //看看信号量是否有效
if (sem == SYS_SEM_NULL) { if (sem == SYS_SEM_NULL) {
return SYS_ARCH_TIMEOUT; return SYS_ARCH_TIMEOUT;
} }
//<EFBFBD><EFBFBD><EFBFBD>Ȼ<EFBFBD>ȡ<EFBFBD><EFBFBD>ʼ<EFBFBD>ȴ<EFBFBD><EFBFBD>ź<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʱ<EFBFBD>ӽ<EFBFBD><EFBFBD><EFBFBD> //首先获取开始等待信号量的时钟节拍
start_tick = sys_now(); start_tick = sys_now();
//timeout != 0<EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ҫ<EFBFBD><EFBFBD>ms<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ϵͳ<EFBFBD><EFBFBD>ʱ<EFBFBD>ӽ<EFBFBD><EFBFBD><EFBFBD> //timeout != 0需要将ms换成系统的时钟节拍
if (timeout != 0) { if (timeout != 0) {
//<EFBFBD><EFBFBD>msת<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʱ<EFBFBD>ӽ<EFBFBD><EFBFBD><EFBFBD> //将ms转换成时钟节拍
wait_tick = timeout / (1000 / TOS_CFG_CPU_TICK_PER_SECOND); wait_tick = timeout / (1000 / TOS_CFG_CPU_TICK_PER_SECOND);
if (wait_tick == 0) { if (wait_tick == 0) {
wait_tick = 1; wait_tick = 1;
} }
} else { } else {
wait_tick = TOS_TIME_FOREVER; //һֱ<EFBFBD><EFBFBD><EFBFBD><EFBFBD> wait_tick = TOS_TIME_FOREVER; //一直阻塞
} }
//<EFBFBD>ȴ<EFBFBD><EFBFBD>ɹ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ȴ<EFBFBD><EFBFBD><EFBFBD>ʱ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͱ<EFBFBD>ʾ<EFBFBD>ȴ<EFBFBD><EFBFBD><EFBFBD>ʱ //等待成功,计算等待的时间,否则就表示等待超时
if (tos_sem_pend(sem, wait_tick) == K_ERR_NONE) { if (tos_sem_pend(sem, wait_tick) == K_ERR_NONE) {
return ((sys_now() - start_tick) * (1000 / TOS_CFG_CPU_TICK_PER_SECOND)); return ((sys_now() - start_tick) * (1000 / TOS_CFG_CPU_TICK_PER_SECOND));
} }
@@ -224,17 +224,20 @@ sys_thread_t sys_thread_new(const char *name, lwip_thread_fn function, void *arg
return NULL; return NULL;
} }
task_stack = tos_mmheap_alloc(stacksize); task_stack = (k_stack_t *)tos_mmheap_alloc(stacksize);
if (!task_stack) { if (!task_stack) {
printf("[sys_arch]:memalloc task stack fail!\n"); printf("[sys_arch]:memalloc task stack fail!\n");
tos_mmheap_free(task);
return NULL; return NULL;
} }
/* <EFBFBD><EFBFBD><EFBFBD><EFBFBD>MidPriority_Task<EFBFBD><EFBFBD><EFBFBD><EFBFBD> */ /* 创建MidPriority_Task任务 */
rc = tos_task_create(task, (char*)name, function, arg, rc = tos_task_create(task, (char*)name, function, arg,
prio, task_stack, stacksize, 20); prio, task_stack, stacksize, 20);
if (rc != K_ERR_NONE) { if (rc != K_ERR_NONE) {
printf("[sys_arch]:create task fail! code: %d \r\n", rc); printf("[sys_arch]:create task fail! code: %d \r\n", rc);
tos_mmheap_free(task);
tos_mmheap_free(task_stack);
return NULL; return NULL;
} }
@@ -310,25 +313,25 @@ u32_t sys_arch_mbox_fetch(sys_mbox_t *q, void **msg, u32_t timeout)
k_tick_t wait_tick = 0; k_tick_t wait_tick = 0;
k_tick_t start_tick = 0; k_tick_t start_tick = 0;
if (!msg) { // <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ϣ<EFBFBD>ĵط<EFBFBD><EFBFBD>Ƿ<EFBFBD><EFBFBD><EFBFBD>Ч if (!msg) { // 看看存储消息的地方是否有效
msg = &dummyptr; msg = &dummyptr;
} }
// <EFBFBD><EFBFBD><EFBFBD>Ȼ<EFBFBD>ȡ<EFBFBD><EFBFBD>ʼ<EFBFBD>ȴ<EFBFBD><EFBFBD>ź<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʱ<EFBFBD>ӽ<EFBFBD><EFBFBD><EFBFBD> // 首先获取开始等待信号量的时钟节拍
start_tick = sys_now(); start_tick = sys_now();
// timeout != 0<EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ҫ<EFBFBD><EFBFBD>ms<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ϵͳ<EFBFBD><EFBFBD>ʱ<EFBFBD>ӽ<EFBFBD><EFBFBD><EFBFBD> // timeout != 0需要将ms换成系统的时钟节拍
if (timeout != 0) { if (timeout != 0) {
//<EFBFBD><EFBFBD>msת<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʱ<EFBFBD>ӽ<EFBFBD><EFBFBD><EFBFBD> //将ms转换成时钟节拍
wait_tick = timeout / (1000 / TOS_CFG_CPU_TICK_PER_SECOND); wait_tick = timeout / (1000 / TOS_CFG_CPU_TICK_PER_SECOND);
if (wait_tick == 0) { if (wait_tick == 0) {
wait_tick = 1; wait_tick = 1;
} }
} else { // һֱ<EFBFBD><EFBFBD><EFBFBD><EFBFBD> } else { // 一直阻塞
wait_tick = TOS_TIME_FOREVER; wait_tick = TOS_TIME_FOREVER;
} }
// <EFBFBD>ȴ<EFBFBD><EFBFBD>ɹ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ȴ<EFBFBD><EFBFBD><EFBFBD>ʱ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͱ<EFBFBD>ʾ<EFBFBD>ȴ<EFBFBD><EFBFBD><EFBFBD>ʱ // 等待成功,计算等待的时间,否则就表示等待超时
if (tos_msg_q_pend(q,&(*msg), wait_tick) == K_ERR_NONE) { if (tos_msg_q_pend(q,&(*msg), wait_tick) == K_ERR_NONE) {
return ((sys_now() - start_tick) * (1000 / TOS_CFG_CPU_TICK_PER_SECOND)); return ((sys_now() - start_tick) * (1000 / TOS_CFG_CPU_TICK_PER_SECOND));
} }