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

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

?? ucos ii v2.9 ?

?? uCOSII_V2.9
?? 9 ?
?? 第 1 頁 / 共 4 頁
字號:
#if OS_CRITICAL_METHOD == 3u                               /* Allocate storage for CPU status register */
    OS_CPU_SR     cpu_sr = 0u;
#endif



#ifdef OS_SAFETY_CRITICAL
    if (perr == (INT8U *)0) {
        OS_SAFETY_CRITICAL_EXCEPTION();
    }
#endif

#if OS_ARG_CHK_EN > 0u
    if (pgrp == (OS_FLAG_GRP *)0) {                        /* Validate 'pgrp'                          */
        *perr = OS_ERR_FLAG_INVALID_PGRP;
        return (pgrp);
    }
#endif
    if (OSIntNesting > 0u) {                               /* See if called from ISR ...               */
        *perr = OS_ERR_DEL_ISR;                            /* ... can't DELETE from an ISR             */
        return (pgrp);
    }
    if (pgrp->OSFlagType != OS_EVENT_TYPE_FLAG) {          /* Validate event group type                */
        *perr = OS_ERR_EVENT_TYPE;
        return (pgrp);
    }
    OS_ENTER_CRITICAL();
    if (pgrp->OSFlagWaitList != (void *)0) {               /* See if any tasks waiting on event flags  */
        tasks_waiting = OS_TRUE;                           /* Yes                                      */
    } else {
        tasks_waiting = OS_FALSE;                          /* No                                       */
    }
    switch (opt) {
        case OS_DEL_NO_PEND:                               /* Delete group if no task waiting          */
             if (tasks_waiting == OS_FALSE) {
#if OS_FLAG_NAME_EN > 0u
                 pgrp->OSFlagName     = (INT8U *)(void *)"?";
#endif
                 pgrp->OSFlagType     = OS_EVENT_TYPE_UNUSED;
                 pgrp->OSFlagWaitList = (void *)OSFlagFreeList; /* Return group to free list           */
                 pgrp->OSFlagFlags    = (OS_FLAGS)0;
                 OSFlagFreeList       = pgrp;
                 OS_EXIT_CRITICAL();
                 *perr                = OS_ERR_NONE;
                 pgrp_return          = (OS_FLAG_GRP *)0;  /* Event Flag Group has been deleted        */
             } else {
                 OS_EXIT_CRITICAL();
                 *perr                = OS_ERR_TASK_WAITING;
                 pgrp_return          = pgrp;
             }
             break;

        case OS_DEL_ALWAYS:                                /* Always delete the event flag group       */
             pnode = (OS_FLAG_NODE *)pgrp->OSFlagWaitList;
             while (pnode != (OS_FLAG_NODE *)0) {          /* Ready ALL tasks waiting for flags        */
                 (void)OS_FlagTaskRdy(pnode, (OS_FLAGS)0);
                 pnode = (OS_FLAG_NODE *)pnode->OSFlagNodeNext;
             }
#if OS_FLAG_NAME_EN > 0u
             pgrp->OSFlagName     = (INT8U *)(void *)"?";
#endif
             pgrp->OSFlagType     = OS_EVENT_TYPE_UNUSED;
             pgrp->OSFlagWaitList = (void *)OSFlagFreeList;/* Return group to free list                */
             pgrp->OSFlagFlags    = (OS_FLAGS)0;
             OSFlagFreeList       = pgrp;
             OS_EXIT_CRITICAL();
             if (tasks_waiting == OS_TRUE) {               /* Reschedule only if task(s) were waiting  */
                 OS_Sched();                               /* Find highest priority task ready to run  */
             }
             *perr = OS_ERR_NONE;
             pgrp_return          = (OS_FLAG_GRP *)0;      /* Event Flag Group has been deleted        */
             break;

        default:
             OS_EXIT_CRITICAL();
             *perr                = OS_ERR_INVALID_OPT;
             pgrp_return          = pgrp;
             break;
    }
    return (pgrp_return);
}
#endif
/*$PAGE*/
/*
*********************************************************************************************************
*                                 GET THE NAME OF AN EVENT FLAG GROUP
*
* Description: This function is used to obtain the name assigned to an event flag group
*
* Arguments  : pgrp      is a pointer to the event flag group.
*
*              pname     is pointer to a pointer to an ASCII string that will receive the name of the event flag
*                        group.
*
*              perr      is a pointer to an error code that can contain one of the following values:
*
*                        OS_ERR_NONE                if the requested task is resumed
*                        OS_ERR_EVENT_TYPE          if 'pevent' is not pointing to an event flag group
*                        OS_ERR_PNAME_NULL          You passed a NULL pointer for 'pname'
*                        OS_ERR_FLAG_INVALID_PGRP   if you passed a NULL pointer for 'pgrp'
*                        OS_ERR_NAME_GET_ISR        if you called this function from an ISR
*
* Returns    : The length of the string or 0 if the 'pgrp' is a NULL pointer.
*********************************************************************************************************
*/

