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

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

?? rtlmiiapi.c

?? INTEL IXP425的VXWORKS BSP
?? C
?? 第 1 頁 / 共 2 頁
字號:
/** * file relMiAPIi.c * * * * brief realtek MII control functions * */#include <stdio.h>#include "IxOsServices.h"#include "IxEthAcc.h"#include "IxEthAcc_p.h"#include "IxTypes.h"#include "IxEthAccMac_p.h"#include "IxEthAccMii_p.h"#include "rtlMiiAPI.h"/* realtek8305 vlan register definitions -  */PRIVATE VLAN_register_t  RTL_PORT_PVID_REGISTER[]={{RTL8305_PHY0,0x21},  {RTL8305_PHY0,0x21},  {RTL8305_PHY0,0x21},  {RTL8305_PHY0,0x21},  {RTL8305_PHY0,0x22}, };PRIVATE VLAN_register_t RTL_VLAN_MEMBER_REGISTER[]= {{RTL8305_PHY1,0x25},  {RTL8305_PHY1,0x26},  {RTL8305_PHY1,0x28},  {RTL8305_PHY1,0x29},  {RTL8305_PHY1,0x31},};PRIVATE VLAN_register_t RTL_VLANA_IDENTIFIER_REGISTER={RTL8305_PHY1,0x24};PRIVATE VLAN_register_t RTL_VLANB_IDENTIFIER_LOWER_REGISTER={RTL8305_PHY1,0x25};PRIVATE VLAN_register_t RTL_VLANB_IDENTIFIER_UPPER_REGISTER={RTL8305_PHY1,0x26};PRIVATE VLAN_register_t RTL_VLANC_IDENTIFIER_REGISTER={RTL8305_PHY1,0x27};PRIVATE VLAN_register_t RTL_VLAND_IDENTIFIER_LOWER_REGISTER={RTL8305_PHY1,0x28};PRIVATE VLAN_register_t RTL_VLAND_IDENTIFIER_UPPER_REGISTER={RTL8305_PHY1,0x29};PRIVATE VLAN_register_t RTL_VLANE_IDENTIFIER_REGISTER={RTL8305_PHY1,0x30};PRIVATE VLAN_register_t RTL_PRIORITY_CTRL_REGISTER={RTL8305_PHY2,0x16};PRIVATE VLAN_register_t  RTL_VLAN_CTRL_REGISTER={RTL8305_PHY2,0x17};PRIVATE VLAN_register_t RTL_PORT_CTRL_REGISTER={RTL8305_PHY3, 0x16};PRIVATE IxMutex rtlmiiAccessLock;PRIVATE voidrealtekMdioCmdWrite(UINT32 port, UINT32 mdioCommand){    UINT32 baseAddress;    if (port == PORTA )	baseAddress = IX_ETH_ACC_MAC_0_BASE;    else if ( port == PORTB )	baseAddress = IX_ETH_ACC_MAC_1_BASE;    else return;		    REG_WRITE(baseAddress,	      IX_ETH_ACC_MAC_MDIO_CMD_1,	      mdioCommand & 0xff);    REG_WRITE(baseAddress,	      IX_ETH_ACC_MAC_MDIO_CMD_2,	      (mdioCommand >> 8) & 0xff);    REG_WRITE(baseAddress,	      IX_ETH_ACC_MAC_MDIO_CMD_3,	      (mdioCommand >> 16) & 0xff);    REG_WRITE(baseAddress,	      IX_ETH_ACC_MAC_MDIO_CMD_4,	      (mdioCommand >> 24) & 0xff);}PRIVATE voidrealtekMdioCmdRead(UINT32 port, UINT32 *data){    UINT32 regval;    UINT32 baseAddress;    if (port == PORTA )	baseAddress = IX_ETH_ACC_MAC_0_BASE;    else if ( port == PORTB )	baseAddress = IX_ETH_ACC_MAC_1_BASE;    else return;    REG_READ(baseAddress,	     IX_ETH_ACC_MAC_MDIO_CMD_1,	     regval);    *data = regval & 0xff;    REG_READ(baseAddress,	     IX_ETH_ACC_MAC_MDIO_CMD_2,	     regval);    *data |= (regval & 0xff) << 8;    REG_READ(baseAddress,	     IX_ETH_ACC_MAC_MDIO_CMD_3,	     regval);    *data |= (regval & 0xff) << 16;    REG_READ(baseAddress,	     IX_ETH_ACC_MAC_MDIO_CMD_4,	     regval);        *data |= (regval & 0xff) << 24;    }PRIVATE voidrealtekMdioStatusRead(UINT32 port,UINT32 *data){    UINT32 regval;    UINT32 baseAddress;    if (port == PORTA )	baseAddress = IX_ETH_ACC_MAC_0_BASE;    else if ( port == PORTB )	baseAddress = IX_ETH_ACC_MAC_1_BASE;    else return;    REG_READ(baseAddress,	     IX_ETH_ACC_MAC_MDIO_STS_1,	     regval);    *data = regval & 0xff;    REG_READ(baseAddress,	     IX_ETH_ACC_MAC_MDIO_STS_2,	     regval);    *data |= (regval & 0xff) << 8;    REG_READ(baseAddress,	     IX_ETH_ACC_MAC_MDIO_STS_3,	     regval);    *data |= (regval & 0xff) << 16;    REG_READ(baseAddress,	     IX_ETH_ACC_MAC_MDIO_STS_4,	     regval);        *data |= (regval & 0xff) << 24;    }/******************************************************************** * realtekMiiInit */IxEthAccStatusrealtekMiiInit(){    if(ixOsServMutexInit(&rtlmiiAccessLock)!= IX_SUCCESS)    {	return IX_ETH_ACC_FAIL;    }    if(ixOsServMutexUnlock(&rtlmiiAccessLock)!= IX_SUCCESS)    {	return IX_ETH_ACC_FAIL;    }    return IX_ETH_ACC_SUCCESS;}/********************************************************************* * realtekMiiReadRtn - read a 16 bit value from realtek 8305SB */IxEthAccStatus      realtekMiiReadRtn (UINT32 port,UINT8 phyAddr, 		    UINT8 phyReg, 		    UINT16 *value){    UINT32 mdioCommand;    UINT32 regval;    UINT32 miiTimeout;    ixOsServMutexLock(&rtlmiiAccessLock);    mdioCommand = phyReg <<  IX_ETH_ACC_MII_REG_SHL 	| phyAddr << IX_ETH_ACC_MII_ADDR_SHL;    mdioCommand |= IX_ETH_ACC_MII_GO;    realtekMdioCmdWrite(port,mdioCommand);        miiTimeout = IX_ETH_ACC_MII_TIMEOUT_10TH_SECS;    while(miiTimeout)    {		realtekMdioCmdRead(port,&regval);     	if((regval & IX_ETH_ACC_MII_GO) == 0x0)	{	    	    break;	}	/*Sleep for 10th of a second*/	ixOsServTaskSleep(IX_ETH_ACC_MII_10TH_SEC_IN_MILLIS);	miiTimeout--;    }            if(miiTimeout == 0)    {		ixOsServMutexUnlock(&rtlmiiAccessLock);	return IX_ETH_ACC_FAIL;    }            realtekMdioStatusRead(port,&regval);    if(regval & IX_ETH_ACC_MII_READ_FAIL)    {	ixOsServMutexUnlock(&rtlmiiAccessLock);	return IX_ETH_ACC_FAIL;    }    *value = regval & 0xffff;    ixOsServMutexUnlock(&rtlmiiAccessLock);    return IX_ETH_ACC_SUCCESS;    }/********************************************************************* * realtekMiiWriteRtn - write a 16 bit value to realtek 8305SB */IxEthAccStatusrealtekMiiWriteRtn (UINT32 port,UINT8 phyAddr, 		     UINT8 phyReg, 		     UINT16 value){    UINT32 mdioCommand;    UINT32 regval;    UINT32 miiTimeout;    ixOsServMutexLock(&rtlmiiAccessLock);    mdioCommand = phyReg << IX_ETH_ACC_MII_REG_SHL	| phyAddr << IX_ETH_ACC_MII_ADDR_SHL ;    mdioCommand |= IX_ETH_ACC_MII_GO | IX_ETH_ACC_MII_WRITE | value;    realtekMdioCmdWrite(port,mdioCommand);        miiTimeout = IX_ETH_ACC_MII_TIMEOUT_10TH_SECS;    while(miiTimeout--)    {		realtekMdioCmdRead(port,&regval);	/*The "GO" bit is reset to 0 when the write completes*/	if((regval & IX_ETH_ACC_MII_GO) == 0x0)	{	    	    	    break;	}	/*Sleep for 100 milliseconds*/	ixOsServTaskSleep(IX_ETH_ACC_MII_10TH_SEC_IN_MILLIS);    }        ixOsServMutexUnlock(&rtlmiiAccessLock);    if(miiTimeout == 0)    {	return IX_ETH_ACC_FAIL;    }    return IX_ETH_ACC_SUCCESS;}/************************************************************ * * Configure the rtl8305 at the specified address *  */IxEthAccStatusrealtekMiiPhyConfig(UINT32 port,UINT32 phyAddr,		     BOOL speed100, 		     BOOL fullDuplex, 		     BOOL autonegotiate){    UINT16 regval=0;        if(autonegotiate)    {	regval |= IX_ETH_ACC_MII_CR_AUTO_EN | IX_ETH_ACC_MII_CR_RESTART;    }    else    {	if(speed100) 	{	    regval |= IX_ETH_ACC_MII_CR_100;	}	if(fullDuplex)	{	    regval |= IX_ETH_ACC_MII_CR_FDX;	}    }    return realtekMiiWriteRtn(port,phyAddr, IX_ETH_ACC_MII_CTRL_REG, regval);}/********************************************************* * * Scan for rtl8305 on the MII bus. This function returns * an array of booleans, one for each PHY address. * If a PHY is found at a particular address, the  * corresponding entry in the array is set to TRUE. * */IxEthAccStatusrealtekMiiPhyScan(BOOL *phyPresent[]){    UINT32 i;    UINT16 regval;    /*Search for PHYs on the MII*/    /*Search for extant phys on the MDIO bus*/    for(i=0;i<IXP425_ETH_ACC_MII_MAX_ADDR;i++)    {	if(realtekMiiReadRtn(PORTA,i,IX_ETH_ACC_MII_CTRL_REG,&regval)	   ==IX_ETH_ACC_SUCCESS)	{	    if((regval & 0xffff) != 0xffff)	    {		phyPresent[PORTA][i] = TRUE;	    }	    else	    {		phyPresent[PORTA][i] = FALSE;	    }	}	else	{	    phyPresent[PORTA][i] = FALSE;	}	if(realtekMiiReadRtn(PORTB,i,IX_ETH_ACC_MII_CTRL_REG,&regval)	   ==IX_ETH_ACC_SUCCESS)	{	    if((regval & 0xffff) != 0xffff)	    {		phyPresent[PORTB][i] = TRUE;	    }	    else	    {		phyPresent[PORTB][i] = FALSE;	    }	}	else	{	    phyPresent[PORTB][i] = FALSE;	}    }    return IX_ETH_ACC_SUCCESS;}/****************************************************************** * *  Reset the realtek8305 at the specified address */IxEthAccStatusrealtekMiiPhyReset(UINT32 port,UINT32 phyAddr){        realtekMiiWriteRtn(port,phyAddr, IX_ETH_ACC_MII_CTRL_REG, 			IX_ETH_ACC_MII_CR_RESET);    ixOsServTaskSleep (IX_ETH_ACC_MII_RESET_DELAY_MS);    realtekMiiWriteRtn(port,phyAddr, IX_ETH_ACC_MII_CTRL_REG, 			IX_ETH_ACC_MII_CR_NORM_EN);    return IX_ETH_ACC_SUCCESS;}/************************************************************ * * Configure the rtl8305  port pvid at the specified address *  */IxEthAccStatusrealtekPvidSetup(UINT32 port, UINT8 rtl8305port, UINT8 pvid){    UINT16 regval=0;        UINT8 phyAddr=0;    UINT8 vlanReg =0;    if(port!=PORTB)  return ERR_PORT_ERROR;    if (rtl8305port >= 5 ) return ERR_PORT_ERROR;    phyAddr = RTL_PORT_PVID_REGISTER[rtl8305port].PHY_address;    vlanReg = RTL_PORT_PVID_REGISTER[rtl8305port].VLAN_register;    realtekMiiReadRtn(port, phyAddr,vlanReg, &regval);    realtekMiiReadRtn(port, phyAddr,vlanReg, &regval);    pvid &= RTL_PVID_BIT_WITH;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本不卡高清视频| 韩国精品一区二区| 色屁屁一区二区| 亚洲人成在线观看一区二区| 91精品国产免费久久综合| 91丝袜高跟美女视频| 日韩影视精彩在线| 日韩欧美一区二区免费| 蜜桃视频第一区免费观看| 欧美电影精品一区二区| 精品一区二区三区在线观看| 久久久久久综合| 成人精品gif动图一区| 一区二区在线观看视频| 欧美高清激情brazzers| 久久国产日韩欧美精品| 国产日产欧美一区| 色欧美乱欧美15图片| 亚洲韩国精品一区| 久久久久久久精| 色94色欧美sute亚洲线路二| 日韩精品一级中文字幕精品视频免费观看 | 国产精品456| 亚洲色图欧美在线| 7777精品伊人久久久大香线蕉经典版下载 | 高清av一区二区| 亚洲精品videosex极品| 色噜噜夜夜夜综合网| 中文av一区特黄| 99久久免费国产| 日韩视频一区二区在线观看| 国产乱码字幕精品高清av| 亚洲视频 欧洲视频| 91精品久久久久久蜜臀| 成人亚洲精品久久久久软件| 亚洲一区二区视频在线观看| 精品久久国产97色综合| 色综合中文字幕国产| 午夜伦理一区二区| 国产精品国产三级国产有无不卡 | 日韩一区二区三区观看| www.久久久久久久久| 日本免费新一区视频| 亚洲精品日产精品乱码不卡| 日韩天堂在线观看| 欧美伊人久久大香线蕉综合69| 久久91精品国产91久久小草| 一区二区三区久久久| 欧美激情中文字幕一区二区| 91精品国产色综合久久ai换脸| 99久久综合国产精品| 韩国一区二区在线观看| 日韩经典一区二区| 亚洲一区二区三区四区的| 亚洲欧美自拍偷拍| 国产天堂亚洲国产碰碰| 欧美一级理论片| 欧美日韩国产综合草草| 91国偷自产一区二区三区观看| 懂色av噜噜一区二区三区av| 裸体一区二区三区| 午夜一区二区三区视频| 一级做a爱片久久| 中文字幕制服丝袜成人av| 久久久国产精品午夜一区ai换脸| 欧美一区中文字幕| 欧美剧情片在线观看| 欧洲国内综合视频| 欧洲一区二区三区在线| 色婷婷综合久色| 99精品欧美一区| 不卡区在线中文字幕| 国产凹凸在线观看一区二区| 久国产精品韩国三级视频| 免费日本视频一区| 捆绑变态av一区二区三区| 久久精品国产久精国产爱| 美女在线视频一区| 免费人成网站在线观看欧美高清| 亚洲第一搞黄网站| 午夜免费久久看| 日本vs亚洲vs韩国一区三区| 日韩精彩视频在线观看| 日本不卡视频一二三区| 精品亚洲欧美一区| 国产一区二区三区四| 国产电影一区二区三区| 成人一区在线观看| 97久久超碰国产精品| 91香蕉视频mp4| 欧美丝袜自拍制服另类| 777午夜精品视频在线播放| 91精品国产综合久久香蕉的特点| 日韩视频123| 国产午夜精品久久久久久久| 中文久久乱码一区二区| 亚洲一区二区三区美女| 丝袜亚洲精品中文字幕一区| 久久99精品国产麻豆不卡| 国产xxx精品视频大全| 一本大道综合伊人精品热热| 欧美色爱综合网| 精品国产一区二区三区久久影院 | 成人欧美一区二区三区1314| 亚洲少妇30p| 日韩国产欧美在线观看| 国内外成人在线| 91视频免费看| 欧美一区二区三区精品| 国产精品久久久99| 亚洲国产美女搞黄色| 国产一区二区视频在线播放| 99免费精品视频| 欧美一区日韩一区| 国产精品视频一二三| 五月天激情综合| 成人午夜精品在线| 欧美性色欧美a在线播放| 26uuu另类欧美| 一级日本不卡的影视| 国内精品伊人久久久久av一坑| 99热这里都是精品| 在线播放欧美女士性生活| ww亚洲ww在线观看国产| 国产精品灌醉下药二区| 免费成人你懂的| av亚洲精华国产精华精| 欧美日韩国产一二三| 欧美性感一区二区三区| 国产欧美日韩综合精品一区二区| 亚洲美女屁股眼交3| 奇米影视一区二区三区| 成av人片一区二区| 在线亚洲+欧美+日本专区| 欧美精品一区二区三区久久久| 亚洲欧洲av另类| 美国毛片一区二区| 99免费精品视频| 欧美体内she精高潮| 久久久久久一二三区| 亚洲福利视频三区| 国产成人av资源| 色婷婷综合在线| 中文字幕一区二区5566日韩| 蜜臀精品久久久久久蜜臀| 成人夜色视频网站在线观看| 91精品国产免费| 最新不卡av在线| 精品写真视频在线观看| 欧美性猛片aaaaaaa做受| 久久精品视频网| 青青草原综合久久大伊人精品优势| 97久久超碰国产精品| 久久久精品黄色| 韩国三级电影一区二区| 欧美色视频一区| 亚洲精品免费在线观看| 丰满岳乱妇一区二区三区| 欧美日韩在线播放三区| 亚洲色欲色欲www| 丁香婷婷综合色啪| 精品国精品国产尤物美女| 天堂影院一区二区| 懂色av一区二区三区免费观看| 日韩一级片在线播放| 免费成人在线网站| 欧美一区午夜视频在线观看| 亚洲一区二区三区影院| 91麻豆.com| 亚洲最新视频在线观看| 色综合色狠狠天天综合色| 欧美激情一二三区| 日韩高清不卡一区| 欧美精品一区视频| 久久99精品一区二区三区三区| 欧美日韩五月天| 亚洲精品欧美专区| 欧美日本乱大交xxxxx| 亚洲国产精品一区二区www | 欧美一区二区在线不卡| 亚洲综合男人的天堂| 色婷婷激情一区二区三区| 国产精品视频观看| 不卡大黄网站免费看| 欧美激情中文不卡| 国产精品99久久久久久宅男| 国产视频一区不卡| 国产成人在线电影| 国产女主播视频一区二区| 色狠狠桃花综合| 亚洲国产精品精华液网站| 欧美日韩一区二区在线观看| 国产精品久久精品日日| 色婷婷精品大在线视频| 亚洲精品免费播放| 91视频国产资源| 另类小说一区二区三区| 国产亚洲成aⅴ人片在线观看| 国产成人精品三级麻豆| 日韩一区二区中文字幕|