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

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

?? myson803.c

?? myson803源代碼 myson803.c: A Linux device driver for the Myson mtd803 Ethernet chip.
?? C
?? 第 1 頁 / 共 4 頁
字號:
	/* Initialize other registers. */	/* Configure the PCI bus bursts and FIFO thresholds. */	writel(0x01f8, ioaddr + PCIBusCfg);	if (dev->if_port == 0)		dev->if_port = np->default_port;	np->txrx_config = TxEnable | RxEnable | RxFlowCtrl | 0x00600000;	np->mcast_filter[0] = np->mcast_filter[1] = 0;	np->rx_died = 0;	set_rx_mode(dev);	netif_start_tx_queue(dev);	/* Enable interrupts by setting the interrupt mask. */	np->intr_enable = IntrRxDone | IntrRxErr | IntrRxEmpty | IntrTxDone		| IntrTxEmpty | StatsMax | RxOverflow | TxUnderrun | IntrPCIErr		| NWayDone | LinkChange;	writel(np->intr_enable, ioaddr + IntrEnable);	if (np->msg_level & NETIF_MSG_IFUP)		printk(KERN_DEBUG "%s: Done netdev_open(), PHY status: %x %x.\n",			   dev->name, (int)readw(ioaddr + PHYMgmt),			   (int)readw(ioaddr + PHYMgmt + 2));	/* Set the timer to check for link beat. */	init_timer(&np->timer);	np->timer.expires = jiffies + 3*HZ;	np->timer.data = (unsigned long)dev;	np->timer.function = &netdev_timer;				/* timer handler */	add_timer(&np->timer);	return 0;}static void check_duplex(struct net_device *dev){	struct netdev_private *np = (struct netdev_private *)dev->priv;	long ioaddr = dev->base_addr;	int new_tx_mode = np->txrx_config;	if (np->medialock) {	} else {		int mii_reg5 = mdio_read(dev, np->phys[0], 5);		int negotiated = mii_reg5 & np->advertising;		int duplex = (negotiated & 0x0100) || (negotiated & 0x01C0) == 0x0040;		if (np->duplex_lock  ||  mii_reg5 == 0xffff)			return;		if (duplex)			new_tx_mode |= TxModeFDX;		if (np->full_duplex != duplex) {			np->full_duplex = duplex;			if (np->msg_level & NETIF_MSG_LINK)				printk(KERN_INFO "%s: Setting %s-duplex based on MII #%d"					   " negotiated capability %4.4x.\n", dev->name,					   duplex ? "full" : "half", np->phys[0], negotiated);		}	}	if (np->txrx_config != new_tx_mode)		writel(new_tx_mode, ioaddr + RxConfig);}static void netdev_timer(unsigned long data){	struct net_device *dev = (struct net_device *)data;	struct netdev_private *np = (struct netdev_private *)dev->priv;	long ioaddr = dev->base_addr;	int next_tick = 10*HZ;	if (np->msg_level & NETIF_MSG_TIMER) {		printk(KERN_DEBUG "%s: Media selection timer tick, status %8.8x.\n",			   dev->name, (int)readw(ioaddr + PHYMgmt + 10));	}	/* This will either have a small false-trigger window or will not catch	   tbusy incorrectly set when the queue is empty. */	if (netif_queue_paused(dev)  &&		np->cur_tx - np->dirty_tx > 1  &&		(jiffies - dev->trans_start) > TX_TIMEOUT) {		tx_timeout(dev);	}	/* It's dead Jim, no race condition. */	if (np->rx_died)		netdev_rx(dev);	check_duplex(dev);	np->timer.expires = jiffies + next_tick;	add_timer(&np->timer);}static void tx_timeout(struct net_device *dev){	struct netdev_private *np = (struct netdev_private *)dev->priv;	long ioaddr = dev->base_addr;	printk(KERN_WARNING "%s: Transmit timed out, status %8.8x,"		   " resetting...\n", dev->name, (int)readl(ioaddr + IntrStatus));	if (np->msg_level & NETIF_MSG_TX_ERR) {		int i;		printk(KERN_DEBUG "  Rx ring %p: ", np->rx_ring);		for (i = 0; i < RX_RING_SIZE; i++)			printk(" %8.8x", (unsigned int)np->rx_ring[i].status);		printk("\n"KERN_DEBUG"  Tx ring %p: ", np->tx_ring);		for (i = 0; i < TX_RING_SIZE; i++)			printk(" %8.8x", np->tx_ring[i].status);		printk("\n");	}	/* Stop and restart the chip's Tx processes . */	writel(np->txrx_config & ~TxEnable, ioaddr + RxConfig);	writel(virt_to_bus(np->tx_ring + (np->dirty_tx%TX_RING_SIZE)),		   ioaddr + TxRingPtr);	writel(np->txrx_config, ioaddr + RxConfig);	/* Trigger an immediate transmit demand. */	writel(0, dev->base_addr + TxStartDemand);	dev->trans_start = jiffies;	np->stats.tx_errors++;	return;}/* Initialize the Rx and Tx rings, along with various 'dev' bits. */static void init_ring(struct net_device *dev){	struct netdev_private *np = (struct netdev_private *)dev->priv;	int i;	np->tx_full = 0;	np->cur_rx = np->cur_tx = 0;	np->dirty_rx = np->dirty_tx = 0;	np->rx_buf_sz = (dev->mtu <= 1532 ? PKT_BUF_SZ : dev->mtu + 4);	np->rx_head_desc = &np->rx_ring[0];	/* Initialize all Rx descriptors. */	for (i = 0; i < RX_RING_SIZE; i++) {		np->rx_ring[i].ctrl_length = cpu_to_le32(np->rx_buf_sz);		np->rx_ring[i].status = 0;		np->rx_ring[i].next_desc = virt_to_le32desc(&np->rx_ring[i+1]);		np->rx_skbuff[i] = 0;	}	/* Mark the last entry as wrapping the ring. */	np->rx_ring[i-1].next_desc = virt_to_le32desc(&np->rx_ring[0]);	/* Fill in the Rx buffers.  Handle allocation failure gracefully. */	for (i = 0; i < RX_RING_SIZE; i++) {		struct sk_buff *skb = dev_alloc_skb(np->rx_buf_sz);		np->rx_skbuff[i] = skb;		if (skb == NULL)			break;		skb->dev = dev;			/* Mark as being used by this device. */		np->rx_ring[i].buf_addr = virt_to_le32desc(skb->tail);		np->rx_ring[i].status = cpu_to_le32(DescOwn);	}	np->dirty_rx = (unsigned int)(i - RX_RING_SIZE);	for (i = 0; i < TX_RING_SIZE; i++) {		np->tx_skbuff[i] = 0;		np->tx_ring[i].status = 0;		np->tx_ring[i].next_desc = virt_to_le32desc(&np->tx_ring[i+1]);	}	np->tx_ring[i-1].next_desc = virt_to_le32desc(&np->tx_ring[0]);	return;}static int start_tx(struct sk_buff *skb, struct net_device *dev){	struct netdev_private *np = (struct netdev_private *)dev->priv;	unsigned entry;	/* Block a timer-based transmit from overlapping.  This happens when	   packets are presumed lost, and we use this check the Tx status. */	if (netif_pause_tx_queue(dev) != 0) {		/* This watchdog code is redundant with the media monitor timer. */		if (jiffies - dev->trans_start > TX_TIMEOUT)			tx_timeout(dev);		return 1;	}	/* Note: Ordering is important here, set the field with the	   "ownership" bit last, and only then increment cur_tx. */	/* Calculate the next Tx descriptor entry. */	entry = np->cur_tx % TX_RING_SIZE;	np->tx_skbuff[entry] = skb;	np->tx_ring[entry].buf_addr = virt_to_le32desc(skb->data);	np->tx_ring[entry].ctrl_length =		cpu_to_le32(TxIntrOnDone | TxNormalPkt | (skb->len << 11) | skb->len);	np->tx_ring[entry].status = cpu_to_le32(DescOwn);	np->cur_tx++;	/* On some architectures: explicitly flushing cache lines here speeds	   operation. */	if (np->cur_tx - np->dirty_tx >= TX_QUEUE_LEN - 1) {		np->tx_full = 1;		/* Check for a just-cleared queue. */		if (np->cur_tx - (volatile unsigned int)np->dirty_tx			< TX_QUEUE_LEN - 2) {			np->tx_full = 0;			netif_unpause_tx_queue(dev);		} else			netif_stop_tx_queue(dev);	} else		netif_unpause_tx_queue(dev);		/* Typical path */	/* Wake the potentially-idle transmit channel. */	writel(0, dev->base_addr + TxStartDemand);	dev->trans_start = jiffies;	if (np->msg_level & NETIF_MSG_TX_QUEUED) {		printk(KERN_DEBUG "%s: Transmit frame #%d queued in slot %d.\n",			   dev->name, np->cur_tx, entry);	}	return 0;}/* The interrupt handler does all of the Rx thread work and cleans up   after the Tx thread. */static void intr_handler(int irq, void *dev_instance, struct pt_regs *rgs){	struct net_device *dev = (struct net_device *)dev_instance;	struct netdev_private *np;	long ioaddr;	int boguscnt;#ifndef final_version			/* Can never occur. */	if (dev == NULL) {		printk (KERN_ERR "Netdev interrupt handler(): IRQ %d for unknown "				"device.\n", irq);		return;	}#endif	ioaddr = dev->base_addr;	np = (struct netdev_private *)dev->priv;	boguscnt = np->max_interrupt_work;#if defined(__i386__)  &&  LINUX_VERSION_CODE < 0x020300	/* A lock to prevent simultaneous entry bug on Intel SMP machines. */	if (test_and_set_bit(0, (void*)&dev->interrupt)) {		printk(KERN_ERR"%s: SMP simultaneous entry of an interrupt handler.\n",			   dev->name);		dev->interrupt = 0;	/* Avoid halting machine. */		return;	}#endif	do {		u32 intr_status = readl(ioaddr + IntrStatus);		/* Acknowledge all of the current interrupt sources ASAP. */		writel(intr_status, ioaddr + IntrStatus);		if (np->msg_level & NETIF_MSG_INTR)			printk(KERN_DEBUG "%s: Interrupt, status %4.4x.\n",				   dev->name, intr_status);		if (intr_status == 0)			break;		if (intr_status & IntrRxDone)			netdev_rx(dev);		for (; np->cur_tx - np->dirty_tx > 0; np->dirty_tx++) {			int entry = np->dirty_tx % TX_RING_SIZE;			int tx_status = le32_to_cpu(np->tx_ring[entry].status);			if (tx_status & DescOwn)				break;			if (np->msg_level & NETIF_MSG_TX_DONE)				printk(KERN_DEBUG "%s: Transmit done, Tx status %8.8x.\n",					   dev->name, tx_status);			if (tx_status & (TxErrAbort | TxErrCarrier | TxErrLate							 | TxErr16Colls | TxErrHeartbeat)) {				if (np->msg_level & NETIF_MSG_TX_ERR)					printk(KERN_DEBUG "%s: Transmit error, Tx status %8.8x.\n",						   dev->name, tx_status);				np->stats.tx_errors++;				if (tx_status & TxErrCarrier) np->stats.tx_carrier_errors++;				if (tx_status & TxErrLate) np->stats.tx_window_errors++;				if (tx_status & TxErrHeartbeat) np->stats.tx_heartbeat_errors++;#ifdef ETHER_STATS				if (tx_status & TxErr16Colls) np->stats.collisions16++;				if (tx_status & TxErrAbort) np->stats.tx_aborted_errors++;#else				if (tx_status & (TxErr16Colls|TxErrAbort))					np->stats.tx_aborted_errors++;#endif			} else {				np->stats.tx_packets++;				np->stats.collisions += tx_status & TxColls;#if LINUX_VERSION_CODE > 0x20127				np->stats.tx_bytes += np->tx_skbuff[entry]->len;#endif#ifdef ETHER_STATS				if (tx_status & TxErrDefer) np->stats.tx_deferred++;#endif			}			/* Free the original skb. */			dev_free_skb_irq(np->tx_skbuff[entry]);			np->tx_skbuff[entry] = 0;		}		/* Note the 4 slot hysteresis to mark the queue non-full. */		if (np->tx_full  &&  np->cur_tx - np->dirty_tx < TX_QUEUE_LEN - 4) {			/* The ring is no longer full, allow new TX entries. */			np->tx_full = 0;			netif_resume_tx_queue(dev);		}		/* Abnormal error summary/uncommon events handlers. */		if (intr_status & (IntrRxErr | IntrRxEmpty | StatsMax | RxOverflow						   | TxUnderrun | IntrPCIErr | NWayDone | LinkChange))			netdev_error(dev, intr_status);		if (--boguscnt < 0) {			printk(KERN_WARNING "%s: Too much work at interrupt, "				   "status=0x%4.4x.\n",				   dev->name, intr_status);			break;		}	} while (1);	if (np->msg_level & NETIF_MSG_INTR)		printk(KERN_DEBUG "%s: exiting interrupt, status=%#4.4x.\n",			   dev->name, (int)readl(ioaddr + IntrStatus));#if defined(__i386__)  &&  LINUX_VERSION_CODE < 0x020300	clear_bit(0, (void*)&dev->interrupt);#endif	return;}/* This routine is logically part of the interrupt handler, but separated   for clarity and better register allocation. */static int netdev_rx(struct net_device *dev){	struct netdev_private *np = (struct netdev_private *)dev->priv;	int entry = np->cur_rx % RX_RING_SIZE;	int boguscnt = np->dirty_rx + RX_RING_SIZE - np->cur_rx;	int refilled = 0;	if (np->msg_level & NETIF_MSG_RX_STATUS) {		printk(KERN_DEBUG " In netdev_rx(), entry %d status %4.4x.\n",			   entry, np->rx_ring[entry].status);	}	/* If EOP is set on the next entry, it's a new packet. Send it up. */	while ( ! (np->rx_head_desc->status & cpu_to_le32(DescOwn))) {		struct netdev_desc *desc = np->rx_head_desc;		u32 desc_status = le32_to_cpu(desc->status);		if (np->msg_level & NETIF_MSG_RX_STATUS)			printk(KERN_DEBUG "  netdev_rx() status was %8.8x.\n",				   desc_status);		if (--boguscnt < 0)			break;		if ((desc_status & RxDescWholePkt) != RxDescWholePkt) {			printk(KERN_WARNING "%s: Oversized Ethernet frame spanned "				   "multiple buffers, entry %#x length %d status %4.4x!\n",				   dev->name, np->cur_rx, desc_status >> 16, desc_status);			np->stats.rx_length_errors++;		} else if (desc_status & RxDescErrSum) {			/* There was a error. */			if (np->msg_level & NETIF_MSG_RX_ERR)				printk(KERN_DEBUG "  netdev_rx() Rx error was %8.8x.\n",					   desc_status);			np->stats.rx_errors++;			if (desc_status & (RxErrLong|RxErrRunt))				np->stats.rx_length_errors++;			if (desc_status & (RxErrFrame|RxErrCode))				np->stats.rx_frame_errors++;			if (desc_status & RxErrCRC)				np->stats.rx_crc_errors++;		} else {			struct sk_buff *skb;			/* Reported length should omit the CRC. */			u16 pkt_len = ((desc_status >> 16) & 0xfff) - 4;#ifndef final_version			if (np->msg_level & NETIF_MSG_RX_STATUS)				printk(KERN_DEBUG "  netdev_rx() normal Rx pkt length %d"					   " of %d, bogus_cnt %d.\n",					   pkt_len, pkt_len, boguscnt);#endif			/* Check if the packet is long enough to accept without copying			   to a minimally-sized skbuff. */			if (pkt_len < np->rx_copybreak				&& (skb = dev_alloc_skb(pkt_len + 2)) != NULL) {				skb->dev = dev;				skb_reserve(skb, 2);	/* 16 byte align the IP header */				eth_copy_and_sum(skb, np->rx_skbuff[entry]->tail, pkt_len, 0);				skb_put(skb, pkt_len);			} else {				skb_put(skb = np->rx_skbuff[entry], pkt_len);				np->rx_skbuff[entry] = NULL;			}#ifndef final_version				/* Remove after testing. */			/* You will want this info for the initial debug. */			if (np->msg_level & NETIF_MSG_PKTDATA)				printk(KERN_DEBUG "  Rx data %2.2x:%2.2x:%2.2x:%2.2x:%2.2x:"					   "%2.2x %2.2x:%2.2x:%2.2x:%2.2x:%2.2x:%2.2x %2.2x%2.2x "					   "%d.%d.%d.%d.\n",					   skb->data[0], skb->data[1], skb->data[2], skb->data[3],					   skb->data[4], skb->data[5], skb->data[6], skb->data[7],					   skb->data[8], skb->data[9], skb->data[10],					   skb->data[11], skb->data[12], skb->data[13],					   skb->data[14], skb->data[15], skb->data[16],					   skb->data[17]);#endif			skb->mac.raw = skb->data;			/* Protocol lookup disabled until verified with all kernels. */			if (0 && ntohs(skb->mac.ethernet->h_proto) >= 0x0800) {

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲成人tv网| 在线不卡a资源高清| 欧美美女一区二区在线观看| 欧美va在线播放| 亚洲黄色小视频| 国产成人精品一区二区三区四区 | 日韩欧美一级二级三级久久久| 国产亚洲污的网站| 裸体一区二区三区| 在线中文字幕不卡| 国产精品色一区二区三区| 九九九精品视频| 666欧美在线视频| 亚洲一区二区三区中文字幕在线 | 欧美精品xxxxbbbb| 亚洲欧美成aⅴ人在线观看| 国产真实精品久久二三区| 欧美一区二区三区四区高清| 亚洲一区二区三区自拍| 91视频一区二区三区| 国产精品网站在线观看| 国产传媒欧美日韩成人| 2020国产精品自拍| 国产精品一二三四区| 精品国产一区久久| 日韩精品亚洲专区| 欧美一区二区三区日韩| 蜜臀av一区二区在线观看| 欧美丰满少妇xxxxx高潮对白| 亚洲成a人片综合在线| 欧美亚洲国产bt| 亚洲国产中文字幕在线视频综合| 欧洲一区在线电影| 黄色成人免费在线| 日韩欧美aaaaaa| eeuss鲁片一区二区三区在线观看 eeuss鲁片一区二区三区在线看 | 日韩一级欧美一级| 免费在线看成人av| 日韩免费成人网| 国产高清在线精品| 国产精品久久看| 欧美在线一区二区| 日韩高清欧美激情| 精品国产乱码久久久久久夜甘婷婷 | 成人欧美一区二区三区视频网页| 成+人+亚洲+综合天堂| 亚洲黄一区二区三区| 91久久线看在观草草青青| 亚洲第一狼人社区| 日韩一区二区电影在线| 国产麻豆日韩欧美久久| 中文字幕第一区综合| 91高清视频在线| 美国十次综合导航| 欧美激情在线观看视频免费| 一本一道综合狠狠老| 国产99久久久国产精品潘金 | 欧美色图天堂网| 青青青爽久久午夜综合久久午夜| 久久影视一区二区| eeuss鲁一区二区三区| 丝袜美腿一区二区三区| 国产欧美精品区一区二区三区 | 成人欧美一区二区三区白人| 欧美剧情电影在线观看完整版免费励志电影 | 国内精品伊人久久久久av一坑 | 亚洲综合色自拍一区| 日韩女优毛片在线| 色综合欧美在线| 蜜臀va亚洲va欧美va天堂| 亚洲色图欧洲色图婷婷| 91麻豆精品国产无毒不卡在线观看| 国产在线日韩欧美| 亚洲欧美电影一区二区| 欧美精品一区二区在线观看| 色8久久人人97超碰香蕉987| 国内精品写真在线观看| 亚洲一区二区美女| 久久久噜噜噜久噜久久综合| 在线亚洲人成电影网站色www| 国产一区二区三区国产| 亚洲一区中文在线| 欧美韩日一区二区三区| 日韩一二三四区| 91国内精品野花午夜精品 | 奇米影视在线99精品| 中文字幕一区二区5566日韩| 精品国产乱码久久久久久老虎 | 色欧美日韩亚洲| 国产成人福利片| 久久精品久久久精品美女| 亚洲香肠在线观看| 亚洲欧洲制服丝袜| 欧美激情一区不卡| 久久亚洲私人国产精品va媚药| 欧美日韩综合一区| 91久久线看在观草草青青| 成人aa视频在线观看| 岛国精品一区二区| 国产一区二区三区不卡在线观看 | 8x8x8国产精品| 在线观看av不卡| 色婷婷国产精品| 91在线观看视频| 成人av片在线观看| 国产乱一区二区| 国产精品一区二区三区四区| 老司机精品视频线观看86| 日韩电影在线免费看| 视频一区国产视频| 免费看欧美美女黄的网站| 日韩影视精彩在线| 奇米777欧美一区二区| 日韩福利电影在线| 免费亚洲电影在线| 另类小说图片综合网| 久久99热狠狠色一区二区| 麻豆极品一区二区三区| 另类的小说在线视频另类成人小视频在线| 日韩综合一区二区| 青青草成人在线观看| 国产在线精品一区二区不卡了| 激情亚洲综合在线| 国产jizzjizz一区二区| 91欧美激情一区二区三区成人| 91丨九色porny丨蝌蚪| 欧美亚洲动漫另类| 911精品国产一区二区在线| 日韩视频国产视频| 久久精品网站免费观看| 亚洲色图一区二区三区| 亚洲曰韩产成在线| 奇米精品一区二区三区四区| 国产乱码精品一区二区三区av | 国产又黄又大久久| 国产精品一区二区三区乱码| 99久久久精品| 欧美高清视频一二三区 | 欧美va在线播放| 亚洲国产成人在线| 亚洲综合男人的天堂| 免费观看在线色综合| 国产精品18久久久久久久网站| 色综合天天综合网国产成人综合天| 日韩电影在线免费| 国产精品一区二区在线播放| 在线视频中文字幕一区二区| 欧美sm极限捆绑bd| 中文字幕人成不卡一区| 日韩福利电影在线观看| 99在线视频精品| 欧美一区二区三区色| 中文字幕一区三区| 奇米色777欧美一区二区| av资源网一区| 日韩欧美久久久| 一区二区三区在线观看欧美| 激情五月播播久久久精品| 欧美在线观看你懂的| 欧美国产精品久久| 天堂va蜜桃一区二区三区| 成人av免费网站| 精品福利一区二区三区免费视频| 成人欧美一区二区三区白人| 国产在线播放一区二区三区| 精品视频一区二区三区免费| 亚洲国产精品成人综合色在线婷婷| 亚洲国产成人av网| 91小视频免费看| 久久九九全国免费| 蜜桃av一区二区三区电影| 欧美亚洲一区二区三区四区| 欧美激情一区在线观看| 麻豆精品蜜桃视频网站| 欧美欧美欧美欧美首页| 最新国产精品久久精品| 国产精品一区二区在线看| 日韩女优视频免费观看| 天堂va蜜桃一区二区三区漫画版| 色94色欧美sute亚洲线路一久| 久久精品欧美日韩精品 | 99久久久久久| 中文字幕第一区二区| 国产精品一二三四区| 欧美一卡在线观看| 三级在线观看一区二区| 在线观看国产91| 亚洲欧美日韩一区| 91在线视频观看| 亚洲视频综合在线| 色综合色综合色综合色综合色综合 | 欧美日韩一本到| 亚洲国产精品一区二区久久| 91天堂素人约啪| 一区二区三区在线免费观看| 91丝袜美腿高跟国产极品老师| 亚洲天堂精品在线观看| 91社区在线播放| 亚洲色图欧美偷拍| 色视频欧美一区二区三区|