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

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

?? at91eth.c

?? 詳細介紹了DM9161相關的驅動函數及實現
?? C
?? 第 1 頁 / 共 3 頁
字號:
        {        DEBUG_LOG (DRV_DEBUG_RX, "at91EndRecv: Out of Cluster Blocks!\n",                 0,0,0,0,0,0);        dev->lastError.errCode = END_ERR_NO_BUF;        muxError(&dev->endObj, &dev->lastError);        goto cleanRXD;        }        END_ERR_ADD (&dev->endObj, MIB2_IN_UCAST, +1);       /* Note: we rely on the hardware to pad 2 bytes so we don't need to copy to     * a new buffer to solve alignment problems     */    /* Join the cluster to the MBlock */    if (netClBlkJoin (pClBlk, pNewCluster, SIZE_ETH_MDMA, NULL, 0, 0, 0) == NULL)        {        DEBUG_LOG (DRV_DEBUG_RX, "at91EndRecv: netClBlkJoin failed\n",                 0,0,0,0,0,0);        dev->lastError.errCode = END_ERR_NO_BUF;        muxError(&dev->endObj,&dev->lastError);        goto cleanRXD;        }                             if (netMblkClJoin (pMblk, pClBlk) == NULL)        {        DEBUG_LOG (DRV_DEBUG_RX, "at91EndRecv: netMblkClJoin failed\n",                 0,0,0,0,0,0);        dev->lastError.errCode = END_ERR_NO_BUF;        muxError(&dev->endObj, &dev->lastError);        goto cleanRXD;        }        /* The ip structure is 14 bytes from the beginning of the valid frame data     * yet it must be aligned on a word boundary.  We have told the ethernet     * controller to insert 2 bytes of garbage at the beginning of each frame     * so now all we need to do is move our pointer to the frame data to the     * real start of the frame causing the frame to be half-word aligned but     * not word aligned.  By counting 14 bytes from the beginning of the frame     * to the ip, we arrive on a word boundary.     */    pMblk->mBlkHdr.mData += SIZE_ETH_WA;    pMblk->mBlkHdr.mData+= (2+__CLUSTER_OFFSET__);	    pMblk->mBlkHdr.mFlags |= M_PKTHDR;    pMblk->mBlkHdr.mLen   = len;    pMblk->mBlkPktHdr.len = len;    /* Call the upper layer's receive routine. */    END_RCV_RTN_CALL(&dev->endObj, pMblk); /*   pRxD->rxFrameData.frameDataPtr = (UINT32)pNewCluster;*/    /* Free the used RBD. */    at91EthRbdFree(dev, pRbd);    index = dev->priv->rxBuffIndex; }	return;cleanRXD:    /* Free the used RBD. */    at91EthRbdFree(dev, pRbd);    if (pClBlk != NULL)        {        netClBlkFree (dev->endObj.pNetPool, pClBlk);         }/*    if (pNewCluster != NULL)        {        netClFree (dev->endObj.pNetPool, pNewCluster);        pNewCluster = NULL;        }*/    if (pMblk != NULL)        {        netMblkFree (dev->endObj.pNetPool, pMblk);        }    END_ERR_ADD (&dev->endObj, MIB2_IN_ERRS, +1);    #if 0        ULONG length;    int index = dev->priv->rxBuffIndex;    unsigned char* pBuf = pRbd->recv_buf[index]; /*   length = at91EthRbdCheck(dev, pRbd);*/    length = pRbd->descriptors[index].size & 0x7ff;    if (length == 0)    {        /* Up-date statistics. *///        dev->MIB2TBL.ifInErrors++;        END_ERR_ADD (&dev->endObj, MIB2_IN_ERRS, +1);    }    else    {#ifdef  DEBUG_TRACE        at91EthHexDump((UCHAR *)(pBuf + SIZE_ETH_WA), length);#endif  /* DEBUG_TRACE */        /* Up-date statistics. *//*        dev->MIB2TBL.ifInOctets += length;        if (((UINT8 *)(pBuf + SIZE_ETH_WA))[0] & 0x01)        {            dev->MIB2TBL.ifInNUcastPkts += 1;        }        else        {            dev->MIB2TBL.ifInUcastPkts += 1;        }*/        /* Add one to our unicast data. */	    END_ERR_ADD (&dev->endObj, MIB2_IN_UCAST, +1);        if (dev->pClPool)        {            M_BLK_ID pMblk;            CL_BLK_ID pClBlk;            char *pBuf;            if (dev->pClPool->clNumFree > (NUM_TBD_ETH / 8))            {                pMblk   = netMblkGet(dev->endObj.pNetPool, M_DONTWAIT, MT_DATA);                pClBlk  = netClBlkGet(dev->endObj.pNetPool, M_DONTWAIT);                END_TX_SEM_TAKE(&dev->endObj, WAIT_FOREVER);                pBuf    = netClusterGet(dev->endObj.pNetPool, dev->pClPool);                END_TX_SEM_GIVE(&dev->endObj);            }            else            {#ifdef  DEBUG_TRACE                printf("at91Eth Error: no cluster buffer for the Rx\n");#endif  /* DEBUG_TRACE */                pMblk   = NULL;                pClBlk  = NULL;                pBuf    = NULL;            }            if ((!pMblk) || (!pClBlk) || (!pBuf))            {                /* Up-date statistics. */                dev->MIB2TBL.ifInDiscards++;                if (pMblk)                {                    netMblkFree(dev->endObj.pNetPool, pMblk);                }#ifdef  DEBUG_TRACE                else                {                    printf("eth%d Error: failed to allocate M_BLK\n", dev->unit);                }#endif  /* DEBUG_TRACE */                if (pClBlk)                {                    netClBlkFree(dev->endObj.pNetPool, pClBlk);                }#ifdef  DEBUG_TRACE                else                {                    printf("eth%d Error: failed to allocate CL_BLK\n", dev->unit);                }#endif  /* DEBUG_TRACE */                if (pBuf)                {                    netClFree(dev->endObj.pNetPool, pBuf);                }#ifdef  DEBUG_TRACE                else                {                    printf("eth%d Error: failed to allocate cluster buffer\n", dev->unit);                }#endif  /* DEBUG_TRACE */            }            else            {                netClBlkJoin(pClBlk, (char *)(pBuf - (SIZE_ETH_FB_HDR - 4)), SIZE_ETH_MDMA, NULL, 0, 0, 0);                netMblkClJoin(pMblk, pClBlk);                /* Set up the mBlk properly. */                pMblk->mBlkHdr.mFlags  |= M_PKTHDR;                pMblk->mBlkHdr.mData    = (char *)(pBuf + SIZE_ETH_WA);                pMblk->mBlkHdr.mLen     = length;                pMblk->mBlkPktHdr.len   = length;                /* Swap the buffer. */                pBuf = (pBuf + (SIZE_ETH_FB_HDR - 4));                /* Call END receive routine. */                END_RCV_RTN_CALL(&dev->endObj, pMblk);            }        }        else if (dev->receiveRtn)        {            dev->receiveRtn(dev, (char *)(pBuf + SIZE_ETH_WA), length);        }    }    /* Free the used RBD. */    at91EthRbdFree(dev, pRbd);#endif    }/********************************************************************************* at91EthTbdProcess - porcess a TBD** RETURNS : N/A*/void at91EthTbdProcess(    ETH_DRV_CTRL *dev,                                 /* pointer to driver structure */    unsigned char* pBuf                                            /* pointer to the TBD */    ){	struct at91_private *lp = (struct at91_private *) dev->priv;    if (at91EthTbdCheck(dev, pBuf) == ERROR)    {        /* Up-date statistics. */        dev->MIB2TBL.ifOutErrors++;    }    else    {        /* Up-date statistics. */        dev->MIB2TBL.ifOutOctets += (ULONG)lp->skb_length;        if (((UINT8 *)(pBuf + SIZE_ETH_WA))[0] & 0x01)        {            dev->MIB2TBL.ifOutNUcastPkts += 1;        }        else        {            dev->MIB2TBL.ifOutUcastPkts += 1;        }    }    END_TX_SEM_TAKE(&dev->endObj, WAIT_FOREVER);    /*pci_unmap_single(NULL, lp->skb_physaddr, lp->skb_length, PCI_DMA_TODEVICE);*/    /* Free the used TBD. */    at91EthTbdFree(dev, lp->skb);    END_TX_SEM_GIVE(&dev->endObj);}/********************************************************************************* at91EthRxHandler - Rx interrupt handler** RETURNS : N/A*/void at91EthRxHandler(    ETH_DRV_CTRL *dev                                  /* pointer to driver structure */    ){    struct at91_private *lp = (struct at91_private *) dev->priv;    PETHRBD pRbd;    dev->bRxHandler = FALSE;    pRbd = lp->dlist;	/*    while (pRbd->descriptors[lp->rxBuffIndex].addr & EMAC_DESC_DONE)*/    {        /* Get the first available RBD. */        /*pRbd = at91EthRbdGet(dev);*/	/*        if (pRbd == NULL)        {            break;        }*/        at91EthRbdProcess(dev, pRbd);    }  }/********************************************************************************* at91EthTxHandler - Tx interrupt handler** RETURNS : N/A*/void at91EthTxHandler(    ETH_DRV_CTRL *dev                                  /* pointer to driver structure */    ){    dev->bTxHandler = FALSE;    do    {                END_TX_SEM_TAKE(&dev->endObj, WAIT_FOREVER);        at91EthTbdProcess(dev, 0);        END_TX_SEM_GIVE(&dev->endObj);    } while (0);    /* Restart Tx if it was blocked. */    if (dev->bTxBlocked)    {#ifdef  DEBUG_TRACE        printf("eth%d Restart Tx\n", dev->unit);#endif  /* DEBUG_TRACE */        muxTxRestart(&dev->endObj);        dev->bTxBlocked = FALSE;    }}/********************************************************************************* at91EthShow - display driver statstics.** RETURNS : N/A*/STATUS at91EthShow(int unit){    return OK;}/********************************************************************************* at91EthMiiShow - display MII registers.** RETURNS : N/A*/STATUS at91EthMiiShow(int unit){#if 0    ETH_DRV_CTRL *dev = (ETH_DRV_CTRL *)endFindByName(ETH_DEV_NAME, unit);    UINT8 phyAddr;    if (!dev)    {        return -1;    }    phyAddr = dev->phyInfo.phyAddr;    at91EthMiiRead(dev, phyAddr, MII_CTRL_REG,      &dev->PHYREGS.phyCtrl);    at91EthMiiRead(dev, phyAddr, MII_STAT_REG,      &dev->PHYREGS.phyStatus);    at91EthMiiRead(dev, phyAddr, MII_PHY_ID1_REG,   &dev->PHYREGS.phyId1);    at91EthMiiRead(dev, phyAddr, MII_PHY_ID2_REG,   &dev->PHYREGS.phyId2);    at91EthMiiRead(dev, phyAddr, MII_AN_ADS_REG,    &dev->PHYREGS.phyAds);    at91EthMiiRead(dev, phyAddr, MII_AN_PRTN_REG,   &dev->PHYREGS.phyPrtn);    at91EthMiiRead(dev, phyAddr, MII_AN_EXP_REG,    &dev->PHYREGS.phyExp);    at91EthMiiRead(dev, phyAddr, MII_AN_NEXT_REG,   &dev->PHYREGS.phyNext);    at91EthMiiRead(dev, phyAddr, MII_LPA,   &dev->l80225Status);    printf("Standard MII register\n");    printf("    MII_CTRL_REG:       0x%04X\n", dev->PHYREGS.phyCtrl);    printf("    MII_STAT_REG:       0x%04X\n", dev->PHYREGS.phyStatus);    printf("    MII_PHY_ID1_REG:    0x%04X\n", dev->PHYREGS.phyId1);    printf("    MII_PHY_ID2_REG:    0x%04X\n", dev->PHYREGS.phyId2);    printf("    MII_AN_ADS_REG:     0x%04X\n", dev->PHYREGS.phyAds);    printf("    MII_AN_PRTN_REG:    0x%04X\n", dev->PHYREGS.phyPrtn);    printf("    MII_AN_EXP_REG:     0x%04X\n", dev->PHYREGS.phyExp);    printf("    MII_AN_NEXT_REG:    0x%04X\n", dev->PHYREGS.phyNext);    printf("PHY specific register\n");    printf("    L80225_STAT_REG:    0x%04X\n", dev->l80225Status);#endif    return OK;}#ifdef  DEBUG_TRACE/********************************************************************************* at91EthHexDump - dump buffer.** RETURNS : N/A*/void at91EthHexDump(UCHAR *p, ULONG l){    ULONG i;    while (l)    {        printf("%08X:  ", (UINT32)p);        for (i=0; i<16; i++)        {            printf("%02X ", *p++);            if (--l == 0)            {                break;            }        }        printf("\n");    }}#endif  /* DEBUG_TRACE */#ifdef  INCLUDE_SEC_END#include "src/drv/end/secEnd.c"#endif  /* INCLUDE_SEC_END */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久精品免费免费| 亚洲国产欧美另类丝袜| 亚洲一区二区三区免费视频| 99久久夜色精品国产网站| 国产日韩精品久久久| 亚洲成人av资源| 色欧美乱欧美15图片| 亚洲欧美偷拍三级| 91免费视频网址| 亚洲老司机在线| 色中色一区二区| 国产日韩精品一区二区浪潮av| 精品无码三级在线观看视频| 精品福利在线导航| 国产精品99久久久久久宅男| 国产人伦精品一区二区| 成人av在线资源| 国产精品欧美久久久久无广告| 国产精品一区二区免费不卡| 欧美国产欧美综合| 91亚洲精品久久久蜜桃| 亚洲在线观看免费| 91日韩一区二区三区| 一区二区高清免费观看影视大全 | 香蕉久久一区二区不卡无毒影院 | 亚洲一区二区视频在线观看| 在线欧美日韩国产| 日韩成人精品在线| 国产午夜精品久久久久久久 | 自拍偷自拍亚洲精品播放| 一本到不卡精品视频在线观看| 亚洲一区在线观看视频| 日韩三级在线观看| 成人综合日日夜夜| 亚洲欧美偷拍卡通变态| 欧美一区二视频| 国产91精品露脸国语对白| 一区二区三区在线影院| 欧美成人aa大片| 国产精华液一区二区三区| 自拍偷拍国产精品| 欧美一级生活片| 成人午夜视频网站| 日韩精品成人一区二区在线| 久久精品日产第一区二区三区高清版 | 91精品国产综合久久久久| 国产一区不卡视频| 亚洲综合成人在线| 久久久av毛片精品| 日本久久一区二区| 激情综合色综合久久综合| 亚洲精品乱码久久久久久黑人 | 久久久国产午夜精品| 在线精品亚洲一区二区不卡| 婷婷夜色潮精品综合在线| 久久亚洲免费视频| 欧美性猛交一区二区三区精品| 国产成人av资源| 亚洲男女一区二区三区| 欧美精三区欧美精三区| 成人短视频下载| 免费的成人av| 亚洲欧洲精品一区二区精品久久久| 在线播放国产精品二区一二区四区| 成人在线综合网| 老司机精品视频在线| 国产欧美日韩另类视频免费观看| 欧美色中文字幕| 国产99久久久国产精品潘金| 免费看黄色91| 一区二区高清免费观看影视大全| 中文av一区特黄| 精品国产免费一区二区三区四区| 欧美日韩亚洲综合在线 欧美亚洲特黄一级| 国产精品小仙女| 午夜精品久久久久久不卡8050| 中文字幕一区二区三中文字幕| 久久色.com| 91精品国产91久久久久久一区二区| 在线观看视频一区二区欧美日韩| 99久久久国产精品| 国内精品国产三级国产a久久| 午夜电影久久久| 亚洲成人一区二区在线观看| 亚洲欧洲制服丝袜| 亚洲人成网站在线| 亚洲欧洲av一区二区三区久久| 欧美一区二区三区免费视频| 欧美日本一区二区| 欧美亚洲高清一区二区三区不卡| 一本久久精品一区二区| 91丨九色丨尤物| 精品一区二区三区在线播放视频| 蜜桃视频一区二区三区 | 欧美乱熟臀69xxxxxx| 色综合久久久久网| 一本大道久久a久久综合| av中文一区二区三区| 99精品视频在线免费观看| 黄色日韩三级电影| 国产精品66部| 99这里都是精品| 欧美唯美清纯偷拍| 精品日韩欧美在线| 亚洲视频每日更新| 美女在线一区二区| 51午夜精品国产| 精品国产伦一区二区三区观看体验| 日本一区二区三区四区| 亚洲小说春色综合另类电影| 麻豆高清免费国产一区| 99精品视频在线免费观看| 777亚洲妇女| 国产精品婷婷午夜在线观看| 亚洲成人一区在线| 国产91精品露脸国语对白| 欧美日韩一区中文字幕| 久久精品一区蜜桃臀影院| 一区二区在线电影| 激情久久五月天| 欧美三级视频在线播放| 亚洲国产精品黑人久久久| 亚洲一区二区三区四区五区黄| 国产精品456露脸| 欧美日韩日日摸| 中文字幕一区在线观看视频| 日本美女视频一区二区| 91看片淫黄大片一级在线观看| 日韩欧美亚洲另类制服综合在线 | 欧美变态tickling挠脚心| 亚洲欧美另类综合偷拍| 国产在线日韩欧美| 欧美精品久久久久久久多人混战| 国产欧美日韩不卡免费| 奇米综合一区二区三区精品视频| 色婷婷一区二区| 亚洲国产高清在线| 精品一区二区三区在线观看| 欧美精品久久一区| 一区二区三区中文字幕电影| 福利视频网站一区二区三区| 精品国产免费久久| 蜜桃av一区二区三区| 欧美日韩亚洲综合在线 | 国产精品不卡在线| 精品一区二区国语对白| 欧美一区二区福利视频| 一区二区三区欧美视频| 91在线观看一区二区| 国产三级精品视频| 激情成人综合网| 欧美tk—视频vk| 免费欧美在线视频| 91麻豆精品国产| 日韩制服丝袜先锋影音| 欧美日韩国产另类一区| 一区二区日韩av| 在线一区二区视频| 一个色综合网站| 在线看国产日韩| 亚洲国产乱码最新视频| 欧美日韩亚洲综合| 丝袜脚交一区二区| 欧美精品一二三区| 免费观看成人av| 欧美电视剧在线观看完整版| 狠狠狠色丁香婷婷综合久久五月| 日韩欧美电影一区| 国产一区二区不卡老阿姨| 久久久精品免费观看| 国产ts人妖一区二区| 国产精品国产三级国产三级人妇| 成人晚上爱看视频| 综合久久综合久久| 欧洲中文字幕精品| 亚洲成a人v欧美综合天堂下载| 91精品久久久久久久久99蜜臂| 蜜桃久久精品一区二区| 久久嫩草精品久久久久| 不卡一区二区在线| 亚洲伦在线观看| 欧美日韩久久一区二区| 久久精品国产免费看久久精品| 久久综合国产精品| 国产成人午夜视频| 亚洲男人的天堂在线观看| 欧美日韩国产综合一区二区三区| 日韩精品乱码免费| 久久精品亚洲麻豆av一区二区 | 午夜电影久久久| 精品卡一卡二卡三卡四在线| 风流少妇一区二区| 亚洲伦理在线精品| 日韩一级片在线播放| 国产.精品.日韩.另类.中文.在线.播放| 国产精品免费网站在线观看| 欧美性感一区二区三区| 91蝌蚪porny九色| 日韩专区中文字幕一区二区| 国产午夜精品久久久久久免费视 |