浅析μcosii v285内核ossempend和ossempost函数工作原理.docVIP

浅析μcosii v285内核ossempend和ossempost函数工作原理.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
浅析μcosii v285内核ossempend和ossempost函数工作原理

浅析μCOS/II v2.85内核OSSemPend()和OSSemPost()函数工作原理 文章来源:[转载请声明出处] //---------------------------------------------------------------------- //1.OSSemPend()函数 void OSSemPend (OS_EVENT *pevent, INT16U timeout, INT8U *perr) { ????INT8U pend_stat; #if OS_CRITICAL_METHOD == 3 ????OS_CPU_SR cpu_sr = 0; #endif #if OS_ARG_CHK_EN 0 ????if (perr == (INT8U *)0) { ????????return; ????} ????if (pevent == (OS_EVENT *)0) { ????????*perr = OS_ERR_PEVENT_NULL; ????????return; ????} #endif ????if (pevent-OSEventType != OS_EVENT_TYPE_SEM) { //确保该event控制块是Sem类型 ????????*perr = OS_ERR_EVENT_TYPE; ????????return; ????} ????if (OSIntNesting 0) { //ISR中,不能使用OSSemPend() ????????*perr = OS_ERR_PEND_ISR; ????????return; ????} ????if (OSLockNesting 0) { //μCOS/II v2.85内核已经被强制锁住 ????????*perr = OS_ERR_PEND_LOCKED; ????????return; ????} //非法的统统不是,信号正常,所以有必要进一步处理 ????OS_ENTER_CRITICAL(); ????if (pevent-OSEventCnt 0) { //程序的其他地方已经触发了事件,异或在初始化时设定了n,如:OSSemCreate(2); //所以该task无需悬停,直接获得事件的使用权 ????????pevent-OSEventCnt--; ????????OS_EXIT_CRITICAL(); ????????*perr = OS_ERR_NONE; ????????return; ????} //当前还没有任何事件发生,所以本task需要悬停,让出cpu[gliethttp] ????OSTCBCur-OSTCBStat |= OS_STAT_SEM;//是sem事件让本task进入悬停等待的 ????OSTCBCur-OSTCBStatPend = OS_STAT_PEND_OK;//假定不是超时,为正常收到信号 //超时,如果timeout=0,那么,本task将一直悬停,仅仅当收到事件触发信号后才重新进入调度队列 ????OSTCBCur-OSTCBDly = timeout; //OS_EventTaskWait()函数实现的功能: //把本task从就绪控制矩阵中摘下,放到pevent事件专有的进程事件控制矩阵表中. ????OS_EventTaskWait(pevent); ????OS_EXIT_CRITICAL(); //因为本task正在运行,所以本task现在的优先级最高,现在本task已经将自己从就绪控制矩阵--调度器(x,y)矩形阵列中 //把自己摘掉,所以调度函数OS_Sched()一定会切换到另一个task中执行新task的代码[gliethttp] ????OS_Sched();//具体参见《浅析μC/OS-II v2.85内核调度函数》 //2007-09-09 gliethttp //可能因为OSSemPend()中指定的timeout已经超时 //[由OSTimeTick()函数把本task重新置入了就绪控制矩阵,具体参考《浅析μC/OS-II v2.85内核OSTimeDly()函数工作原理》], //又或者确实在应用程序的某个地方调用了OSSemPost(),以下代码将具体解析是有什么引起的:1.超时,2.收到正常信号 ????OS_ENTER_CRITICAL(); ????if (OSTCBCur-OSTCBStatPend != OS_STAT_PEND_OK) { //是因为timeout超时,使得本task获得重新执行的机会 ????????pend_stat = OSTCBCur-OSTCBStatPend; //清除event事件块上本t

文档评论(0)

shenlan118 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档