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

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

?? ucos.c

?? ppc860平臺上移植uc OS的實例
?? C
?? 第 1 頁 / 共 5 頁
字號:
    pevent = OSEventFreeList;                              /* Get next free event control block        */
    if (OSEventFreeList != (OS_EVENT *)0) {                /* See if pool of free ECB pool was empty   */
        OSEventFreeList = (OS_EVENT *)OSEventFreeList->OSEventPtr;
    }
    OS_EXIT_CRITICAL();
    if (pevent != (OS_EVENT *)0) {                         /* Get an event control block               */
        pevent->OSEventCnt    = cnt;                       /* Set semaphore value                      */
        pevent->OSEventGrp    = 0x00;                      /* Initialize rest of event control block   */
        pevent->OSEventTbl[0] = 0x00;
        pevent->OSEventTbl[1] = 0x00;
        pevent->OSEventTbl[2] = 0x00;
        pevent->OSEventTbl[3] = 0x00;
        pevent->OSEventTbl[4] = 0x00;
        pevent->OSEventTbl[5] = 0x00;
        pevent->OSEventTbl[6] = 0x00;
        pevent->OSEventTbl[7] = 0x00;
        return (pevent);
    } else {
        return ((OS_EVENT *)0);
    }
}

/*$PAGE*/
/*
*********************************************************************************************************
*                                           ACCEPT SEMAPHORE
*
* Description: This function checks the semaphore to see if the resource is available or if an event
*              occurred.  Unlike OSSemPend(), OSSemAccept() does not suspend the calling task if the
*              resource is not available or the event did not occur.
* Arguments  : 'pevent'   is a pointer to the event control block
* Returns    : >  0       if the resource is available or the event did not occur
*                         the semaphore is decremented so the next time OSSemAccept() is called, the
*                         resource will no longer be available.
*              == 0       if the resource is not available or the event did not occur
*********************************************************************************************************
*/

UWORD OSSemAccept(OS_EVENT *pevent)
{
    UWORD cnt;


    OS_ENTER_CRITICAL();
    cnt = pevent->OSEventCnt;
    if (cnt > 0) {                               /* See if resource is available                       */
        pevent->OSEventCnt--;                    /* Yes, decrement semaphore and notify caller         */
    }
    OS_EXIT_CRITICAL();
    return (cnt);                                /* Return semaphore count                             */
}

/*$PAGE*/
/*
*********************************************************************************************************
*                                           PEND ON SEMAPHORE
*********************************************************************************************************
*/

void OSSemPend(OS_EVENT *pevent, UWORD timeout, UBYTE *err)
{
    OS_ENTER_CRITICAL();
    if (pevent->OSEventCnt > 0) {                     /* If sem. is positive, resource available ...   */
        pevent->OSEventCnt--;                         /* ... decrement semaphore only if positive.     */
        OS_EXIT_CRITICAL();
        *err = OS_NO_ERR;
    } else {                                          /* Otherwise, must wait until event occurs       */
        OSTCBCur->OSTCBStat    |= OS_STAT_SEM;        /* Resource not available, pend on semaphore     */
        OSTCBCur->OSTCBDly      = timeout;            /* Store pend timeout in TCB                     */
        OSTCBCur->OSTCBEventPtr = pevent;             /* Store pointer to ECB 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;
        OS_EXIT_CRITICAL();
        OSSched();                                    /* Find next highest priority task ready         */
        OS_ENTER_CRITICAL();
        if (OSTCBCur->OSTCBStat & OS_STAT_SEM) {      /* Must have timed out if still waiting for event*/
            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;  /* Task is no longer waiting for the event       */
            OS_EXIT_CRITICAL();
            *err = OS_TIMEOUT;                        /* Indicate that didn't get event within TO      */
        } else {
            OSTCBCur->OSTCBEventPtr = (OS_EVENT *)0;
            OS_EXIT_CRITICAL();
            *err = OS_NO_ERR;
        }
    }
}
/*$PAGE*/
/*
*********************************************************************************************************
*                                         POST TO A SEMAPHORE
*********************************************************************************************************
*/

