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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? os_task.lst

?? uCOS 嵌入式操作系統的改進版,增加了網絡通訊.
?? LST
?? 第 1 頁 / 共 5 頁
字號:
C51 COMPILER V7.06   OS_TASK                                                               07/18/2003 11:06:04 PAGE 1   


C51 COMPILER V7.06, COMPILATION OF MODULE OS_TASK
OBJECT MODULE PLACED IN .\os_task.obj
COMPILER INVOKED BY: C:\KEIL\C51\BIN\C51.EXE ..\keilc51\os_task.c LARGE BROWSE DEBUG OBJECTEXTEND PRINT(.\os_task.lst) O
                    -BJECT(.\os_task.obj)

stmt level    source

   1          /*
   2          *********************************************************************************************************
   3          *                                                uC/OS-II
   4          *                                          The Real-Time Kernel
   5          *                                            TASK MANAGEMENT
   6          *
   7          *                          (c) Copyright 1992-2002, Jean J. Labrosse, Weston, FL
   8          *                                           All Rights Reserved
   9          *
  10          * File : OS_TASK.C
  11          * By   : Jean J. Labrosse
  12          *********************************************************************************************************
  13          */
  14          
  15          #ifndef  OS_MASTER_FILE
  16          #include "includes.h"
  17          #endif
  18          
  19          /*
  20          *********************************************************************************************************
  21          *                                        CHANGE PRIORITY OF A TASK
  22          *
  23          * Description: This function allows you to change the priority of a task dynamically.  Note that the new
  24          *              priority MUST be available.
  25          *
  26          * Arguments  : oldp     is the old priority
  27          *
  28          *              newp     is the new priority
  29          *
  30          * Returns    : OS_NO_ERR        is the call was successful
  31          *              OS_PRIO_INVALID  if the priority you specify is higher that the maximum allowed
  32          *                               (i.e. >= OS_LOWEST_PRIO)
  33          *              OS_PRIO_EXIST    if the new priority already exist.
  34          *              OS_PRIO_ERR      there is no task with the specified OLD priority (i.e. the OLD task does
  35          *                               not exist.
  36          *********************************************************************************************************
  37          */
  38          
  39          #if OS_TASK_CHANGE_PRIO_EN > 0
  40          INT8U  OSTaskChangePrio (INT8U oldprio, INT8U newprio) reentrant //using 0
  41          {
  42   1      #if OS_CRITICAL_METHOD == 3                      /* Allocate storage for CPU status register           */
  43   1          OS_CPU_SR    cpu_sr;
  44   1      #endif
  45   1      
  46   1      #if OS_EVENT_EN > 0
  47   1          OS_EVENT    *pevent;
  48   1      #endif
  49   1      
  50   1          OS_TCB      *ptcb;
  51   1          INT8U        x;
  52   1          INT8U        y;
  53   1          INT8U        bitx;
  54   1          INT8U        bity;
C51 COMPILER V7.06   OS_TASK                                                               07/18/2003 11:06:04 PAGE 2   

  55   1          INT8U        y_old;
  56   1      
  57   1      
  58   1      #if OS_ARG_CHK_EN > 0
  59   1          if (oldprio >= OS_LOWEST_PRIO) {
  60   2                  if (oldprio != OS_PRIO_SELF) {
  61   3                  return (OS_PRIO_INVALID);
  62   3                      }
  63   2              }
  64   1          if (newprio >= OS_LOWEST_PRIO) {
  65   2              return (OS_PRIO_INVALID);
  66   2          }
  67   1      #endif
  68   1          OS_ENTER_CRITICAL();
  69   1          if (OSTCBPrioTbl[newprio] != (OS_TCB *)0) {                 /* New priority must not already exist */
  70   2              OS_EXIT_CRITICAL();
  71   2              return (OS_PRIO_EXIST);
  72   2          } 
  73   1          if (oldprio == OS_PRIO_SELF) {                              /* See if changing self                */
  74   2              oldprio = OSTCBCur->OSTCBPrio;                          /* Yes, get priority                   */
  75   2          }
  76   1          ptcb = OSTCBPrioTbl[oldprio];
  77   1          if (ptcb == (OS_TCB *)0) {                                  /* Does task to change exist?          */
  78   2              OS_EXIT_CRITICAL();                                     /* No, can't change its priority!      */
  79   2              return (OS_PRIO_ERR);
  80   2          }                                       
  81   1          y                     = newprio >> 3;                       /* Yes, compute new TCB fields         */
  82   1          bity                  = OSMapTbl[y];
  83   1          x                     = newprio & 0x07;
  84   1          bitx                  = OSMapTbl[x];
  85   1          OSTCBPrioTbl[oldprio] = (OS_TCB *)0;                        /* Remove TCB from old priority        */
  86   1          OSTCBPrioTbl[newprio] = ptcb;                               /* Place pointer to TCB @ new priority */
  87   1          y_old                 = ptcb->OSTCBY;
  88   1          if ((OSRdyTbl[y_old] & ptcb->OSTCBBitX) != 0x00) {          /* If task is ready make it not        */
  89   2              OSRdyTbl[y_old] &= ~ptcb->OSTCBBitX;
  90   2              if (OSRdyTbl[y_old] == 0x00) {
  91   3                  OSRdyGrp &= ~ptcb->OSTCBBitY;
  92   3              }
  93   2              OSRdyGrp    |= bity;                                    /* Make new priority ready to run      */
  94   2              OSRdyTbl[y] |= bitx;
  95   2      #if OS_EVENT_EN > 0
  96   2          } else {                                                    /* Task was not ready ...              */
  97   2              pevent = ptcb->OSTCBEventPtr;
  98   2              if (pevent != (OS_EVENT *)0) {                          /* ... remove from event wait list     */
  99   3                  pevent->OSEventTbl[y_old] &= ~ptcb->OSTCBBitX;
 100   3                  if (pevent->OSEventTbl[y_old] == 0) {
 101   4                      pevent->OSEventGrp &= ~ptcb->OSTCBBitY;
 102   4                  }
 103   3                  pevent->OSEventGrp    |= bity;                      /* Add new priority to wait list       */
 104   3                  pevent->OSEventTbl[y] |= bitx;
 105   3              }
 106   2      #endif
 107   2          }
 108   1          ptcb->OSTCBPrio = newprio;                                  /* Set new task priority               */
 109   1          ptcb->OSTCBY    = y;
 110   1          ptcb->OSTCBX    = x;
 111   1          ptcb->OSTCBBitY = bity;
 112   1          ptcb->OSTCBBitX = bitx;
 113   1          OS_EXIT_CRITICAL();
 114   1          OS_Sched();                                                 /* Run highest priority task ready     */
 115   1          return (OS_NO_ERR);
 116   1      }
