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

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

?? ibmemacend.c

?? WINDRIVER SBC405 BSP
?? C
?? 第 1 頁 / 共 5 頁
字號:
        else            isrClear = EMAC_ISR_TX_INTS | EMAC_ISR_DB0;        EMAC_REG_WRITE(pDrvCtrl, EMAC_ISR, isrClear);        }    /*     * Check to see if there was a RX error.  Clear the status bits for the     * RX error.  Keep count of these errors in the main device structure.     *     * Note that non-zero values of EMAC_ISR_RX_INTS are used primarily     * for debugging.  When EMAC_ISR_RX_INTS is zero, some compilers     * may warn about an always-false conditional expression.     */    if (isrReg & EMAC_ISR_RX_INTS)        {        pDrvCtrl->intErrorRX++;        EMAC_REG_WRITE(pDrvCtrl, EMAC_ISR, EMAC_ISR_RX_INTS);        }    return;    }/********************************************************************************* ibmEmacTxeobInt - handle controller TX end-of-buffer interrupt** This routine is called at interrupt level in response to an interrupt from* the MAL.*/LOCAL void ibmEmacTxeobInt    (    EMAC_DRV_CTRL *   pDrvCtrl    )    {    DRV_LOG (DRV_DEBUG_TX, "EMAC TX EOB int\n", 1, 2, 3, 4, 5, 6);    /* Start the cleanup job */    if ((pDrvCtrl->localFlags & EMAC_TX_CLEAN_RUNNING) == 0)        {        if (netTaskId && netTaskId != ERROR)            {            pDrvCtrl->localFlags |= EMAC_TX_CLEAN_RUNNING;            netJobAdd((FUNCPTR)ibmEmacSendCleanup, (int)pDrvCtrl, 0, 0, 0, 0);            }        else            ibmEmacSendCleanup(pDrvCtrl);        }    if (pDrvCtrl->localFlags & EMAC_TX_BLOCKED)        {        DRV_LOG (DRV_DEBUG_ERROR, "TX blocked.  Call muxRestart\n",                                  1 , 2, 3, 4, 5, 6);        pDrvCtrl->localFlags &= ~EMAC_TX_BLOCKED;        if (netTaskId && netTaskId != ERROR)            netJobAdd((FUNCPTR)muxTxRestart, (int)&pDrvCtrl->end, 0, 0, 0, 0);        else            muxTxRestart(&pDrvCtrl->end);        }    return;    }/********************************************************************************* ibmEmacWdRestart - handle restart in case MUX blocks or driver fails** This routine is called at interrupt level (WatchDog) in case the MUX is blocked* or the hardware fails.*/LOCAL void ibmEmacWdRestart    (    EMAC_DRV_CTRL *   pDrvCtrl    ){    DRV_LOG(DRV_DEBUG_ERROR, "INFO: RestartWatchdog kicks driver\n", 1, 2, 3, 4, 5, 6);    /* Now that status from the packet just transmitted has been copied back     * to the main TX ring, it is safe to allow another TX operation. */	/* semGive (pDrvCtrl->txSem2nd); */    /* Start the cleanup job */    if ((pDrvCtrl->localFlags & EMAC_TX_CLEAN_RUNNING) == 0)	{        pDrvCtrl->localFlags |= EMAC_TX_CLEAN_RUNNING;        if ( netJobAdd((FUNCPTR)ibmEmacSendCleanup, (int)pDrvCtrl, 0, 0, 0, 0) == ERROR )			DRV_LOG (DRV_DEBUG_ERROR, "FATAL: netJobAdd ibmEmacSendCleanup failed\n",1,2,3,4,5,6); 	}	/* check if TX is/was blocked, unblock it*/    if (pDrvCtrl->localFlags & EMAC_TX_BLOCKED)	{		DRV_LOG (DRV_DEBUG_ERROR, "INFO: Watchdog expired: MUX blocked, unblocking, calling muxRestart\n",1,2,3,4,5,6);        pDrvCtrl->localFlags &= ~EMAC_TX_BLOCKED;        if ( netJobAdd((FUNCPTR)muxTxRestart, (int)&pDrvCtrl->end, 0, 0, 0, 0) == ERROR )			DRV_LOG (DRV_DEBUG_ERROR, "FATAL: netJobAdd muxTxRestart failed\n",1,2,3,4,5,6);	}    return;}/********************************************************************************* ibmEmacRxeobInt - handle controller RX end-of-buffer interrupt** This routine is called at interrupt level in response to an interrupt from* the MAL.*/LOCAL void ibmEmacRxeobInt    (    EMAC_DRV_CTRL *   pDrvCtrl    )    {    DRV_LOG (DRV_DEBUG_INT, "EMAC RX EOB int: 0x%x 0x%x\n", pDrvCtrl->indexRxD,        (pDrvCtrl->pRxDesc + pDrvCtrl->indexRxD)->statusControl, 3, 4, 5, 6);    /*     * If tnetTask is running and not already handling received packets     * for this interface, arrange to process the received packets at     * task level.     */    if (!(pDrvCtrl->localFlags & EMAC_HANDLE_RX_RUNNING))        {        if (netTaskId && netTaskId != ERROR)            {            pDrvCtrl->localFlags |= EMAC_HANDLE_RX_RUNNING;            netJobAdd((FUNCPTR)ibmEmacHandleRecvInt, (int)pDrvCtrl,FALSE,0,0,0);            }        else            ibmEmacHandleRecvInt(pDrvCtrl, FALSE);        }    return;    }/********************************************************************************* ibmEmacTxdeInt - handle TX descriptor error interrupt** This routine is called at interrupt level in response to an interrupt from* the MAL.*/LOCAL void ibmEmacTxdeInt    (    EMAC_DRV_CTRL *   pDrvCtrl    )    {    DRV_LOG (DRV_DEBUG_ERROR, "EMAC TX DE int\n", 1, 2, 3, 4, 5, 6);    /*     * The send routines check to be sure that enough TX descriptors are     * available to send a packet, and initialize all descriptors required     * to transmit the packet before kicking the transmitter.     * This interrupt should never occur.  If it does, restart.     */    ibmEmacRestart(pDrvCtrl);    return;    }/********************************************************************************* ibmEmacRxdeInt - handle RX descriptor error interrupt** This routine is called at interrupt level in response to an interrupt from* the MAL.*/LOCAL void ibmEmacRxdeInt    (    EMAC_DRV_CTRL *   pDrvCtrl    )    {    DRV_LOG (DRV_DEBUG_ERROR, "EMAC RX DE int\n", 1, 2, 3, 4, 5, 6);    /*     * Start ibmEmacHandleRecvInt running (at task level if tnetTask     * is available), and tell it to restart the RX channel when it is     * finished because MAL automatically disables the channel when     * this interrupt occurred.     */    if (netTaskId && netTaskId != ERROR)        {        pDrvCtrl->localFlags |= EMAC_HANDLE_RX_RUNNING;        netJobAdd((FUNCPTR)ibmEmacHandleRecvInt, (int)pDrvCtrl, TRUE,0,0,0);        }    else        ibmEmacHandleRecvInt(pDrvCtrl, TRUE);    return;    }/********************************************************************************* ibmEmacMalSerrInt - handle MAL SERR (system error) interrupt** This routine is called at interrupt level in response to an interrupt from* the controller.*/LOCAL void ibmEmacMalSerrInt    (    EMAC_DRV_CTRL *   pDrvCtrl    )    {    DRV_LOG (DRV_DEBUG_ERROR, "EMAC-MAL SERR int\n", 1, 2, 3, 4, 5, 6);    /* MAL should have already reset the channel */    /* SERR is fatal, just restart the EMAC */    pDrvCtrl->lastError.errCode = END_ERR_RESET;    pDrvCtrl->lastError.pMesg = "MAL System Error.";    if (netTaskId && netTaskId != ERROR)        netJobAdd ((FUNCPTR)muxError, (int)&pDrvCtrl->end,                   (int)&pDrvCtrl->lastError,                   0, 0, 0);    else        muxError (&pDrvCtrl->end, &pDrvCtrl->lastError);    END_FLAGS_CLR (&pDrvCtrl->end, (IFF_UP | IFF_RUNNING));    ibmEmacRestart(pDrvCtrl);    return;    }/********************************************************************************* ibmEmacHandleRecvInt - task level interrupt service for received packets** This routine is called at task level indirectly by the interrupt* service routine to process received messages.** The double loop is to protect against a race condition where the interrupt* code sees EMAC_HANDLE_RX_RUNNING as TRUE, but it is then turned off by the* task code.*/LOCAL void ibmEmacHandleRecvInt    (    EMAC_DRV_CTRL *   pDrvCtrl,    int               resetChan    )    {    MAL_BD * pRxDesc;    /*     * Keep getting RX descriptors and calling the receive function until     * there are no more ready to handle.     */    pRxDesc = (MAL_BD *)NULL;    do        {        pDrvCtrl->localFlags |= EMAC_HANDLE_RX_RUNNING;        while ((pRxDesc = ibmEmacRecvDescGet(pDrvCtrl)) != (MAL_BD *)NULL)            {            ibmEmacRecv(pDrvCtrl, pRxDesc);            };        pDrvCtrl->localFlags &= ~EMAC_HANDLE_RX_RUNNING;        }    while (ibmEmacRecvDescGet(pDrvCtrl) != NULL);    /*     * This function may have been run as a result of an RX descriptor error     * interrupt (RXDE).  If so, the RX channel was disabled by MAL and must     * be re-activated for RX operation to continue. When a channel is     * reactivated, it begins to process descriptors from the beginning of the     * descriptor table, so the current RX descriptor index must be reset.     */    if (resetChan == TRUE)        {        pDrvCtrl->indexRxD = 0;        malChannelActivate(pDrvCtrl->pMalData, MAL_RX_TYPE,                           pDrvCtrl->rxChn0MalChannel);        }    }/********************************************************************************* ibmEmacRecvDescGet - get the next receive descriptor** Returns a ptr to next RX descriptor to process, or NULL if none are ready.*/LOCAL MAL_BD * ibmEmacRecvDescGet    (    EMAC_DRV_CTRL *   pDrvCtrl    )    {    volatile MAL_BD *            pRxDesc;    /* Point to the next RX descriptor */    pRxDesc = pDrvCtrl->pRxDesc + pDrvCtrl->indexRxD;    /*     * If the descriptor says the buffer is no longer empty, return the     * pointer to the descriptor, else return NULL (buffer is still empty).     */    if ((pRxDesc->statusControl & MAL_RX_CTRL_EMPTY) == 0)        {        DRV_LOG (DRV_DEBUG_RX, "RX desc got data\n", 1, 2, 3, 4, 5, 6);        return((MAL_BD *)pRxDesc);        }    else        {        DRV_LOG (DRV_DEBUG_RX, "RX desc no data yet\n", 1, 2, 3, 4, 5, 6);        return ((MAL_BD *)NULL);        }    }/********************************************************************************* ibmEmacRecv - process the next incoming packet** RETURNS: OK/ERROR*/LOCAL STATUS ibmEmacRecv    (    EMAC_DRV_CTRL *   pDrvCtrl,    MAL_BD *          pRxDesc    )    {    int                 len;    char *              pCluster;    char *              pNewCluster = NULL;    CL_BLK_ID           pClBlk;    M_BLK_ID            pMblk;    USHORT              statusRx;    int                 index;    DRV_LOG (DRV_DEBUG_RECV, "->ibmEmacRecv \n", 1, 2, 3, 4, 5, 6);    index = pDrvCtrl->indexRxD;    /* Bump the RX descriptor ring placeholder to the next position. */    pDrvCtrl->indexRxD = (index + 1) % pDrvCtrl->numRxD;    /* Check packet for errors */    statusRx = pRxDesc->statusControl;    DRV_LOG (DRV_DEBUG_RX, "EmacRecv : RxDesc = %X index = %d\n", statusRx,                            index, 3, 4, 5, 6);    /* If any of the error bits are set in the RX descriptor bump error count */    if (statusRx & EMAC_RX_ERRORS)        {        DRV_LOG (DRV_DEBUG_ERROR, "Status in RX Desc = 0x%x\n",                                   statusRx, 2, 3, 4, 5, 6);        END_ERR_ADD (&pDrvCtrl->end, MIB2_IN_ERRS, +1);        /* Toss the packet, but reuse the cluster */        goto cleanRXD;        }    /* If the packet spans more than one buffer, this is also an error. */    if ((statusRx & MAL_RX_ONE_BUFFER) != MAL_RX_ONE_BUFFER)        {        DRV_LOG (DRV_DEBUG_ERROR, "RX packet spans >1 buffer\n",                                   1, 2, 3, 4, 5, 6);        END_ERR_ADD (&pDrvCtrl->end, MIB2_IN_ERRS, +1);        /* Toss the packet, but reuse the cluster */        goto cleanRXD;        }    /* If we cannot get a new cluster to replace the full one, then bail out. */    pNewCluster = netClusterGet (pDrvCtrl->end.pNetPool,                                 pDrvCtrl->pClPoolId);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲午夜久久久久久久久久久 | 国产精品女同互慰在线看| 欧美日韩亚洲综合| 色老头久久综合| 91免费看视频| 色噜噜狠狠色综合欧洲selulu| 99久久亚洲一区二区三区青草| 国产高清一区日本| 国产一区二区三区黄视频 | 欧美成人video| 91精品蜜臀在线一区尤物| 在线欧美小视频| 欧洲亚洲精品在线| 欧美日韩精品一区二区三区四区| 欧美性猛交xxxx黑人交 | 亚洲狠狠爱一区二区三区| 一区二区免费视频| 亚洲一区二区三区四区的| 亚洲国产精品久久久男人的天堂 | 国产高清不卡二三区| 国产美女娇喘av呻吟久久| 国精产品一区一区三区mba视频| 天堂va蜜桃一区二区三区| 婷婷成人综合网| 精品一区二区三区的国产在线播放 | 国产精品伦理在线| 亚洲欧美日韩国产一区二区三区 | 午夜免费久久看| 男女激情视频一区| 精品无人码麻豆乱码1区2区 | 成人免费毛片高清视频| www.亚洲精品| 日本道免费精品一区二区三区| 欧美中文字幕不卡| 91精品一区二区三区久久久久久| 欧美va亚洲va在线观看蝴蝶网| 国产色婷婷亚洲99精品小说| 国产精品视频麻豆| 一区二区三区不卡视频在线观看 | 欧美日韩精品欧美日韩精品一| 7777精品久久久大香线蕉| 欧美一级片在线看| 久久精品日韩一区二区三区| 国产精品午夜电影| 亚洲一区二区在线观看视频 | 欧美日韩国产片| 精品免费视频.| 国产精品天美传媒| 亚洲成人高清在线| 国产福利一区二区三区视频| 在线免费观看不卡av| 91精品国模一区二区三区| 久久久一区二区三区捆绑**| 国产精品美女视频| 午夜久久久影院| 成人性生交大片免费看中文 | 中文在线资源观看网站视频免费不卡| 国产精品久久久久久久久免费桃花| 一区二区三区四区不卡在线| 婷婷六月综合网| 国产高清在线精品| 欧美日韩成人一区| 国产亚洲一区二区在线观看| 亚洲品质自拍视频网站| 久久国产精品99精品国产 | 欧美激情一区二区三区四区| 亚洲成av人影院在线观看网| 国产成人自拍高清视频在线免费播放| 色激情天天射综合网| 欧美精品一区视频| 亚洲尤物视频在线| 国产成人免费xxxxxxxx| 欧美精品电影在线播放| 中文字幕一区二区三区四区不卡| 麻豆成人在线观看| 欧美伊人久久久久久久久影院| 久久久久国产精品免费免费搜索| 亚洲第一福利视频在线| 成人黄色在线视频| 精品国产一区二区国模嫣然| 亚洲国产成人91porn| 成人av动漫在线| 欧美成人国产一区二区| 香蕉乱码成人久久天堂爱免费| www.视频一区| 国产日韩视频一区二区三区| 秋霞成人午夜伦在线观看| 在线视频国产一区| 欧美国产精品一区二区| 国内精品视频一区二区三区八戒 | 精品久久国产老人久久综合| 亚洲成av人片一区二区梦乃| 国产成人av一区二区三区在线观看| 在线成人午夜影院| 中文字幕一区二区在线播放| 国产v综合v亚洲欧| 欧美理论在线播放| 亚洲第一成人在线| 欧美亚洲另类激情小说| 亚洲桃色在线一区| av在线不卡电影| 国产精品免费网站在线观看| 国内外成人在线| 久久网站最新地址| 国产在线日韩欧美| 精品久久国产字幕高潮| 激情欧美一区二区| 精品免费日韩av| 欧美日韩一区二区三区四区 | 日韩一区二区三区电影在线观看 | 欧美三级日韩三级国产三级| 欧美一级片免费看| 国产精品久久午夜夜伦鲁鲁| 国产成人精品午夜视频免费| 久久午夜电影网| 丁香婷婷综合五月| 亚洲成人手机在线| 国产成人免费在线观看不卡| 成人h版在线观看| 国产激情视频一区二区在线观看| 亚洲精品中文字幕乱码三区| 99久久国产综合精品色伊| 国产精品污网站| 色天天综合久久久久综合片| 亚洲女同女同女同女同女同69| 在线一区二区三区做爰视频网站| 亚洲三级视频在线观看| 欧美专区亚洲专区| 日韩在线观看一区二区| 日韩欧美一区二区不卡| 国产一区二区成人久久免费影院| 日本一区二区视频在线| 不卡一区二区中文字幕| 亚洲免费成人av| 欧美日韩精品欧美日韩精品一 | 国产v综合v亚洲欧| 中文字幕免费不卡| 成人国产电影网| 亚洲视频免费看| 91久久国产综合久久| 亚洲狠狠爱一区二区三区| 欧洲av一区二区嗯嗯嗯啊| 亚洲一级电影视频| 欧美一区二区成人| 黄网站免费久久| 国产丝袜在线精品| 97久久人人超碰| 亚洲国产一区二区a毛片| 精品蜜桃在线看| 国产成人综合在线播放| 国产精品天干天干在观线 | 色婷婷精品大在线视频| 婷婷开心激情综合| 久久你懂得1024| 色综合一个色综合| 日韩电影在线免费看| 久久蜜桃一区二区| 一本色道a无线码一区v| 日韩精品每日更新| 国产日产欧美一区二区三区| 国产福利电影一区二区三区| 成人欧美一区二区三区小说| 欧美亚洲免费在线一区| 激情五月婷婷综合网| 亚洲一区二区精品视频| 欧美一级夜夜爽| 99国内精品久久| 日韩不卡手机在线v区| 亚洲欧美激情在线| 精品久久国产老人久久综合| 91亚洲精品久久久蜜桃网站| 日韩高清一区在线| 国产精品盗摄一区二区三区| 555夜色666亚洲国产免| 成人性生交大片| 同产精品九九九| 亚洲另类在线一区| 久久人人97超碰com| 欧美自拍丝袜亚洲| 成人精品一区二区三区四区 | 青青草91视频| ...xxx性欧美| 欧美性受极品xxxx喷水| 国产成人99久久亚洲综合精品| 亚洲大片精品永久免费| 欧美激情一区二区在线| 日韩一区二区视频在线观看| 91麻豆高清视频| 国产suv精品一区二区6| 丝瓜av网站精品一区二区| 久久精品一区四区| 久久日一线二线三线suv| 欧美日韩国产乱码电影| 成人免费观看av| 日韩精品午夜视频| 亚洲国产另类av| 中文字幕在线不卡国产视频| 欧美三级电影一区| 色婷婷久久综合| 成人av在线资源网|