UBYTE OSSemPost(OS_EVENT *pevent)
{
    OS_TCB *ptcb;
    UBYTE   x;
    UBYTE   y;
    UBYTE   bitx;
    UBYTE   bity;
    UBYTE   p;


    OS_ENTER_CRITICAL();
    if (pevent->OSEventGrp) {                         /* See if any task waiting for semaphore         */
        y    = OSUnMapTbl[pevent->OSEventGrp];        /* Find highest priority task pending on event   */
        bity = OSMapTbl[y];
        x    = OSUnMapTbl[pevent->OSEventTbl[y]];
        bitx = OSMapTbl[x];
        p    = (y << 3) + x;
        if ((pevent->OSEventTbl[y] &= ~bitx) == 0) {  /* Remove this task from the waiting list        */
            pevent->OSEventGrp &= ~bity;
        }
        ptcb                 =  OSTCBPrioTbl[p];      /* Point to this task's OS_TCB                   */
        ptcb->OSTCBDly       =  0;                    /* Prevent OSTimeTick() from readying this task  */
        ptcb->OSTCBEventPtr  = (OS_EVENT *)0;         /* Unlink event control block from this task     */
        ptcb->OSTCBStat     &= ~OS_STAT_SEM;          /* Clear bit associated with event type          */
        if (ptcb->OSTCBStat == OS_STAT_RDY) {         /* See if task is ready (could be suspended)     */
            OSRdyGrp        |=  bity;                 /* Put task in the ready to run list             */
            OSRdyTbl[y]     |=  bitx;
        }
        OS_EXIT_CRITICAL();
        OSSched();                                    /* Find highest priority task ready to run       */
        return (OS_NO_ERR);
    } else {
        if (pevent->OSEventCnt < 65535) {             /* Make sure semaphore will not overflow         */
            pevent->OSEventCnt++;                     /* Increment semaphore count to register event   */
            OS_EXIT_CRITICAL();
            return (OS_NO_ERR);
        } else {                                      /* Semaphore value has reached its maximum       */
            OS_EXIT_CRITICAL();
            return (OS_SEM_OVF);
        }
    }
}
#endif
/*$PAGE*/
#if OS_MBOX_EN
/*
*********************************************************************************************************
*                                      INITIALIZE MESSAGE MAILBOX
*********************************************************************************************************
*/

OS_EVENT *OSMboxCreate(void *msg)
{
    OS_EVENT *pevent;


    OS_ENTER_CRITICAL();
    pevent = OSEventFreeList;                    /* Get next free event control block                  */
    if (OSEventFreeList != (OS_EVENT *)0) {      /* See if pool of free ECB pool was empty             */
        OSEventFreeList = (OS_EVENT *)OSEventFreeList->OSEventPtr;
    }
    OS_EXIT_CRITICAL();
    if (pevent != (OS_EVENT *)0) {
        pevent->OSEventPtr    = msg;             /* Deposit message in event control block             */
        pevent->OSEventGrp    = 0x00;            /* Initialize rest of event control block             */
        pevent->OSEventTbl[0] = 0x00;
        pevent->OSEventTbl[1] = 0x00;
        pevent->OSEventTbl[2] = 0x00;
        pevent->OSEventTbl[3] = 0x00;
        pevent->OSEventTbl[4] = 0x00;
        pevent->OSEventTbl[5] = 0x00;
        pevent->OSEventTbl[6] = 0x00;
        pevent->OSEventTbl[7] = 0x00;
    }
    return (pevent);                             /* Return pointer to event control block              */
}
/*$PAGE*/
/*
*********************************************************************************************************
*                                     ACCEPT MESSAGE FROM MAILBOX
*
* Description: This function checks the mailbox to see if a message is available.  Unlike OSMboxPend(),
*              OSMboxAccept() does not suspend the calling task if a message is not available.
* Arguments  : 'pevent'      is a pointer to the event control block
* Returns    : != (void *)0  is the message in the mailbox if one is available.  The mailbox is cleared
*                            so the next time OSMboxAccept() is called, the mailbox will be empty.
*              == (void *)0  if the mailbox is empty
*********************************************************************************************************
*/

void *OSMboxAccept(OS_EVENT *pevent)
{
    void  *msg;


    OS_ENTER_CRITICAL();
    if ((msg = pevent->OSEventPtr) != (void *)0) {    /* See if there is already a message             */
        pevent->OSEventPtr = (void *)0;               /* Clear the mailbox                             */
    }
    OS_EXIT_CRITICAL();
    return (msg);                                     /* Return the message received (or NULL)         */
}
/*$PAGE*/
/*
*********************************************************************************************************
*                                      PEND ON MAILBOX FOR A MESSAGE
*********************************************************************************************************
*/

void *OSMboxPend(OS_EVENT *pevent, UWORD timeout, UBYTE *err)
{
    void  *msg;


    OS_ENTER_CRITICAL();
    if ((msg = pevent->OSEventPtr) != (void *)0) {    /* See if there is already a message             */
        pevent->OSEventPtr = (void *)0;               /* Clear the mailbox                             */
        OS_EXIT_CRITICAL();
        *err = OS_NO_ERR;
    } else {
        OSTCBCur->OSTCBStat    |= OS_STAT_MBOX;       /* Message not available, task will pend         */
        OSTCBCur->OSTCBDly      = timeout;            /* Load timeout in TCB                           */
        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;
        OS_EXIT_CRITICAL();
        OSSched();                                    /* Find next highest priority task ready to run  */
        OS_ENTER_CRITICAL();
        if ((msg = OSTCBCur->OSTCBMsg) != (void *)0) {     /* See if we were given the message         */
            OSTCBCur->OSTCBMsg      = (void *)0;           /* Yes, clear message received              */
            OSTCBCur->OSTCBStat     = OS_STAT_RDY;
            OSTCBCur->OSTCBEventPtr = (OS_EVENT *)0;       /* No longer waiting for event              */
            OS_EXIT_CRITICAL();
            *err                    = OS_NO_ERR;
        } else if (OSTCBCur->OSTCBStat & OS_STAT_MBOX) {   /* If status is not OS_STAT_RDY, timed out  */
            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;
            OS_EXIT_CRITICAL();
            msg                     = (void *)0;           /* Set message contents to NULL             */
            *err                    = OS_TIMEOUT;          /* Indicate that a timeout occured          */
        } else {
            msg                     = pevent->OSEventPtr;  /* Message received                         */
            pevent->OSEventPtr      = (void *)0;           /* Clear the mailbox                        */
            OS_EXIT_CRITICAL();
            *err                    = OS_NO_ERR;
        }
    }
    return (msg);                                          /* Return the message received (or NULL)    */
}
/*$PAGE*/
/*
*********************************************************************************************************
*                                       POST MESSAGE TO A MAILBOX
*********************************************************************************************************
*/

