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

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

?? ethernet.c

?? 4510b的vxworks的BSP
?? C
?? 第 1 頁 / 共 5 頁
字號:
	*(UINT32 *)SNDS_BDMASTAT = RxGood ;	
*/
    do
        {
		/*
		 * Check if Null list interrupt has occurred.  If yes, reset
		 * and restart the Ethernet MAC (as given in Samsung sample code.
		 */
		if (bdmaStat.stat_reg.bdmaRxNullList)
			{
			sndsEndStop(pDrvCtrl);	/* Stop RX and TX */
			sndsEndReset(pDrvCtrl);	/* reset the chip */
			sndsEndFdFree(pDrvCtrl);	/* Free the FDs */
			sndsEndFdInitialize(pDrvCtrl);	/* Reinitialize FDs */
			sndsEndMacInitialize(pDrvCtrl);	/* Initialize MAC */
			sndsEndStart(pDrvCtrl);	/* Start RX and TX */
			break;
			}
		/*
		 * Received a good frame
		 */
		frameLength = gpReceiveFrameDescStart->rxStatusLength.frameLength;

	    /*Update error statistics counters */
/*
		if(	  
			(gpReceiveFrameDescStart->rxStatusLength.ovMax)|
			(gpReceiveFrameDescStart->rxStatusLength.ctlRcv)|
			(gpReceiveFrameDescStart->rxStatusLength.rx10Stat)|
			(gpReceiveFrameDescStart->rxStatusLength.alignErr)|
			(gpReceiveFrameDescStart->rxStatusLength.crcErr)|
			(gpReceiveFrameDescStart->rxStatusLength.overFlow)|
			(gpReceiveFrameDescStart->rxStatusLength.longErr)|
			(gpReceiveFrameDescStart->rxStatusLength.rxPar)|
			(gpReceiveFrameDescStart->rxStatusLength.rxHalted))
			{
*/

	if ((*(UINT32 *) (&gpReceiveFrameDescStart->rxStatusLength)) & 0xbfff0000 )
			{
			pDrvCtrl->statistics.rxBad++;
	    	*(UINT32 *)SNDS_IOPDATA = 0xf3 ; 
			if (gpReceiveFrameDescStart->rxStatusLength.ovMax)
				pDrvCtrl->statistics.rxOvMaxSize++;
			if (gpReceiveFrameDescStart->rxStatusLength.ctlRcv)
				pDrvCtrl->statistics.rxCtlRecd++;
			if (gpReceiveFrameDescStart->rxStatusLength.rx10Stat)
				pDrvCtrl->statistics.rx10Stat++;
			if (gpReceiveFrameDescStart->rxStatusLength.alignErr)
				pDrvCtrl->statistics.rxAlignErr++;
			if (gpReceiveFrameDescStart->rxStatusLength.crcErr)
				pDrvCtrl->statistics.rxCRCErr++;
			if (gpReceiveFrameDescStart->rxStatusLength.overFlow)
				pDrvCtrl->statistics.rxOverflowErr++;
			if (gpReceiveFrameDescStart->rxStatusLength.longErr)
				pDrvCtrl->statistics.rxLongErr++;
			if (gpReceiveFrameDescStart->rxStatusLength.rxPar)
				pDrvCtrl->statistics.rxParErr++;
			if (gpReceiveFrameDescStart->rxStatusLength.rxHalted)
				pDrvCtrl->statistics.rxHalted++;
			}
		else if((gpReceiveFrameDescStart->rxStatusLength.good))
			{
			pDrvCtrl->statistics.rxGood++;
			pFrameData = (UINT16 *)(gpReceiveFrameDescStart->rxFrameData.frameDataPtr);
			sndsEndBugFix (pFrameData);
			sndsEndRecv (pDrvCtrl, (char *)pFrameData, frameLength);
			GoodCnt++ ;

	    	*(UINT32 *)SNDS_IOPDATA = 0x3f ; 
			/*printf("\n GoodCount %d, RxStatus %x \n", GoodCnt, *(UINT32 *)(&gpReceiveFrameDescStart->rxStatusLength) );*/
			/*printf("G");*/
			}
		else ;
		gpReceiveFrameDescStart->rxFrameData.o_bit = 1;	/* Ownership back to BDMA */
		gStatusLengthPrevious = *(UINT32 *)(&gpReceiveFrameDescStart->rxStatusLength);	/* For MAC bug fix */
		*(UINT32 *)(&gpReceiveFrameDescStart->rxStatusLength) = 0;	/* Rx status length field */

		gpReceiveFrameDescStart = gpReceiveFrameDescStart->nextRxFrameDesc;
		} while (gpReceiveFrameDescStart != pReceiveFrameDesc);

