Raw-OS源代码分析之任务删除与总结
分析的内核版本号截止到2014-04-15,基于1.05正式版,blogs会及时跟进最新版本号的内核开发进度,若源代码凝视出现”???”字样,则是未深究理解部分。
Raw-OS官方站点:http://www.raw-os.org/
Raw-OS托管地址:https://github.com/jorya/raw-os/
那么。先给出总结的Raw-OS的任务状态转换图,这个图出自:
http://blog.csdn.net/shengnan_wu/article/details/8536030
那么。这个状态图都能够出现RAW_DELETE的状态重点。那么相应的就是任务删除,对于删除任务也有一些限制使用方法。详细看代码里面的凝视
RAW_U16 raw_task_delete(RAW_TASK_OBJ *task_ptr)
{
RAW_SR_ALLOC(); #if (RAW_TASK_FUNCTION_CHECK > 0)
/* 选择被删除的任务TCB不存在,返回 */
if (task_ptr == 0) {
return RAW_NULL_OBJECT;
} /* 中断中不同意删除任务 */
if (raw_int_nesting) {
return RAW_NOT_CALLED_BY_ISR;
}
#endif /* IDLE任务不同意删除 */
if (task_ptr->priority == IDLE_PRIORITY) {
return RAW_DELETE_TASK_NOT_ALLOWED;
} #if (CONFIG_RAW_TASK_0 > 0)
/* 假设开启task 0宏例化task 0后。task 0不同意删除 */
if (task_ptr->priority == 0) {
return RAW_DELETE_TASK_NOT_ALLOWED;
}
#endif /* 给系统上锁一次。系统锁标志变量+1 */
RAW_CRITICAL_ENTER();
/*
* 这里检查系统锁标志变量是否只由上一个语句产生一个叠加操作,假设锁标志位>=2
* 说明在这里之前,其它位置已经发生了系统上锁操作,所以这里解除前一语句的上锁操作。返回
*/
if (task_ptr == raw_task_active) {
SYSTEM_LOCK_PROCESS();
} /* 释放任务控制块内的相互排斥锁。Raw-OS设计的任务内有任务相互排斥锁,这里要释放,对于相互排斥锁。兴许blog分析 */
#if (CONFIG_RAW_MUTEX > 0)
raw_task_free_mutex(task_ptr);
#endif
/* 检查被删除任务的任务状态,运行对应操作 */
switch (task_ptr->task_state) {
/* 就绪态 */
case RAW_RDY:
/* 从就绪队列中移除 */
remove_ready_list(&raw_ready_queue, task_ptr);
break;
/* 挂起态。不存在就绪队列,能够直接删除 */
case RAW_SUSPENDED:
break;
/* 假设任务处于等待超时的tick list中,从tick list中移除 */
case RAW_DLY:
case RAW_DLY_SUSPENDED:
tick_list_remove(task_ptr);
break;
/* 这里是任务堵塞状态相关 */
case RAW_PEND:
case RAW_PEND_SUSPENDED:
case RAW_PEND_TIMEOUT:
case RAW_PEND_TIMEOUT_SUSPENDED:
/* 从tick list移除堵塞任务 */
tick_list_remove(task_ptr);
/* 这里还要list delete???难道堵塞态还存在别的链表中??? */
list_delete(&task_ptr->task_list);
/* 相互排斥锁相关。如今就当自己是刚開始学习的人,不懂何用??? */
#if (CONFIG_RAW_MUTEX > 0)
mutex_state_change(task_ptr);
#endif
break;
default:
RAW_CRITICAL_EXIT();
return RAW_STATE_UNKNOWN;
}
/* 任务状态设置为删除态 */
task_ptr->task_state = RAW_DELETED; /* 系统检測??? */
#if (RAW_SYSTEM_CHECK > 0)
/* make after_delete_list to right position??? */
system_debug.after_delete_list = task_ptr->stack_check_list.next; if (system_debug.after_delete_list == (&(system_debug.task_head))) {
system_debug.after_delete_list = system_debug.task_head.next;
} list_delete(&task_ptr->stack_check_list);
#endif
/* 将之前上锁操作释放 */
RAW_CRITICAL_EXIT();
/* 删除任务时的trace debug??? */
TRACE_TASK_DELETE(task_ptr);
/* 移植相关。调用删除任务时的钩子函数 */
#if (CONFIG_RAW_USER_HOOK > 0)
raw_task_delete_hook(task_ptr);
#endif
/* 删除任务后运行系统调度 */
raw_sched();
/* 保留一个疑问,例化任务的时候假设堆栈是静态分配,那么就浪费资源??? */
return RAW_SUCCESS;
}
Raw-OS源代码分析之任务删除与总结的更多相关文章
- Openck_Swift源代码分析——添加、删除设备时算法详细的实现过程
1 初始加入设备后.上传Object的详细流程 前几篇博客中,我们讲到环的基本原理即详细的实现过程,加入我们在初始创建Ring是执行例如以下几条命令: •swift-ring-builder obj ...
- STL源代码分析——STL算法remove删除算法
前言 因为在前文的<STL算法剖析>中,源代码剖析许多.不方便学习,也不方便以后复习,这里把这些算法进行归类.对他们单独的源代码剖析进行解说.本文介绍的STL算法中的remove删除算法. ...
- 转:RTMPDump源代码分析
0: 主要函数调用分析 rtmpdump 是一个用来处理 RTMP 流媒体的开源工具包,支持 rtmp://, rtmpt://, rtmpe://, rtmpte://, and rtmps://. ...
- Android系统匿名共享内存Ashmem(Anonymous Shared Memory)驱动程序源代码分析
文章转载至CSDN社区罗升阳的安卓之旅,原文地址:http://blog.csdn.net/luoshengyang/article/details/6664554 在上一文章Android系统匿名共 ...
- Android系统进程间通信(IPC)机制Binder中的Client获得Server远程接口过程源代码分析
文章转载至CSDN社区罗升阳的安卓之旅,原文地址:http://blog.csdn.net/luoshengyang/article/details/6633311 在上一篇文章中,我 们分析了And ...
- 【Android开源项目分析】android轻量级开源缓存框架——ASimpleCache(ACache)源代码分析
转载请注明出处:http://blog.csdn.net/zhoubin1992/article/details/46379055 ASimpleCache框架源代码链接 https://github ...
- Android异步任务处理框架AsyncTask源代码分析
[转载请注明出处:http://blog.csdn.net/feiduclear_up CSDN 废墟的树] 引言 在平时项目开发中难免会遇到异步耗时的任务(比方最常见的网络请求).遇到这样的问题.我 ...
- OpenStack_Swift源代码分析——Ring的rebalance算法源代码具体分析
1 Command类中的rebalnace方法 在上篇文章中解说了,创建Ring已经为Ring加入设备.在加入设备后须要对Ring进行平衡,平衡 swift-ring-builder object.b ...
- 转:SDL2源代码分析
1:初始化(SDL_Init()) SDL简介 有关SDL的简介在<最简单的视音频播放示例7:SDL2播放RGB/YUV>以及<最简单的视音频播放示例9:SDL2播放PCM>中 ...
随机推荐
- c 最简单的链表
#include <stdio.h> struct node { int data; struct node *next; //指向本身的指针 }; // main() { struct ...
- Bridge桥接模式(设计模式11)
在没有使用桥接模式: 扩展新问题(类归属膨胀问题) 1增加性的电脑类型,要增加每个品牌下面的类 2如果要增加一个新的电脑品牌,要增加美中电脑类型的类 违背单一职责原则: · 一个类:联想笔记本,有两个 ...
- DebugBar v7.0.2 注册码
blog.sina.com.cn/seoerx 14d4fb95f89bdd277fff0d20910be400 seoerx.diandian.com 505dc8424062f9895c2dd14 ...
- ASP.NET-js和C#混合编程的例子
使用<text>这个伪元素来强制Razor从编译模式返回到内容模式: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 ...
- 数据库中的java.sql.Timestamp转换成Date
查询数据库中的时间类型为 java.sql.Timestamp 保存在json中需要格式化 自定义工具类 DateJsonValueProcessor package com.rom.util; i ...
- leetcode第一刷_Add Binary
二进制相加,本质上就是大整数加法,有关大整数加法我的舍友教过我一个非常好的方法,先用一个int数组保存结果,将两个数相应位置相加,所有加完后.再统一处理进位的问题.这种方法相同适用于大整数的乘法. 这 ...
- bzoj4823: [Cqoi2017]老C的方块(最小割)
4823: [Cqoi2017]老C的方块 题目:传送门 题解: 毒瘤题ORZ.... 太菜了看出来是最小割啥边都不会建...狂%大佬强强强 黑白染色?不!是四个色一起染,四层图跑最小割... 很 ...
- iOS中respondsToSelector与conformsToProtocol的相关理解和使用
respondsToSelector相关的方法 : -(BOOL) isKindOfClass: classObj 用来判断是否是某个类或其子类的实例 -(BOOL) isMemberOfClass: ...
- 相辅相成的求最单源短路径算法:(SPFA& dijkstra)
引用一位老oier的话: 一道题如果边权没有负数,那么一定是在卡SPFA.这时候就用到了堆优化的Dijkstra; 写在前面: 多打代码! 最好都掌握,灵活变通 SPFA: 主要用于稀疏图和有负权边的 ...
- 15.boost最小生成树 prim_minimum_spanning_tree
#include <iostream> #include <boost/config.hpp> //图(矩阵实现) #include <boost/graph/adjac ...