#if OS_FLAG_NAME_EN > 0u
INT8U  OSFlagNameGet (OS_FLAG_GRP   *pgrp,
                      INT8U        **pname,
                      INT8U         *perr)
{
    INT8U      len;
#if OS_CRITICAL_METHOD == 3u                     /* Allocate storage for CPU status register           */
    OS_CPU_SR  cpu_sr = 0u;
#endif



#ifdef OS_SAFETY_CRITICAL
    if (perr == (INT8U *)0) {
        OS_SAFETY_CRITICAL_EXCEPTION();
    }
#endif

#if OS_ARG_CHK_EN > 0u
    if (pgrp == (OS_FLAG_GRP *)0) {              /* Is 'pgrp' a NULL pointer?                          */
        *perr = OS_ERR_FLAG_INVALID_PGRP;
        return (0u);
    }
    if (pname == (INT8U **)0) {                   /* Is 'pname' a NULL pointer?                         */
        *perr = OS_ERR_PNAME_NULL;
        return (0u);
    }
#endif
    if (OSIntNesting > 0u) {                     /* See if trying to call from an ISR                  */
        *perr = OS_ERR_NAME_GET_ISR;
        return (0u);
    }
    OS_ENTER_CRITICAL();
    if (pgrp->OSFlagType != OS_EVENT_TYPE_FLAG) {
        OS_EXIT_CRITICAL();
        *perr = OS_ERR_EVENT_TYPE;
        return (0u);
    }
    *pname = pgrp->OSFlagName;
    len    = OS_StrLen(*pname);
    OS_EXIT_CRITICAL();
    *perr  = OS_ERR_NONE;
    return (len);
}
#endif

/*$PAGE*/
/*
*********************************************************************************************************
*                                 ASSIGN A NAME TO AN EVENT FLAG GROUP
*
* Description: This function assigns a name to an event flag group.
*
* Arguments  : pgrp      is a pointer to the event flag group.
*
*              pname     is a pointer to an ASCII string that will be used as the name of the event flag
*                        group.
*
*              perr      is a pointer to an error code that can contain one of the following values:
*
*                        OS_ERR_NONE                if the requested task is resumed
*                        OS_ERR_EVENT_TYPE          if 'pevent' is not pointing to an event flag group
*                        OS_ERR_PNAME_NULL          You passed a NULL pointer for 'pname'
*                        OS_ERR_FLAG_INVALID_PGRP   if you passed a NULL pointer for 'pgrp'
*                        OS_ERR_NAME_SET_ISR        if you called this function from an ISR
*
* Returns    : None
*********************************************************************************************************
*/

