一,UCOSII的定时中断

绝大多数的内核要求提供定时中断,以实现延时与超时控制等功能。这个定时中断叫做时钟节拍。时钟的中断子程序ISR和时钟节拍函数OSTimeTick()该函数通知UCOSII,发生了时钟节拍中断。

二,UCOSII系统时钟函数

1,任务延时函数, OSTimeDly(INT16U ticks)
实现申请该服务的任务可以延时一段时间这个系统服务的函数叫做 OSTimeDly(),这段时间的长短是用时钟节拍的数目来确定的。调用该函数会使µC/OS-Ⅱ进行一次任务调度,并且执行下一个优先级最高的就绪态任务。

void  OSTimeDly (INT32U ticks)
{INT8U      y;
#if OS_CRITICAL_METHOD == 3u  /* Allocate storage for CPU status register  */OS_CPU_SR  cpu_sr = 0u;
#endifif (OSIntNesting > 0u) {                     /* See if trying to call from an ISR */return;}if (OSLockNesting > 0u) {                    /* See if called with scheduler locked*/return;}if (ticks > 0u) {              /* 0 means no delay!  */OS_ENTER_CRITICAL();y  =  OSTCBCur->OSTCBY; /* Delay current task  */OSRdyTbl[y] &= (OS_PRIO)~OSTCBCur->OSTCBBitX;if (OSRdyTbl[y] == 0u) {OSRdyGrp &= (OS_PRIO)~OSTCBCur->OSTCBBitY;}OSTCBCur->OSTCBDly = ticks;  /* Load ticks in TCB */OS_EXIT_CRITICAL();OS_Sched();    /* Find next task to run! */}
}

(1)任务调用 OSTimeDly()后,一旦规定的时间期满或者有其它的任务通过调用 OSTimeDlyResume()取消了延时,它就会马上进入就绪状态。

(2)参数分析:ticks:代表的是多少个时钟周期节拍

(3)实现过程:
把相应任务的就绪表中的位图的位置清零。把需要执行的等待节拍进行处理。
最后进行任务调度,寻找下一个这个时刻最高优先级的任务。

(4)在OS_TCB的结构体当中的Ticks填写相应的数字的时候通过OSTimeTick()函数可以把任务从就绪态变为等待的状态

