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

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

?? ibmemacend.c

?? WINDRIVER SBC405 BSP
?? C
?? 第 1 頁 / 共 5 頁
字號:
     * MAL this EMAC is attached to.     */    tok = strtok_r (NULL, ":", ppHolder);    if (tok == NULL)        return ERROR;    pDrvCtrl->pMalData = (MAL_DATA *)strtoul (tok, NULL, 16);    /*     * Fourteenth parameter is the OPB bus speed in MHz.     */    tok = strtok_r (NULL, ":", ppHolder);    if (tok == NULL)        return ERROR;    pDrvCtrl->opbSpeedMhz = atoi (tok);    return OK;    }/********************************************************************************* ibmEmacMemInit - initialize memory required for the driver** Using data in the control structure (some of which came from the* initialization string), setup and initialize the memory regions as needed.** RETURNS: OK or ERROR.*/LOCAL STATUS ibmEmacMemInit    (    EMAC_DRV_CTRL * pDrvCtrl    )    {    UINT32      tempSize;    int         i, j;    MAL_BD *    pTempDesc;    char *      pTempBuf;    /*     * If a memory region was specified in the initialization string, determine     * if it is large enough to hold the minimum number of buffers (clusters).     * It is assumed that this memory is not cached.  Descriptor memory has     * already been allocated by malLib.     */    if ((int)pDrvCtrl->memInputAdrs != NONE)        {        pDrvCtrl->memAdrs = pDrvCtrl->memInputAdrs;        pDrvCtrl->memSize = pDrvCtrl->memInputSize;        /* If not properly aligned, align it */        while ((int)pDrvCtrl->memAdrs & (pDrvCtrl->cacheLineSize - 1))            {            pDrvCtrl->memAdrs++;            pDrvCtrl->memSize--;            }        /* initialize the space */        bzero((char *)pDrvCtrl->memAdrs, pDrvCtrl->memSize);        if (pDrvCtrl->memSize > EMAC_MIN_MEM_SIZE)            {            /*             * Determine the number of buffers this region can hold, and             * determine the numbers of descriptors needed for both TX and             * RX.             */            tempSize = pDrvCtrl->memSize;            if (tempSize > EMAC_MAX_MEM_SIZE)                tempSize = EMAC_MAX_MEM_SIZE;            /*             * Give half of the descriptors to the RX channel, the rest to the             * TX channel(s).             */            tempSize = tempSize / EMAC_BSC_MEM_SIZE;            pDrvCtrl->numRxD = tempSize / 2;            if (pDrvCtrl->inputFlags & EMAC_INPUT_TX_2_CHANNEL)                {                pDrvCtrl->txInfo[0].numTxD = (tempSize - pDrvCtrl->numRxD) / 2;                pDrvCtrl->txInfo[1].numTxD = pDrvCtrl->txInfo[0].numTxD;                }            else                {                pDrvCtrl->txInfo[0].numTxD = tempSize - pDrvCtrl->numRxD;                }            /* Assume the memory is cache safe, copy null structure */            pDrvCtrl->cacheFuncs = cacheNullFuncs;            }        else            {            printf("MemSize specified in the ibmEmacEnd load string is not\n");            printf("large enough.  It must be at least %d bytes.\n",                                                        EMAC_MIN_MEM_SIZE);            }        }    /*     * If a memory region was not specified in the load string, allocate one     * (default size).  Buffer memory does NOT have to be cache safe (i.e.     * uncached)  If buffer memory is cached, this driver will manage cache     * coherency.     */    if ((int)pDrvCtrl->memInputAdrs == NONE)        {        /*         * Allocate the default sized chunk of memory to hold buffers.         * The inputFlags parameter that was passed into the load string         * indicates whether the buffers should be allocated from cached         * or cache safe memory.         * Add the size of a cache line because it may have to be         * adjusted for proper cache line alignment.         */        pDrvCtrl->memSizeMalloc = EMAC_DFT_MEM_SIZE + pDrvCtrl->cacheLineSize;        if (pDrvCtrl->inputFlags & EMAC_INPUT_UNCACHED_BUF)            {            /* Allocate cache safe (uncached) memory for buffers */            pDrvCtrl->memAdrsMalloc = cacheDmaMalloc(pDrvCtrl->memSizeMalloc);            pDrvCtrl->cacheFuncs = cacheDmaFuncs;            }        else            {            /*             * Allocate cached memory for buffers             * Specify the flush and invalidate functions needed to maintain             * data cache coherency.             */            pDrvCtrl->memAdrsMalloc = malloc(pDrvCtrl->memSizeMalloc);            pDrvCtrl->cacheFuncs.flushRtn = cacheFlush;            pDrvCtrl->cacheFuncs.invalidateRtn = cacheInvalidate;            }        if (pDrvCtrl->memAdrsMalloc == NULL)            {            printf("Could not allocate memory for ibmEmacEnd\n");            return(ERROR);            }        /* Initialize region to zeros */        bzero((char *)pDrvCtrl->memAdrsMalloc, pDrvCtrl->memSizeMalloc);        /* Adjust the alignment. Put on a cache line boundary */        pDrvCtrl->memAdrs = pDrvCtrl->memAdrsMalloc;        pDrvCtrl->memSize = pDrvCtrl->memSizeMalloc;        while ((int)pDrvCtrl->memAdrs & (pDrvCtrl->cacheLineSize - 1))            {            pDrvCtrl->memAdrs++;	    pDrvCtrl->memSize--;            }        DRV_LOG (DRV_DEBUG_INFO, "Buffer space = 0x%x size = 0x%x\n",                                        pDrvCtrl->memAdrs,                                        pDrvCtrl->memSize, 3, 4, 5, 6);        pDrvCtrl->numRxD = EMAC_RXD_DFT;        /*         * Depending on how many TX channels are being used, TX channel 0 gets         * all of the allotted TX descriptors, or half.  TX channel 1 gets what         * is left.         */        pDrvCtrl->txInfo[0].numTxD = EMAC_TXD_DFT / pDrvCtrl->numTxChannels;        pDrvCtrl->txInfo[1].numTxD = EMAC_TXD_DFT - pDrvCtrl->txInfo[0].numTxD;        }    /* Get the address of the TX descriptor tables */    malChannelDescTblPtrGet(pDrvCtrl->pMalData, MAL_TX_TYPE,                            pDrvCtrl->txChn0MalChannel,                            &pDrvCtrl->txInfo[0].pTxDesc);    DRV_LOG (DRV_DEBUG_INFO, "TX 0 Desc Ring 0x%x\n",                                    pDrvCtrl->txInfo[0].pTxDesc, 2, 3, 4, 5, 6);    malChannelDescTblPtrGet(pDrvCtrl->pMalData, MAL_TX_TYPE,                            pDrvCtrl->txChn1MalChannel,                            &pDrvCtrl->txInfo[1].pTxDesc);    DRV_LOG (DRV_DEBUG_INFO, "TX 1 Desc Ring 0x%x\n",                                    pDrvCtrl->txInfo[1].pTxDesc, 2, 3, 4, 5, 6);    /*     * Initialize the arrays that will be used by SendCleanup to free clusters     * or mBlks after a packet has been transmitted.     */    for (i = 0; i < pDrvCtrl->numTxChannels; i++)        {        for (j = 0; j < pDrvCtrl->txInfo[i].numTxD; j++)            {            pDrvCtrl->txInfo[i].txFree[j].typeFree = EMAC_TX_FREE_NONE;            pDrvCtrl->txInfo[i].txFree[j].pFree = NULL;            }        }    /*     * Allocate memory for a net pool structure, and initialize it.     * There will be one cluster for each descriptor, one cluster block     * for each cluster, and two mBlks for each cluster block.     */    pDrvCtrl->end.pNetPool = malloc(sizeof(NET_POOL));    if (pDrvCtrl->end.pNetPool == NULL)        return (ERROR);    pDrvCtrl->clDesc.clNum    = (pDrvCtrl->numRxD * EMAC_RXD_LOAN_X)                                + pDrvCtrl->txInfo[0].numTxD                                + pDrvCtrl->txInfo[1].numTxD;    pDrvCtrl->mClCfg.clBlkNum = pDrvCtrl->clDesc.clNum;    pDrvCtrl->mClCfg.mBlkNum  = pDrvCtrl->mClCfg.clBlkNum * 2;    /* Determine the memory required to hold all mBlks and clBlks */    pDrvCtrl->mClCfg.memSize =                    (pDrvCtrl->mClCfg.mBlkNum * (M_BLK_SZ + sizeof (long))) +                    (pDrvCtrl->mClCfg.clBlkNum * (CL_BLK_SZ + sizeof (long)));    /* Allocate memory to hold the mBlk and clBlk structures*/    pDrvCtrl->mClCfg.memArea = memalign(sizeof(long), pDrvCtrl->mClCfg.memSize);    if (pDrvCtrl->mClCfg.memArea == NULL)        return (ERROR);    DRV_LOG (DRV_DEBUG_INFO, "mBlk clBlk storage = 0x%x size = 0x%x\n",                                                   pDrvCtrl->mClCfg.memArea,                                                   pDrvCtrl->mClCfg.memSize,                                                   3, 4, 5, 6);    /*     * Finally determine the memory required to hold all of the clusters.     * The size of a cluster MUST be an even multiple of the cache line size.     * Memory for the clusters was allocated above.     */    pDrvCtrl->clDesc.clSize  = EMAC_BUF_SIZE;    pDrvCtrl->clDesc.memSize = pDrvCtrl->clDesc.clNum *                               (pDrvCtrl->clDesc.clSize + sizeof(long));    pDrvCtrl->clDesc.memArea = (char *)pDrvCtrl->memAdrs;    /* Initialize the net pool */    if (netPoolInit (pDrvCtrl->end.pNetPool, &pDrvCtrl->mClCfg,                     &pDrvCtrl->clDesc, 1, NULL) == ERROR)        {        DRV_LOG (DRV_DEBUG_ERROR, "Could not init buffering\n",                 1, 2, 3, 4, 5, 6);        return (ERROR);        }    /* Get and save the net cluster pool id */    pDrvCtrl->pClPoolId = clPoolIdGet(pDrvCtrl->end.pNetPool,                                               EMAC_BUF_SIZE, FALSE);    /*     * Get the address of the RX channel descriptor table.     * Go ahead and get a cluster from the pool for each of the RX descriptors.     * Assign each of the clusters to one of the RX descriptors.     * This is done to make the driver almost ready to receive packets.     */    malChannelDescTblPtrGet(pDrvCtrl->pMalData, MAL_RX_TYPE,                            pDrvCtrl->rxChn0MalChannel,                            &pDrvCtrl->pRxDesc);    DRV_LOG (DRV_DEBUG_INFO, "RX Desc Ring 0x%x\n",                                        pDrvCtrl->pRxDesc, 2, 3, 4, 5, 6);    pTempDesc = pDrvCtrl->pRxDesc;    for (i = 0; i < pDrvCtrl->numRxD; i++)        {        pTempBuf = netClusterGet(pDrvCtrl->end.pNetPool, pDrvCtrl->pClPoolId);        if (pTempBuf == NULL)            {            DRV_LOG (DRV_DEBUG_LOAD, "Get RX cluster from pool failed\n",                     1, 2, 3, 4, 5, 6);            return (ERROR);            }        /* Put the cluster address in the buffer addr field of the descriptor */        pTempDesc[i].bufferAdrs = pTempBuf;        }    return OK;    }/********************************************************************************* ibmEmacStart - start the device** This function calls BSP functions to connect interrupts and start the* device running in interrupt mode.** RETURNS: OK or ERROR*/LOCAL STATUS ibmEmacStart    (    EMAC_DRV_CTRL *   pDrvCtrl    )    {    int     rc;    DRV_LOG (DRV_DEBUG_START, "ibmEmacStart \n", 1, 2, 3, 4, 5, 6);    pDrvCtrl->localFlags &= ~EMAC_TX_CLEAN_RUNNING;    pDrvCtrl->localFlags &= ~EMAC_TX_BLOCKED;    /*     * Connect, clear status, then enable the Ethernet interrupt.     * This interrupt is primarily for error conditions.     * MAL handles interrupts for TX/RX end-of-buffer, and descriptor errors.     */    EMAC_INT_CONNECT (pDrvCtrl, ibmEmacInt, pDrvCtrl, &rc);    EMAC_REG_WRITE(pDrvCtrl, EMAC_ISR, 0xFFFFFFFF);    EMAC_INT_ENABLE (pDrvCtrl);    /* Allow MAL EOB and Descriptor error interrupts */    malChannelIntMaskSet(pDrvCtrl->pMalData, MAL_TX_TYPE,                         pDrvCtrl->txChn0MalChannel,                         MAL_EOB_INT_EN | MAL_DE_INT_EN | MAL_SERR_INT_EN);    if (pDrvCtrl->inputFlags & EMAC_INPUT_TX_2_CHANNEL)        malChannelIntMaskSet(pDrvCtrl->pMalData, MAL_TX_TYPE,                             pDrvCtrl->txChn1MalChannel,                             MAL_EOB_INT_EN | MAL_DE_INT_EN | MAL_SERR_INT_EN);    malChannelIntMaskSet(pDrvCtrl->pMalData, MAL_RX_TYPE,                         pDrvCtrl->rxChn0MalChannel,                         MAL_EOB_INT_EN | MAL_DE_INT_EN | MAL_SERR_INT_EN);    DRV_LOG (DRV_DEBUG_START, "TX and RX channels active.\n", 1, 2, 3, 4, 5, 6);    return (OK);    }/********************************************************************************* ibmEmacInt - handle EMAC controller interrupt** This routine is called at interrupt level in response to an interrupt from* the EMAC controller.  The interrupt occurs because of TX or RX error* conditions.**/LOCAL void ibmEmacInt    (    EMAC_DRV_CTRL *   pDrvCtrl    )    {    UINT isrReg;    UINT isrClear;    /* Read the EMAC interrupt status register */    EMAC_REG_READ(pDrvCtrl, EMAC_ISR, isrReg);    pDrvCtrl->errorEmac = isrReg;    DRV_LOG (DRV_DEBUG_ENET_INT, "EMAC Ethernet int 0x%x\n",                                                       isrReg, 2, 3, 4, 5, 6);    /*     * Check to see if there was a TX error.  If there was, the Dead bit     * will be set. Clear the status bits for the TX error, and clear the     * dead bit.  Keep count of these errors in the main device structure.     *     * Note that non-zero values of EMAC_ISR_TX_INTS are used primarily     * for debugging.  When EMAC_ISR_TX_INTS is zero, some compilers     * may warn about an always-false conditional expression.     */    if (isrReg & EMAC_ISR_TX_INTS)        {        pDrvCtrl->intErrorTX++;        if (pDrvCtrl->inputFlags & EMAC_INPUT_TX_2_CHANNEL)            isrClear = EMAC_ISR_TX_INTS | EMAC_ISR_DB0 | EMAC_ISR_DB1;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
偷拍日韩校园综合在线| 亚洲国产一区二区三区| 色婷婷综合在线| 精品一区二区三区免费播放| 亚洲九九爱视频| 国产精品视频一二三| 国产亚洲女人久久久久毛片| 久久91精品国产91久久小草| 国产精品久久久久久久久免费相片| 欧美一区二区视频在线观看2022 | 欧美日韩国产一区| 在线观看视频一区二区| 91精彩视频在线观看| 日本久久一区二区三区| 一本大道久久a久久综合婷婷| 国产宾馆实践打屁股91| 国产成人av电影在线播放| 精油按摩中文字幕久久| 激情文学综合丁香| 国产传媒日韩欧美成人| 成人亚洲一区二区一| 在线亚洲欧美专区二区| 欧美精品九九99久久| 日韩欧美在线网站| 国产午夜精品在线观看| 久久精品欧美一区二区三区麻豆| 欧美韩日一区二区三区四区| 亚洲天堂a在线| 日韩高清不卡在线| 黑人巨大精品欧美黑白配亚洲| 国产福利一区二区三区视频| 99久久综合国产精品| 欧美在线免费观看亚洲| 日韩无一区二区| 国产精品国产三级国产普通话蜜臀| 亚洲欧美色一区| 久久精品国产99国产精品| av电影在线观看完整版一区二区| 在线视频欧美精品| 亚洲欧美影音先锋| 奇米影视一区二区三区| 成人av在线网站| 日韩视频在线一区二区| 国产精品不卡一区| 国产精品一级二级三级| 欧美日韩高清一区二区三区| 国产欧美一区二区三区在线老狼| 亚洲国产日韩一级| 91麻豆文化传媒在线观看| 日韩欧美一区二区视频| 亚洲图片欧美视频| 成人成人成人在线视频| 亚洲精品一区二区三区精华液| 一区二区视频免费在线观看| 国产黄色成人av| 精品国偷自产国产一区| 亚洲电影一级片| 欧洲精品一区二区| 国产曰批免费观看久久久| 日韩久久精品一区| 麻豆91免费观看| 欧美成va人片在线观看| 久久国产欧美日韩精品| 欧美成人乱码一区二区三区| 午夜精品久久久| 欧美精品久久久久久久久老牛影院| 亚洲欧洲中文日韩久久av乱码| 成人午夜激情片| 日韩美女精品在线| 色狠狠色噜噜噜综合网| 亚洲精品乱码久久久久久| 91官网在线免费观看| 一区二区三区免费在线观看| 色婷婷亚洲精品| 午夜电影网亚洲视频| 国产三级精品在线| 国产在线精品一区在线观看麻豆| jizzjizzjizz欧美| 精品一区二区三区久久久| 精品免费国产二区三区| 日本韩国欧美一区| caoporn国产精品| 国产一区二区三区四区在线观看| 亚洲国产一区二区在线播放| 欧美激情综合网| 国产欧美一区二区三区在线老狼| 国产精品原创巨作av| 中文字幕一区二区不卡| 69堂精品视频| 国产精品888| 亚洲va欧美va国产va天堂影院| 日韩欧美在线观看一区二区三区| 国产尤物一区二区| 亚洲女同一区二区| 久久精品视频一区二区三区| 成人亚洲一区二区一| 亚洲精品视频观看| 欧美高清精品3d| 国产激情偷乱视频一区二区三区| 欧美—级在线免费片| 欧美午夜一区二区三区| 美女视频免费一区| 欧美一区二区三区在线观看| 九九国产精品视频| 国产精品国产自产拍高清av王其| 欧美探花视频资源| 白白色亚洲国产精品| 狠狠久久亚洲欧美| 亚洲精品久久7777| 中文字幕一区二区三区视频| 久久一区二区视频| 日韩一区和二区| 在线观看成人小视频| 成人晚上爱看视频| 国产黄色成人av| 精品一区二区三区香蕉蜜桃| 日韩专区中文字幕一区二区| 亚洲视频一区二区免费在线观看| 久久久激情视频| 精品久久人人做人人爱| 欧美一卡二卡在线| 欧美一区二区在线视频| 欧美亚洲国产一区二区三区| 国产福利一区二区三区| 从欧美一区二区三区| 一本色道久久综合狠狠躁的推荐| 国产suv精品一区二区6| av成人免费在线| 欧美日韩国产首页| 欧美一级午夜免费电影| 久久综合久久久久88| 欧美激情一区二区三区全黄| 久久久午夜精品| 亚洲国产美女搞黄色| 日韩av一区二区在线影视| 久久国产精品99精品国产| 国产一区三区三区| 91传媒视频在线播放| 在线播放中文一区| 国产欧美精品一区| 日日骚欧美日韩| 国产一区二区三区免费观看 | 天天做天天摸天天爽国产一区| 手机精品视频在线观看| 成人伦理片在线| 日韩欧美亚洲另类制服综合在线| 亚洲精品免费视频| 国产原创一区二区| 日韩一区二区免费视频| 一区二区三区在线免费视频| 国产精品影视在线观看| 日韩欧美一二区| 日韩黄色片在线观看| 99精品久久99久久久久| 久久精品日韩一区二区三区| 免费精品视频在线| 91麻豆福利精品推荐| 日韩精品一区二区三区在线播放| 一区二区三区色| 豆国产96在线|亚洲| 91.com视频| 一区二区三区小说| 国产激情视频一区二区三区欧美 | 国产精品久久看| 国产麻豆精品在线| 国产夜色精品一区二区av| 日本不卡一区二区三区| 欧洲视频一区二区| 国产精品亲子乱子伦xxxx裸| 看电影不卡的网站| 欧美一区二区观看视频| 日本不卡1234视频| 欧美男同性恋视频网站| 亚洲国产aⅴ成人精品无吗| 色综合天天综合色综合av| 中文字幕在线一区免费| 国产精品一区二区不卡| 精品成人一区二区三区四区| 免费人成黄页网站在线一区二区 | 在线亚洲+欧美+日本专区| 亚洲免费在线观看视频| 91一区在线观看| 一区二区三区四区激情| 欧美色图12p| 国产69精品久久久久777| 久久精品视频在线看| 国产福利一区在线| 国产精品久久久久久久久晋中 | 成人国产视频在线观看| 久久久五月婷婷| 成人h精品动漫一区二区三区| 亚洲色大成网站www久久九九| 91麻豆国产在线观看| 亚洲成人你懂的| 在线不卡欧美精品一区二区三区| 肉丝袜脚交视频一区二区| 久久影音资源网| 成人国产视频在线观看| 久久精品国内一区二区三区| 一区在线观看免费|