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

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

?? ss_queue.c

?? 中國石油二期加油站IC系統后臺通訊軟件
?? C
?? 第 1 頁 / 共 3 頁
字號:
SsDmndQ *dQueue                        /* demand Queue */
)
#else
PUBLIC S16 ssDestroyDmndQ(dQueue)
SsDmndQ *dQueue;                       /* demand Queue */
#endif
{
    U8     i;
    Buffer *tBuf;
    S16    ret;

    TRC0(ssDestroyDmndQ)

#if (ERRCLASS & ERRCLS_INT_PAR)
    if (dQueue == NULLP)
    {
        SSLOGERROR(ERRCLS_INT_PAR, ESS404, ERRZERO, "NULL DQ Pointer");
        RETVALUE(RFAILED);
    }
#endif

    for (i = 0; i < SS_DQ_BIT_MASK_LEN; i++)
    {
        ret = SDestroyLock(&dQueue->dmndQLock[i]);
        if (ret != ROK)
        {
#if (ERRCLASS & ERRCLS_DEBUG)
            SSLOGERROR(ERRCLS_DEBUG, ESS405, (ErrVal)ret, "Failed to destroy lock");
#endif
            RETVALUE(RFAILED);
        }
    }
    for (i = 0; i < SS_MAX_NUM_DQ; i++)
    {
        while (dQueue->queue[i].head != NULLP)
        {
            tBuf = dQueue->queue[i].head;
            dQueue->queue[i].head = dQueue->queue[i].head->b_next;
            SPutMsg(tBuf);
        }
    }
    ssDestroySema(&dQueue->dmndQSema);
    RETVALUE (ROK);

} /* end of ssDestroyDmndQ */


/*
*
*       Fun:   ssDmndQPut
*
*       Desc:  This function adds a message to the head or tail of the 
*              priority queue specified. The priority specified is the 
*              destination Q index i.e 
*              ((dst_Tsk_pri * SS_MAX_MSG_PRI) + msg_pri)
*
*       Ret:   ROK      - ok
*              RFAILED  - failed
*
*       Notes: 
*
*       File:  ss_queue.c
*
*/
#ifdef ANSI
PUBLIC S16 ssDmndQPut
(
SsDmndQ *dQueue,                       /* demand Queue */
Buffer  *mBuf,                         /* message buffer */
Prior   priority,                      /* priority */
Order   order                          /* position */
)
#else
PUBLIC S16 ssDmndQPut(dQueue, mBuf, priority, order)
SsDmndQ *dQueue;                       /* demand Queue */
Buffer  *mBuf;                         /* message buffer */
Prior   priority;                      /* priority */
Order   order;                         /* position */
#endif
{
    U8     maskIndex;                   /* mask Index */
    U8     bitPosition;                 /* bit position in index */
    Queue *queue;                       /* queue in demand queue */
    S16    ret;                         /* return value */

    TRC0(ssDmndQPut)

#if (ERRCLASS & ERRCLS_INT_PAR)
    if (dQueue == NULLP)
    {
        SSLOGERROR(ERRCLS_INT_PAR, ESS406, ERRZERO, "NULL DQ Pointer");
        RETVALUE(RFAILED);
    }

    if (mBuf == NULLP)
    {
        SSLOGERROR(ERRCLS_INT_PAR, ESS407, ERRZERO, "NULL mBuf Pointer");
        RETVALUE(RFAILED);
    }

    if ((priority == PRIORNC) || (priority > SS_MAX_DQ_PRIOR))
    {
        SSLOGERROR(ERRCLS_INT_PAR, ESS408, ERRZERO, "invalid priority ");
        RETVALUE(RFAILED);
    }

    if ((order != SS_DQ_FIRST) && (order != SS_DQ_LAST))
    {
        SSLOGERROR(ERRCLS_INT_PAR, ESS409, ERRZERO, "invalid order ");
        RETVALUE(RFAILED);
    }
#endif

    maskIndex   = priority >> 3;
    bitPosition = 7 - (priority % 8);
    queue       = &dQueue->queue[priority];

    ret = SLock(&dQueue->dmndQLock[maskIndex]);
    if (ret != ROK)
    {
#if (ERRCLASS & ERRCLS_DEBUG)
        SSLOGERROR(ERRCLS_DEBUG, ESS410, (ErrVal)ret, "Failed to get lock");
#endif
        RETVALUE (RFAILED);
    }

    if (queue->crntSize == 0)
    {
        queue->head   = mBuf;
        queue->tail   = mBuf;
        mBuf->b_next  = NULLP;
        mBuf->b_prev  = NULLP;

        /* Set the corresponding bit in bit mask */
        dQueue->bitMask[maskIndex] |= (1 << bitPosition);
    } else
    {
        if (order == SS_DQ_LAST)
        {
            mBuf->b_prev        = queue->tail;
            mBuf->b_next        = NULLP;
            queue->tail->b_next = mBuf;
            queue->tail         = mBuf;
        } else
        {
            mBuf->b_next        = queue->head;
            mBuf->b_prev        = NULLP;
            queue->head->b_prev = mBuf;
            queue->head         = mBuf;
        }
    }
    queue->crntSize++;

    ret = SUnlock(&dQueue->dmndQLock[maskIndex]);
    if (ret != ROK)
    {
#if (ERRCLASS & ERRCLS_DEBUG)
        SSLOGERROR(ERRCLS_DEBUG, ESS411, (ErrVal)ret, "Failed to release lock");
#endif
        RETVALUE (RFAILED);
    }

    /* increment the counting semaphore */
    ssPostSema(&dQueue->dmndQSema);

    RETVALUE(ROK);

} /* End of ssDmndQPut */