C51 COMPILER V7.06   OS_TASK                                                               07/18/2003 11:06:04 PAGE 3   

 117          #endif
 118          /*$PAGE*/
 119          /*
 120          *********************************************************************************************************
 121          *                                            CREATE A TASK
 122          *
 123          * Description: This function is used to have uC/OS-II manage the execution of a task.  Tasks can either
 124          *              be created prior to the start of multitasking or by a running task.  A task cannot be
 125          *              created by an ISR.
 126          *
 127          * Arguments  : task     is a pointer to the task's code
 128          *
 129          *              pdata    is a pointer to an optional data area which can be used to pass parameters to
 130          *                       the task when the task first executes.  Where the task is concerned it thinks
 131          *                       it was invoked and passed the argument 'pdata' as follows:
 132          *
 133          *                           void Task (void *pdata)
 134          *                           {
 135          *                               for (;;) {
 136          *                                   Task code;
 137          *                               }
 138          *                           }
 139          *
 140          *              ptos     is a pointer to the task's top of stack.  If the configuration constant
 141          *                       OS_STK_GROWTH is set to 1, the stack is assumed to grow downward (i.e. from high
 142          *                       memory to low memory).  'pstk' will thus point to the highest (valid) memory
 143          *                       location of the stack.  If OS_STK_GROWTH is set to 0, 'pstk' will point to the
 144          *                       lowest memory location of the stack and the stack will grow with increasing
 145          *                       memory locations.
 146          *
 147          *              prio     is the task's priority.  A unique priority MUST be assigned to each task and the
 148          *                       lower the number, the higher the priority.
 149          *
 150          * Returns    : OS_NO_ERR        if the function was successful.
 151          *              OS_PRIO_EXIT     if the task priority already exist
 152          *                               (each task MUST have a unique priority).
 153          *              OS_PRIO_INVALID  if the priority you specify is higher that the maximum allowed
 154          *                               (i.e. >= OS_LOWEST_PRIO)
 155          *********************************************************************************************************
 156          */
 157          
 158          #if OS_TASK_CREATE_EN > 0
 159          INT8U  OSTaskCreate (void (*task)(void *pd), void *pndata, OS_STK *ptos, INT8U prio) reentrant //using 0
 160          {
 161   1      #if OS_CRITICAL_METHOD == 3                  /* Allocate storage for CPU status register               */
 162   1          OS_CPU_SR  cpu_sr;
 163   1      #endif
 164   1          OS_STK    *psp;
 165   1          INT8U      err;
 166   1      
 167   1      
 168   1      #if OS_ARG_CHK_EN > 0
 169   1          if (prio > OS_LOWEST_PRIO) {             /* Make sure priority is within allowable range           */
 170   2              return (OS_PRIO_INVALID);
 171   2          }
 172   1      #endif
 173   1          OS_ENTER_CRITICAL();
 174   1          if (OSTCBPrioTbl[prio] == (OS_TCB *)0) { /* Make sure task doesn't already exist at this priority  */
 175   2              OSTCBPrioTbl[prio] = (OS_TCB *)1;    /* Reserve the priority to prevent others from doing ...  */
 176   2                                                   /* ... the same thing until task is created.              */
 177   2              OS_EXIT_CRITICAL();
 178   2              psp = (OS_STK *)OSTaskStkInit(task, pndata, ptos, 0);    /* Initialize the task's stack         */
C51 COMPILER V7.06   OS_TASK                                                               07/18/2003 11:06:04 PAGE 4   

 179   2              err = OS_TCBInit(prio, psp, (OS_STK *)0, 0, 0, (void *)0, 0);
 180   2              if (err == OS_NO_ERR) {
 181   3                  OS_ENTER_CRITICAL();
 182   3                  OSTaskCtr++;                                        /* Increment the #tasks counter        */
 183   3                  OS_EXIT_CRITICAL();
 184   3                  if (OSRunning == TRUE) {         /* Find highest priority task if multitasking has started */
 185   4                      OS_Sched();
 186   4                  }
 187   3              } else {
 188   3                  OS_ENTER_CRITICAL();
 189   3                  OSTCBPrioTbl[prio] = (OS_TCB *)0;/* Make this priority available to others                 */
 190   3                  OS_EXIT_CRITICAL();
 191   3              }
 192   2              return (err);
 193   2          }
 194   1          OS_EXIT_CRITICAL();
 195   1          return (OS_PRIO_EXIST);
 196   1      }
 197          #endif
 198          /*$PAGE*/
 199          /*

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产成人精品影视| 国模冰冰炮一区二区| 久久国产精品99久久人人澡| 激情五月婷婷综合| 国产一区二区三区黄视频| 91国产免费观看| 中文在线一区二区| 看片的网站亚洲| 色综合久久88色综合天天6| 久久久电影一区二区三区| 午夜免费欧美电影| 色综合一区二区三区| 国产嫩草影院久久久久| 亚洲一区二区三区爽爽爽爽爽| 国产尤物一区二区| 91精品福利在线一区二区三区| 亚洲欧美日韩在线播放| 丁香婷婷综合激情五月色| 欧美成人a视频| 免费在线看成人av| 欧美一二三四在线| 亚洲午夜精品一区二区三区他趣| 成人精品一区二区三区四区| 国产午夜亚洲精品午夜鲁丝片| 久久国产剧场电影| 欧美一级生活片| 肉色丝袜一区二区| 4hu四虎永久在线影院成人| 亚洲国产精品嫩草影院| 欧美午夜理伦三级在线观看| 亚洲精品视频免费看| 91在线免费视频观看| 中文字幕一区二区三区av | 精品91自产拍在线观看一区| 午夜精品久久久久久久久久| 欧美亚洲免费在线一区| 亚洲国产一二三| 欧美日韩精品欧美日韩精品 | 欧美乱熟臀69xxxxxx| 亚洲一线二线三线视频| 欧美性猛交一区二区三区精品| 亚洲一区二区在线视频| 欧美日韩成人高清| 日韩电影免费在线| 精品久久国产字幕高潮| 国产激情精品久久久第一区二区 | 亚洲成人黄色影院| 91麻豆精品国产91久久久使用方法| 午夜电影一区二区| 欧美一区二区视频网站| 韩国女主播一区二区三区| 久久综合给合久久狠狠狠97色69| 国产成人精品综合在线观看| 亚洲欧洲美洲综合色网| 欧美日韩在线直播| 精品亚洲成av人在线观看| 国产欧美一区二区精品婷婷| 91麻豆精品一区二区三区| 亚洲超碰97人人做人人爱| 欧美一区二区成人6969| 国产91精品一区二区| 亚洲精选一二三| 欧美成人国产一区二区| 成人免费视频视频| 日韩制服丝袜av| 欧美国产综合一区二区| 欧美午夜电影一区| 久久超碰97人人做人人爱| 国产亚洲综合性久久久影院| 91国产精品成人| 国产风韵犹存在线视精品| 亚洲一区在线观看视频| 26uuu亚洲综合色| 在线看国产一区二区| 国产尤物一区二区| 五月天亚洲精品| 国产精品欧美精品| 欧美一区二区二区| 色94色欧美sute亚洲线路一久| 国产综合色产在线精品| 亚洲国产精品久久久久婷婷884 | 一区二区三国产精华液| 国产欧美日本一区二区三区| 制服丝袜在线91| 色噜噜狠狠成人网p站| 国产成人免费网站| 蜜乳av一区二区| 亚洲一区影音先锋| 亚洲国产经典视频| 久久嫩草精品久久久精品一| 欧美乱妇20p| 欧美自拍偷拍午夜视频| av毛片久久久久**hd| 精品无码三级在线观看视频| 亚洲成人av在线电影| 亚洲欧美日韩精品久久久久| 国产欧美1区2区3区| 精品不卡在线视频| 日韩欧美高清在线| 这里只有精品电影| 欧美理论在线播放| 91香蕉视频污| 成人18精品视频| 国产精品资源网站| 久久99热99| 激情六月婷婷综合| 麻豆高清免费国产一区| 午夜精品久久久久久久 | 欧美视频一区二区| 色94色欧美sute亚洲13| 91日韩一区二区三区| 99久久精品费精品国产一区二区| 国产成人免费网站| www.欧美色图| 成人av午夜电影| 菠萝蜜视频在线观看一区| 国产91丝袜在线观看| 成人做爰69片免费看网站| 国产夫妻精品视频| 成人av电影在线观看| 99国产一区二区三精品乱码| av激情亚洲男人天堂| 91在线免费播放| 欧美系列日韩一区| 欧美精品免费视频| 欧美videos中文字幕| 久久精品视频在线看| 国产精品美女久久久久久久| 17c精品麻豆一区二区免费| 夜夜嗨av一区二区三区网页| 丝袜美腿亚洲色图| 久久精品国产99国产| 粉嫩aⅴ一区二区三区四区| av不卡免费电影| 在线中文字幕一区二区| 欧美一区二区三区婷婷月色| 精品国产乱码久久久久久老虎| 久久久久国产精品麻豆ai换脸| 国产精品第一页第二页第三页| 一区二区在线电影| 久久精品国产99国产精品| 成人免费黄色在线| 欧美性高清videossexo| 日韩精品综合一本久道在线视频| 欧美激情在线一区二区| 一区二区三区欧美视频| 蜜臀va亚洲va欧美va天堂 | |精品福利一区二区三区| 亚洲在线中文字幕| 精品一区二区在线视频| 91视频观看免费| 欧美一区二区三区小说| 国产精品卡一卡二| 免费高清成人在线| 97久久精品人人做人人爽| 91精品国产一区二区三区蜜臀| 国产精品视频一二三| 日本aⅴ免费视频一区二区三区| 成人激情综合网站| 日韩免费在线观看| 1区2区3区精品视频| 精品一区二区成人精品| 91丨九色丨蝌蚪丨老版| 日韩欧美国产综合一区| 一区二区三区中文免费| 国产精品1024久久| 制服丝袜日韩国产| 亚洲激情自拍视频| 国产精品综合二区| 欧美一区二区三区思思人| 国产精品毛片高清在线完整版| 视频一区二区欧美| 91啦中文在线观看| 久久蜜臀精品av| 日韩黄色片在线观看| 91在线观看视频| 久久久国产一区二区三区四区小说| 亚洲激情图片qvod| 成人久久久精品乱码一区二区三区| 欧美一区二区视频在线观看2020| 亚洲人成在线观看一区二区| 国产成都精品91一区二区三| 91精品国产一区二区人妖| 夜夜嗨av一区二区三区中文字幕| 成人在线一区二区三区| xvideos.蜜桃一区二区| 日本女人一区二区三区| 精品视频999| 亚洲国产一区二区a毛片| 91网站最新网址| 国产精品久久久久久亚洲毛片| 国产在线精品一区二区夜色| 欧美电影免费观看高清完整版 | 日韩欧美国产系列| 天堂成人免费av电影一区| 欧美午夜不卡在线观看免费| 亚洲国产综合色| 在线观看日韩电影| 亚洲午夜久久久| 制服丝袜激情欧洲亚洲|