void  OSTimeTick (void)
{OS_TCB    *ptcb;if (OSRunning == OS_TRUE) {
#if OS_TICK_STEP_EN > 0uswitch (OSTickStepState) {                         /* Determine whether we need to process a tick  */case OS_TICK_STEP_DIS:                         /* Yes, stepping is disabled                    */step = OS_TRUE;break;case OS_TICK_STEP_WAIT:                        /* No,  waiting for uC/OS-View to set ...       */step = OS_FALSE;                          /*      .. OSTickStepState to OS_TICK_STEP_ONCE */break;case OS_TICK_STEP_ONCE:                        /* Yes, process tick once and wait for next ... */step            = OS_TRUE;                /*      ... step command from uC/OS-View        */OSTickStepState = OS_TICK_STEP_WAIT;break;default:                                       /* Invalid case, correct situation              */step            = OS_TRUE;OSTickStepState = OS_TICK_STEP_DIS;break;}if (step == OS_FALSE) {                            /* Return if waiting for step command           */return;}
#endif//此处为此任务运行的核心的代码:ptcb = OSTCBList;                                  /* Point at first TCB in TCB list               */while (ptcb->OSTCBPrio != OS_TASK_IDLE_PRIO) {     /* Go through all TCBs in TCB list              */OS_ENTER_CRITICAL();if (ptcb->OSTCBDly != 0u) {                    /* No, Delayed or waiting for event with TO     */ptcb->OSTCBDly--;                          /* Decrement nbr of ticks to end of delay       */if (ptcb->OSTCBDly == 0u) {                /* Check for timeout                            */if ((ptcb->OSTCBStat & OS_STAT_PEND_ANY) != OS_STAT_RDY) {ptcb->OSTCBStat  &= (INT8U)~(INT8U)OS_STAT_PEND_ANY;          /* Yes, Clear status flag   */ptcb->OSTCBStatPend = OS_STAT_PEND_TO;                 /* Indicate PEND timeout    */} else {ptcb->OSTCBStatPend = OS_STAT_PEND_OK;}if ((ptcb->OSTCBStat & OS_STAT_SUSPEND) == OS_STAT_RDY) {  /* Is task suspended?       */OSRdyGrp               |= ptcb->OSTCBBitY;             /* No,  Make ready          */OSRdyTbl[ptcb->OSTCBY] |= ptcb->OSTCBBitX;}}}ptcb = ptcb->OSTCBNext;                        /* Point at next TCB in TCB list                */OS_EXIT_CRITICAL();}}
}

2,按时分秒延时函数 OSTimeDlyHMSM( INT8U hours, INT8U minutes, INT8U seconds, INT16U milli):

调用 OSTimeDlyHMSM()函数也会使µC/OS-Ⅱ进行一次任务调度,并且执行下一个优先级最高的就绪态任务。任务调用 OSTimeDlyHMSM()后,一旦规定的时间期满或者有其它的任务通过调用 OSTimeDlyResume()取消了延时,它就会马上处于就绪态。只有当该任务在所有就绪态任务中具有最高的优先级时,它才会立即运行。若将时钟频率(OS_TICKS_PER_SEC)设置成 100Hz(10ms),4ms 的延时不会产生任何延时!而 5ms 的延时就等于延时 10ms。µC/OS-Ⅱ支持的延时最长为 65,535 个节拍。要想支持更长时间的延时,OSTimeDlyHMSM()确定了用户想延时多少次超过 65,535 个节拍的数目和剩下的节拍数,超过的节拍数会被分为几次去延时。由于OSTimeDlyHMSM()的具体实现方法,用户不能结束延时调用 OSTimeDlyHMSM()要求延时超过 65535 个节拍的任务。

3,恢复延时的任务:OSTimeDlyResume():把那个全局的时间计数器变量设置为0

INT8U  OSTimeDlyResume (INT8U prio)
{OS_TCB    *ptcb;if (prio >= OS_LOWEST_PRIO) {return (OS_ERR_PRIO_INVALID);}OS_ENTER_CRITICAL();ptcb = OSTCBPrioTbl[prio];                                 /* Make sure that task exist            */if (ptcb == (OS_TCB *)0) {OS_EXIT_CRITICAL();return (OS_ERR_TASK_NOT_EXIST);                        /* The task does not exist              */}if (ptcb == OS_TCB_RESERVED) {OS_EXIT_CRITICAL();return (OS_ERR_TASK_NOT_EXIST);                        /* The task does not exist              */}if (ptcb->OSTCBDly == 0u) {                                /* See if task is delayed               */OS_EXIT_CRITICAL();return (OS_ERR_TIME_NOT_DLY);                          /* Indicate that task was not delayed   */}ptcb->OSTCBDly = 0u;                                       /* 清除任务计数器       */if ((ptcb->OSTCBStat & OS_STAT_PEND_ANY) != OS_STAT_RDY) {ptcb->OSTCBStat     &= ~OS_STAT_PEND_ANY;              /* Yes, Clear status flag               */ptcb->OSTCBStatPend  =  OS_STAT_PEND_TO;               /* Indicate PEND timeout                */} else {ptcb->OSTCBStatPend  =  OS_STAT_PEND_OK;}if ((ptcb->OSTCBStat & OS_STAT_SUSPEND) == OS_STAT_RDY) {  /* Is task suspended?                   */OSRdyGrp               |= ptcb->OSTCBBitY;             /* No,  Make ready                      */OSRdyTbl[ptcb->OSTCBY] |= ptcb->OSTCBBitX;OS_EXIT_CRITICAL();OS_Sched();                                            /* See if this is new highest priority  */} else {OS_EXIT_CRITICAL();                                    /* Task may be suspended                */}return (OS_ERR_NONE);
}

4,让处在延时期的任务结束延时:OSTimeDlyResume( INT8U prio)
  延时的任务可以不等待延时期满,而是通过其它任务取消延时来使自己处于就绪态。实际上,OSTimeDlyResume()也可以唤醒正在等待事件。

5,系统时间, OSTimeGet()函数和 OSTimeSet()函数:在访问 OSTime 的时候中断是关掉的。这是因为在大多数 8 位处理器上增加和拷贝一个 32位的数都需要数条指令,这些指令一般都需要一次执行完毕,而不能被中断等因素打断。
无论时钟节拍何时发生, µCOSⅡ会将一个 32 位的计数器加 1。这个计数器在用户调用 OSStart()初始化多任务和 4,294,967,295 个节拍执行完一遍的时候从 0 开始计数。在时钟节拍的频率等于 100Hz 的时候,这个 32 位的计数器每隔 497 天就重新开始计数。

UCOSII系统时间管理相关推荐

  1. Linux_系统时间管理

    目录 目录 时间管理 date指令 系统时间设置timedatectl指令 本地时间同步 时间服务器NTP RHEL6 RHEL7 计划任务 一次性计划任务 at指令 限制用户建立一次性计划任务 周期 ...

  2. 嵌入式系统 - 时间管理

    教材:嵌入式系统及应用,罗蕾.李允.陈丽蓉等,电子工业出版社 嵌入式系统开发 时间管理 时间管理一般具有以下功能: 维持日历时间: 任务有限等待的计时: 软定时器的定时管理: 维持系统时间片轮转调度 ...

  3. linux日程管理系统,Linux系统时间管理

    一.时区配置 显示时区 [root@node2 ~]# date -R Mon, 19 Dec 2016 14:02:47 +0800 [root@node2 ~]# [root@node2 ~]# ...

  4. 企业生产过程中的日志和时间管理详解

    系统中的日志管理 1.什么时是系统日志? 系统日志是记录系统中硬件.软件和系统问题的信息,同时还可以监视系统中发生的事件.用户可以通过它来检查错误发生的原因,或者寻找受到攻击时攻击者留下的痕迹.系统日 ...

  5. Linux系统之时间管理

    Linux系统之时间管理 一.date命令介绍 1.date帮助 2.查询系统时间 ①查询电脑硬件时间 ②查询UTC时间 ③查询系统时间 ④特定时间格式输出系统时间 ⑤查询电脑所有时间信息 三.修改系 ...

  6. 基于Android的时间管理源码,基于安卓的手机时间管理APP系统

    随着生活环境节奏的加快,人们反而对时间的概念不强,对时间的有效利用率在降低,特别是对于自制能力差的人来说尤为严重,针对自制能力差的人,设计一款关于时间管理的手机APP是很有必要的,有利于合理有效的利用 ...

  7. 计算机网络时间校时,若当前系统时间与标准时间误差在( )分钟内,需进行校准。出处:《计算机化系统时钟校准管理规程》MS-E050。...

    若当前系统时间与标准时间误差在( )分钟内,需进行校准.出处:<计算机化系统时钟校准管理规程>MS-E050. 更多相关问题 发生人工费索赔时能按日计工费计算的是( ). 工业的飞速进步使 ...

  8. 13 freertos系统节拍和时间管理

    十三 FreeRTOS 的时间相关函数 FreeRTOS 时间相关的函数主要有以下 4 个: vTaskDelay () vTaskDelayUntil () xTaskGetTickCount() ...

  9. springboot大学生时间管理分析系统毕业设计源码130930

    摘  要 时间是一种无形资源,但可以对其进行有效的使用与管理.时间管理倾向是个体在运用时间方式上所表现出来的心理和行为特征,具有多维度.多层次的心理结构,由时间价值感.时间监控观和时间效能感构成.时间 ...

最新文章

  1. js原型链prototype与__proto__以及new表达式
  2. oracle性能调整的九大要点:四诊断latch竞争
  3. Learn Python the Hard Way: 字典
  4. 怎样借助Python爬虫给宝宝起个好名字
  5. 在load事件中关闭窗体
  6. 记一次吐血的ping: unknown host
  7. vue-cli项目布署问题解决:空白页、静态资源文件404错误、refrenceError:promise未定义(部分浏览器不支持ES6语法)
  8. 错误的艺术!20个创意的404错误页面设计
  9. 马克·扎克伯格分享Facebook水冷数据中心照片
  10. Android UI开发第三十二篇——Creating a Navigation Drawer
  11. UIButton常用属性
  12. 最新尚硅谷Git和GitHub视频教程完整版
  13. android Aidl原理分析
  14. java 绘制点阵_[Java基础知识]点阵字库在JAVA中的实现
  15. iFunk翼S苏宁京东热卖进行中
  16. Github开始强制使用PAT(Personal Access Token)了
  17. ARM64(M1版)Mac运行MAA以及AzurLaneAutoScript自动化打明日方舟和碧蓝航线
  18. createBuilderConfig 0XFFFF异常
  19. 毕马威《2021年中国证券业调查报告》:金融科技和数字化将成为发展核心
  20. SAP中输出采购订单附件清单操作实例

热门文章

  1. 线性表的抽象数据类型
  2. Windows10安装Rtools [+解决system('g++ -v' 127错误]
  3. Bios工程师手边事—HDA Audio
  4. 江西理工大学matlab考试,江西理工
  5. 冲量在线通过信通院联邦学习信创环境基础能力专项评测
  6. 第十四届蓝桥杯大赛软件赛省赛 C/C++ 大学 A 组 C题
  7. 隐性解析_开发移动应用程序的隐性成本
  8. 大疆智图软件(用于生产正射影像图和实景三维模型)
  9. OpenGL渲染视频(二)
  10. UML类图和关系--idea使用PlantUML插件画类图