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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? sngks32cend.c

?? Vxworks下BSP源碼
?? C
?? 第 1 頁(yè) / 共 5 頁(yè)
字號(hào):
        pDrvCtrl->addrList[count] = 0;    /* Zero the addresses */    pDrvCtrl->mcastAddrCount = 0;        /* Init the multi count */    pAddr = (UCHAR *)(&pDrvCtrl->addrList[0]);    pAddr += 6;        /*  Leave first 6 bytes for our MAC address */    pCurr = END_MULTI_LST_FIRST (&pDrvCtrl->end);#if 1    /*     * Now copy the addresses from ether_multi_list to our own array.  In our     * array, the first 6 bytes are for our own MAC address.  This array is     * an exact replica of the internal CAM registers of Ethernet controller.     * The CAM registers will be updated in at91cEndMacInitialize() function     */          /*源地址為8bit大端格式--> 32bit 小/大端格式     * 例:     * MAC: A-B-C-D-E-F ,0-1-2-3-4-5,6-7-8-9-a-b,??....     *     *大端:ABCD-EF01-2345-6789-ab??....     *小端:DCBA-10FE-5432-9876-??ba.....     *     */    while (pCurr != NULL)        {        if (pDrvCtrl->mcastAddrCount > AT91C_MAX_MULTI)            break;#if (_BYTE_ORDER == _LITTLE_ENDIAN)        if (!(pDrvCtrl->mcastAddrCount & 0x01))            {            pAddr -= 2;            /* little endian: address has to be stored in a swapped fashion! */            *(UINT16 *)pAddr = htons (*(UINT16 *)pCurr->addr);            pAddr += 4;            *(UINT16 *)pAddr = htons (*(UINT16 *)(pCurr->addr+4));            pAddr += 2;            *(UINT16 *)pAddr = htons (*(UINT16 *)(pCurr->addr+2));            }        else            {            pAddr += 2;            /* little endian: address has to be stored in a swapped fashion! */            *(UINT16 *)pAddr = htons (*(UINT16 *)(pCurr->addr+2));            pAddr += 2;            *(UINT16 *)pAddr = htons (*(UINT16 *)pCurr->addr);            pAddr += 4;            *(UINT16 *)pAddr = htons (*(UINT16 *)(pCurr->addr+4));            }#else /* _LITTLE_ENDIAN */        /* big endian: no need to swap */        for (pEnetAddr=pCurr->addr;             pEnetAddr < (UCHAR *)(pCurr->addr+6);             pEnetAddr++)            {            *pAddr++ = *pEnetAddr;            }#endif /* _LITTLE_ENDIAN */        /* Bump the multicast address count */        pDrvCtrl->mcastAddrCount++;            /* Get the next address in the list */        pCurr = END_MULTI_LST_NEXT(pCurr);        }#endif	    }/******************************************************************************* at91cEndMCastAdd - add a multicast address for the device** This routine adds a multicast address to whatever the driver* is already listening for.  It then resets the address filter.** RETURNS: OK or ERROR.*/LOCAL STATUS at91cEndMCastAdd    (    END_DEVICE *pDrvCtrl,    /* device pointer */    char* pAddress        /* new address to add */    )    {    int error;    if ((error = etherMultiAdd (&pDrvCtrl->end.multiList,                                pAddress)) == ENETRESET)        at91cEndConfig (pDrvCtrl);    return (OK);    }/******************************************************************************* at91cEndMCastDel - delete a multicast address for the device** This routine removes a multicast address from whatever the driver* is listening for.  It then resets the address filter.** RETURNS: OK or ERROR.*/LOCAL STATUS at91cEndMCastDel    (    END_DEVICE* pDrvCtrl,    /* device pointer */    char* pAddress        /* address to be deleted */    )    {    int error;    if ((error = etherMultiDel (&pDrvCtrl->end.multiList,                                (char *)pAddress)) == ENETRESET)        at91cEndConfig (pDrvCtrl);    return (OK);    }/******************************************************************************* at91cEndMCastGet - get the multicast address list for the device** This routine gets the multicast list of whatever the driver* is already listening for.** RETURNS: OK or ERROR.*/LOCAL STATUS at91cEndMCastGet    (    END_DEVICE* pDrvCtrl,    /* device pointer */    MULTI_TABLE* pTable        /* address table to be filled in */    )    {    int error;    error = etherMultiGet (&pDrvCtrl->end.multiList, pTable);    return (error);    }/******************************************************************************** at91cEndStop - stop the device** This function calls BSP functions to disconnect interrupts and stop* the device from operating in interrupt mode.** RETURNS: OK or ERROR.*/LOCAL STATUS at91cEndStop    (    END_DEVICE *pDrvCtrl    /* device to be stopped */    )    {    STATUS result = OK;    *(volatile UINT32 *)AT91C_EMAC_CTL &= ~(AT91C_EMAC_RE | AT91C_EMAC_TE);	    intDisable (pDrvCtrl->ivecEMAC);    END_FLAGS_CLR (&pDrvCtrl->end, IFF_UP | IFF_RUNNING);    return (result);    }/******************************************************************************* at91cEndReset - Reset the device* This function resets the driver after initializing from at91cEndLoad*/LOCAL void    at91cEndReset    (    END_DEVICE* pDrvCtrl    /* device to be reset */    )    {    	UINT32 stat1, stat2;	char lab;  	    if(pDrvCtrl->unit != 0)        return;	    if (pDrvCtrl->autoNeg == 1) /* auto negotiation enabled? */     {        		at91cEndPhyWrite (PHY_CONTROL_REG, PHY_ADDR, _AUTO_NEGOTIATE);		stat1 = at91cEndPhyRead(PHY_STS1_REG,0);		if(!(stat1 & 0x4))			{				    			return;	/* no link */		}				stat2 = at91cEndPhyRead(PHY_STS2_REG,0);					if ((stat1 & 0x4000) && (stat2 & 0x8000) ) 		/*set RMII for 100BaseTX and Full Duplex*/		{			lab = 'A';	    	}    		else if ((stat1 & 0x2000) && (stat2 & 0x4000))    /*set MII for 100BaseTX and Half Duplex */		{			lab = 'B';	    	}    		else if ((stat1 & 0x1000) && (stat2 & 0x2000))     /*set MII for 10BaseT and Full Duplex */		{			lab = 'C';	    	}    		else if ((stat1 & 0x0800) && (stat2 & 0x1000))     /*set MII for 10BaseT and Half Duplex */		{			lab = 'D';		}	    	}    else if (pDrvCtrl->netSpeed == 10)    {    	    	if (pDrvCtrl->duplexMode == 1)    /* FDX */        	    	{	    		at91cEndPhyWrite (PHY_CONTROL_REG, PHY_ADDR, _10_MB_FDX);					lab = 'C';    	    	}		else				{	           	at91cEndPhyWrite (PHY_CONTROL_REG, PHY_ADDR, _10_MB_HDX);					lab = 'D';	    	}	    }	    else if (pDrvCtrl->netSpeed == 100)    {	        if (pDrvCtrl->duplexMode == 1)    /* FDX */	        {	        	at91cEndPhyWrite (PHY_CONTROL_REG, PHY_ADDR, _100_MB_FDX);			lab = 'A';	        }	        else	        {	            	at91cEndPhyWrite (PHY_CONTROL_REG, PHY_ADDR, _100_MB_HDX);			lab = 'B';	        }    }	switch(lab)	{		case 'A':    			*(volatile UINT32 *)AT91C_EMAC_CFG |= AT91C_EMAC_SPD| AT91C_EMAC_FD;		break;		case 'B':			*(volatile UINT32 *)AT91C_EMAC_CFG |= AT91C_EMAC_SPD;			*(volatile UINT32 *)AT91C_EMAC_CFG &=	~AT91C_EMAC_FD;		break;		case 'C':			*(volatile UINT32 *)AT91C_EMAC_CFG &=	~AT91C_EMAC_SPD;			*(volatile UINT32 *)AT91C_EMAC_CFG |= AT91C_EMAC_FD;		break;		case 'D':			*(volatile UINT32 *)AT91C_EMAC_CFG &= ~(AT91C_EMAC_SPD| AT91C_EMAC_FD);		break;		default :		break;	}   *(volatile UINT32 *)AT91C_EMAC_CTL |= AT91C_EMAC_CSR;   /*clear the statistic regs*/   *(volatile UINT32 *)AT91C_EMAC_CTL = 0;   *(volatile UINT32 *)AT91C_EMAC_TSR= 0;   *(volatile UINT32 *)AT91C_EMAC_RSR= 0;  /* *(volatile UINT32 *)AT91C_EMAC_CFG |= (AT91C_EMAC_RMII |AT91C_EMAC_CAF);*/   *(volatile UINT32 *)AT91C_EMAC_CFG |= (AT91C_EMAC_RMII );    return;    }#undef DYNAMIC_PHY/******************************************************************************* at91cEndPhyRead - Read PHY device* This function is used to read a byte from the PHY device*/LOCAL UINT32 at91cEndPhyRead    (    UINT32 phyRegAddr, /* Address of PHY register to be read */    UINT32 phyAddr     /* Address of the PHY chip (usually 0 for single PHY) */    )    {    UINT32 phyData;    *(volatile UINT32 *)AT91C_EMAC_CTL |= AT91C_EMAC_MPE; /*Management Port Enable */    *(volatile UINT32 *)AT91C_EMAC_MAN  = AT91C_EMAC_CODE |AT91C_EMAC_RD |AT91C_EMAC_HIGH 									| phyRegAddr << 18 |phyAddr <<23;    while ( (*(volatile UINT32 *)AT91C_EMAC_SR & 0x4) == 0) /***** IDLE bit ******/        ;    /* Wait till IDLE bit is SET */    phyData = *(volatile UINT32*)AT91C_EMAC_MAN & AT91C_EMAC_DATA ;   *(volatile UINT32 *)AT91C_EMAC_CTL &= ~AT91C_EMAC_MPE; /*Management Port disable */	    return (phyData);    } /*DYNAMIC_PHY*//******************************************************************************* at91cEndPhyWrite    - Write into PHY device* This function is used to write a byte to the PHY device*/LOCAL void at91cEndPhyWrite    (    UINT32 phyRegAddr, /* Address of PHY register to be written */    UINT32 phyAddr,    /* Address of the PHY chip (usually 0 for single PHY) */    UINT32 phyData     /* Data to be written */    )    {  /*  UINT32 count = 1000;*/    *(volatile UINT32 *)AT91C_EMAC_CTL |= AT91C_EMAC_MPE; /*Management Port Enable */    *(volatile UINT32 *)AT91C_EMAC_MAN  = AT91C_EMAC_CODE |AT91C_EMAC_WR |AT91C_EMAC_HIGH 									| phyRegAddr << 18 |phyAddr <<23 | phyData ;    while ( (*(volatile UINT32 *)AT91C_EMAC_SR & 0x4) == 0) /***** IDLE bit ******/        ;    /* Wait till IDLE bit is SET *//*    while (count--)        ;  */  /* Dummy delay after PHY write */   *(volatile UINT32 *)AT91C_EMAC_CTL &= ~AT91C_EMAC_MPE; /*Management Port disable */	    }/******************************************************************************* at91cEndMacIntialize - Initialize MAC/BDMA registers* Initialize the MAC and BDMA registers to make the Ethernet* interface functional*/LOCAL void at91cEndMacInitialize    (    END_DEVICE *pDrvCtrl    /* Device that has to be initialized */    )    {    UCHAR    *pAddr;  /* UINT32 temp;     UINT32 * SAH;    UINT32 *SAL;    UCHAR count;	*/	#if 1#if (_BYTE_ORDER != _LITTLE_ENDIAN)    UCHAR *pEnetAddr;#endif#endif#if 0#ifdef DYNAMIC_PHY    UINT32    phyStat2;#endif DYNAMIC_PHY    /* init MAC register *//*動(dòng)態(tài)物理層處理?*/#ifdef DYNAMIC_PHY    phyStat2 = at91cEndPhyRead (PHY_DSCSR_REG,0);    if (phyStat2 & FDX)	    *(volatile UINT32 *)AT91C_EMAC_CFG |= AT91C_EMAC_FD;#else /*DYNAMIC_PHY*/    if ((pDrvCtrl->autoNeg == 0) && (pDrvCtrl->duplexMode == 1))	    *(volatile UINT32 *)AT91C_EMAC_CFG |= AT91C_EMAC_FD;#endif /*DYNAMIC_PHY*/#ifdef LOOPBACK_DEBUG    printf ("********* END DRIVER LOOPBACK DEBUG MODE *************\n");	    *(volatile UINT32 *)AT91C_EMAC_CTL |= AT91C_EMAC_LBL;#endif /*LOOPBACK_DEBUG*/#endif#if 1    /* Copy our MAC address to the first location in address array */    pAddr = (UCHAR *)(&(pDrvCtrl->addrList[0]));#if (_BYTE_ORDER == _LITTLE_ENDIAN)    *(UINT32 *)pAddr = htonl (*(UINT32 *)pDrvCtrl->enetAddr);    pAddr += 6;    *(UINT16 *)pAddr = htons (*(UINT16 *)(pDrvCtrl->enetAddr+4));#else /* (_BYTE_ORDER == _LITTLE_ENDIAN) */    /* big endian: no need to swap */    for (pEnetAddr=pDrvCtrl->enetAddr;         pEnetAddr<pDrvCtrl->enetAddr+6;         pEnetAddr++)        {        *pAddr++ = *pEnetAddr;        }#endif /* (_BYTE_ORDER == _LITTLE_ENDIAN) */#endif    /* Copy the address array into Specific registers */#if 0/*對(duì)不對(duì)呢*/pAddr = (UCHAR *)(&(pDrvCtrl->addrList[0]));SAH = AT91C_EMAC_SA1H;SAL = AT91C_EMAC_SA1L;count = 0;while((count <4)&&(count<=(pDrvCtrl->mcastAddrCount)) )/*4 specificed address*/{	#if (_BYTE_ORDER == _LITTLE_ENDIAN)	/*3-2-1-0,7-6-5-4,B-A-9-8,F-E-D-C...*/	if((count & 1) == 0)	{		*(volatile UINT32 *)SAH = htons(*(UINT16 *)(pAddr+2));	       *(volatile UINT32 *)SAL = htons(*(UINT16 *)pAddr)<<16 + htons(*(UINT16 *)(pAddr + 6));				}	else	{		        *(volatile UINT32 *)SAH = htons(*(UINT16*)(pAddr - 2));             		 *(volatile UINT32 *)SAL = htonl(*(UINT32 *)(pAddr + 2));		 		}#else       *(volatile UINT32 *)SAH = *(UINT16 *)pAddr;       *(volatile UINT32 *)SAL = *(UINT32 *)(pAddr+2);#endif /* (_BYTE_ORDER == _LITTLE_ENDIAN) */	(UINT32 *)SAH += 2;	(UINT32 *)SAL += 2;	pAddr += 6;	count++;}#endif/*MAC地址--寫(xiě)入特殊地址*//*pAddr = sysAt91cMacAddr;*/#if 0#if (_BYTE_ORDER == _LITTLE_ENDIAN)*(volatile UINT32 *) AT91C_EMAC_SA1H = htons(*(UINT16 *)pAddr);*(volatile UINT32 *) AT91C_EMAC_SA1L = htonl (*(UINT32 *)(pAddr+2));#else /* (_BYTE_ORDER == _LITTLE_ENDIAN) */    /* big endian: no need to swap */*(volatile UINT32 *) AT91C_EMAC_SA1H = (*(UINT16 *)pAddr);*(volatile UINT32 *) AT91C_EMAC_SA1L = *(UINT32 *)(pAddr+2);#endif /* (_BYTE_ORDER == _LITTLE_ENDIAN) */#endif#if 0*(vol

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久精品男人的天堂| 99麻豆久久久国产精品免费优播| 中文字幕久久午夜不卡| 国产精品福利av| 91免费在线播放| 一区二区三区美女视频| 欧美影院午夜播放| 亚洲一区二区欧美日韩| 91麻豆精品国产综合久久久久久 | 91免费国产在线| 亚洲国产精品天堂| 欧美一区二区三区精品| 精品中文字幕一区二区| 久久久久久久免费视频了| va亚洲va日韩不卡在线观看| 一区二区三区在线免费| 欧美日韩亚洲另类| 国产一区啦啦啦在线观看| **网站欧美大片在线观看| 欧美视频一区在线| 国模少妇一区二区三区| 亚洲天堂2014| 日韩精品一区二区三区中文精品| 国产精品一区二区免费不卡| 亚洲欧美日韩久久精品| 亚洲欧美国产高清| 亚洲激情一二三区| 激情文学综合插| 国产成人亚洲精品青草天美| 国产一区二区精品久久| 欧美一区二区播放| 欧美日韩综合在线免费观看| 欧美在线观看一区| 久久9热精品视频| 欧美日韩精品一区二区三区| 日韩av在线发布| 精品一二三四区| 久久免费午夜影院| 欧美一区在线视频| 精品一区二区av| 欧美一区二区精品在线| 一卡二卡三卡日韩欧美| 懂色av一区二区三区免费观看| 在线观看成人小视频| 欧美va亚洲va| 久久99在线观看| 在线精品视频一区二区| 中文一区在线播放| 欧美老人xxxx18| www久久精品| 中文字幕一区在线观看| www..com久久爱| 日韩欧美一区二区在线视频| 首页国产欧美日韩丝袜| 欧美成人vps| 国产精一区二区三区| 久久久久久影视| 午夜精品一区二区三区三上悠亚 | 日韩国产精品久久久| 波波电影院一区二区三区| 国产精品视频看| 在线免费观看视频一区| 欧美一区二区三区思思人| 国产精品免费av| 粉嫩一区二区三区性色av| 日韩免费观看高清完整版| 日韩精品五月天| 欧美日韩在线免费视频| 亚洲国产美女搞黄色| 91国内精品野花午夜精品| 欧美不卡一区二区| 欧洲亚洲国产日韩| 亚洲成人精品一区| 久久综合久久久久88| 粉嫩绯色av一区二区在线观看 | 午夜精品免费在线| 国产精品一区二区视频| 国产精品三级在线观看| 国产999精品久久久久久| 91麻豆免费在线观看| 国产精品国产三级国产aⅴ入口| 色老头久久综合| 91亚洲精品久久久蜜桃| 性做久久久久久免费观看欧美| 国产精品不卡一区| 欧美成人性战久久| 91一区二区在线| 亚洲午夜日本在线观看| 欧美精品视频www在线观看 | 国产精品久久久99| 在线综合+亚洲+欧美中文字幕| jvid福利写真一区二区三区| 波多野结衣在线aⅴ中文字幕不卡| 国产精品乡下勾搭老头1| 国产福利一区二区三区视频| 5566中文字幕一区二区电影| 婷婷一区二区三区| 国产呦萝稀缺另类资源| 国产精品久久久久久亚洲伦| 久久综合久色欧美综合狠狠| 宅男噜噜噜66一区二区66| 国产精品一区专区| 亚洲午夜免费福利视频| 亚洲综合丝袜美腿| 日韩一区在线看| 国产色一区二区| 国产日韩欧美精品一区| 一区二区免费视频| 亚洲福中文字幕伊人影院| 老司机精品视频导航| 国产成人自拍高清视频在线免费播放| 99久久99久久综合| 欧美日韩精品一区二区三区| 在线观看91精品国产麻豆| 91.com在线观看| 国产日韩欧美激情| 亚洲国产aⅴ成人精品无吗| 裸体在线国模精品偷拍| 国产ts人妖一区二区| 色婷婷精品久久二区二区蜜臀av| 555www色欧美视频| 国产精品久久久久9999吃药| 日韩av一二三| av一本久道久久综合久久鬼色| 在线观看日韩一区| 久久久久久久久免费| 亚洲一区二区三区三| 国产一区二区影院| 在线一区二区三区四区| 日韩欧美中文字幕公布| 中文字幕av一区二区三区高| 日韩成人精品视频| 成人av网站免费观看| 91久久精品一区二区三区| 久久久91精品国产一区二区精品| 亚洲精品中文在线影院| 国产成人在线视频播放| 日韩亚洲欧美高清| 亚洲成在人线在线播放| 成人黄色av电影| 26uuu亚洲综合色| 日韩av电影一区| 91福利在线看| 国产精品电影院| 国产精品影视天天线| 91精品欧美综合在线观看最新| 一区二区三区精品在线观看| 成人小视频免费在线观看| 成人av片在线观看| 久久久久久久综合日本| 麻豆成人综合网| 欧美一级高清片| 丝袜诱惑亚洲看片| 欧美日韩一区中文字幕| 亚洲精品高清在线| 国产精品水嫩水嫩| 成人av网址在线观看| 中文字幕第一区第二区| 成人av小说网| 亚洲另类春色国产| 欧美午夜精品一区二区蜜桃| 激情综合网激情| 成人久久视频在线观看| 欧美乱熟臀69xxxxxx| 一区二区三区在线视频播放| 日本人妖一区二区| 极品少妇xxxx精品少妇偷拍| 视频一区二区不卡| 中文字幕一区二区三区在线播放 | 国产日韩精品视频一区| 日韩成人精品在线观看| 精品国产91久久久久久久妲己 | 9191久久久久久久久久久| 亚洲欧美偷拍另类a∨色屁股| 欧美一区二区视频在线观看 | 国产精品女人毛片| 日本道在线观看一区二区| 成人激情午夜影院| 国产一区二区中文字幕| 激情深爱一区二区| 丝袜国产日韩另类美女| 亚洲视频资源在线| 精品日韩欧美在线| 久久久久久久久久久电影| 91麻豆精品国产综合久久久久久| 粉嫩嫩av羞羞动漫久久久 | 8v天堂国产在线一区二区| 色哟哟一区二区三区| 午夜久久久久久电影| 亚洲青青青在线视频| 日韩免费在线观看| 欧美一区二区三区喷汁尤物| 99国产欧美另类久久久精品 | 精品国产乱码久久久久久影片| 91欧美一区二区| 99在线热播精品免费| 韩国一区二区视频| 三级久久三级久久| 日韩福利视频网| 国产99精品视频|