UBYTE OSMboxPost(OS_EVENT *pevent, void *msg)
{

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲欧洲成人自拍| 亚洲国产一区二区视频| 欧美日韩dvd在线观看| 国产麻豆91精品| 热久久一区二区| 亚洲欧美日韩在线| 久久嫩草精品久久久精品| 欧美色精品天天在线观看视频| 激情偷乱视频一区二区三区| 亚洲成人午夜影院| 国产精品国产自产拍高清av王其 | 国产一区二区中文字幕| 一区二区三区在线免费观看| 久久人人97超碰com| 欧美精品色综合| 日本韩国精品一区二区在线观看| 九色|91porny| 日本网站在线观看一区二区三区| 亚洲欧洲av色图| 中文字幕欧美国产| 亚洲精品一区二区三区香蕉| 91精品国产综合久久香蕉的特点| 日本丶国产丶欧美色综合| 成人一级黄色片| 国产一区二区精品久久99| 日韩国产精品大片| 图片区小说区国产精品视频| 一区二区三区日韩欧美精品| 国产精品久久久久久亚洲伦| 国产亚洲精品免费| 26uuu欧美日本| 日韩欧美一区二区免费| 91精品国模一区二区三区| 欧美日韩一区中文字幕| 欧美性猛片xxxx免费看久爱| 色噜噜狠狠色综合欧洲selulu| 成人国产在线观看| 成人毛片视频在线观看| 成人福利视频网站| 99久久精品一区| 91视视频在线观看入口直接观看www| 国产精品一区二区你懂的| 韩国欧美国产1区| 国产资源精品在线观看| 国产乱淫av一区二区三区| 国产乱码精品一区二区三区av | 成人动漫在线一区| 成人黄色av网站在线| 99国产精品99久久久久久| 成人高清伦理免费影院在线观看| 国产成人8x视频一区二区| 国产福利不卡视频| 99久久国产综合精品麻豆| 色呦呦日韩精品| 欧美喷潮久久久xxxxx| 日韩一区二区三免费高清| www国产精品av| 国产精品萝li| 亚洲精品日韩综合观看成人91| 亚洲影视在线播放| 日韩高清不卡在线| 国产精品一区二区无线| 99re亚洲国产精品| 欧美性欧美巨大黑白大战| 91麻豆精品国产91久久久久久 | 亚洲卡通欧美制服中文| 亚洲最新视频在线观看| 日日摸夜夜添夜夜添国产精品| 美女一区二区久久| 成人免费观看视频| 欧美日韩一区二区在线观看视频| 日韩一区二区精品在线观看| 欧美国产欧美综合| 亚洲国产精品影院| 国产一区二区电影| 色88888久久久久久影院按摩| 在线播放91灌醉迷j高跟美女 | 亚洲国产日韩a在线播放| 日韩电影在线一区二区| 国产成人精品一区二区三区四区| 色综合色综合色综合| 欧美一二三四区在线| 欧美国产成人精品| 污片在线观看一区二区| 成人免费视频网站在线观看| 欧美精品精品一区| 中文字幕av一区二区三区免费看 | 亚洲精品在线观看网站| 亚洲精品少妇30p| 国产精品正在播放| 欧美日韩大陆一区二区| 日本一区二区三级电影在线观看 | 亚洲www啪成人一区二区麻豆| 国产一本一道久久香蕉| 欧美中文一区二区三区| 久久精品一二三| 日韩电影网1区2区| 91在线观看成人| 26uuu久久天堂性欧美| 亚洲一区二区三区视频在线| 成人性生交大合| 欧美成人综合网站| 亚洲国产综合人成综合网站| 成人黄页在线观看| 亚洲精品一区二区三区四区高清| 亚洲自拍偷拍欧美| 成人h动漫精品| 91成人国产精品| 精油按摩中文字幕久久| av电影一区二区| 精品理论电影在线| 亚洲一区二区三区四区在线观看| 粉嫩av一区二区三区| 欧美精品一区二区三区很污很色的 | 欧美日韩黄色一区二区| 国产三级欧美三级| 国产一区二区三区四区五区美女 | 玉足女爽爽91| av不卡一区二区三区| 国产日韩欧美电影| 国产毛片精品视频| 欧美xxx久久| 日本不卡一区二区三区| 欧美日韩国产综合一区二区| 一区二区三区**美女毛片| 91在线观看美女| 综合欧美亚洲日本| 成人小视频在线观看| 久久综合九色综合欧美就去吻 | 亚洲一区av在线| 91麻豆精品视频| 亚洲色图视频网| 99久久精品情趣| 亚洲欧美另类久久久精品| a美女胸又www黄视频久久| 欧美国产1区2区| 99视频精品全部免费在线| 国产精品久久久久三级| 99久久精品国产观看| 亚洲精品国产a| 欧美色图一区二区三区| 亚洲二区在线视频| 5858s免费视频成人| 日本va欧美va瓶| 2023国产精品视频| 成人小视频免费在线观看| 国产精品美女www爽爽爽| 不卡的av在线播放| 一区二区三区在线视频免费| 91久久一区二区| 五月激情综合网| 精品国产污污免费网站入口 | 国模冰冰炮一区二区| 久久精品一区二区| av电影天堂一区二区在线观看| 中文字幕中文在线不卡住| 91视频com| 亚洲成人一区在线| 欧美大片免费久久精品三p| 国产成人精品网址| 亚洲激情综合网| 欧美一级淫片007| 国产美女一区二区三区| 亚洲欧美在线高清| 欧美高清www午色夜在线视频| 免费av网站大全久久| 国产亚洲精品免费| 91福利精品视频| 蜜桃久久久久久| 国产精品久久久久影视| 久久综合成人精品亚洲另类欧美 | 欧美高清视频www夜色资源网| 蜜桃久久av一区| 国产精品乱码一区二三区小蝌蚪| 色综合久久久久综合体| 日韩成人一级大片| 国产精品三级久久久久三级| 欧美日韩在线免费视频| 国产一区二区精品久久| 一区二区欧美精品| 2020国产精品久久精品美国| 色狠狠一区二区| 激情图区综合网| 亚洲电影视频在线| 国产精品视频线看| 制服丝袜成人动漫| av在线不卡电影| 麻豆91在线看| 伊人婷婷欧美激情| 欧美成人猛片aaaaaaa| 色屁屁一区二区| 国产一区二区三区最好精华液| 亚洲精品久久久蜜桃| 国产亚洲午夜高清国产拍精品| 欧美日韩精品一区二区在线播放| 国产尤物一区二区| 日韩电影在线观看一区| 亚洲欧美成人一区二区三区| 久久久精品国产免费观看同学| 欧美片在线播放|