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

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

?? os_core.c

?? 在ATEML公司EB40/40a/42/63/55開(kāi)發(fā)板上運(yùn)行的uCOS-II v2.0
?? C
?? 第 1 頁(yè) / 共 3 頁(yè)
字號(hào):
/*
*********************************************************************************************************
*                                                uC/OS-II
*                                          The Real-Time Kernel
*                                             CORE FUNCTIONS
*
*                        (c) Copyright 1992-1998, Jean J. Labrosse, Plantation, FL
*                                           All Rights Reserved
*
*                                                  V2.00
*
* File : OS_CORE.C
* By   : Jean J. Labrosse
*********************************************************************************************************
*/

#ifndef  OS_MASTER_FILE
#define  OS_GLOBALS
#include "includes.h"
#endif

/*
*********************************************************************************************************
*                                         LOCAL GLOBAL VARIABLES
*********************************************************************************************************
*/
                                       
static  INT8U        OSIntExitY;               /* Variable used by 'OSIntExit' to prevent using locals */

static  OS_STK       OSTaskIdleStk[OS_TASK_IDLE_STK_SIZE];       /* Idle       task stack              */

#if     OS_TASK_STAT_EN
static  OS_STK       OSTaskStatStk[OS_TASK_STAT_STK_SIZE];      /* Statistics task stack               */
#endif

static  OS_TCB       OSTCBTbl[OS_MAX_TASKS + OS_N_SYS_TASKS];   /* Table of TCBs                       */

/*$PAGE*/
/*
*********************************************************************************************************
*                              MAPPING TABLE TO MAP BIT POSITION TO BIT MASK
*
* Note: Index into table is desired bit position, 0..7
*       Indexed value corresponds to bit mask
*********************************************************************************************************
*/

INT8U const OSMapTbl[]   = {0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80};

/*
*********************************************************************************************************
*                                       PRIORITY RESOLUTION TABLE
*
* Note: Index into table is bit pattern to resolve highest priority
*       Indexed value corresponds to highest priority bit position (i.e. 0..7)
*********************************************************************************************************
*/

INT8U const OSUnMapTbl[] = {
    0, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,
    4, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,
    5, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,
    4, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,
    6, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,
    4, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,
    5, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,
    4, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,
    7, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,
    4, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,
    5, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,
    4, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,
    6, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,
    4, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,
    5, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,
    4, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0
};

/*$PAGE*/
/*
*********************************************************************************************************
*                             MAKE TASK READY TO RUN BASED ON EVENT OCCURING
*
* Description: This function is called by other uC/OS-II services and is used to ready a task that was
*              waiting for an event to occur.
*
* Arguments  : pevent    is a pointer to the event control block corresponding to the event.
*
*              msg       is a pointer to a message.  This pointer is used by message oriented services
*                        such as MAILBOXEs and QUEUEs.  The pointer is not used when called by other
*                        service functions.
*
*              msk       is a mask that is used to clear the status byte of the TCB.  For example,
*                        OSSemPost() will pass OS_STAT_SEM, OSMboxPost() will pass OS_STAT_MBOX etc.
*
* Returns    : none
*
* Note       : This function is INTERNAL to uC/OS-II and your application should not call it.
*********************************************************************************************************
*/
#if  (OS_Q_EN && (OS_MAX_QS >= 2)) || OS_MBOX_EN || OS_SEM_EN
void  OSEventTaskRdy (OS_EVENT *pevent, void *msg, INT8U msk)
{
    OS_TCB *ptcb;
    INT8U   x;
    INT8U   y;
    INT8U   bitx;
    INT8U   bity;
    INT8U   prio;


    y    = OSUnMapTbl[pevent->OSEventGrp];            /* Find highest prio. task waiting for message   */
    bity = OSMapTbl[y];
    x    = OSUnMapTbl[pevent->OSEventTbl[y]];
    bitx = OSMapTbl[x];
    prio = (INT8U)((y << 3) + x);                     /* Find priority of task getting the msg         */
    if ((pevent->OSEventTbl[y] &= ~bitx) == 0) {      /* Remove this task from the waiting list        */
        pevent->OSEventGrp &= ~bity;
    }
    ptcb                 =  OSTCBPrioTbl[prio];       /* Point to this task's OS_TCB                   */
    ptcb->OSTCBDly       =  0;                        /* Prevent OSTimeTick() from readying task       */
    ptcb->OSTCBEventPtr  = (OS_EVENT *)0;             /* Unlink ECB from this task                     */
#if (OS_Q_EN && (OS_MAX_QS >= 2)) || OS_MBOX_EN
    ptcb->OSTCBMsg       = msg;                       /* Send message directly to waiting task         */
#else
    msg                  = msg;                       /* Prevent compiler warning if not used          */    
#endif    
    ptcb->OSTCBStat     &= ~msk;                      /* Clear bit associated with event type          */
    if (ptcb->OSTCBStat == OS_STAT_RDY) {             /* See if task is ready (could be susp'd)        */
        OSRdyGrp        |=  bity;                     /* Put task in the ready to run list             */
        OSRdyTbl[y]     |=  bitx;
    }
}
#endif
/*$PAGE*/
/*
*********************************************************************************************************
*                                   MAKE TASK WAIT FOR EVENT TO OCCUR
*
* Description: This function is called by other uC/OS-II services to suspend a task because an event has
*              not occurred.
*
* Arguments  : pevent   is a pointer to the event control block for which the task will be waiting for.
*
* Returns    : none
*
* Note       : This function is INTERNAL to uC/OS-II and your application should not call it.
*********************************************************************************************************
*/
#if  (OS_Q_EN && (OS_MAX_QS >= 2)) || OS_MBOX_EN || OS_SEM_EN
void  OSEventTaskWait (OS_EVENT *pevent)
{
    OSTCBCur->OSTCBEventPtr = pevent;            /* Store pointer to event control block in TCB        */
    if ((OSRdyTbl[OSTCBCur->OSTCBY] &= ~OSTCBCur->OSTCBBitX) == 0) {      /* Task no longer ready      */
        OSRdyGrp &= ~OSTCBCur->OSTCBBitY;
    }
    pevent->OSEventTbl[OSTCBCur->OSTCBY] |= OSTCBCur->OSTCBBitX;          /* Put task in waiting list  */
    pevent->OSEventGrp                   |= OSTCBCur->OSTCBBitY;
}
#endif
/*$PAGE*/
/*
*********************************************************************************************************
*                              MAKE TASK READY TO RUN BASED ON EVENT TIMEOUT
*
* Description: This function is called by other uC/OS-II services to make a task ready to run because a
*              timeout occurred.
*
* Arguments  : pevent   is a pointer to the event control block which is readying a task.
*
* Returns    : none
*
* Note       : This function is INTERNAL to uC/OS-II and your application should not call it.
*********************************************************************************************************
*/
#if  (OS_Q_EN && (OS_MAX_QS >= 2)) || OS_MBOX_EN || OS_SEM_EN
void  OSEventTO (OS_EVENT *pevent)
{
    if ((pevent->OSEventTbl[OSTCBCur->OSTCBY] &= ~OSTCBCur->OSTCBBitX) == 0) {
        pevent->OSEventGrp &= ~OSTCBCur->OSTCBBitY;
    }
    OSTCBCur->OSTCBStat     = OS_STAT_RDY;       /* Set status to ready                                */
    OSTCBCur->OSTCBEventPtr = (OS_EVENT *)0;     /* No longer waiting for event                        */
}
#endif
/*$PAGE*/
/*
*********************************************************************************************************
*                                 INITIALIZE EVENT CONTROL BLOCK'S WAIT LIST
*
* Description: This function is called by other uC/OS-II services to initialize the event wait list.
*
* Arguments  : pevent    is a pointer to the event control block allocated to the event.
*
* Returns    : none
*
* Note       : This function is INTERNAL to uC/OS-II and your application should not call it.
*********************************************************************************************************
*/
#if  (OS_Q_EN && (OS_MAX_QS >= 2)) || OS_MBOX_EN || OS_SEM_EN
void  OSEventWaitListInit (OS_EVENT *pevent)
{
    INT8U i;
    
    
    pevent->OSEventGrp = 0x00;                   /* No task waiting on event                           */
    for (i = 0; i < OS_EVENT_TBL_SIZE; i++) {
        pevent->OSEventTbl[i] = 0x00;
    }
}
#endif
/*$PAGE*/
/*
*********************************************************************************************************
*                                             INITIALIZATION
*
* Description: This function is used to initialize the internals of uC/OS-II and MUST be called prior to
*              creating any uC/OS-II object and, prior to calling OSStart().
*
* Arguments  : none
*
* Returns    : none
*********************************************************************************************************
*/