/*
*
*       Fun:   ssDmndQGet
*
*       Desc:  This function removes a message from head or tail of the 
*              highest non-empty priority queue message. 
*
*       Ret:   ROK      - ok
*              RFAILED  - failed
*              ROKDNA   - ok, no data available in queue
*
*       Notes:  This is a blocking call
*
*       File:  ss_queue.c
*
*/
#ifdef ANSI
PUBLIC S16 ssDmndQGet
(
SsDmndQ *dQueue,                          /* demand queue */
Buffer  **mBuf,                           /* message buffer */
Order   order                             /* position */ 
)
#else
PUBLIC S16 ssDmndQGet(dQueue, mBuf, order)
SsDmndQ *dQueue;                          /* demand queue */
Buffer  **mBuf;                           /* message buffer */
Order   order;                            /* position */
#endif
{
    Queue *queue;
    S16   ret;
    S16   i;
    U8    bitPosition;
    U8    qIndex;

    TRC0(ssDmndQGet)

#if (ERRCLASS & ERRCLS_INT_PAR)
    if (dQueue == NULLP)
    {
        SSLOGERROR(ERRCLS_INT_PAR, ESS412, ERRZERO, "NULL DQ Pointer");
        RETVALUE(RFAILED);
    }

    if (mBuf == NULLP)
    {
        SSLOGERROR(ERRCLS_INT_PAR, ESS413, ERRZERO, "NULL mBuf Pointer");
        RETVALUE(RFAILED);
    }

    if ((order != SS_DQ_FIRST) && (order != SS_DQ_LAST))
    {
        SSLOGERROR(ERRCLS_INT_PAR, ESS414, ERRZERO, "invalid order ");
        RETVALUE(RFAILED);
    }
#endif

    ret = ssWaitSema(&dQueue->dmndQSema);
    if (ret != ROK)
    {
#if (ERRCLASS & ERRCLS_DEBUG)
        SSLOGERROR(ERRCLS_DEBUG, ESS415, (ErrVal)ret, "Failed to get semaphore");
#endif
        RETVALUE (RFAILED);
    }

    for (i = 0; i < SS_DQ_BIT_MASK_LEN; i++)
    {
        ret = SLock(&dQueue->dmndQLock[i]);
        if (ret != ROK)
        {
#if (ERRCLASS & ERRCLS_DEBUG)
            SSLOGERROR(ERRCLS_DEBUG, ESS416, (ErrVal)ret, "Failed to get lock");
#endif
            RETVALUE (RFAILED);
        }

        bitPosition = osCp.dmndQLookupTbl[dQueue->bitMask[i]];
        if (bitPosition != 255)
            break;

        ret = SUnlock(&dQueue->dmndQLock[i]);
        if (ret != ROK)
        {
#if (ERRCLASS & ERRCLS_DEBUG)
            SSLOGERROR(ERRCLS_DEBUG, ESS417, ret, "Failed to release lock");
#endif
            RETVALUE (RFAILED);
        }
    }

    if (i >= SS_DQ_BIT_MASK_LEN)
    {
        /* Demand Queue is empty */
        *mBuf = NULLP;
        RETVALUE (ROKDNA);
    }

    qIndex = (i * 8) +  (7 - bitPosition);
    queue = &dQueue->queue[qIndex];

    if (queue->crntSize == 1)
    {
        *mBuf = queue->head;
        queue->head = NULLP;
        queue->tail = NULLP;

        /* Reset the corresponding bit in bit mask */
        dQueue->bitMask[i] &= (~( 1 << (bitPosition)));
    } else
    {
        if (order == SS_DQ_FIRST)
        {
            *mBuf = queue->head;
            queue->head = queue->head->b_next;
            queue->head->b_prev = NULLP;
        } else
        {
            *mBuf = queue->tail;
            queue->tail = queue->tail->b_prev;
            queue->tail->b_next = NULLP;
        }
    }
    queue->crntSize--;

    ret = SUnlock(&dQueue->dmndQLock[i]); 
    if (ret != ROK)
    {
#if (ERRCLASS & ERRCLS_DEBUG)
        SSLOGERROR(ERRCLS_DEBUG, ESS418, (ErrVal)ret, "Failed to release lock");
#endif
        RETVALUE (RFAILED);
    }

    RETVALUE (ROK);

} /* End of ssDmndQGet */


