LiteOS-任务篇-源码分析-删除任务函数
前言
- 20201009
- LiteOS 2018
- 需要会通用链表
笔录草稿
源码分析
LOS_TaskDelete函数源码分析
完整源码
- 进入处理前,需要进入任务临界
- 通过任务ID来获取任务句柄
- 根据各种状态进行处理
- 处于 OS_TASK_STATUS_UNUSED (未使用) 状态
- 退出
- 处于 OS_TASK_STATUS_RUNNING (运行态) 且调度被锁定了
- 解锁任务调度
- 处于 就绪态 或 阻塞态 或 阻塞队列态
- 处于 OS_TASK_STATUS_READY (就绪态)
- 从就绪列表中删除该节点
- 取消该任务的就绪态
- 处于 OS_TASK_STATUS_PEND(阻塞态) 或 OS_TASK_STATUS_PEND_QUEUE(阻塞队列态)
- 从就绪列表中删除该节点
- 处于 OS_TASK_STATUS_READY (就绪态)
- 处于 OS_TASK_STATUS_DELAY (延时态)或 OS_TASK_STATUS_TIMEOUT(超时态)
- 从时间列表中删除该任务
- 处于 OS_TASK_STATUS_UNUSED (未使用) 状态
- 被删除的任务需要做一些复位处理
- 初始化任务状态
- 初始化任务事件相关的一些变量
- 被删除的任务s是否处于运行态
- 是
- 不能完全删除该任务,因为,调度过程中需要该任务参与
- 把当前任务插入到回收列表中,待运行创建任务函数时在进行回收处理。(其它RTOS都是在空闲任务中处理)
- 把当前任务(被删除的任务)copy到最低优先级的任务中,即是比空闲任务还低一个优先级的备用任务中,被赋给 g_stLosTask.pstRunTask,用于下main调度使用
- 解锁中断
- 调度
- 否
- 标记为未使用状态
- 直接放到空闲列表中
- 释放任务堆空间
- 初始化栈顶指针
- 是
- 解锁中断
/*****************************************************************************
Function : LOS_TaskDelete
Description : Delete a task
Input : uwTaskID --- Task ID
Output : None
Return : LOS_OK on success or error code on failure
*****************************************************************************/
LITE_OS_SEC_TEXT_INIT UINT32 LOS_TaskDelete(UINT32 uwTaskID)
{
UINTPTR uvIntSave;
LOS_TASK_CB *pstTaskCB;
UINT16 usTempStatus;
UINT32 uwErrRet = OS_ERROR;
CHECK_TASKID(uwTaskID); // 检查任务 ID
uvIntSave = LOS_IntLock(); // 锁中断
pstTaskCB = OS_TCB_FROM_TID(uwTaskID); // 通过任务 ID 获取任务控制块句柄
usTempStatus = pstTaskCB->usTaskStatus; // 获取任务状态
/* 判断任务状态是否处于 UNUSED (即未被创建) 状态,若是则退出*/
if (OS_TASK_STATUS_UNUSED & usTempStatus)
{
uwErrRet = LOS_ERRNO_TSK_NOT_CREATED;
OS_GOTO_ERREND();
}
/* If the task is running and scheduler is locked then you can not delete it */
if ((OS_TASK_STATUS_RUNNING & usTempStatus) && (g_usLosTaskLock != 0))
{
PRINT_INFO("In case of task lock, task deletion is not recommended\n");
g_usLosTaskLock = 0;
}
/* 判断任务状态是否处于 READY (即就绪态) 状态*/
if (OS_TASK_STATUS_READY & usTempStatus) // 处于就绪态
{
osPriqueueDequeue(&pstTaskCB->stPendList); // 从对应链表中删除该任务节点
pstTaskCB->usTaskStatus &= (~OS_TASK_STATUS_READY); // 取消就绪态
}
else if ((OS_TASK_STATUS_PEND & usTempStatus) || (OS_TASK_STATUS_PEND_QUEUE & usTempStatus)) // 处于阻塞态
{
LOS_ListDelete(&pstTaskCB->stPendList); // 从对应链表中删除该任务节点
}
if ((OS_TASK_STATUS_DELAY | OS_TASK_STATUS_TIMEOUT) & usTempStatus) // 处于任务延时会或超时状态
{
osTimerListDelete(pstTaskCB); // 从对应链表中删除该任务节点
}
pstTaskCB->usTaskStatus &= (~(OS_TASK_STATUS_SUSPEND)); // 取消挂起态
pstTaskCB->usTaskStatus |= OS_TASK_STATUS_UNUSED; // 标为未使用状态
pstTaskCB->uwEvent.uwEventID = 0xFFFFFFFF; // 复位时间ID
pstTaskCB->uwEventMask = 0;
#if (LOSCFG_BASE_CORE_CPUP == YES)
(VOID)memset((VOID *)&g_pstCpup[pstTaskCB->uwTaskID], 0, sizeof(OS_CPUP_S));
#endif
g_stLosTask.pstNewTask = LOS_DL_LIST_ENTRY(osPriqueueTop(), LOS_TASK_CB, stPendList); /*lint !e413*/ // 在就绪列表中寻找最高优先级的任务,标为下一个需要运行的任务
if (OS_TASK_STATUS_RUNNING & pstTaskCB->usTaskStatus) // 如果被删除的任务为运行态
{
/*
* 如果删除的任务为运行态时,就不能完全删除该任务,因为,调度过程中需要当前任务参与。
* 需要把当前任务插入到回收列表中,待运行创建任务函数时在进行回收处理。(其它RTOS都是在空闲任务中处理)
*/
LOS_ListTailInsert(&g_stTskRecyleList, &pstTaskCB->stPendList); // 把该任务插入回收列表
g_stLosTask.pstRunTask = &g_pstTaskCBArray[g_uwTskMaxNum];
g_stLosTask.pstRunTask->uwTaskID = uwTaskID;
g_stLosTask.pstRunTask->usTaskStatus = pstTaskCB->usTaskStatus;
g_stLosTask.pstRunTask->uwTopOfStack = pstTaskCB->uwTopOfStack;
g_stLosTask.pstRunTask->pcTaskName = pstTaskCB->pcTaskName;
pstTaskCB->usTaskStatus = OS_TASK_STATUS_UNUSED;
(VOID)LOS_IntRestore(uvIntSave); // 解锁中断
osSchedule(); // 调度
return LOS_OK;
}
else // 如果不为运行态
{
pstTaskCB->usTaskStatus = OS_TASK_STATUS_UNUSED; // 标为未使用
LOS_ListAdd(&g_stLosFreeTask, &pstTaskCB->stPendList); // 插入到可用列表
(VOID)LOS_MemFree(m_aucSysMem0, (VOID *)pstTaskCB->uwTopOfStack); // 释放任务堆空间内存
pstTaskCB->uwTopOfStack = (UINT32)NULL; // 标记栈顶为空
}
(VOID)LOS_IntRestore(uvIntSave); // 解锁中断
return LOS_OK;
LOS_ERREND: // 错误
(VOID)LOS_IntRestore(uvIntSave);
return uwErrRet;
}
参考
链接
- LiteOS源码链接
- 常见问题
- 华为开发者社区
- 华为LiteOS官方教程
- 我的源码
- 包含 裸机源码
- LiteOS 工程模板
- 其它关于 LiteOS 的 demo 及 note
LiteOS-任务篇-源码分析-删除任务函数的更多相关文章
- 【LiteOS】LiteOS任务篇-源码分析-创建任务函数
目录 前言 链接 参考 笔录草稿 部分源码分析 源码分析 LOS_TaskCreate函数 LOS_TaskCreateOnly函数 宏 OS_TCB_FROM_PENDLIST 和 宏 LOS_DL ...
- LiteOS-任务篇-源码分析-系统启动函数
目录 前言 链接 参考 开启调度 LOS_Start 函数源码 osTickStart 函数源码 LOS_StartToRun 函数源码 前言 20201009 移植好内核后,开始实战内核. 源码分析 ...
- LiteOS-任务篇-源码分析-任务调度函数
目录 前言 笔录草稿 核心源码分析 osTaskSchedule函数源码分析 osPendSV函数源码分析 TaskSwitch函数源码分析 调度上层源码分析 osSchedule函数源码分析 LOS ...
- SequoiaDB 系列之五 :源码分析之main函数
好久好久没有写博客了,因为一直要做各种事,工作上的,生活上的,这一下就是半年. 时光如梭. 这两天回头看了看写的博客,感觉都是贻笑大方. 但是还是想坚持把SequoiaDB系列写完. 初步的打算已经确 ...
- jQuery 源码分析(五) map函数 $.map和$.fn.map函数 详解
$.map() 函数用于使用指定函数处理数组中的每个元素(或对象的每个属性),并将处理结果封装为新的数组返回,该函数有三个参数,如下: elems Array/Object类型 指定的需要处理的数组或 ...
- jQuery 源码分析(四) each函数 $.each和$.fn.each方法 详解
$.each一般用来遍历一个数组或对象,$.fn.each()就是指jQuery实例可以执行的操作(因为$.fn是jQuery对象的原型) $.each用来遍历一个数组或对象,并依次执行回掉函数,最后 ...
- twemproxy源码分析1——入口函数及启动过程
最近工作中需要写一个一致性哈希的代理,在网上找到了twemproxy,结合网上资料先学习一下源码. 一.Twemproxy简介 Twemproxy是memcache与redis的代理,由twitter ...
- php源码分析之base64_encode函数
base64_encode编码规律分析 字符串长度除以3向上取整乘以4等于编码后的字符串长度 ceil(strlen($string)/3)*4 = strlen(base64_encode($str ...
- MySQL源码分析之SQL函数执行
1.MySQL中执行一条SQL的总体流程 2.SQL函数执行过程 1.MySQL中执行一条SQL的总体流程 一条包含函数的SQL语句,在mysql中会经过: 客户端发送,服务器连接,语法解析,语句执行 ...
随机推荐
- WebStorm 运行Rect Native 项目
今天教大家如何直接使用WebStorm这个IDE直接完成编码+运行项目工作.这样就可以不用打开Xcode了. 1.首先点击WebStorm右上方的下拉箭头弹出的Edit Configurations. ...
- 面试【JAVA基础】集合类
1.ArrayList的扩容机制 每次扩容是原来容量的1.5倍,通过移位的方法实现. 使用copyOf的方式进行扩容. 扩容算法是首先获取到扩容前容器的大小.然后通过oldCapacity (oldC ...
- Activiti7 任务人员动态分配(UEL-Value方式)
先修改流程图 测试之前记得先删除之前发布的流程定义,并重新发布改过的 /** * 使用UEL-Value动态分配任务人员 */ @Test public void uelValue(){ // 获取R ...
- tomcat-8.0.18 cluster 使用Redis共享Session 配置
事实证明 这位作者提在https://jingyan.baidu.com/article/ac6a9a5e10415f2b653eace8.html 最底下的http://pan.baidu.com/ ...
- hadoop不能互相访问和linux防火墙守护进程
前言——作为装过几次集群的菜鸟,对于hadoop集群的安装还是比较有心得的:只要配置文件够好,集群配置就非常容易,否则也容易出现莫名其妙的问题!总结了一份3台机器搭建较完好的集群的一份配置文件. 在我 ...
- leetcode刷题-43字符串相乘
题目 给定两个以字符串形式表示的非负整数 num1 和 num2,返回 num1 和 num2 的乘积,它们的乘积也表示为字符串形式. 思路 字符串转数字:从字符串第一位开始取,每次取出的值转换为数字 ...
- composer 国内镜像
本文列举一些最常用的国内镜像,配置国内镜像后可以提高composer包的下载速度.使用阿里云镜像的开发者较多,我也一直在使用这个镜像. 1. composer 中文网提供的中国全量镜像 https:/ ...
- path.resolve和path.join的区别
// test.js const path = require('path') let x1 = path.resolve('/目录1/目录2', '/目录3/目录4/') let x2 = path ...
- 【LeetCode/LintCode】丨Google面试题:N皇后问题
n皇后问题是将n个皇后放置在n*n的棋盘上,皇后彼此之间不能相互攻击(任意两个皇后不能位于同一行,同一列,同一斜线). 给定一个整数n,返回所有不同的n皇后问题的解决方案. 每个解决方案包含一个明确的 ...
- Spring使用@Async实现异步
使用场景 在实际项目中,一个接口如果需要处理很多数据,如果是同步执行,通过网络请求接口可能会出现请求超时.这时候就需要使用异步执行处理了. 使用经验 代码 异步服务类 @Service // Spri ...