void OSInit (void)
{
    INT16U i;


    OSTime        = 0L;                                    /* Clear the 32-bit system clock            */
    OSIntNesting  = 0;                                     /* Clear the interrupt nesting counter      */
    OSLockNesting = 0;                                     /* Clear the scheduling lock counter        */
#if OS_TASK_CREATE_EN  || OS_TASK_CREATE_EXT_EN || OS_TASK_DEL_EN
    OSTaskCtr     = 0;                                     /* Clear the number of tasks                */
#endif
    OSRunning     = FALSE;                                 /* Indicate that multitasking not started   */
    OSIdleCtr     = 0L;                                    /* Clear the 32-bit idle counter            */
#if OS_TASK_STAT_EN && OS_TASK_CREATE_EXT_EN
    OSIdleCtrRun  = 0L;
    OSIdleCtrMax  = 0L;
    OSStatRdy     = FALSE;                                 /* Statistic task is not ready              */
#endif
    OSCtxSwCtr    = 0;                                     /* Clear the context switch counter         */
    OSRdyGrp      = 0;                                     /* Clear the ready list                     */
    for (i = 0; i < OS_RDY_TBL_SIZE; i++) {
        OSRdyTbl[i] = 0;
    }
                
    OSPrioCur     = 0;
    OSPrioHighRdy = 0;                                           
    OSTCBHighRdy  = (OS_TCB *)0;                                 /* TCB Initialization                 */
    OSTCBCur      = (OS_TCB *)0;
    OSTCBList     = (OS_TCB *)0;
    for (i = 0; i < (OS_LOWEST_PRIO + 1); i++) {                 /* Clear the priority table           */
        OSTCBPrioTbl[i] = (OS_TCB *)0;
    }
    for (i = 0; i < (OS_MAX_TASKS + OS_N_SYS_TASKS - 1); i++) {  /* Init. list of free TCBs            */
        OSTCBTbl[i].OSTCBNext = &OSTCBTbl[i + 1];
    }
    OSTCBTbl[OS_MAX_TASKS + OS_N_SYS_TASKS - 1].OSTCBNext = (OS_TCB *)0;    /* Last OS_TCB             */
    OSTCBFreeList                                         = &OSTCBTbl[0];

#if OS_MAX_EVENTS >= 2
    for (i = 0; i < (OS_MAX_EVENTS - 1); i++) {            /* Init. list of free EVENT control blocks  */
        OSEventTbl[i].OSEventPtr = (OS_EVENT *)&OSEventTbl[i + 1];
    }
    OSEventTbl[OS_MAX_EVENTS - 1].OSEventPtr = (OS_EVENT *)0;
    OSEventFreeList                          = &OSEventTbl[0];    
#endif

#if OS_Q_EN && (OS_MAX_QS >= 2)
    OSQInit();                                             /* Initialize the message queue structures  */
#endif

#if OS_MEM_EN && OS_MAX_MEM_PART >= 2

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91黄色免费版| 欧美一区二区私人影院日本| 日韩电影免费一区| 一区在线中文字幕| 日韩精品一区二区三区四区| 一本大道久久a久久精品综合| 久久福利视频一区二区| 亚洲精品亚洲人成人网| 国产日本欧美一区二区| 欧美一级精品在线| 欧美日韩视频不卡| 色婷婷精品久久二区二区蜜臀av| 国产乱人伦精品一区二区在线观看| 亚洲成人资源在线| 亚洲一区二区视频在线观看| 亚洲国产精品t66y| 精品国产伦一区二区三区免费| 欧美日韩中文另类| 91麻豆精品一区二区三区| 国产黄色精品网站| 国产原创一区二区三区| 精品一区精品二区高清| 日韩国产成人精品| 石原莉奈一区二区三区在线观看| 亚洲乱码国产乱码精品精小说| 欧美国产乱子伦| 国产日韩精品一区二区三区 | 国产精品理伦片| 精品国精品国产| 精品欧美乱码久久久久久 | 99精品国产一区二区三区不卡| 国产专区欧美精品| 国产在线视频精品一区| 久久99热这里只有精品| 麻豆国产精品视频| 久久精品国产网站| 精品系列免费在线观看| 国产一区二区调教| 国产成人综合自拍| 成人黄页毛片网站| 91亚洲精品乱码久久久久久蜜桃| 日韩avvvv在线播放| 中文字幕成人av| 国产精品视频观看| 亚洲欧洲日韩在线| 亚洲日本丝袜连裤袜办公室| 亚洲精品成人a在线观看| 亚洲一区二区不卡免费| 石原莉奈在线亚洲二区| 久久国产麻豆精品| 国产福利一区二区| av不卡免费在线观看| 91九色最新地址| 欧美日韩国产系列| 精品少妇一区二区三区日产乱码| 欧美va日韩va| 国产精品视频免费看| 亚洲精品第1页| 免费在线看成人av| 国产乱码精品一区二区三区忘忧草 | 精品视频在线免费| 日韩精品中文字幕在线不卡尤物 | 在线亚洲一区二区| 日韩午夜精品电影| 国产精品日韩成人| 一区二区三区免费看视频| 偷拍自拍另类欧美| 国产一区二区三区免费观看| 97精品国产露脸对白| 9191久久久久久久久久久| 久久久久国产精品麻豆| 亚洲欧美日韩中文播放 | 色天天综合色天天久久| 91精品国产全国免费观看| 久久精品人人做| 亚洲成人777| 国产激情视频一区二区三区欧美| 一本大道久久a久久精品综合| 国产成人免费在线观看| 中文无字幕一区二区三区 | 一区二区三区精品视频| 蜜臀av亚洲一区中文字幕| 波多野结衣中文字幕一区二区三区 | 国产精品欧美一区喷水| 亚洲高清免费一级二级三级| 国产精品亚洲一区二区三区妖精| 色呦呦网站一区| 26uuu色噜噜精品一区二区| 亚洲精品乱码久久久久久| 久久草av在线| 在线免费不卡电影| 国产喂奶挤奶一区二区三区| 亚洲一区二区三区在线| 高清成人在线观看| 日韩一级大片在线观看| 一区二区久久久久| 国产高清久久久| 欧美丰满高潮xxxx喷水动漫 | 国产真实乱偷精品视频免| 在线观看三级视频欧美| 欧美经典一区二区| 老司机精品视频导航| 在线观看亚洲a| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | 国产精品高潮呻吟| 国产一区二区免费视频| 欧美妇女性影城| 亚洲欧洲av另类| 国产成a人无v码亚洲福利| 欧美xfplay| 日本成人在线不卡视频| 色就色 综合激情| 国产精品狼人久久影院观看方式| 国产主播一区二区| 欧美xxxxx牲另类人与| 日韩精品福利网| 欧美午夜一区二区| 一区二区三区色| 色网综合在线观看| 亚洲欧洲综合另类| 9人人澡人人爽人人精品| 国产婷婷色一区二区三区四区| 久久国产尿小便嘘嘘| 日韩一级二级三级精品视频| 午夜精品久久久久久久久 | 亚洲国产高清在线| 成人性生交大片免费看中文 | 日韩黄色小视频| 91精品国产一区二区三区| 日韩精品一卡二卡三卡四卡无卡| 日本久久一区二区| 一区二区三区日韩欧美精品| 欧洲精品一区二区| 亚洲精品国产a| 精品视频免费看| 日日夜夜精品视频免费| 欧美高清激情brazzers| 青草av.久久免费一区| 日韩美女视频一区二区在线观看| 久久精品久久久精品美女| 日韩欧美精品三级| 国产在线日韩欧美| 欧美国产日韩亚洲一区| 99久久精品一区| 亚洲一区二区精品视频| 8v天堂国产在线一区二区| 久久精品国产999大香线蕉| 久久嫩草精品久久久精品一| 国产福利一区二区三区视频在线| 中文字幕欧美日本乱码一线二线| youjizz国产精品| 一区二区三区四区视频精品免费| 91福利社在线观看| 日韩av电影免费观看高清完整版| 精品日韩在线观看| 成人国产电影网| 亚洲高清一区二区三区| 日韩精品一区二区在线| 成人黄色在线看| 亚洲一区二区免费视频| 精品少妇一区二区| 99久久精品国产精品久久| 亚洲一区二区在线观看视频| 日韩你懂的在线播放| 成人福利视频在线| 亚洲一区影音先锋| 欧美电影免费提供在线观看| 粗大黑人巨茎大战欧美成人| 伊人夜夜躁av伊人久久| 欧美成人激情免费网| 99精品视频免费在线观看| 亚洲成人tv网| 国产日产亚洲精品系列| 欧美午夜一区二区三区免费大片| 精品一区二区三区久久久| 亚洲天堂精品在线观看| 日韩一区二区三区精品视频| www.色综合.com| 日本aⅴ免费视频一区二区三区| 国产嫩草影院久久久久| 欧美色老头old∨ideo| 丰满岳乱妇一区二区三区| 午夜亚洲国产au精品一区二区| 欧美国产日韩a欧美在线观看| 欧美色精品天天在线观看视频| 国产一区二区三区黄视频 | 国产精品影视在线| 性做久久久久久免费观看欧美| 久久九九久久九九| 欧美日韩国产一级| 91亚洲国产成人精品一区二区三 | 亚洲综合激情另类小说区| 久久久精品影视| 欧美日韩在线综合| 91在线播放网址| 岛国精品一区二区| 麻豆精品视频在线观看视频| 亚洲一区在线播放| 中文字幕一区二区三区不卡| 日韩视频永久免费|