亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? os_flag.lst

?? uCOS 嵌入式操作系統(tǒng)的改進(jìn)版,增加了網(wǎng)絡(luò)通訊.
?? LST
?? 第 1 頁 / 共 5 頁
字號:
 600   3                       *err      = OS_NO_ERR;
 601   3                       return (flags_cur);
 602   3                   } else {                                      /* Block task until events occur or timeout */
 603   3                       OS_FlagBlock(pgrp, &node, flags, wait_type, timeout);
 604   3                       OS_EXIT_CRITICAL();
 605   3                   }
 606   2                   break;
 607   2      #endif
 608   2      
 609   2              default:
C51 COMPILER V7.06   OS_FLAG                                                               07/18/2003 11:05:57 PAGE 11  

 610   2                   OS_EXIT_CRITICAL();
 611   2                   flags_cur = (OS_FLAGS)0;
 612   2                   *err      = OS_FLAG_ERR_WAIT_TYPE;
 613   2                   return (flags_cur);
 614   2          }
 615   1          OS_Sched();                                            /* Find next HPT ready to run               */
 616   1          OS_ENTER_CRITICAL();
 617   1          if (OSTCBCur->OSTCBStat & OS_STAT_FLAG) {              /* Have we timed-out?                       */
 618   2              OS_FlagUnlink(&node);
 619   2              OSTCBCur->OSTCBStat = OS_STAT_RDY;                 /* Yes, make task ready-to-run              */
 620   2              OS_EXIT_CRITICAL();
 621   2              flags_cur           = (OS_FLAGS)0;
 622   2              *err                = OS_TIMEOUT;                  /* Indicate that we timed-out waiting       */
 623   2          } else {
 624   2              if (consume == TRUE) {                             /* See if we need to consume the flags      */
 625   3                  switch (wait_type) {
 626   4                      case OS_FLAG_WAIT_SET_ALL:
 627   4                      case OS_FLAG_WAIT_SET_ANY:                 /* Clear ONLY the flags we got              */
 628   4                           pgrp->OSFlagFlags &= ~OSTCBCur->OSTCBFlagsRdy;
 629   4                           break;
 630   4      
 631   4      #if OS_FLAG_WAIT_CLR_EN > 0
 632   4                      case OS_FLAG_WAIT_CLR_ALL:
 633   4                      case OS_FLAG_WAIT_CLR_ANY:                 /* Set   ONLY the flags we got              */
 634   4                           pgrp->OSFlagFlags |= OSTCBCur->OSTCBFlagsRdy;
 635   4                           break;
 636   4      #endif
 637   4                      default:
 638   4                           OS_EXIT_CRITICAL();
 639   4                           *err = OS_FLAG_ERR_WAIT_TYPE;
 640   4                           return ((OS_FLAGS)0);
 641   4                  }
 642   3              }
 643   2              flags_cur = pgrp->OSFlagFlags;
 644   2              OS_EXIT_CRITICAL();
 645   2              *err      = OS_NO_ERR;                             /* Event(s) must have occurred              */
 646   2          }
 647   1          return (flags_cur);
 648   1      }
 649          /*$PAGE*/
 650          /*
 651          *********************************************************************************************************
 652          *                               GET FLAGS WHO CAUSED TASK TO BECOME READY
 653          *
 654          * Description: This function is called to obtain the flags that caused the task to become ready to run.
 655          *              In other words, this function allows you to tell "Who done it!".
 656          *
 657          * Arguments  : None
 658          *
 659          * Returns    : The flags that caused the task to be ready.
 660          *
 661          * Called from: Task ONLY
 662          *********************************************************************************************************
 663          */
 664          
 665          OS_FLAGS  OSFlagPendGetFlagsRdy (void) reentrant //using 0
 666          {
 667   1      #if OS_CRITICAL_METHOD == 3                                /* Allocate storage for CPU status register */
 668   1          OS_CPU_SR     cpu_sr;
 669   1      #endif
 670   1          OS_FLAGS      flags;
 671   1      
C51 COMPILER V7.06   OS_FLAG                                                               07/18/2003 11:05:57 PAGE 12  

 672   1      
 673   1          OS_ENTER_CRITICAL();
 674   1          flags = OSTCBCur->OSTCBFlagsRdy;
 675   1          //OS_ENTER_CRITICAL();//#Lin@20030714
 676   1          OS_EXIT_CRITICAL();
 677   1          return (flags);
 678   1      }
 679          
 680          /*$PAGE*/
 681          /*
 682          *********************************************************************************************************
 683          *                                         POST EVENT FLAG BIT(S)
 684          *
 685          * Description: This function is called to set or clear some bits in an event flag group.  The bits to
 686          *              set or clear are specified by a 'bit mask'.
 687          *
 688          * Arguments  : pgrp          is a pointer to the desired event flag group.
 689          *
 690          *              flags         If 'opt' (see below) is OS_FLAG_SET, each bit that is set in 'flags' will
 691          *                            set the corresponding bit in the event flag group.  e.g. to set bits 0, 4
 692          *                            and 5 you would set 'flags' to:
 693          *
 694          *                                0x31     (note, bit 0 is least significant bit)
 695          *
 696          *                            If 'opt' (see below) is OS_FLAG_CLR, each bit that is set in 'flags' will
 697          *                            CLEAR the corresponding bit in the event flag group.  e.g. to clear bits 0,
 698          *                            4 and 5 you would specify 'flags' as:
 699          *
 700          *                                0x31     (note, bit 0 is least significant bit)
 701          *
 702          *              opt           indicates whether the flags will be:
 703          *                                set     (OS_FLAG_SET) or
 704          *                                cleared (OS_FLAG_CLR)
 705          *
 706          *              err           is a pointer to an error code and can be:
 707          *                            OS_NO_ERR              The call was successfull
 708          *                            OS_FLAG_INVALID_PGRP   You passed a NULL pointer
 709          *                            OS_ERR_EVENT_TYPE      You are not pointing to an event flag group
 710          *                            OS_FLAG_INVALID_OPT    You specified an invalid option
 711          *
 712          * Returns    : the new value of the event flags bits that are still set.
 713          *
 714          * Called From: Task or ISR
 715          *
 716          * WARNING(s) : 1) The execution time of this function depends on the number of tasks waiting on the event
 717          *                 flag group.
 718          *              2) The amount of time interrupts are DISABLED depends on the number of tasks waiting on
 719          *                 the event flag group.
 720          *********************************************************************************************************
 721          */
 722          OS_FLAGS  OSFlagPost (OS_FLAG_GRP *pgrp, OS_FLAGS flags, INT8U opt, INT8U *err) reentrant //using 0
 723          {
 724   1      #if OS_CRITICAL_METHOD == 3                          /* Allocate storage for CPU status register       */
 725   1          OS_CPU_SR     cpu_sr;
 726   1      #endif
 727   1          OS_FLAG_NODE *pnode;
 728   1          BOOLEAN       sched;
 729   1          OS_FLAGS      flags_cur;
 730   1          OS_FLAGS      flags_rdy;
 731   1              BOOLEAN       rdy;
 732   1      
 733   1      
C51 COMPILER V7.06   OS_FLAG                                                               07/18/2003 11:05:57 PAGE 13  

 734   1      #if OS_ARG_CHK_EN > 0
 735   1          if (pgrp == (OS_FLAG_GRP *)0) {                  /* Validate 'pgrp'                                */
 736   2              *err = OS_FLAG_INVALID_PGRP;
 737   2              return ((OS_FLAGS)0);
 738   2          }
 739   1      #endif
 740   1          if (pgrp->OSFlagType != OS_EVENT_TYPE_FLAG) {    /* Make sure we are pointing to an event flag grp */
 741   2              *err = OS_ERR_EVENT_TYPE;
 742   2              return ((OS_FLAGS)0);
 743   2          }
 744   1      /*$PAGE*/
 745   1          OS_ENTER_CRITICAL();
 746   1          switch (opt) {
 747   2              case OS_FLAG_CLR:
 748   2                   pgrp->OSFlagFlags &= ~flags;            /* Clear the flags specified in the group         */
 749   2                   break;
 750   2      
 751   2              case OS_FLAG_SET:
 752   2                   pgrp->OSFlagFlags |=  flags;            /* Set   the flags specified in the group         */
 753   2                   break;
 754   2      
 755   2              default:
 756   2                   OS_EXIT_CRITICAL();                     /* INVALID option                                 */
 757   2                   *err = OS_FLAG_INVALID_OPT;
 758   2                   return ((OS_FLAGS)0);
 759   2          }
 760   1          sched = FALSE;                                   /* Indicate that we don't need rescheduling       */
 761   1          pnode = (OS_FLAG_NODE *)pgrp->OSFlagWaitList;
 762   1          while (pnode != (OS_FLAG_NODE *)0) {             /* Go through all tasks waiting on event flag(s)  */
 763   2              switch (pnode->OSFlagNodeWaitType) {
 764   3                  case OS_FLAG_WAIT_SET_ALL:               /* See if all req. flags are set for current node */
 765   3                       flags_rdy = pgrp->OSFlagFlags & pnode->OSFlagNodeFlags;
 766   3                       if (flags_rdy == pnode->OSFlagNodeFlags) {
 767   4                                           rdy = OS_FlagTaskRdy(pnode, flags_rdy);  /* Make task RTR, event(s) Rx'd          */
 768   4                           if (rdy == TRUE) {                     
 769   5                               sched = TRUE;                        /* When done we will reschedule          */
 770   5                           }
 771   4                       }
 772   3                       break;
 773   3      
 774   3                  case OS_FLAG_WAIT_SET_ANY:               /* See if any flag set                            */
 775   3                       flags_rdy = pgrp->OSFlagFlags & pnode->OSFlagNodeFlags;
 776   3                       if (flags_rdy != (OS_FLAGS)0) {
 777   4                                           rdy = OS_FlagTaskRdy(pnode, flags_rdy);  /* Make task RTR, event(s) Rx'd          */
 778   4                           if (rdy == TRUE) {                      
 779   5                               sched = TRUE;                        /* When done we will reschedule          */
 780   5                           }
 781   4                       }
 782   3                       break;
 783   3      
 784   3      #if OS_FLAG_WAIT_CLR_EN > 0
 785   3                  case OS_FLAG_WAIT_CLR_ALL:               /* See if all req. flags are set for current node */
 786   3                       flags_rdy = ~pgrp->OSFlagFlags & pnode->OSFlagNodeFlags;
 787   3                       if (flags_rdy == pnode->OSFlagNodeFlags) {
 788   4                                           rdy = OS_FlagTaskRdy(pnode, flags_rdy);  /* Make task RTR, event(s) Rx'd          */
 789   4                           if (rdy == TRUE) {                       
 790   5                               sched = TRUE;                        /* When done we will reschedule          */
 791   5                           }
 792   4                       }
 793   3                       break;
 794   3      
 795   3                  case OS_FLAG_WAIT_CLR_ANY:               /* See if any flag set                            */
C51 COMPILER V7.06   OS_FLAG                                                               07/18/2003 11:05:57 PAGE 14  

 796   3                       flags_rdy = ~pgrp->OSFlagFlags & pnode->OSFlagNodeFlags;
 797   3                       if (flags_rdy != (OS_FLAGS)0) {
 798   4                                           rdy = OS_FlagTaskRdy(pnode, flags_rdy);  /* Make task RTR, event(s) Rx'd          */
 799   4                           if (rdy == TRUE) {                       
 800   5                               sched = TRUE;                        /* When done we will reschedule          */
 801   5                           }

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品日韩一区二区三区免费视频| 国产高清精品网站| 91成人网在线| 洋洋成人永久网站入口| 91国偷自产一区二区开放时间| 一区二区三区中文在线观看| 91搞黄在线观看| 天天av天天翘天天综合网色鬼国产| 欧美视频一区二区在线观看| 日本不卡的三区四区五区| 精品久久久久香蕉网| 国产成人自拍网| 中文字幕在线播放不卡一区| 欧美中文字幕一区| 免费三级欧美电影| 久久精品一区二区三区不卡牛牛| kk眼镜猥琐国模调教系列一区二区| 一级中文字幕一区二区| 日韩一卡二卡三卡国产欧美| 国产精品资源在线看| 亚洲欧美日韩精品久久久久| 欧美午夜电影一区| 激情综合一区二区三区| 国产精品不卡在线| 日韩欧美成人一区二区| 成人av影院在线| 日韩中文字幕91| 中文字幕巨乱亚洲| 91麻豆精品国产综合久久久久久| 国产一区二区成人久久免费影院| 一区二区三区精品在线| 精品国产露脸精彩对白| 日本高清不卡aⅴ免费网站| 亚洲三级在线观看| 欧美无人高清视频在线观看| 欧美一二三四区在线| 色综合天天性综合| 一区二区欧美国产| 日韩欧美高清dvd碟片| 97超碰欧美中文字幕| 男女性色大片免费观看一区二区 | 欧美三级中文字幕在线观看| 久久综合综合久久综合| 亚洲日本在线观看| 国产三级精品视频| 欧美精品一二三| av中文字幕不卡| 美女mm1313爽爽久久久蜜臀| 中文字幕一区二区视频| 日韩精品中文字幕在线不卡尤物| 色综合激情五月| 国产精品一区二区久久不卡| 亚洲成人自拍一区| 亚洲欧洲精品天堂一级| 久久久久久久久岛国免费| 6080yy午夜一二三区久久| 在线观看国产日韩| 色呦呦国产精品| 成人激情午夜影院| 国产一区二区三区黄视频| 日韩精品久久久久久| 亚洲免费在线观看视频| 日本一区二区动态图| 久久亚区不卡日本| 日韩三级中文字幕| 制服丝袜在线91| 欧美区一区二区三区| 色88888久久久久久影院野外| 成人精品视频.| 岛国av在线一区| 国产成人综合在线播放| 国产黄色精品网站| 国产精品一区免费视频| 经典一区二区三区| 久久av老司机精品网站导航| 麻豆国产91在线播放| 麻豆精品蜜桃视频网站| 精品一区二区三区在线视频| 久久成人麻豆午夜电影| 久久精品国产久精国产爱| 久久国产免费看| 国产一区视频在线看| 国产揄拍国内精品对白| 国产成人精品综合在线观看| 成人综合在线观看| 色综合久久天天| 欧美色图天堂网| 91精品福利在线一区二区三区| 欧美一区二区三区婷婷月色| 欧美不卡一区二区三区四区| 欧美精品一区二区三区四区| 国产三级一区二区三区| 国产精品日韩成人| 亚洲综合色丁香婷婷六月图片| 亚洲一区二区黄色| 麻豆高清免费国产一区| 国产乱子伦一区二区三区国色天香| 国产成人精品在线看| 色偷偷成人一区二区三区91| 91精品久久久久久久91蜜桃| 精品日韩欧美在线| 亚洲色图.com| 日韩二区在线观看| 国产成人在线免费观看| 91行情网站电视在线观看高清版| 欧美日本一道本在线视频| 精品少妇一区二区三区在线播放 | 亚洲久本草在线中文字幕| 亚洲bdsm女犯bdsm网站| 久久精品国产一区二区| 99在线精品免费| 777午夜精品视频在线播放| 2021国产精品久久精品| 亚洲美女在线一区| 另类成人小视频在线| 99久久精品免费看国产 | 婷婷六月综合亚洲| 国产精品123区| 欧美日韩中文字幕一区二区| 久久影院午夜论| 亚洲午夜视频在线| 国产福利电影一区二区三区| 色综合久久综合| 久久亚洲精精品中文字幕早川悠里 | 国产精品久久网站| 午夜久久电影网| 粗大黑人巨茎大战欧美成人| 精品视频色一区| 国产人成一区二区三区影院| 午夜久久久久久| 91同城在线观看| 26uuu色噜噜精品一区| 亚洲一区二区在线观看视频| 精品一区二区三区在线视频| 欧美午夜精品久久久| 国产精品视频一二| 久久精品国产99国产| 日本精品裸体写真集在线观看| 久久嫩草精品久久久精品| 五月婷婷激情综合| 色www精品视频在线观看| 日本一区免费视频| 免费观看久久久4p| 欧美视频在线一区| 自拍偷自拍亚洲精品播放| 国产一区二区三区视频在线播放| 欧美日韩免费一区二区三区视频| 欧美国产一区二区在线观看| 蜜臀av国产精品久久久久 | 青青草伊人久久| 91官网在线观看| 亚洲日本免费电影| 成人综合激情网| 国产亚洲成aⅴ人片在线观看| 久草在线在线精品观看| 欧美美女喷水视频| 一区二区在线观看免费| 97久久人人超碰| 一色屋精品亚洲香蕉网站| 春色校园综合激情亚洲| 欧美极品少妇xxxxⅹ高跟鞋| 国产精品66部| 国产亚洲精品aa午夜观看| 国产美女在线精品| 久久久久久9999| 国产a精品视频| 国产亚洲午夜高清国产拍精品 | 亚洲国产成人tv| 欧美日韩免费高清一区色橹橹| 一区二区三区中文字幕| 欧美综合一区二区| 亚洲一区二区在线播放相泽| 欧美日韩国产免费| 男女男精品网站| 国产色91在线| 91碰在线视频| 亚洲国产一区二区a毛片| 欧美在线视频你懂得| 天天做天天摸天天爽国产一区| 8v天堂国产在线一区二区| 蜜臀av国产精品久久久久| 精品国产乱码久久久久久浪潮| 国产一本一道久久香蕉| 国产精品理伦片| 91激情在线视频| 男男视频亚洲欧美| 国产日韩v精品一区二区| www.欧美色图| 亚洲国产精品久久一线不卡| 91精品国产综合久久久久久久| 蜜臀av一区二区| 国产欧美视频一区二区| 色综合久久中文综合久久97| 亚洲一二三级电影| 精品剧情在线观看| 成人激情免费网站| 亚洲福利国产精品| 久久久久久免费网| 色又黄又爽网站www久久| 蜜臀va亚洲va欧美va天堂|