/*
*
*       Fun:   ssFndLenDmndQ 
*
*       Desc:  This function returns the number of messages in a queue
*              If priority is specified, length of the associated Q is 
*              returned otherwise total length of all Qs is returned.
*
*       Ret:   ROK      - ok
*              RFAILED  - failed
*
*       Notes: 
*
*       File:  ss_queue.c
*
*/
#ifdef ANSI
PUBLIC S16 ssFndLenDmndQ
(
SsDmndQ *dQueue,                               /* demand queue */
Prior   priority,                              /* priority */
QLen    *len                                   /* queue length */
)
#else
PUBLIC S16 ssFndLenDmndQ(dQueue, priority, len)
SsDmndQ *dQueue;                               /* demand queue */
Prior   priority;                              /* priority */
QLen    *len;                                  /* queue length */
#endif
{

    S16  ret;                                   /* return value */
    U8   i;

    TRC0(ssFndLenDmndQ)

#if (ERRCLASS & ERRCLS_INT_PAR)
    if ((dQueue == NULLP) || (len == NULLP))
    {
        SSLOGERROR(ERRCLS_INT_PAR, ESS419, ERRZERO, "NULL Pointer");
        RETVALUE(RFAILED);
    }
#endif

    *len = 0;
    if (priority != PRIORNC)
    {
        i = priority >> 3; 
        ret = SLock(&dQueue->dmndQLock[i]);
        if (ret != ROK)
        {
#if (ERRCLASS & ERRCLS_DEBUG)
            SSLOGERROR(ERRCLS_DEBUG, ESS420, (ErrVal)ret, "Failed to get lock");
#endif
            RETVALUE (RFAILED);
        }

        *len = dQueue->queue[priority].crntSize;

        ret = SUnlock(&dQueue->dmndQLock[i]);
        if (ret != ROK)
        {
#if (ERRCLASS & ERRCLS_DEBUG)
            SSLOGERROR(ERRCLS_DEBUG, ESS421, (ErrVal)ret,  \
                       "Failed to release lock");
#endif
            RETVALUE (RFAILED);
        }
    } else
    {
        for (i = 0; i < SS_DQ_BIT_MASK_LEN; i++)
        {
            ret = SLock(&dQueue->dmndQLock[i]);
            if (ret != ROK)
            {
#if (ERRCLASS & ERRCLS_DEBUG)
                SSLOGERROR(ERRCLS_DEBUG, ESS422, (ErrVal)ret, "Failed to get lock");
#endif

                /* Release all the locks aquired */
                while (i > 0)
                {
                    SUnlock(&dQueue->dmndQLock[i-1]);
                    i--;
                }

                RETVALUE (RFAILED);
            }
        }

        for (i = 0; i  < SS_MAX_NUM_DQ; i++)
            *len  += dQueue->queue[i].crntSize;

        for ( i = 0; i < SS_DQ_BIT_MASK_LEN; i++)
        {
            ret = SUnlock(&dQueue->dmndQLock[i]);
            if (ret != ROK)
            {
#if (ERRCLASS & ERRCLS_DEBUG)
                SSLOGERROR(ERRCLS_DEBUG, ESS423, (ErrVal)ret, "Failed to get lock");
#endif
                RETVALUE (RFAILED);
            }
        }
    }
    RETVALUE(ROK);

} /* End of ssFndLenDmndQ */



