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

📄 csc.c

📁 test file nucleus source
💻 C
📖 第 1 页 / 共 2 页
字号:
/*                                                                       *//*      head                                Pointer to head pointer      *//*      node                                Pointer to node to add       *//*                                                                       *//* OUTPUTS                                                               *//*                                                                       *//*      modified list                                                    *//*                                                                       *//* HISTORY                                                               *//*                                                                       *//*         NAME            DATE                    REMARKS               *//*                                                                       *//*      W. Lamie        03-01-1993      Created initial version 1.0      *//*      D. Lamie        04-19-1993      Verified version 1.0             *//*                                                                       *//*************************************************************************/VOID    CSC_Priority_Place_On_List(CS_NODE **head, CS_NODE *new_node){CS_NODE         *search_ptr;                /* List search pointer       */NU_SUPERV_USER_VARIABLES    /* Switch to supervisor mode */    NU_SUPERVISOR_MODE();    /* Determine if the list in non-empty.  */    if (*head)    {        /* Search the list to find the proper place for the new node.  */        search_ptr =  (*head);        /* Check for insertion before the first node on the list.  */        if (search_ptr -> cs_priority > new_node -> cs_priority)        {            /* Update the head pointer to point at the new node.  */            (*head) =  new_node;        }        else        {            /* We know that the new node is not the highest priority and               must be placed somewhere after the head pointer.  */            /* Move search pointer up to the next node since we are trying               to find the proper node to insert in front of. */            search_ptr =  search_ptr -> cs_next;            while ((search_ptr -> cs_priority <= new_node -> cs_priority) &&                   (search_ptr != (*head)))            {                /* Move along to the next node.  */                search_ptr =  search_ptr -> cs_next;            }        }        /* Insert before search pointer.  */        new_node -> cs_previous =               search_ptr -> cs_previous;        (new_node -> cs_previous) -> cs_next =  new_node;        new_node -> cs_next =                   search_ptr;        (new_node -> cs_next) -> cs_previous =  new_node;    }    else    {        /* The list is empty, setup the head and the new node.  */        (*head) =  new_node;        new_node -> cs_previous =  new_node;        new_node -> cs_next =      new_node;    }    /* Return to user mode */    NU_USER_MODE();}/*************************************************************************//*                                                                       *//* FUNCTION                                                              *//*                                                                       *//*      CSC_Remove_From_List                                             *//*                                                                       *//* DESCRIPTION                                                           *//*                                                                       *//*      This function removes the specified node from the specified      *//*      linked list.                                                     *//*                                                                       *//* CALLED BY                                                             *//*                                                                       *//*      various components                                               *//*                                                                       *//* CALLS                                                                 *//*                                                                       *//*      None                                                             *//*                                                                       *//* INPUTS                                                                *//*                                                                       *//*      head                                Pointer to head pointer      *//*      node                                Pointer to node to add       *//*                                                                       *//* OUTPUTS                                                               *//*                                                                       *//*      modified list                                                    *//*                                                                       *//* HISTORY                                                               *//*                                                                       *//*         NAME            DATE                    REMARKS               *//*                                                                       *//*      W. Lamie        03-01-1993      Created initial version 1.0      *//*      D. Lamie        04-19-1993      Verified version 1.0             *//*      W. Lamie        03-01-1994      Removed clearing link pointers   *//*                                        during removal of a node from  *//*                                        list, resulting in version 1.1 *//*      R. Pfaff -                                                       *//*      D. Lamie        03-18-1994      Verified version 1.1             *//*                                                                       *//*************************************************************************/#ifndef NU_INLINEVOID    CSC_Remove_From_List(CS_NODE **head, CS_NODE *node){NU_SUPERV_USER_VARIABLES    /* Switch to supervisor mode */    NU_SUPERVISOR_MODE();    /* Determine if this is the only node in the system.  */    if (node -> cs_previous == node)    {        /* Yes, this is the only node in the system.  Clear the node's           pointers and the head pointer.  */        (*head) =              NU_NULL;    }    else    {        /* Unlink the node from a multiple node list.  */        (node -> cs_previous) -> cs_next =  node -> cs_next;        (node -> cs_next) -> cs_previous =  node -> cs_previous;        /* Check to see if the node to delete is at the head of the           list. */        if (node == *head)            /* Move the head pointer to the node after.  */            *head =  node -> cs_next;    }    /* Return to user mode */    NU_USER_MODE();}#endif

⌨️ 快捷键说明

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