#if 0
/* cjw */
	    if(!((*(UINT32 *)SNDS_BDMARXCON) & BRxEn)){ 
			*(UINT32 *)SNDS_IOPDATA = 0xf0 ; 
        	printf("\n\n\n\n  BDMA Rx Stopped !!!!!! %x @@@@@@@@@@@@@@@\n\n\n\n\n", *(UINT32 *)SNDS_BDMARXCON);
		}
		
	    if(!((*(UINT32 *)SNDS_BDMASTAT) & BRxNO)) {
			*(UINT32 *)SNDS_IOPDATA = 0x00 ; 
	    	*(UINT32 *)SNDS_BDMASTAT = BRxNO; 
		}
	*(UINT32 *)SNDS_IOPDATA = 0x0f ; 
#endif
    }


/*******************************************************************************
*
* sndsEndRecv - process the next incoming packet
*
* Handle one incoming packet.  The packet is checked for errors.
*
* RETURNS: N/A.
*/

LOCAL STATUS sndsEndRecv
    (
    END_DEVICE *pDrvCtrl,	/* device structure */
    char* pData,			/* packet to process */
	UINT32 len
    )
    {
    M_BLK_ID 	pMblk;
    char*       pNewCluster;
    CL_BLK_ID	pClBlk;

	
    /* Add one to our unicast data. */
	END_ERR_ADD (&pDrvCtrl->end, MIB2_IN_UCAST, +1);

    /*
     * We implicitly are loaning here, if copying is necessary this
     * step may be skipped, but the data must be copied before being
     * passed up to the protocols.
     */
    
    pNewCluster = netClusterGet (pDrvCtrl->end.pNetPool, pDrvCtrl->end.pNetPool->clTbl[0]);

    if (pNewCluster == NULL)
        {
		END_ERR_ADD (&pDrvCtrl->end, MIB2_IN_ERRS, +1);
		goto cleanRXD;
        }

    /* Grab a cluster block to marry to the cluster we received. */

    if ((pClBlk = netClBlkGet (pDrvCtrl->end.pNetPool, M_DONTWAIT)) == NULL)
        {
        netClFree (pDrvCtrl->end.pNetPool, pNewCluster);
		END_ERR_ADD (&pDrvCtrl->end, MIB2_IN_ERRS, +1);
		goto cleanRXD;
        }

    
    /*
     * OK we've got a spare, let's get an M_BLK_ID and marry it to the
     * one in the ring.
     */

    if ((pMblk = mBlkGet (pDrvCtrl->end.pNetPool, M_DONTWAIT, MT_DATA)) == NULL)
        {
        netClBlkFree (pDrvCtrl->end.pNetPool, pClBlk); 
        netClFree (pDrvCtrl->end.pNetPool, pNewCluster);
		END_ERR_ADD (&pDrvCtrl->end, MIB2_IN_ERRS, +1);
		goto cleanRXD;
        }

    END_ERR_ADD (&pDrvCtrl->end, MIB2_IN_UCAST, +1);
	
	(UINT32)pData &= ~NON_CACHE_REGION;

    /* Join the cluster to the MBlock */
    netClBlkJoin (pClBlk, pData, SNDS_CL_SIZE, NULL, 0, 0, 0);
	
	
	netMblkClJoin (pMblk, pClBlk);

	pMblk->mBlkHdr.mData += SNDS_DATA_OFFSET;
	if (gBugFixDone == TRUE)
		pMblk->mBlkHdr.mData += 4;

    pMblk->mBlkHdr.mLen = len;
    pMblk->mBlkHdr.mFlags |= M_PKTHDR;
    pMblk->mBlkPktHdr.len = len;

    /* Call the upper layer's receive routine. */
    END_RCV_RTN_CALL(&pDrvCtrl->end, pMblk);
	/* gpReceiveFrameDescStart->rxFrameData.frameDataPtr = (UINT32) pNewCluster;  Mistral Solution re-add */

	gpReceiveFrameDescStart->rxFrameData.frameDataPtr = (UINT32) pNewCluster; 

	cleanRXD: /* old line 1 */

	/* gpReceiveFrameDescStart->rxFrameData.frameDataPtr = (UINT32) pNewCluster; */

/* Mistral Solution re-add */
	gpReceiveFrameDescStart->rxFrameData.frameDataPtr |= NON_CACHE_REGION;

    return (OK);
    }

/*******************************************************************************
*
* sndsEndSend - the driver send routine
*
* This routine takes a M_BLK_ID sends off the data in the M_BLK_ID.
* The buffer must already have the addressing information properly installed
* in it.  This is done by a higher layer.  The last arguments are a free
* routine to be called when the device is done with the buffer and a pointer
* to the argument to pass to the free routine.  
*
* RETURNS: OK or ERROR.
*/

LOCAL STATUS sndsEndSend
    (
    END_DEVICE *pDrvCtrl,	/* device ptr */
    M_BLK_ID pNBuff		/* data to send */
    )
    {
    int         len;
    int         oldLevel;
    BOOL        freeNow = TRUE;
	TRANSMIT_FRAME_DESC *pTxFd;
	BDMATXCON bdmaTxCon;
	MACTXCON macTxCon;

	*(UINT32 *)(&bdmaTxCon) = 0;
	*(UINT32 *)(&macTxCon) = 0;
    
	if (gpTransmitFrameDescStart->txFrameData.o_bit)	/* Ownership with BDMA? */
		return ERROR;
	pTxFd = gpTransmitFrameDescStart;
	len = pNBuff->mBlkPktHdr.len;
    /*
     * Obtain exclusive access to transmitter.  This is necessary because
     * we might have more than one stack transmitting at once.
     */
	END_TX_SEM_TAKE (&pDrvCtrl->end, WAIT_FOREVER);

    /* Set pointers in local structures to point to data. */
	netMblkToBufCopy(pNBuff, (void *)pTxFd->txFrameData.frameDataPtr, NULL) ;

	*(UINT32 *)(&pTxFd->txControl) = 0;	/* Reset control word */
	pTxFd->txControl.t_bit = 1;
	pTxFd->txControl.a_bit = 1;
	pTxFd->txControl.l_bit = 1;

	pTxFd->txStatusLength.frameLength = len;
	pTxFd->txFrameData.o_bit = 1;

    /* place a transmit request */

     oldLevel = intLock ();   /* now sndsEndInt won't get confused */

    /* initiate device transmit */
	bdmaTxCon.txCon_resetval = *(UINT32 *)SNDS_BDMATXCON;
	bdmaTxCon.txCon_reg.enable = 1;
	*(UINT32 *)SNDS_BDMATXCON = bdmaTxCon.txCon_resetval;

	macTxCon.macTxCon_resetval = *(UINT32 *)SNDS_MACTXCON;
	macTxCon.macTxCon_reg.transmitEnable = 1;
	*(UINT32 *)SNDS_MACTXCON = macTxCon.macTxCon_resetval;

    intUnlock (oldLevel);   /* now sndsEndInt won't get confused */
    
    /* Advance our management index */
	gpTransmitFrameDescStart = gpTransmitFrameDescStart->nextTxFrameDesc;

	END_TX_SEM_GIVE (&pDrvCtrl->end);
    
    /* Bump the statistic counter. */

    END_ERR_ADD (&pDrvCtrl->end, MIB2_OUT_UCAST, +1);

    /*
     * Cleanup.  The driver must either free the packet now or
     * set up a structure so it can be freed later after a transmit
     * interrupt occurs.
     */

    if (freeNow)
        netMblkClChainFree (pNBuff);

    return (OK);
    }

/*******************************************************************************
*
* sndsEndIoctl - the driver I/O control routine
*
* Process an ioctl request.
*
* RETURNS: A command specific response, usually OK or ERROR.
*/

LOCAL int sndsEndIoctl
    (
    END_DEVICE *pDrvCtrl,	/* device receiving command */
    int cmd,			/* ioctl command code */
    caddr_t data		/* command argument */
    )
    {
    int error = 0;
    long value;

    switch (cmd)
        {
        case EIOCSADDR:
	    if (data == NULL)
		return (EINVAL);
            bcopy ((char *)data, (char *)END_HADDR(&pDrvCtrl->end),
		   END_HADDR_LEN(&pDrvCtrl->end));
            break;

        case EIOCGADDR:
	    if (data == NULL)
		return (EINVAL);
            bcopy ((char *)END_HADDR(&pDrvCtrl->end), (char *)data,
		    END_HADDR_LEN(&pDrvCtrl->end));
            break;

        case EIOCSFLAGS:
	    value = (long)data;
	    if (value < 0)
		{
		value = ~value;
		END_FLAGS_CLR (&pDrvCtrl->end, value);
		}
	    else
		{
		END_FLAGS_SET (&pDrvCtrl->end, value);
		}
	    sndsEndConfig (pDrvCtrl);
            break;

        case EIOCGFLAGS:
	    *(int *)data = END_FLAGS_GET(&pDrvCtrl->end);
            break;

	case EIOCPOLLSTART:
	    sndsEndPollStart (pDrvCtrl);
	    break;

	case EIOCPOLLSTOP:
	    sndsEndPollStop (pDrvCtrl);
	    break;

    case EIOCGMIB2:
         if (data == NULL)
            return (EINVAL);
            bcopy((char *)&pDrvCtrl->end.mib2Tbl, (char *)data,
            sizeof(pDrvCtrl->end.mib2Tbl));
            break;
    
    case EIOCGFBUF:
         if (data == NULL)
             return (EINVAL);
            *(int *)data = 0;	/**END_MIN_FBUF;**/
            break;

    default:
            error = EINVAL;
        }

    return (error);
    }

/******************************************************************************
*
* sndsEndConfig - reconfigure the interface under us.
*
* Reconfigure the interface setting promiscuous mode
*
* RETURNS: N/A.
*/

LOCAL void sndsEndConfig
    (
    END_DEVICE *pDrvCtrl	/* device to be re-configured */
    )
    {
	sndsEndReset(pDrvCtrl);	/* reset the chip */

    /* Set up address filter for multicasting. */
	
    if (END_MULTI_LST_CNT(&pDrvCtrl->end) > 0)
		sndsEndAddrFilterSet (pDrvCtrl);

	if (pDrvCtrl->fdInitialized == TRUE)
		sndsEndFdFree(pDrvCtrl);	/* Free the FDs */
	sndsEndFdInitialize(pDrvCtrl);	/* Reinitialize FDs */
	sndsEndMacInitialize(pDrvCtrl);	/* Initialize MAC */

	/* Was started before in interrupt mode? */
	if ((END_FLAGS_GET(&pDrvCtrl->end) & IFF_RUNNING) && \
		((pDrvCtrl->flags & LS_POLLING) == 0))
			sndsEndStart(pDrvCtrl);	/* Start again */

    return;
    }

/*******************************************************************************
*
* sndsEndPollStart - start polled mode operations
*
* RETURNS: OK or ERROR.
*/

LOCAL STATUS sndsEndPollStart
    (
    END_DEVICE* pDrvCtrl	/* device to be polled */
    )
    {

    int         oldLevel;
	BDMARXCON bdmaRxCon;
	MACRXCON macRxCon;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
4438x亚洲最大成人网| 欧美三级日韩三级| 在线免费一区三区| 久久人人爽人人爽| 亚洲国产成人av网| 成人毛片视频在线观看| 制服丝袜一区二区三区| 中文字幕在线一区二区三区| 青青草国产成人av片免费| a美女胸又www黄视频久久| 日韩免费视频一区| 午夜精品一区二区三区电影天堂| 成人综合婷婷国产精品久久蜜臀| 制服丝袜在线91| 亚洲午夜电影在线观看| gogo大胆日本视频一区| 精品国产制服丝袜高跟| 午夜精品国产更新| 欧美天堂一区二区三区| 亚洲欧美偷拍卡通变态| 成人激情小说网站| 国产视频一区不卡| 国产精品一品二品| 亚洲精品一区二区三区精华液| 亚洲综合免费观看高清在线观看| jizzjizzjizz欧美| 中文字幕在线视频一区| 国产成人欧美日韩在线电影| 精品奇米国产一区二区三区| 免播放器亚洲一区| 欧美一区二区三区视频免费| 日日夜夜免费精品视频| 欧美日韩精品福利| 亚洲成av人片在线观看| 欧美日韩高清不卡| 午夜欧美视频在线观看| 91.com视频| 麻豆精品国产91久久久久久| 日韩一卡二卡三卡四卡| 麻豆国产精品官网| 精品国产精品一区二区夜夜嗨| 六月丁香婷婷色狠狠久久| 日韩视频123| 国产一区二区三区四区五区美女| 精品国产一区久久| 成人激情黄色小说| 亚洲欧美国产毛片在线| 色婷婷av一区二区三区软件 | 成人av电影在线| 国产精品久久久久久久久图文区| av在线播放成人| 亚洲综合色丁香婷婷六月图片| 欧美日韩在线免费视频| 麻豆精品在线播放| 国产精品女上位| 在线看日韩精品电影| 婷婷综合另类小说色区| 精品乱人伦小说| 成人高清av在线| 一区二区不卡在线视频 午夜欧美不卡在| 91福利在线导航| 秋霞成人午夜伦在线观看| 久久久久久久性| 色网综合在线观看| 蜜臀av亚洲一区中文字幕| 国产亲近乱来精品视频 | 蜜桃av噜噜一区| 国产蜜臀av在线一区二区三区 | 国产一区二区三区久久久| 国产精品日产欧美久久久久| 日本电影亚洲天堂一区| 美国一区二区三区在线播放| 国产精品久久免费看| 欧美无砖砖区免费| 国产成人亚洲精品青草天美| 亚洲午夜电影在线观看| 国产欧美一区二区三区在线看蜜臀 | 欧美亚洲国产一区二区三区| 亚洲成人动漫av| 久久久久国产精品麻豆ai换脸| 福利一区在线观看| 日韩电影免费在线看| 亚洲国产精品成人综合 | 亚洲综合小说图片| 久久久久久久国产精品影院| 欧美午夜寂寞影院| 粉嫩av一区二区三区在线播放 | 综合av第一页| 精品1区2区在线观看| 欧美天堂一区二区三区| 国产乱子轮精品视频| 亚洲观看高清完整版在线观看| 国产亚洲女人久久久久毛片| 欧美一区中文字幕| 91女人视频在线观看| 风流少妇一区二区| 美腿丝袜亚洲色图| 亚洲a一区二区| 亚洲婷婷国产精品电影人久久| 日韩精品一区二区三区swag| 欧美午夜精品免费| 欧洲av在线精品| 91麻豆6部合集magnet| 高清shemale亚洲人妖| 国产一区欧美二区| 久久99国产精品免费| 日韩精品欧美精品| 性做久久久久久| 成人夜色视频网站在线观看| 亚洲va中文字幕| 一区二区三区成人在线视频| 中文字幕一区二区三区不卡在线| 国精产品一区一区三区mba视频 | 免费视频最近日韩| 天涯成人国产亚洲精品一区av| 尤物av一区二区| 中文字幕一区日韩精品欧美| 首页亚洲欧美制服丝腿| 欧美一区永久视频免费观看| 色综合一区二区| 色婷婷综合久久| 在线视频你懂得一区二区三区| 99精品久久99久久久久| 色婷婷av一区| 欧美人与禽zozo性伦| 在线播放中文一区| 欧美电影免费观看高清完整版在线观看| 欧美喷潮久久久xxxxx| 欧美日韩国产精品成人| 911精品国产一区二区在线| 日韩一区二区三区av| 成人精品小蝌蚪| 91蜜桃免费观看视频| 欧美午夜宅男影院| 欧美一区二区精美| 久久久久久久免费视频了| 亚洲国产精品v| 亚洲综合自拍偷拍| 日韩成人免费在线| 国产老女人精品毛片久久| 高清在线不卡av| 色噜噜狠狠成人网p站| 色综合久久久网| 欧美日本在线视频| 国产日韩欧美精品在线| 亚洲色图在线播放| 日本在线观看不卡视频| 国产成人精品免费看| 色哟哟在线观看一区二区三区| 欧美日韩中文一区| 久久伊人中文字幕| 国产精品女上位| 视频在线观看一区二区三区| 国产精品一区在线观看乱码| 一本到不卡精品视频在线观看| 91精品国产欧美一区二区18| 国产女人水真多18毛片18精品视频 | 一区二区三区四区在线播放| 日韩av一区二区三区四区| 国产精品123| 欧美视频自拍偷拍| 国产亚洲精品bt天堂精选| 国产一区二区三区香蕉| 久久99精品国产.久久久久久| www.欧美色图| 亚洲精品一区二区三区香蕉| 亚洲一区视频在线观看视频| 国产一区免费电影| 欧美日韩国产美| 亚洲欧洲日韩一区二区三区| 卡一卡二国产精品| 欧美亚洲高清一区| 中国色在线观看另类| 免费成人你懂的| 欧美吻胸吃奶大尺度电影 | 国产一二精品视频| 555www色欧美视频| 亚洲欧美另类图片小说| 国产麻豆视频精品| 日韩一区二区精品| 午夜久久久影院| 亚洲午夜视频在线观看| av高清久久久| 久久久久久9999| 极品少妇xxxx偷拍精品少妇| 精品久久久三级丝袜| 欧美三区在线观看| 亚洲欧美日韩久久| 99综合影院在线| 国产日韩欧美不卡| 91久久香蕉国产日韩欧美9色| 欧美日韩高清在线播放| 亚洲自拍欧美精品| 在线亚洲人成电影网站色www| 国产精品三级电影| 国产aⅴ综合色| 欧美国产精品专区| 国产ts人妖一区二区| 国产欧美va欧美不卡在线| 国产91露脸合集magnet|