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

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

?? npe.c

?? 友善mini2440嵌入式
?? C
?? 第 1 頁 / 共 2 頁
字號:
	}	return 1;}static int npe_init(struct eth_device *dev, bd_t * bis){	struct npe *p_npe = (struct npe *)dev->priv;	int i;	u16 reg_short;	int speed;	int duplex;	debug("%s: 1\n", __FUNCTION__);	miiphy_read (dev->name, p_npe->phy_no, PHY_BMSR, &reg_short);	/*	 * Wait if PHY is capable of autonegotiation and autonegotiation is not complete	 */	if ((reg_short & PHY_BMSR_AUTN_ABLE) && !(reg_short & PHY_BMSR_AUTN_COMP)) {		puts ("Waiting for PHY auto negotiation to complete");		i = 0;		while (!(reg_short & PHY_BMSR_AUTN_COMP)) {			/*			 * Timeout reached ?			 */			if (i > PHY_AUTONEGOTIATE_TIMEOUT) {				puts (" TIMEOUT !\n");				break;			}			if ((i++ % 1000) == 0) {				putc ('.');				miiphy_read (dev->name, p_npe->phy_no, PHY_BMSR, &reg_short);			}			udelay (1000);	/* 1 ms */		}		puts (" done\n");		udelay (500000);	/* another 500 ms (results in faster booting) */	}	speed = miiphy_speed (dev->name, p_npe->phy_no);	duplex = miiphy_duplex (dev->name, p_npe->phy_no);	if (p_npe->print_speed) {		p_npe->print_speed = 0;		printf ("ENET Speed is %d Mbps - %s duplex connection\n",			(int) speed, (duplex == HALF) ? "HALF" : "FULL");	}	npe_alloc_end = npe_alloc_pool + sizeof(npe_alloc_pool);	npe_alloc_free = (u8 *)(((unsigned)npe_alloc_pool +				 CFG_CACHELINE_SIZE - 1) & ~(CFG_CACHELINE_SIZE - 1));	/* initialize mbuf pool */	init_rx_mbufs(p_npe);	init_tx_mbufs(p_npe);	if (ixEthAccPortRxCallbackRegister(p_npe->eth_id, npe_rx_callback,					   (u32)p_npe) != IX_ETH_ACC_SUCCESS) {		printf("can't register RX callback!\n");		return 0;	}	if (ixEthAccPortTxDoneCallbackRegister(p_npe->eth_id, npe_tx_callback,					       (u32)p_npe) != IX_ETH_ACC_SUCCESS) {		printf("can't register TX callback!\n");		return 0;	}	npe_set_mac_address(dev);	if (ixEthAccPortEnable(p_npe->eth_id) != IX_ETH_ACC_SUCCESS) {		printf("can't enable port!\n");		return 0;	}	p_npe->active = 1;	return 1;}#if 0 /* test-only: probably have to deal with it when booting linux (for a clean state) *//* Uninitialize CSR library. */static void npe_csr_unload(void){	ixEthAccUnload();	ixEthDBUnload();	ixNpeMhUnload();	ixQMgrUnload();}/* callback which is used by ethAcc to recover RX buffers when stopping */static void npe_rx_stop_callback(u32 cbTag, IX_OSAL_MBUF *m, IxEthAccPortId portid){	debug("%s\n", __FUNCTION__);}/* callback which is used by ethAcc to recover TX buffers when stopping */static void npe_tx_stop_callback(u32 cbTag, IX_OSAL_MBUF *m){	debug("%s\n", __FUNCTION__);}#endifstatic void npe_halt(struct eth_device *dev){	struct npe *p_npe = (struct npe *)dev->priv;	int i;	debug("%s\n", __FUNCTION__);	/* Delay to give time for recovery of mbufs */	for (i = 0; i < 100; i++) {		npe_poll(p_npe->eth_id);		udelay(100);	}#if 0 /* test-only: probably have to deal with it when booting linux (for a clean state) */	if (ixEthAccPortRxCallbackRegister(p_npe->eth_id, npe_rx_stop_callback,					   (u32)p_npe) != IX_ETH_ACC_SUCCESS) {		debug("Error registering rx callback!\n");	}	if (ixEthAccPortTxDoneCallbackRegister(p_npe->eth_id, npe_tx_stop_callback,					       (u32)p_npe) != IX_ETH_ACC_SUCCESS) {		debug("Error registering tx callback!\n");	}	if (ixEthAccPortDisable(p_npe->eth_id) != IX_ETH_ACC_SUCCESS) {		debug("npe_stop: Error disabling NPEB!\n");	}	/* Delay to give time for recovery of mbufs */	for (i = 0; i < 100; i++) {		npe_poll(p_npe->eth_id);		udelay(10000);	}	/*	 * For U-Boot only, we are probably launching Linux or other OS that	 * needs a clean slate for its NPE library.	 */#if 0 /* test-only */	for (i = 0; i < IX_ETH_ACC_NUMBER_OF_PORTS; i++) {		if (npe_used[i] && npe_exists[i])			if (ixNpeDlNpeStopAndReset(__eth_to_npe(i)) != IX_SUCCESS)				printf("Failed to stop and reset NPE B.\n");	}#endif#endif	p_npe->active = 0;}static int npe_send(struct eth_device *dev, volatile void *packet, int len){	struct npe *p_npe = (struct npe *)dev->priv;	u8 *dest;	int err;	IX_OSAL_MBUF *m;	debug("%s\n", __FUNCTION__);	m = mbuf_dequeue(&p_npe->txQHead);	dest = IX_OSAL_MBUF_MDATA(m);	IX_OSAL_MBUF_PKT_LEN(m) = IX_OSAL_MBUF_MLEN(m) = len;	IX_OSAL_MBUF_NEXT_PKT_IN_CHAIN_PTR(m) = NULL;	memcpy(dest, (char *)packet, len);	if ((err = ixEthAccPortTxFrameSubmit(p_npe->eth_id, m, IX_ETH_ACC_TX_DEFAULT_PRIORITY))	    != IX_ETH_ACC_SUCCESS) {		printf("npe_send: Can't submit frame. err[%d]\n", err);		mbuf_enqueue(&p_npe->txQHead, m);		return 0;	}#ifdef DEBUG_PRINT_TX_FRAMES	{		u8 *ptr = IX_OSAL_MBUF_MDATA(m);		int i;		for (i=0; i<IX_OSAL_MBUF_MLEN(m); i++) {			printf("%02x ", *ptr++);		}		printf(" (tx-len=%d)\n", IX_OSAL_MBUF_MLEN(m));	}#endif	npe_poll(p_npe->eth_id);	return len;}static int npe_rx(struct eth_device *dev){	struct npe *p_npe = (struct npe *)dev->priv;	debug("%s\n", __FUNCTION__);	npe_poll(p_npe->eth_id);	debug("%s: rx_write=%d rx_read=%d\n", __FUNCTION__, p_npe->rx_write, p_npe->rx_read);	while (p_npe->rx_write != p_npe->rx_read) {		debug("Reading message #%d\n", p_npe->rx_read);		NetReceive(NetRxPackets[p_npe->rx_read], p_npe->rx_len[p_npe->rx_read]);		p_npe->rx_read++;		if (p_npe->rx_read == PKTBUFSRX)			p_npe->rx_read = 0;	}	return 0;}int npe_initialize(bd_t * bis){	static int virgin = 0;	struct eth_device *dev;	int eth_num = 0;	struct npe *p_npe = NULL;	for (eth_num = 0; eth_num < CFG_NPE_NUMS; eth_num++) {		/* See if we can actually bring up the interface, otherwise, skip it */		switch (eth_num) {		default:		/* fall through */		case 0:			if (memcmp (bis->bi_enetaddr, "\0\0\0\0\0\0", 6) == 0) {				continue;			}			break;#ifdef CONFIG_HAS_ETH1		case 1:			if (memcmp (bis->bi_enet1addr, "\0\0\0\0\0\0", 6) == 0) {				continue;			}			break;#endif		}		/* Allocate device structure */		dev = (struct eth_device *)malloc(sizeof(*dev));		if (dev == NULL) {			printf ("%s: Cannot allocate eth_device %d\n", __FUNCTION__, eth_num);			return -1;		}		memset(dev, 0, sizeof(*dev));		/* Allocate our private use data */		p_npe = (struct npe *)malloc(sizeof(struct npe));		if (p_npe == NULL) {			printf("%s: Cannot allocate private hw data for eth_device %d",			       __FUNCTION__, eth_num);			free(dev);			return -1;		}		memset(p_npe, 0, sizeof(struct npe));		switch (eth_num) {		default:		/* fall through */		case 0:			memcpy(dev->enetaddr, bis->bi_enetaddr, 6);			p_npe->eth_id = 0;			p_npe->phy_no = CONFIG_PHY_ADDR;			break;#ifdef CONFIG_HAS_ETH1		case 1:			memcpy(dev->enetaddr, bis->bi_enet1addr, 6);			p_npe->eth_id = 1;			p_npe->phy_no = CONFIG_PHY1_ADDR;			break;#endif		}		sprintf(dev->name, "NPE%d", eth_num);		dev->priv = (void *)p_npe;		dev->init = npe_init;		dev->halt = npe_halt;		dev->send = npe_send;		dev->recv = npe_rx;		p_npe->print_speed = 1;		if (0 == virgin) {			virgin = 1;			if (ixFeatureCtrlDeviceRead() == IX_FEATURE_CTRL_DEVICE_TYPE_IXP42X) {				switch (ixFeatureCtrlProductIdRead() & IX_FEATURE_CTRL_SILICON_STEPPING_MASK) {				case IX_FEATURE_CTRL_SILICON_TYPE_B0:					/*					 * If it is B0 Silicon, we only enable port when its corresponding					 * Eth Coprocessor is available.					 */					if (ixFeatureCtrlComponentCheck(IX_FEATURECTRL_ETH0) ==					    IX_FEATURE_CTRL_COMPONENT_ENABLED)						npe_exists[IX_ETH_PORT_1] = TRUE;					if (ixFeatureCtrlComponentCheck(IX_FEATURECTRL_ETH1) ==					    IX_FEATURE_CTRL_COMPONENT_ENABLED)						npe_exists[IX_ETH_PORT_2] = TRUE;					break;				case IX_FEATURE_CTRL_SILICON_TYPE_A0:					/*					 * If it is A0 Silicon, we enable both as both Eth Coprocessors					 * are available.					 */					npe_exists[IX_ETH_PORT_1] = TRUE;					npe_exists[IX_ETH_PORT_2] = TRUE;					break;				}			} else if (ixFeatureCtrlDeviceRead() == IX_FEATURE_CTRL_DEVICE_TYPE_IXP46X) {				if (ixFeatureCtrlComponentCheck(IX_FEATURECTRL_ETH0) ==				    IX_FEATURE_CTRL_COMPONENT_ENABLED)					npe_exists[IX_ETH_PORT_1] = TRUE;				if (ixFeatureCtrlComponentCheck(IX_FEATURECTRL_ETH1) ==				    IX_FEATURE_CTRL_COMPONENT_ENABLED)					npe_exists[IX_ETH_PORT_2] = TRUE;			}			npe_used[IX_ETH_PORT_1] = 1;			npe_used[IX_ETH_PORT_2] = 1;			npe_alloc_end = npe_alloc_pool + sizeof(npe_alloc_pool);			npe_alloc_free = (u8 *)(((unsigned)npe_alloc_pool +						 CFG_CACHELINE_SIZE - 1)						& ~(CFG_CACHELINE_SIZE - 1));			if (!npe_csr_load())				return 0;		}		eth_register(dev);#if defined(CONFIG_MII) || (CONFIG_COMMANDS & CFG_CMD_MII)		miiphy_register(dev->name, npe_miiphy_read, npe_miiphy_write);#endif	}			/* end for each supported device */	return 1;}#endif /* CONFIG_IXP4XX_NPE */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲精品中文在线观看| 欧美精品一区二区三区在线| 日韩av不卡一区二区| 欧美国产精品v| 制服视频三区第一页精品| 国产精品99久久久久久久vr| 亚洲一区二区欧美| 国产精品素人一区二区| 日韩精品一区二区三区四区 | 日韩免费性生活视频播放| 成人av电影免费观看| 青青青伊人色综合久久| 一区二区高清在线| 日本一区二区电影| 精品区一区二区| 欧美亚洲国产怡红院影院| 国产激情精品久久久第一区二区| 亚洲国产精品一区二区久久恐怖片| 精品国产一区二区三区av性色| 在线国产电影不卡| 99国产欧美久久久精品| 国产成人精品免费视频网站| 美国十次综合导航| 丝袜诱惑制服诱惑色一区在线观看| 亚洲免费在线视频| 国产精品毛片a∨一区二区三区| 久久午夜免费电影| 欧美大片国产精品| 欧美一区二区三区喷汁尤物| 欧美喷水一区二区| 欧美老肥妇做.爰bbww| 91精品福利视频| 色综合久久中文字幕综合网| 99综合影院在线| www.成人在线| av高清久久久| 97久久精品人人爽人人爽蜜臀| 丰满亚洲少妇av| 国产成人精品免费看| 国产成人在线看| 国产盗摄视频一区二区三区| 国产不卡视频在线播放| 国产98色在线|日韩| 懂色av噜噜一区二区三区av| 亚洲男帅同性gay1069| 日韩一区二区三区在线观看 | 韩国精品主播一区二区在线观看| 日韩国产成人精品| 日韩和欧美一区二区三区| 国产精品综合久久| 国产一区二区三区视频在线播放| 久久99国产精品久久| 国产综合色精品一区二区三区| 狠狠色综合播放一区二区| 国产精品一区免费视频| 粉嫩蜜臀av国产精品网站| 92国产精品观看| 欧美日韩一区二区在线视频| 日韩一区二区麻豆国产| 久久嫩草精品久久久精品| 国产精品视频看| 亚洲自拍偷拍综合| 美女免费视频一区二区| 国产成人亚洲精品青草天美 | 欧美日韩精品是欧美日韩精品| 欧美日本一区二区三区四区| 欧美v日韩v国产v| 国产精品第四页| 亚洲成人激情社区| 国内成人免费视频| jizzjizzjizz欧美| 欧美日本国产视频| 国产亲近乱来精品视频| 亚洲免费观看高清| 欧美aⅴ一区二区三区视频| 国产激情91久久精品导航 | 欧美日韩精品专区| 久久久久久久久久电影| 亚洲免费观看高清完整版在线| 免费成人av在线播放| 99国产精品99久久久久久| 欧美乱妇20p| 国产精品人人做人人爽人人添| 亚洲午夜激情av| 国产乱人伦精品一区二区在线观看| 99re8在线精品视频免费播放| 欧美一区三区四区| 中文字幕一区在线观看视频| 天堂成人免费av电影一区| 成人午夜看片网址| 制服丝袜一区二区三区| 亚洲视频资源在线| 精品一区二区免费在线观看| 日本韩国一区二区三区视频| 久久综合久久综合九色| 亚洲一区二区黄色| 懂色av一区二区三区蜜臀| 欧美一区二区成人| 亚洲免费在线播放| 国产jizzjizz一区二区| 日韩一区二区免费电影| 亚洲一区精品在线| 成人av网址在线| 26uuu国产日韩综合| 五月激情丁香一区二区三区| a亚洲天堂av| 国产亚洲欧美日韩俺去了| 日韩高清不卡在线| 欧美午夜电影一区| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆| 久久综合综合久久综合| 欧美日韩黄色一区二区| 亚洲视频香蕉人妖| 国产.欧美.日韩| 精品国产乱码91久久久久久网站| 亚洲二区在线观看| 在线一区二区三区做爰视频网站| 久久九九影视网| 国产综合色产在线精品| 精品国产乱码久久久久久图片| 亚洲不卡一区二区三区| 91福利精品第一导航| 亚洲精品国产第一综合99久久| 北条麻妃国产九九精品视频| 国产日韩欧美a| 国产成人综合在线播放| 久久人人超碰精品| 国产一区二区免费在线| 精品毛片乱码1区2区3区| 久久99精品国产麻豆婷婷| 欧美一区二区三区在线看| 五月天欧美精品| 日韩欧美亚洲国产另类| 久久不见久久见免费视频1| 日韩视频免费直播| 久久黄色级2电影| 日韩精品中文字幕一区 | 精品婷婷伊人一区三区三| 亚洲欧洲av在线| 色综合一区二区三区| 亚洲男人的天堂av| 欧美亚洲综合网| 亚洲成在线观看| 91精品一区二区三区在线观看| 日韩电影在线看| 日韩三级高清在线| 黑人精品欧美一区二区蜜桃| 久久久久久亚洲综合| 国产宾馆实践打屁股91| 国产精品灌醉下药二区| 91麻豆免费观看| 图片区小说区区亚洲影院| 欧美一卡二卡在线观看| 久久99国产精品麻豆| 国产精品欧美经典| 欧美亚洲国产怡红院影院| 青青草国产成人av片免费| 久久久噜噜噜久噜久久综合| 成人av在线播放网站| 亚洲综合在线观看视频| 欧美一区二区视频网站| 国产精品原创巨作av| 日韩一区在线看| 精品婷婷伊人一区三区三| 久久福利视频一区二区| 国产精品久久久久aaaa樱花 | 国产大陆亚洲精品国产| 亚洲日本护士毛茸茸| 91麻豆精品国产无毒不卡在线观看| 精品一区二区三区蜜桃| 亚洲欧美日韩小说| 欧美一级搡bbbb搡bbbb| 成人深夜视频在线观看| 亚洲图片欧美视频| 久久这里只有精品6| 在线观看免费亚洲| 久久不见久久见中文字幕免费| 亚洲视频狠狠干| 欧美一级日韩免费不卡| www.亚洲免费av| 久久成人久久鬼色| 亚洲老妇xxxxxx| 久久蜜桃av一区精品变态类天堂| 在线看日韩精品电影| 精品一区二区久久| 亚洲愉拍自拍另类高清精品| 久久综合九色综合97婷婷女人| 91精品办公室少妇高潮对白| 国产精品888| 日韩成人午夜精品| 亚洲色大成网站www久久九九| 日韩免费观看高清完整版| 99九九99九九九视频精品| 蜜臀精品一区二区三区在线观看| 亚洲天堂2014| 国产免费久久精品| 精品三级在线看| 在线成人免费视频| 色哟哟国产精品免费观看| 国产精品99久久久久久久女警|