#if OS_FLAG_NAME_EN > 0u
void  OSFlagNameSet (OS_FLAG_GRP  *pgrp,
                     INT8U        *pname,
                     INT8U        *perr)
{
#if OS_CRITICAL_METHOD == 3u                     /* Allocate storage for CPU status register           */
    OS_CPU_SR  cpu_sr = 0u;
#endif



#ifdef OS_SAFETY_CRITICAL
    if (perr == (INT8U *)0) {
        OS_SAFETY_CRITICAL_EXCEPTION();
    }
#endif

#if OS_ARG_CHK_EN > 0u
    if (pgrp == (OS_FLAG_GRP *)0) {              /* Is 'pgrp' a NULL pointer?                          */
        *perr = OS_ERR_FLAG_INVALID_PGRP;
        return;
    }
    if (pname == (INT8U *)0) {                   /* Is 'pname' a NULL pointer?                         */
        *perr = OS_ERR_PNAME_NULL;
        return;
    }
#endif
    if (OSIntNesting > 0u) {                     /* See if trying to call from an ISR                  */
        *perr = OS_ERR_NAME_SET_ISR;
        return;
    }
    OS_ENTER_CRITICAL();
    if (pgrp->OSFlagType != OS_EVENT_TYPE_FLAG) {
        OS_EXIT_CRITICAL();
        *perr = OS_ERR_EVENT_TYPE;
        return;
    }
    pgrp->OSFlagName = pname;
    OS_EXIT_CRITICAL();
    *perr            = OS_ERR_NONE;
    return;
}
#endif

/*$PAGE*/
/*
*********************************************************************************************************
*                                        WAIT ON AN EVENT FLAG GROUP
*
* Description: This function is called to wait for a combination of bits to be set in an event flag
*              group.  Your application can wait for ANY bit to be set or ALL bits to be set.
*
* Arguments  : pgrp          is a pointer to the desired event flag group.
*
*              flags         Is a bit pattern indicating which bit(s) (i.e. flags) you wish to wait for.
*                            The bits you want are specified by setting the corresponding bits in
*                            'flags'.  e.g. if your application wants to wait for bits 0 and 1 then
*                            'flags' would contain 0x03.
*
*              wait_type     specifies whether you want ALL bits to be set or ANY of the bits to be set.
*                            You can specify the following argument:
*
*                            OS_FLAG_WAIT_CLR_ALL   You will wait for ALL bits in 'mask' to be clear (0)
*                            OS_FLAG_WAIT_SET_ALL   You will wait for ALL bits in 'mask' to be set   (1)
*                            OS_FLAG_WAIT_CLR_ANY   You will wait for ANY bit  in 'mask' to be clear (0)
*                            OS_FLAG_WAIT_SET_ANY   You will wait for ANY bit  in 'mask' to be set   (1)
*
*                            NOTE: Add OS_FLAG_CONSUME if you want the event flag to be 'consumed' by
*                                  the call.  Example, to wait for any flag in a group AND then clear
*                                  the flags that are present, set 'wait_type' to:
*
*                                  OS_FLAG_WAIT_SET_ANY + OS_FLAG_CONSUME
*
*              timeout       is an optional timeout (in clock ticks) that your task will wait for the
*                            desired bit combination.  If you specify 0, however, your task will wait
*                            forever at the specified event flag group or, until a message arrives.
*
*              perr          is a pointer to an error code and can be:
*                            OS_ERR_NONE               The desired bits have been set within the specified
*                                                      'timeout'.
*                            OS_ERR_PEND_ISR           If you tried to PEND from an ISR
*                            OS_ERR_FLAG_INVALID_PGRP  If 'pgrp' is a NULL pointer.
*                            OS_ERR_EVENT_TYPE         You are not pointing to an event flag group
*                            OS_ERR_TIMEOUT            The bit(s) have not been set in the specified
*                                                      'timeout'.
*                            OS_ERR_PEND_ABORT         The wait on the flag was aborted.
*                            OS_ERR_FLAG_WAIT_TYPE     You didn't specify a proper 'wait_type' argument.
*
* Returns    : The flags in the event flag group that made the task ready or, 0 if a timeout or an error
*              occurred.
*
* Called from: Task ONLY
*
* Note(s)    : 1) IMPORTANT, the behavior of this function has changed from PREVIOUS versions.  The
*                 function NOW returns the flags that were ready INSTEAD of the current state of the
*                 event flags.
*********************************************************************************************************
*/

