⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 os_task.lst

📁 实施操作系统的设计和开发
💻 LST
📖 第 1 页 / 共 4 页
字号:
              #endif
 570          /*$PAGE*/
 571          /*
 572          *********************************************************************************************************
 573          *                                             STACK CHECKING
 574          *
 575          * Description: This function is called to check the amount of free memory left on the specified task's
 576          *              stack.
 577          *
 578          * Arguments  : prio     is the task priority
 579          *
 580          *              ppdata    is a pointer to a data structure of type OS_STK_DATA.
 581          *
 582          * Returns    : OS_NO_ERR           upon success
 583          *              OS_PRIO_INVALID     if the priority you specify is higher that the maximum allowed
 584          *                                  (i.e. > OS_LOWEST_PRIO) or, you have not specified OS_PRIO_SELF.
 585          *              OS_TASK_NOT_EXIST   if the desired task has not been created
 586          *              OS_TASK_OPT_ERR     if you did NOT specified OS_TASK_OPT_STK_CHK when the task was created
 587          *********************************************************************************************************
 588          */
 589          #if OS_TASK_CREATE_EXT_EN > 0
              INT8U  OSTaskStkChk (INT8U prio, OS_STK_DATA *ppdata) reentrant
              {
              #if OS_CRITICAL_METHOD == 3                      /* Allocate storage for CPU status register           */
                  OS_CPU_SR  cpu_sr;
              #endif
                  OS_TCB    *ptcb;
                  OS_STK    *pchk;
                  INT32U     free;
                  INT32U     size;
              
              
              #if OS_ARG_CHK_EN > 0
                  if (prio > OS_LOWEST_PRIO && prio != OS_PRIO_SELF) {        /* Make sure task priority is valid    */
                      return (OS_PRIO_INVALID);
                  }
              #endif
                  ppdata->OSFree = 0;                                          /* Assume failure, set to 0 size       */
                  ppdata->OSUsed = 0;
                  OS_ENTER_CRITICAL();
                  if (prio == OS_PRIO_SELF) {                        /* See if check for SELF                        */
                      prio = OSTCBCur->OSTCBPrio;
                  }
C51 COMPILER V7.02b   OS_TASK                                                              11/29/2006 14:48:15 PAGE 11  

                  ptcb = OSTCBPrioTbl[prio];
                  if (ptcb == (OS_TCB *)0) {                         /* Make sure task exist                         */
                      OS_EXIT_CRITICAL();
                      return (OS_TASK_NOT_EXIST);
                  }
                  if ((ptcb->OSTCBOpt & OS_TASK_OPT_STK_CHK) == 0) { /* Make sure stack checking option is set       */
                      OS_EXIT_CRITICAL();
                      return (OS_TASK_OPT_ERR);
                  }
                  free = 0;
                  size = ptcb->OSTCBStkSize;
                  pchk = ptcb->OSTCBStkBottom;
                  OS_EXIT_CRITICAL();
              #if OS_STK_GROWTH == 1
                  while (*pchk++ == (OS_STK)0) {                    /* Compute the number of zero entries on the stk */
                      free++;
                  }
              #else
                  while (*pchk-- == (OS_STK)0) {
                      free++;
                  }
              #endif
                  ppdata->OSFree = free * sizeof(OS_STK);            /* Compute number of free bytes on the stack     */
                  ppdata->OSUsed = (size - free) * sizeof(OS_STK);   /* Compute number of bytes used on the stack     */
                  return (OS_NO_ERR);
              }
              #endif
 639          /*$PAGE*/
 640          /*
 641          *********************************************************************************************************
 642          *                                            SUSPEND A TASK
 643          *
 644          * Description: This function is called to suspend a task.  The task can be the calling task if the
 645          *              priority passed to OSTaskSuspend() is the priority of the calling task or OS_PRIO_SELF.
 646          *
 647          * Arguments  : prio     is the priority of the task to suspend.  If you specify OS_PRIO_SELF, the
 648          *                       calling task will suspend itself and rescheduling will occur.
 649          *
 650          * Returns    : OS_NO_ERR                if the requested task is suspended
 651          *              OS_TASK_SUSPEND_IDLE     if you attempted to suspend the idle task which is not allowed.
 652          *              OS_PRIO_INVALID          if the priority you specify is higher that the maximum allowed
 653          *                                       (i.e. >= OS_LOWEST_PRIO) or, you have not specified OS_PRIO_SELF.
 654          *              OS_TASK_SUSPEND_PRIO     if the task to suspend does not exist
 655          *
 656          * Note       : You should use this function with great care.  If you suspend a task that is waiting for
 657          *              an event (i.e. a message, a semaphore, a queue ...) you will prevent this task from
 658          *              running when the event arrives.
 659          *********************************************************************************************************
 660          */
 661          
 662          #if OS_TASK_SUSPEND_EN > 0
              INT8U  OSTaskSuspend (INT8U prio) reentrant
              {
              #if OS_CRITICAL_METHOD == 3                      /* Allocate storage for CPU status register           */
                  OS_CPU_SR  cpu_sr;
              #endif
                  BOOLEAN    self;
                  OS_TCB    *ptcb;
              
              
              #if OS_ARG_CHK_EN > 0
                  if (prio == OS_IDLE_PRIO) {                                 /* Not allowed to suspend idle task    */
C51 COMPILER V7.02b   OS_TASK                                                              11/29/2006 14:48:15 PAGE 12  

                      return (OS_TASK_SUSPEND_IDLE);
                  }
                  if (prio >= OS_LOWEST_PRIO && prio != OS_PRIO_SELF) {       /* Task priority valid ?               */
                      return (OS_PRIO_INVALID);
                  }
              #endif
                  OS_ENTER_CRITICAL();
                  if (prio == OS_PRIO_SELF) {                                 /* See if suspend SELF                 */
                      prio = OSTCBCur->OSTCBPrio;
                      self = TRUE;
                  } else if (prio == OSTCBCur->OSTCBPrio) {                   /* See if suspending self              */
                      self = TRUE;
                  } else {
                      self = FALSE;                                           /* No suspending another task          */
                  }
                  if ((ptcb = OSTCBPrioTbl[prio]) == (OS_TCB *)0) {           /* Task to suspend must exist          */
                      OS_EXIT_CRITICAL();
                      return (OS_TASK_SUSPEND_PRIO);
                  }
                  if ((OSRdyTbl[ptcb->OSTCBY] &= ~ptcb->OSTCBBitX) == 0x00) { /* Make task not ready                 */
                      OSRdyGrp &= ~ptcb->OSTCBBitY;
                  }
                  ptcb->OSTCBStat |= OS_STAT_SUSPEND;                         /* Status of task is 'SUSPENDED'       */
                  OS_EXIT_CRITICAL();
                  if (self == TRUE) {                                         /* Context switch only if SELF         */
                      OS_Sched();
                  }
                  return (OS_NO_ERR);
              }
              #endif
 704          /*$PAGE*/
 705          /*
 706          *********************************************************************************************************
 707          *                                            QUERY A TASK
 708          *
 709          * Description: This function is called to obtain a copy of the desired task's TCB.
 710          *
 711          * Arguments  : prio     is the priority of the task to obtain information from.
 712          *
 713          * Returns    : OS_NO_ERR       if the requested task is suspended
 714          *              OS_PRIO_INVALID if the priority you specify is higher that the maximum allowed
 715          *                              (i.e. > OS_LOWEST_PRIO) or, you have not specified OS_PRIO_SELF.
 716          *              OS_PRIO_ERR     if the desired task has not been created
 717          *********************************************************************************************************
 718          */
 719          
 720          #if OS_TASK_QUERY_EN > 0
              INT8U  OSTaskQuery (INT8U prio, OS_TCB *ppdata) reentrant
              {
              #if OS_CRITICAL_METHOD == 3                      /* Allocate storage for CPU status register           */
                  OS_CPU_SR  cpu_sr;
              #endif
                  OS_TCB    *ptcb;
              
              
              #if OS_ARG_CHK_EN > 0
                  if (prio > OS_LOWEST_PRIO && prio != OS_PRIO_SELF) {   /* Task priority valid ?                    */
                      return (OS_PRIO_INVALID);
                  }
              #endif
                  OS_ENTER_CRITICAL();
                  if (prio == OS_PRIO_SELF) {                            /* See if suspend SELF                      */
C51 COMPILER V7.02b   OS_TASK                                                              11/29/2006 14:48:15 PAGE 13  

                      prio = OSTCBCur->OSTCBPrio;
                  }
                  if ((ptcb = OSTCBPrioTbl[prio]) == (OS_TCB *)0) {      /* Task to query must exist                 */
                      OS_EXIT_CRITICAL();
                      return (OS_PRIO_ERR);
                  }
                  memcpy(ppdata, ptcb, sizeof(OS_TCB));                  /* Copy TCB into user storage area          */
                  OS_EXIT_CRITICAL();
                  return (OS_NO_ERR);
              }
              #endif


MODULE INFORMATION:   STATIC OVERLAYABLE
   CODE SIZE        =    384    ----
   CONSTANT SIZE    =   ----    ----
   XDATA SIZE       =   ----    ----
   PDATA SIZE       =   ----    ----
   DATA SIZE        =   ----    ----
   IDATA SIZE       =   ----    ----
   BIT SIZE         =   ----    ----
END OF MODULE INFORMATION.


C51 COMPILATION COMPLETE.  1 WARNING(S),  0 ERROR(S)

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -