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

📄 qus.c

📁 test file nucleus source
💻 C
📖 第 1 页 / 共 4 页
字号:
/*************************************************************************//*                                                                       *//*               Copyright Mentor Graphics Corporation 2002              *//*                         All Rights Reserved.                          *//*                                                                       *//* THIS WORK CONTAINS TRADE SECRET AND PROPRIETARY INFORMATION WHICH IS  *//* THE PROPERTY OF MENTOR GRAPHICS CORPORATION OR ITS LICENSORS AND IS   *//* SUBJECT TO LICENSE TERMS.                                             *//*                                                                       *//*************************************************************************//*************************************************************************//*                                                                       *//* FILE NAME                                               VERSION       *//*                                                                       *//*      qus.c                                          Nucleus PLUS 1.14 *//*                                                                       *//* COMPONENT                                                             *//*                                                                       *//*      QU - Queue Management                                            *//*                                                                       *//* DESCRIPTION                                                           *//*                                                                       *//*      This file contains supplemental routines for the Queue           *//*      Management component.                                            *//*                                                                       *//* DATA STRUCTURES                                                       *//*                                                                       *//*      None                                                             *//*                                                                       *//* FUNCTIONS                                                             *//*                                                                       *//*      QUS_Reset_Queue                     Reset a queue                *//*      QUS_Send_To_Front_Of_Queue          Send message to queue's front*//*      QUS_Broadcast_To_Queue              Broadcast a message to queue *//*                                                                       *//* DEPENDENCIES                                                          *//*                                                                       *//*      cs_extr.h                           Common Service functions     *//*      tc_extr.h                           Thread Control functions     *//*      qu_extr.h                           Queue functions              *//*      hi_extr.h                           History functions            *//*                                                                       *//* HISTORY                                                               *//*                                                                       *//*         DATE                    REMARKS                               *//*                                                                       *//*      03-01-1994      Created initial version 1.1 from                 *//*                      routines originally in core                      *//*                                                                       *//*      03-18-1994      Verified version 1.1                             *//*      04-17-1996      updated to version 1.2                           *//*      02-04-1998      Corrected SPR434 resulting in                    *//*                      version 1.2a.                                    *//*      03-24-1998      Released version 1.3                             *//*      03-26-1999      Released 1.11m (new release                      *//*                        numbering scheme)                              *//*      04-17-2002      Released version 1.13m                           *//*      11-07-2002      Released version 1.14                            *//*************************************************************************/#define         NU_SOURCE_FILE#include        "cs_extr.h"                 /* Common service functions  */#include        "tc_extr.h"                 /* Thread control functions  */#include        "qu_extr.h"                 /* Queue functions           */#include        "hi_extr.h"                 /* History functions         */#include        "profiler.h"                /* ProView interface         *//* Define internal component function prototypes.  */VOID    QUC_Cleanup(VOID *information);/*************************************************************************//*                                                                       *//* FUNCTION                                                              *//*                                                                       *//*      QUS_Reset_Queue                                                  *//*                                                                       *//* DESCRIPTION                                                           *//*                                                                       *//*      This function resets the specified queue back to the original    *//*      state.  Any messages in the queue are discarded.  Also, any      *//*      tasks currently suspended on the queue are resumed with the      *//*      reset status.                                                    *//*                                                                       *//* CALLED BY                                                             *//*                                                                       *//*      Application                                                      *//*      QUSE_Reset_Queue                    Error checking shell         *//*                                                                       *//* CALLS                                                                 *//*                                                                       *//*      [HIC_Make_History_Entry]            Make entry in history log    *//*      TCC_Resume_Task                     Resume a suspended task      *//*      [TCT_Check_Stack]                   Stack checking function      *//*      TCT_Control_To_System               Transfer control to system   *//*      TCT_System_Protect                  Protect queue data structures*//*      TCT_Unprotect                       Release protection           *//*                                                                       *//* INPUTS                                                                *//*                                                                       *//*      queue_ptr                           Queue control block pointer  *//*                                                                       *//* OUTPUTS                                                               *//*                                                                       *//*      NU_SUCCESS                                                       *//*                                                                       *//* HISTORY                                                               *//*                                                                       *//*        DATE                    REMARKS                                *//*                                                                       *//*      03-01-1993      Created initial version 1.0                      *//*      04-19-1993      Verified version 1.0                             *//*      03-01-1994      Changed function interfaces to                   *//*                      match those in prototype,                        *//*                      added register options, changed                  *//*                      protection logic to reduce                       *//*                      overhead, fixed read and write                   *//*                      pointers to both point at the                    *//*                      start, resulting in version 1.1                  *//*                                                                       *//*      03-18-1994      Verified version 1.1                             *//*      02-04-1998      Corrected SPR434.                                *//*                                                                       *//*************************************************************************/STATUS  QUS_Reset_Queue(NU_QUEUE *queue_ptr){R1 QU_QCB      *queue;                      /* Queue control block ptr   */QU_SUSPEND     *suspend_ptr;                /* Suspend block pointer     */QU_SUSPEND     *next_ptr;                   /* Next suspend block pointer*/STATUS          preempt;                    /* Status for resume call    */NU_SUPERV_USER_VARIABLES    /* Move input queue pointer into internal pointer.  */    queue =  (QU_QCB *) queue_ptr;    /* Switch to supervisor mode */    NU_SUPERVISOR_MODE();#ifdef  NU_ENABLE_STACK_CHECK    /* Call stack checking function to check for an overflow condition.  */    TCT_Check_Stack();#endif#ifdef  NU_ENABLE_HISTORY    /* Make an entry that corresponds to this function in the system history       log.  */    HIC_Make_History_Entry(NU_RESET_QUEUE_ID, (UNSIGNED) queue,                                        (UNSIGNED) 0, (UNSIGNED) 0);#endif    /* Protect against access to the queue.  */    TCT_System_Protect();    /* Pickup the suspended task suspension list.  */    suspend_ptr =  queue -> qu_suspension_list;    /* Walk the chain task(s) currently suspended on the queue.  */    preempt =  0;    while (suspend_ptr)    {        /* Resume the suspended task.  Insure that the status returned is           NU_QUEUE_RESET.  */        suspend_ptr -> qu_return_status =  NU_QUEUE_RESET;        /* Point to the next suspend structure in the link.  */        next_ptr =  (QU_SUSPEND *) (suspend_ptr -> qu_suspend_link.cs_next);        /* Resume the specified task.  */        preempt =  preempt |            TCC_Resume_Task((NU_TASK *) suspend_ptr -> qu_suspended_task,                                                NU_QUEUE_SUSPEND);        /* Determine if the next is the same as the head pointer.  */        if (next_ptr == queue -> qu_suspension_list)            /* Clear the suspension pointer to signal the end of the list               traversal.  */            suspend_ptr =  NU_NULL;        else            /* Position the suspend pointer to the next suspend block.  */            suspend_ptr =  next_ptr;    }    /* Pickup the urgent message suspension list.  */    suspend_ptr =  queue -> qu_urgent_list;    /* Walk the chain task(s) currently suspended on the queue.  */    while (suspend_ptr)    {        /* Resume the suspended task.  Insure that the status returned is           NU_QUEUE_RESET.  */        suspend_ptr -> qu_return_status =  NU_QUEUE_RESET;        /* Point to the next suspend structure in the link.  */        next_ptr =  (QU_SUSPEND *) (suspend_ptr -> qu_suspend_link.cs_next);        /* Resume the specified task.  */        preempt =  preempt |            TCC_Resume_Task((NU_TASK *) suspend_ptr -> qu_suspended_task,                                                NU_QUEUE_SUSPEND);        /* Determine if the next is the same as the head pointer.  */        if (next_ptr == queue -> qu_urgent_list)            /* Clear the suspension pointer to signal the end of the list               traversal.  */            suspend_ptr =  NU_NULL;        else            /* Position suspend pointer to the next suspend block.  */            suspend_ptr =  next_ptr;    }    /* Initialize various elements of the queue.  */    queue -> qu_available =             queue -> qu_end - queue -> qu_start;    queue -> qu_messages =              0;    queue -> qu_read =                  queue -> qu_start;    queue -> qu_write =                 queue -> qu_start;    queue -> qu_tasks_waiting =         0;    queue -> qu_suspension_list =       NU_NULL;    queue -> qu_urgent_list =           NU_NULL;#ifdef INCLUDE_PROVIEW    _RTProf_DumpQueue(RT_PROF_RESET_QUEUE,queue,RT_PROF_OK);#endif    /* Determine if preemption needs to occur.  */    if (preempt)        /* Transfer control to system to facilitate preemption.  */        TCT_Control_To_System();    /* Release protection against access to the queue.  */    TCT_Unprotect();    /* Return to user mode */    NU_USER_MODE();    /* Return a successful completion.  */    return(NU_SUCCESS);}/*************************************************************************//*                                                                       *//* FUNCTION                                                              *//*                                                                       *//*      QUS_Send_To_Front_Of_Queue                                       *//*                                                                       *//* DESCRIPTION                                                           *//*                                                                       *//*      This function sends a message to the front of the specified      *//*      message queue.  The message length is determined by the caller.  *//*      If there are any tasks suspended on the queue for a message, the */

⌨️ 快捷键说明

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