OS_FLAGS  OSFlagPend (OS_FLAG_GRP  *pgrp,
                      OS_FLAGS      flags,
                      INT8U         wait_type,
                      INT32U        timeout,
                      INT8U        *perr)
{
    OS_FLAG_NODE  node;
    OS_FLAGS      flags_rdy;
    INT8U         result;
    INT8U         pend_stat;
    BOOLEAN       consume;
#if OS_CRITICAL_METHOD == 3u                               /* Allocate storage for CPU status register */
    OS_CPU_SR     cpu_sr = 0u;
#endif



#ifdef OS_SAFETY_CRITICAL
    if (perr == (INT8U *)0) {
        OS_SAFETY_CRITICAL_EXCEPTION();
    }
#endif

#if OS_ARG_CHK_EN > 0u
    if (pgrp == (OS_FLAG_GRP *)0) {                        /* Validate 'pgrp'                          */
        *perr = OS_ERR_FLAG_INVALID_PGRP;
        return ((OS_FLAGS)0);
    }
#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品色呦呦| 精品国产免费久久 | 天天射综合影视| 7777精品伊人久久久大香线蕉 | 国产精品久久二区二区| 国产在线视频不卡二| 久久精子c满五个校花| 成人免费视频播放| 亚洲综合一区二区三区| 777奇米成人网| 国产精品一区二区三区网站| 国产精品美女www爽爽爽| 一本色道综合亚洲| 天天综合网天天综合色| 久久久综合精品| 色综合中文字幕| 日韩影院在线观看| 国产日韩成人精品| 91影院在线免费观看| 国产一区二区三区免费| 久久嫩草精品久久久精品| 成人av免费在线| 亚洲成人精品一区| 久久亚洲影视婷婷| 色8久久人人97超碰香蕉987| 美女视频免费一区| 一色屋精品亚洲香蕉网站| 欧美日韩国产不卡| 成人av手机在线观看| 亚洲成av人影院| 国产日韩精品一区| 69堂成人精品免费视频| 国产999精品久久| 亚洲成av人片一区二区梦乃| 久久久久成人黄色影片| 色诱亚洲精品久久久久久| 久久99精品国产麻豆婷婷洗澡| 国产精品久久久久久亚洲毛片| 欧美手机在线视频| 国产成人综合精品三级| 亚洲国产精品久久久久秋霞影院| 久久精品水蜜桃av综合天堂| 欧美色视频在线观看| 国产精品综合视频| 三级亚洲高清视频| 成人欧美一区二区三区黑人麻豆| 日韩午夜中文字幕| 91国偷自产一区二区使用方法| 韩国欧美国产一区| 五月天亚洲婷婷| 亚洲欧洲日韩女同| 久久久国产精华| 日韩视频中午一区| 欧美日韩中文字幕一区二区| 成人性生交大片免费看中文网站| 免费人成精品欧美精品| 一区二区三区在线免费观看| 久久久久久久精| 日韩一区二区三区高清免费看看| 91视视频在线观看入口直接观看www| 国内成人精品2018免费看| 午夜精品视频在线观看| 一区二区在线观看视频在线观看| 26uuuu精品一区二区| 欧美精品久久久久久久多人混战| 91网站在线播放| 成人一区在线看| 国产精品一区一区| 国产一区视频导航| 国产乱码精品一区二区三| 日产国产高清一区二区三区| 亚洲一二三专区| 亚洲综合色噜噜狠狠| 亚洲精品中文字幕乱码三区| 国产精品二三区| 日韩一区在线播放| 国产精品毛片久久久久久久| 国产日产亚洲精品系列| 久久精品视频一区二区三区| 欧美大胆人体bbbb| 欧美成人在线直播| 欧美成人一级视频| 精品少妇一区二区三区免费观看| 日韩一区二区三区高清免费看看| 欧美一区二区三区四区在线观看| 欧美肥妇free| 91精品在线观看入口| 欧美一级夜夜爽| 精品国产免费一区二区三区香蕉| 2023国产精品| 国产欧美精品在线观看| 国产精品护士白丝一区av| 亚洲少妇中出一区| 亚洲一二三区在线观看| 天堂成人国产精品一区| 亚洲国产美女搞黄色| 三级不卡在线观看| 麻豆成人久久精品二区三区小说| 久久99热这里只有精品| 国产精品亚洲综合一区在线观看| 国产91丝袜在线播放九色| proumb性欧美在线观看| 欧洲精品一区二区| 日韩天堂在线观看| 国产精品区一区二区三| 亚洲一区视频在线| 美腿丝袜亚洲三区| 高清不卡一区二区| 欧美亚洲精品一区| 欧美大片免费久久精品三p| 亚洲国产高清在线观看视频| 亚洲色图丝袜美腿| 日韩av网站在线观看| 国产成人亚洲综合a∨婷婷| 99视频精品在线| 欧美一区二区免费观在线| 久久精品一区蜜桃臀影院| 亚洲精品美国一| 久久精品av麻豆的观看方式| 成人高清视频在线观看| 欧美蜜桃一区二区三区| 久久久久99精品一区| 一区二区三区四区高清精品免费观看 | 国产综合色精品一区二区三区| 国产白丝精品91爽爽久久| 欧美日韩精品综合在线| 国产欧美一区视频| 日韩高清不卡一区| 99久久精品免费看国产 | 国产九色sp调教91| 欧洲视频一区二区| 中文字幕欧美日韩一区| 日韩av一区二区三区| 99久久婷婷国产综合精品| 日韩欧美在线不卡| 亚洲免费成人av| 国产乱理伦片在线观看夜一区 | 99精品1区2区| 日韩精品一区二区三区四区视频| 亚洲人成网站在线| 国产综合成人久久大片91| 欧美麻豆精品久久久久久| 国产精品伦理在线| 国产一区二区在线观看免费| 欧美性猛交xxxx黑人交| 欧美国产日韩一二三区| 秋霞国产午夜精品免费视频| 色婷婷综合激情| 国产精品国模大尺度视频| 国产精品中文字幕日韩精品| 欧美一区二区三区色| 婷婷久久综合九色综合绿巨人| voyeur盗摄精品| 国产三级精品在线| 精品无码三级在线观看视频| 欧美一区二区三区在| 午夜日韩在线观看| 欧美中文字幕久久| 亚洲天堂成人在线观看| 丰满少妇久久久久久久| 精品国产乱码久久久久久久久| 亚洲v中文字幕| 欧美最新大片在线看| 亚洲天堂免费看| 一本色道综合亚洲| 亚洲精品日韩专区silk| 99re热视频这里只精品| 亚洲视频一区二区免费在线观看| 成人永久aaa| 国产精品福利一区二区三区| 成人高清视频在线观看| 国产精品久久毛片| av一区二区三区黑人| 亚洲欧美日韩国产一区二区三区 | 久久免费视频色| 国产精品一区免费视频| 国产亚洲精品aa午夜观看| 国产精品一区二区在线观看网站 | 国产精品国产精品国产专区不蜜| 国产成人av电影在线| 中文字幕 久热精品 视频在线| 成人天堂资源www在线| 中文字幕一区av| 在线观看亚洲成人| 日韩精品亚洲专区| 日韩欧美成人午夜| 国产成人自拍网| 中文字幕欧美激情一区| 91麻豆成人久久精品二区三区| 亚洲日本一区二区三区| 在线亚洲一区二区| 青青青伊人色综合久久| 久久综合九色综合97婷婷女人| 国产在线视频精品一区| 中文字幕中文乱码欧美一区二区| av动漫一区二区| 日韩av高清在线观看| 欧美极品美女视频| 欧美色国产精品| 国产精品一区二区视频|