/********************************************************************30**
  
         End of file: ss_queue.c 1.3  -  10/14/98 14:17:28
  
*********************************************************************31*/

  
/********************************************************************40**
  
        Notes: 
  
*********************************************************************41*/

/********************************************************************50**

*********************************************************************51*/

   
/********************************************************************60**
  
        Revision history:
  
*********************************************************************61*/

/********************************************************************90**
 
     ver       pat    init                  description
------------ -------- ---- ----------------------------------------------
1.1          ---      bsr  1. initial release.
  
1.2          ---      kr   1. defined functions SQueueFirst, 
                              SDequeueFirst, SQueueLast and SDequeueLast
                              under SS_ENABLE_MACROS
             ---      kp   2. Cosmetic changes

1.3          ---      kp   1. Bug fix in ssDmndQGet()

*********************************************************************91*/

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品不卡在线| 亚洲成a人片在线不卡一二三区 | 久久久夜色精品亚洲| 国产精品视频九色porn| 丝袜亚洲精品中文字幕一区| 国产一区二区三区四区五区入口| 色8久久人人97超碰香蕉987| 精品福利在线导航| 亚洲综合色自拍一区| 国产成人aaa| 在线播放亚洲一区| 中文字幕一区二区三区四区| 精彩视频一区二区| 91精品国产综合久久香蕉的特点| 亚洲六月丁香色婷婷综合久久 | 99九九99九九九视频精品| 日韩午夜在线影院| 五月综合激情日本mⅴ| 成人精品高清在线| 久久精品欧美日韩精品| 免费日本视频一区| 欧美电影在线免费观看| 亚洲资源在线观看| 欧美中文一区二区三区| 中文字幕一区二区三区视频| 99久久精品免费精品国产| 国产精品你懂的| 成人app软件下载大全免费| 国产日本亚洲高清| 国产精品一区免费视频| 久久综合久久综合亚洲| 久久精品免费观看| 欧美第一区第二区| 国内成人自拍视频| 国产亚洲欧美日韩日本| 国产一区二区调教| 日本一区二区电影| 972aa.com艺术欧美| 亚洲视频在线观看一区| 一本久久精品一区二区| 一区二区三区视频在线观看| 在线观看亚洲a| 亚洲成人www| 日韩免费看的电影| 国产精品一二二区| 中文字幕一区二区三区不卡在线| 99久久99久久精品国产片果冻| 亚洲三级电影全部在线观看高清| 91成人免费网站| 日本中文字幕一区| 久久色视频免费观看| 国产精品1区二区.| 中文字幕中文字幕在线一区 | 亚洲成人综合视频| 欧美一级二级三级乱码| 国产不卡一区视频| 亚洲天堂av老司机| 欧美日韩成人综合天天影院| 精品一区二区久久久| 国产精品久久久久一区二区三区 | 欧美日本一区二区| 麻豆精品视频在线观看免费| 国产欧美精品区一区二区三区| 99久久综合色| 日本欧美一区二区| 国产欧美一区二区精品久导航| 色综合一个色综合亚洲| 蜜臀99久久精品久久久久久软件| 国产色产综合色产在线视频| 色老综合老女人久久久| 久久99日本精品| 亚洲欧美日韩国产中文在线| 日韩一区二区三| youjizz久久| 老司机精品视频一区二区三区| 亚洲色图欧洲色图| 久久亚洲精华国产精华液| 91久久精品一区二区三区| 久久国产视频网| 一区二区三区四区av| 久久女同精品一区二区| 欧美在线观看视频在线| 国产精品一区二区不卡| 日日骚欧美日韩| 亚洲天堂福利av| 国产农村妇女毛片精品久久麻豆| 777午夜精品免费视频| caoporm超碰国产精品| 久久99精品国产麻豆婷婷洗澡| 亚洲黄色片在线观看| 国产日本亚洲高清| 精品国产一区二区三区忘忧草| 欧美在线制服丝袜| 91浏览器打开| 不卡的av电影| 国产成人精品影视| 九九久久精品视频| 丝袜亚洲精品中文字幕一区| 一区二区三区在线观看网站| 国产精品久久久久三级| 久久久精品黄色| 精品国产91洋老外米糕| 91精品国产综合久久国产大片| 日本韩国欧美一区| 91在线免费播放| 99久久久免费精品国产一区二区| 风间由美性色一区二区三区| 韩国女主播成人在线观看| 美日韩一区二区三区| 美国毛片一区二区| 免费在线观看一区二区三区| 午夜欧美大尺度福利影院在线看| 一区二区成人在线观看| 亚洲精品老司机| 亚洲精品成a人| 一区二区三区精品在线| 亚洲综合男人的天堂| 夜夜嗨av一区二区三区四季av| 亚洲精品写真福利| 亚洲在线视频网站| 一区二区三区在线观看国产| 一区二区三区日韩精品视频| 亚洲综合丝袜美腿| 亚洲韩国精品一区| 午夜私人影院久久久久| 欧美a级理论片| 国产做a爰片久久毛片| 国产麻豆视频精品| 丰满白嫩尤物一区二区| 成人h精品动漫一区二区三区| 97久久久精品综合88久久| 色哟哟国产精品免费观看| 欧美日韩一区三区| 欧美一级欧美三级在线观看| 精品国产一区二区三区久久影院 | 99re这里都是精品| 欧美日韩国产系列| 精品免费国产二区三区 | 亚洲成av人片观看| 青青草成人在线观看| 国产老肥熟一区二区三区| 成人av综合一区| 欧美日韩国产综合一区二区 | 亚洲欧美一区二区三区极速播放 | 综合电影一区二区三区| 亚洲狼人国产精品| 日韩福利视频导航| 国产精品自拍三区| 一本色道久久综合亚洲aⅴ蜜桃| 欧美日韩国产免费| 精品日韩av一区二区| 亚洲天堂精品在线观看| 免费高清视频精品| av一本久道久久综合久久鬼色| 欧美亚洲另类激情小说| 精品国产乱码久久久久久闺蜜 | 久久精品夜夜夜夜久久| 亚洲猫色日本管| 国产一区二区不卡老阿姨| 色综合色狠狠天天综合色| 日韩欧美在线影院| 亚洲女与黑人做爰| 九色综合国产一区二区三区| 99re这里都是精品| 精品国精品国产尤物美女| 一区二区在线观看av| 国产一区二区三区在线看麻豆| 欧美亚洲国产一区二区三区va| 亚洲精品一区二区三区福利| 亚洲一区二区三区四区五区黄 | 国产一区二区不卡| 欧美日韩视频第一区| 国产精品国产三级国产aⅴ无密码| 日产精品久久久久久久性色| 91美女蜜桃在线| 国产精品午夜电影| 另类的小说在线视频另类成人小视频在线 | 成人app网站| 精品久久久久99| 日日摸夜夜添夜夜添精品视频| 91免费看`日韩一区二区| 国产欧美日韩视频在线观看| 男女男精品网站| 69堂国产成人免费视频| 亚洲综合激情网| 成人精品电影在线观看| 久久亚洲一级片| 国产一区二区不卡在线| 欧美videofree性高清杂交| 日韩电影在线免费| 欧美视频一区二| 夜夜精品视频一区二区| 欧洲精品中文字幕| 一区二区三区四区在线免费观看| 成人小视频免费观看| 国产女人18水真多18精品一级做| 韩国中文字幕2020精品| 欧美精品一区二区精品网| 激情综合网天天干| 精品91自产拍在线观看一区|