`
phinecos
  • 浏览: 342407 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

uC/OS-II源码分析(二)

 
阅读更多
在真正开始分析源代码前,先来看使用uC/OS-II三个例子

1)使用信号量

<!--<br /> <br /> Code highlighting produced by Actipro CodeHighlighter (freeware)<br /> http://www.CodeHighlighter.com/<br /> <br /> -->#defineTASK_STK_SIZE512/*每个任务堆栈的大小(以字计算)*/
#defineN_TASKS10/*任务数*/

OS_STKTaskStk[N_TASKS][TASK_STK_SIZE];
/*任务堆栈*/
OS_STKTaskStartStk[TASK_STK_SIZE];
//开始任务的堆栈
charTaskData[N_TASKS];/*传给每个任务的数据*/
OS_EVENT
*RandomSem;//互斥型信号量

voidmain(void)
{
PC_DispClrScr(DISP_FGND_WHITE
+DISP_BGND_BLACK);/*清空屏幕*/

OSInit();
/*初始化uC/OS-II*/

PC_DOSSaveReturn();
/*保存环境以便稍后可以返回DOS环境*/
PC_VectSet(uCOS,OSCtxSw);
/*设置uC/OS-II的切换处理函数*/
RandomSem
=OSSemCreate(1);/*建立一个信号量*/
OSTaskCreate(TaskStart,(
void*)0,&TaskStartStk[TASK_STK_SIZE-1],0);//创建第一个任务,优先级设置为最大值
OSStart();/*开始多任务*/
}
voidTaskStart(void*pdata)
{
#ifOS_CRITICAL_METHOD==3/*为CPU的状态寄存器分配内存*/
OS_CPU_SRcpu_sr;
#endif
chars[100];
INT16Skey;
pdata
=pdata;/*这步是为了防止编译错误*/
TaskStartDispInit();
/*初始化显示屏*/
OS_ENTER_CRITICAL();
PC_VectSet(
0x08,OSTickISR);/*替换机器的时钟中断函数为uC/OS-II所需要的中断函数*/
PC_SetTickRate(OS_TICKS_PER_SEC);
/*调整时钟频率*/
OS_EXIT_CRITICAL();
OSStatInit();
/*初始化统计任务*/
TaskStartCreateTasks();
/*创建其他任务*/
for(;;){
TaskStartDisp();


if(PC_GetKey(&key)==TRUE){/*是否按键*/
if(key==0x1B){/*ESCAPE按下了*/
PC_DOSReturn();
/*返回DOS*/
}
}

OSCtxSwCtr
=0;/*切换次数计数器清零*/
OSTimeDlyHMSM(
0,0,1,0);/*挂起秒,让给其他任务运行*/
}
}
staticvoidTaskStartCreateTasks(void)
{
INT8Ui;
for(i=0;i<N_TASKS;i++){/*创建N_TASKS个任务*/
TaskData[i]
='0'+i;/*每个任务显示其数据*/
OSTaskCreate(Task,(
void*)&TaskData[i],&TaskStk[i][TASK_STK_SIZE-1],i+1);
}
}

voidTask(void*pdata)
{
INT8Ux;
INT8Uy;
INT8Uerr;
for(;;){
OSSemPend(RandomSem,
0,&err);/*获取信号量*/
x
=random(80);/*计算X坐标*/
y
=random(16);/*计算Y坐标*/
OSSemPost(RandomSem);
/*释放信号量*/
/*Displaythetasknumberonthescreen*/
PC_DispChar(x,y
+5,*(char*)pdata,DISP_FGND_BLACK+DISP_BGND_LIGHT_GRAY);
OSTimeDly(
1);/*挂起秒,让给其他任务运行*/
}
}
2007112201.jpg

2)使用消息邮箱

<!--<br /> <br /> Code highlighting produced by Actipro CodeHighlighter (freeware)<br /> http://www.CodeHighlighter.com/<br /> <br /> -->
#defineTASK_STK_SIZE512
#defineTASK_START_ID0/*任务ID*/
#defineTASK_CLK_ID1
#defineTASK_1_ID2
#defineTASK_2_ID3
#defineTASK_3_ID4
#defineTASK_4_ID5
#defineTASK_5_ID6

#defineTASK_START_PRIO10/*任务优先级*/
#defineTASK_CLK_PRIO11
#defineTASK_1_PRIO12
#defineTASK_2_PRIO13
#defineTASK_3_PRIO14
#defineTASK_4_PRIO15
#defineTASK_5_PRIO16
OS_STKTaskStartStk[TASK_STK_SIZE];
OS_STKTaskClkStk[TASK_STK_SIZE];
OS_STKTask1Stk[TASK_STK_SIZE];
OS_STKTask2Stk[TASK_STK_SIZE];
OS_STKTask3Stk[TASK_STK_SIZE];
OS_STKTask4Stk[TASK_STK_SIZE];
OS_STKTask5Stk[TASK_STK_SIZE];
OS_EVENT
*AckMbox;/*任务和使用的消息邮箱*/
OS_EVENT
*TxMbox;

voidmain(void)
{
OS_STK
*ptos;
OS_STK
*pbos;
INT32Usize;
PC_DispClrScr(DISP_FGND_WHITE);
OSInit();
PC_DOSSaveReturn();
PC_VectSet(uCOS,OSCtxSw);
PC_ElapsedInit();
ptos
=&TaskStartStk[TASK_STK_SIZE-1];
pbos
=&TaskStartStk[0];
size
=TASK_STK_SIZE;
OSTaskStkInit_FPE_x86(
&ptos,&pbos,&size);
OSTaskCreateExt(TaskStart,
(
void*)0,
ptos,
TASK_START_PRIO,
TASK_START_ID,
pbos,
size,
(
void*)0,
OS_TASK_OPT_STK_CHK
|OS_TASK_OPT_STK_CLR);
OSStart();
}
voidTaskStart(void*pdata)
{
#ifOS_CRITICAL_METHOD==3
OS_CPU_SRcpu_sr;
#endif
INT16Skey;
pdata
=pdata;
TaskStartDispInit();
OS_ENTER_CRITICAL();
PC_VectSet(
0x08,OSTickISR);
PC_SetTickRate(OS_TICKS_PER_SEC);
OS_EXIT_CRITICAL();
OSStatInit();
AckMbox
=OSMboxCreate((void*)0);/*创建两个消息邮箱*/
TxMbox
=OSMboxCreate((void*)0);
TaskStartCreateTasks();
for(;;){
TaskStartDisp();

if(PC_GetKey(&key)){
if(key==0x1B){
PC_DOSReturn();
}
}
OSCtxSwCtr
=0;
OSTimeDly(OS_TICKS_PER_SEC);
}
}
voidTask1(void*pdata)
{
INT8Uerr;
OS_STK_DATAdata;
/*任务堆栈数据*/
INT16Utime;
INT8Ui;
chars[80];
pdata
=pdata;
for(;;){
for(i=0;i<7;i++){
PC_ElapsedStart();
err
=OSTaskStkChk(TASK_START_PRIO+i,&data);//执行堆栈检查
time=PC_ElapsedStop();
if(err==OS_NO_ERR){
sprintf(s,
"%4ld%4ld%4ld%6d",
data.OSFree
+data.OSUsed,
data.OSFree,
data.OSUsed,
time);
PC_DispStr(
19,12+i,s,DISP_FGND_BLACK+DISP_BGND_LIGHT_GRAY);
}
}
OSTimeDlyHMSM(
0,0,0,100);/*挂起mS*/
}
}
voidTask4(void*data)
{
chartxmsg;
INT8Uerr;
data
=data;
txmsg
='A';
for(;;){
OSMboxPost(TxMbox,(
void*)&txmsg);/*发消息给Task#5*/
OSMboxPend(AckMbox,
0,&err);/*等待Task#5的应答消息*/
txmsg
++;/*下一个要发的消息数据*/
if(txmsg=='Z'){
txmsg
='A';/*循环发送A-Z*/
}
}
}
voidTask5(void*data)
{
char*rxmsg;
INT8Uerr;
data
=data;
for(;;){
rxmsg
=(char*)OSMboxPend(TxMbox,0,&err);/*等待来自Task#4的数据*/
PC_DispChar(
70,18,*rxmsg,DISP_FGND_YELLOW+DISP_BGND_BLUE);
OSTimeDlyHMSM(
0,0,1,0);/*挂起秒,让给其他任务运行*/
OSMboxPost(AckMbox,(
void*)1);/*发送接收到数据的应答消息*/
}
}

运行结果:

2007112202.jpg

3)使用消息队列

<!--<br /> <br /> Code highlighting produced by Actipro CodeHighlighter (freeware)<br /> http://www.CodeHighlighter.com/<br /> <br /> -->#defineTASK_STK_SIZE512
#defineTASK_START_ID0
#defineTASK_CLK_ID1
#defineTASK_1_ID2
#defineTASK_2_ID3
#defineTASK_3_ID4
#defineTASK_4_ID5
#defineTASK_5_ID6
#defineTASK_START_PRIO10
#defineTASK_CLK_PRIO11
#defineTASK_1_PRIO12
#defineTASK_2_PRIO13
#defineTASK_3_PRIO14
#defineTASK_4_PRIO15
#defineTASK_5_PRIO16
#defineMSG_QUEUE_SIZE20/*消息队列大小*/
typedef
struct{
charTaskName[30];
INT16UTaskCtr;
INT16UTaskExecTime;
INT32UTaskTotExecTime;
}TASK_USER_DATA;
OS_STKTaskStartStk[TASK_STK_SIZE];
OS_STKTaskClkStk[TASK_STK_SIZE];
OS_STKTask1Stk[TASK_STK_SIZE];
OS_STKTask2Stk[TASK_STK_SIZE];
OS_STKTask3Stk[TASK_STK_SIZE];
OS_STKTask4Stk[TASK_STK_SIZE];
OS_STKTask5Stk[TASK_STK_SIZE];
TASK_USER_DATATaskUserData[
7];
OS_EVENT
*MsgQueue;/*消息队列指针*/
void*MsgQueueTbl[20];/*消息存储*/
voidmain(void)
{
PC_DispClrScr(DISP_BGND_BLACK);
OSInit();
PC_DOSSaveReturn();
PC_VectSet(uCOS,OSCtxSw);
PC_ElapsedInit();
strcpy(TaskUserData[TASK_START_ID].TaskName,
"StartTask");
OSTaskCreateExt(TaskStart,
(
void*)0,
&TaskStartStk[TASK_STK_SIZE-1],
TASK_START_PRIO,
TASK_START_ID,
&TaskStartStk[0],
TASK_STK_SIZE,
&TaskUserData[TASK_START_ID],
0);
OSStart();
}
voidTaskStart(void*pdata)
{
#ifOS_CRITICAL_METHOD==3
OS_CPU_SRcpu_sr;
#endif
INT16Skey;
pdata
=pdata;
TaskStartDispInit();
OS_ENTER_CRITICAL();
PC_VectSet(
0x08,OSTickISR);
PC_SetTickRate(OS_TICKS_PER_SEC);
OS_EXIT_CRITICAL();
OSStatInit();
MsgQueue
=OSQCreate(&MsgQueueTbl[0],MSG_QUEUE_SIZE);/*创建消息队列,大小为*/
TaskStartCreateTasks();
for(;;){
TaskStartDisp();
if(PC_GetKey(&key)){
if(key==0x1B){
PC_DOSReturn();
}
}
OSCtxSwCtr
=0;
OSTimeDly(OS_TICKS_PER_SEC);
}
}
voidTask1(void*pdata)
{
char*msg;
INT8Uerr;
pdata
=pdata;
for(;;){
msg
=(char*)OSQPend(MsgQueue,0,&err);//从消息队列中取消息
PC_DispStr(70,13,msg,DISP_FGND_YELLOW+DISP_BGND_BLUE);
OSTimeDlyHMSM(
0,0,0,100);
}
}
voidTask2(void*pdata)
{
charmsg[20];
pdata
=pdata;
strcpy(
&msg[0],"Task2");
for(;;){
OSQPost(MsgQueue,(
void*)&msg[0]);//发送消息到队列中
OSTimeDlyHMSM(0,0,0,500);
}
}
voidTask3(void*pdata)
{
charmsg[20];
pdata
=pdata;
strcpy(
&msg[0],"Task3");
for(;;){
OSQPost(MsgQueue,(
void*)&msg[0]);//发送消息到队列中
OSTimeDlyHMSM(0,0,0,500);
}
}
voidTask4(void*pdata)
{
charmsg[20];
pdata
=pdata;
strcpy(
&msg[0],"Task4");
for(;;){
OSQPost(MsgQueue,(
void*)&msg[0]);//发送消息到队列中
OSTimeDlyHMSM(0,0,0,500);
}
}
voidOSTaskStatHook(void)
{
chars[80];
INT8Ui;
INT32Utotal;
INT8Upct;
total
=0L;/*TotalizeTOT.EXEC.TIMEforeachtask
for(i=0;i<7;i++){
total+=TaskUserData[i].TaskTotExecTime;
DispTaskStat(i);/*Displaytaskdata
}
if(total>0){
for(i=0;i<7;i++){/*Derivepercentageofeachtask
*/
pct
=100*TaskUserData[i].TaskTotExecTime/total;
sprintf(s,
"%3d%%",pct);
PC_DispStr(
62,i+11,s,DISP_FGND_BLACK+DISP_BGND_LIGHT_GRAY);
}
}
if(total>1000000000L){/*Resettotaltimecountersat1billion
for(i=0;i<7;i++){
TaskUserData[i].TaskTotExecTime=0L;
}
}
}

voidOSTaskSwHook(void)
{
INT16Utime;
TASK_USER_DATA*puser;
time=PC_ElapsedStop();/*Thistaskisdone
PC_ElapsedStart();/*Startfornexttask
puser=OSTCBCur->OSTCBExtPtr;/*Pointtouseddata
if(puser!=(TASK_USER_DATA*)0){
puser->TaskCtr++;/*Incrementtaskcounter
puser->TaskExecTime=time;/*Updatethetask'sexecutiontime
puser->TaskTotExecTime+=time;/*Updatethetask'stotalexecutiontime
}
}

运行结果:

2007112204.jpg
分享到:
评论

相关推荐

    uC/OS-II源码分析

    首先从main函数开始,下面是uC/OS-II main函数的大致流程: main() { OSInit(); TaskCreate(...); OSStart(); } 首先是调用OSInit进行初始化,然后使用TaskCreate创建几个进程/Task,最后调用OSStart,操作系统就...

    UC/OS-II运行全过程解析

    通过分析uC/OS-II的源码,详细阐述了开发板上电后uC/OS-II启动运行的整个过程,每个源码后面都有详细的注释,以及在任务运行过程中所起的作用,是新手学习uC/OS-II系统的好资料。

    嵌入式实时操作系统μC\OS-Ⅱ(第2版) pdf part1(共3 parts)

    μC/OSII是著名的、源码公开的实时内核,是专为嵌入式应用设计的,可用于各类8位、16位和32位单片机或DSP。从μC/OS算起,该内核已有10余年应用史,在诸多领域得到了广泛应用.本书是MicroC/OSII The Real Time ...

    uCOS-II源码分析

    本文从uC/OS-II main函数的大致流程,开始分析uC/OS-II的工作原理,讲解的很透彻,很明了,是学习uC/OS-II不可不看的一篇文章

    嵌入式系统/ARM技术中的分析M16C62在uC/OS-II嵌入式系统中的应用

    Ⅱ是一个源码公开的实时嵌入式操作系统,它的特点在于公开的源代码,很强的移植性,占先式多任务,每个任务有单独的栈,中断管理及很强的稳定性与可靠性等,目前越来越受到实时嵌入式系统设计者的关注,本文详细讲述...

    分析M16C62在uC/OS-II嵌入式系统中的应用

    Ⅱ是一个源码公开的实时嵌入式操作系统,它的特点在于公开的源代码,很强的移植性,占先式多任务,每个任务有单独的栈,中断管理及很强的稳定性与可靠性等,目前越来越受到实时嵌入式系统设计者的关注,本文详细讲述...

    嵌入式实时操作系统.part3.rar

    uC/OS-II是著名的、源码公开的实时内核,是专为嵌人式应用设计的,可用于各类8位,16位和32位单片机或D5P。从uC/OS算起,该内核已有10余年应用史,在诸多领域得到了广泛应用。 本书是MicrouC/OS一II The Real Time ...

    嵌入式实时操作系统.part1.rar

    uC/OS-II是著名的、源码公开的实时内核,是专为嵌人式应用设计的,可用于各类8位,16位和32位单片机或D5P。从uC/OS算起,该内核已有10余年应用史,在诸多领域得到了广泛应用。 本书是MicrouC/OS一II The Real Time ...

    嵌入式实时操作系统.part2.rar

    uC/OS-II是著名的、源码公开的实时内核,是专为嵌人式应用设计的,可用于各类8位,16位和32位单片机或D5P。从uC/OS算起,该内核已有10余年应用史,在诸多领域得到了广泛应用。 本书是MicrouC/OS一II The Real Time ...

    嵌入式实时操作系统.part4.rar

    uC/OS-II是著名的、源码公开的实时内核,是专为嵌人式应用设计的,可用于各类8位,16位和32位单片机或D5P。从uC/OS算起,该内核已有10余年应用史,在诸多领域得到了广泛应用。 本书是MicrouC/OS一II The Real Time ...

    嵌入式实时操作系统μCOS-II 第二版 邵贝贝译 PDF版.part2

    通过对μC/OSII源代码的分析与描述,讲述了多任务实时的基本概念、竞争与调度算法、任务间同步与通信、存储与定时的管理以及如何处理优先级反转问题;介绍如何将μC/OSII移植到不同CPU上,如何调试移植代码。在所附...

    嵌入式系统/ARM技术中的UC/OS 在TMS320C6711 DSP上的移植过程

     μC/OS-II是一个基于抢占式的实时多任务内核,可固化、可剪裁、具有高稳定性和可靠性,除此以外,μC/OS-II的鲜明特点就是源码公开,便于移植和维护。 在μC/OS-II官方的主页上可以查找到一个比较全面的移植范例...

    嵌入式实时操作系统μCOS-II 第二版 邵贝贝译.part1

    通过对μC/OSII源代码的分析与描述,讲述了多任务实时的基本概念、竞争与调度算法、任务间同步与通信、存储与定时的管理以及如何处理优先级反转问题;介绍如何将μC/OSII移植到不同CPU上,如何调试移植代码。在所附...

    嵌入式实时操作系统μCOS-II 第二版 邵贝贝译 PDF版.part3

    通过对μC/OSII源代码的分析与描述,讲述了多任务实时的基本概念、竞争与调度算法、任务间同步与通信、存储与定时的管理以及如何处理优先级反转问题;介绍如何将μC/OSII移植到不同CPU上,如何调试移植代码。在所附...

    uC/GUI实现WP界面、 UC/GUI移植源码分享-电路方案

    运用uC/OS-II实现任务的管理,简化程序结构。在此基础之上,你可以实现你想要的功能。像MP3播放器,图片浏览器,示波器,频谱分析仪WP界面等。只有你想不到的没有做不到的,并且你的设备将具备惊艳的UI界面(当然是...

    《嵌入式实时操作系统--邵贝贝译》(第二版 光盘资料)

    通过对μC/OSII源代码的分析与描述,讲述了多任务实时的基本概念、竞争与调度算法、任务间同步与通信、存储与定时的管理以及如何处理优先级反转问题;介绍如何将μC/OSII移植到不同CPU上,如何调试移植代码。在所附...

    任哲uCOS-II 书中 源代码

    │ 2-10源码改进&现象分析.txt │ TEST.C │ TEST.EXE │ ├─2-11 │ 2-11截图.bmp │ Test.c │ TEST.EXE │ ├─3-1 │ 3-1完整文件包.rar │ 3-1截图.bmp │ 3-1最小文件集.rar │ 3-1现象完整分析.txt │ EXP...

    c语言编写单片机技巧

    Transform)、频谱分析、图像处理的分析等领域,DSP正在大量进入嵌入式市场。 18. MCU在射频控制时,MCU的时钟(晶振)、数据线会辐射基频或基频的倍频,被低噪放LNA放大后进入混频,出现带内的Spur,无法滤除...

Global site tag (gtag.js) - Google Analytics