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

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

?? 3c509.c

?? <Linux1.0核心游記>電子書+書后源碼+Linux1.0源碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
	/* Transmitter timeout, serious problems. */	if (dev->tbusy) {		int tickssofar = jiffies - dev->trans_start;		if (tickssofar < 10)			return 1;		printk("%s: transmit timed out, tx_status %2.2x status %4.4x.\n",			   dev->name, inb(ioaddr + TX_STATUS), inw(ioaddr + EL3_STATUS));		dev->trans_start = jiffies;		/* Issue TX_RESET and TX_START commands. */		outw(0x5800, ioaddr + EL3_CMD); /* TX_RESET */		outw(0x4800, ioaddr + EL3_CMD); /* TX_START */		dev->tbusy = 0;	}	if (skb == NULL) {		dev_tint(dev);		return 0;	}	/* Fill in the ethernet header. */	if (!skb->arp  &&  dev->rebuild_header(skb->data, dev)) {		skb->dev = dev;		arp_queue (skb);		return 0;	}	skb->arp=1;	if (skb->len <= 0)		return 0;	if (el3_debug > 4) {		printk("%s: el3_start_xmit(lenght = %ld) called, status %4.4x.\n",			   dev->name, skb->len, inw(ioaddr + EL3_STATUS));	}#ifndef final_version	{	/* Error-checking code, delete for 1.00. */		ushort status = inw(ioaddr + EL3_STATUS);		if (status & 0x0001 		/* IRQ line active, missed one. */			&& inw(ioaddr + EL3_STATUS) & 1) { 			/* Make sure. */			printk("%s: Missed interrupt, status then %04x now %04x"				   "  Tx %2.2x Rx %4.4x.\n", dev->name, status,				   inw(ioaddr + EL3_STATUS), inb(ioaddr + TX_STATUS),				   inw(ioaddr + RX_STATUS));			outw(0x7800, ioaddr + EL3_CMD); /* Fake interrupt trigger. */			outw(0x6899, ioaddr + EL3_CMD); /* Ack IRQ */			outw(0x78ff, ioaddr + EL3_CMD); /* Set all status bits visible. */		}	}#endif	/* Avoid timer-based retransmission conflicts. */	if (set_bit(0, (void*)&dev->tbusy) != 0)		printk("%s: Transmitter access conflict.\n", dev->name);	else {		/* Put out the doubleword header... */		outw(skb->len, ioaddr + TX_FIFO);		outw(0x00, ioaddr + TX_FIFO);		/* ... and the packet rounded to a doubleword. */		outsl(ioaddr + TX_FIFO, skb->data, (skb->len + 3) >> 2);			dev->trans_start = jiffies;		if (inw(ioaddr + TX_FREE) > 1536) {			dev->tbusy=0;		} else			/* Interrupt us when the FIFO has room for max-sized packet. */			outw(0x9000 + 1536, ioaddr + EL3_CMD);	}	if (skb->free)		kfree_skb (skb, FREE_WRITE);	/* Clear the Tx status stack. */	{		short tx_status;		int i = 4;		while (--i > 0	&&	(tx_status = inb(ioaddr + TX_STATUS)) > 0) {			if (el3_debug > 5)				printk("		Tx status %4.4x.\n", tx_status);			if (tx_status & 0x38) lp->stats.tx_aborted_errors++;			if (tx_status & 0x30) outw(0x5800, ioaddr + EL3_CMD);			if (tx_status & 0x3C) outw(0x4800, ioaddr + EL3_CMD);			outb(0x00, ioaddr + TX_STATUS); /* Pop the status stack. */		}	}	return 0;}/* The EL3 interrupt handler. */static voidel3_interrupt(int reg_ptr){	int irq = -(((struct pt_regs *)reg_ptr)->orig_eax+2);	struct device *dev = (struct device *)(irq2dev_map[irq]);	int ioaddr, status;	int i = 0;	if (dev == NULL) {		printk ("el3_interrupt(): irq %d for unknown device.\n", irq);		return;	}	if (dev->interrupt)		printk("%s: Re-entering the interrupt handler.\n", dev->name);	dev->interrupt = 1;	ioaddr = dev->base_addr;	status = inw(ioaddr + EL3_STATUS);	if (el3_debug > 4)		printk("%s: interrupt, status %4.4x.\n", dev->name, status);		while ((status = inw(ioaddr + EL3_STATUS)) & 0x01) {		if (status & 0x10)			el3_rx(dev);		if (status & 0x08) {			if (el3_debug > 5)				printk("	TX room bit was handled.\n");			/* There's room in the FIFO for a full-sized packet. */			outw(0x6808, ioaddr + EL3_CMD); /* Ack IRQ */			dev->tbusy = 0;			mark_bh(INET_BH);		}		if (status & 0x80)				/* Statistics full. */			update_stats(ioaddr, dev);				if (++i > 10) {			printk("%s: Infinite loop in interrupt, status %4.4x.\n",				   dev->name, status);			/* Clear all interrupts we have handled. */			outw(0x68FF, ioaddr + EL3_CMD);			break;		}		/* Acknowledge the IRQ. */		outw(0x6891, ioaddr + EL3_CMD); /* Ack IRQ */	}	if (el3_debug > 4) {		printk("%s: exiting interrupt, status %4.4x.\n", dev->name,			   inw(ioaddr + EL3_STATUS));	}		dev->interrupt = 0;	return;}static struct enet_statistics *el3_get_stats(struct device *dev){	struct el3_private *lp = (struct el3_private *)dev->priv;	sti();	update_stats(dev->base_addr, dev);	cli();	return &lp->stats;}/*  Update statistics.  We change to register window 6, so this should be run	single-threaded if the device is active. This is expected to be a rare	operation, and it's simpler for the rest of the driver to assume that	window 1 is always valid rather than use a special window-state variable.	*/static void update_stats(int ioaddr, struct device *dev){	struct el3_private *lp = (struct el3_private *)dev->priv;	if (el3_debug > 5)		printk("   Updating the statistics.\n");	/* Turn off statistics updates while reading. */	outw(0xB000, ioaddr + EL3_CMD);	/* Switch to the stats window, and read everything. */	EL3WINDOW(6);	lp->stats.tx_carrier_errors 	+= inb(ioaddr + 0);	lp->stats.tx_heartbeat_errors	+= inb(ioaddr + 1);	/* Multiple collisions. */	   	inb(ioaddr + 2);	lp->stats.collisions			+= inb(ioaddr + 3);	lp->stats.tx_window_errors		+= inb(ioaddr + 4);	lp->stats.rx_fifo_errors		+= inb(ioaddr + 5);	lp->stats.tx_packets			+= inb(ioaddr + 6);	lp->stats.rx_packets			+= inb(ioaddr + 7);	/* Tx deferrals */				inb(ioaddr + 8);	inw(ioaddr + 10);	/* Total Rx and Tx octets. */	inw(ioaddr + 12);	/* Back to window 1, and turn statistics back on. */	EL3WINDOW(1);	outw(0xA800, ioaddr + EL3_CMD);	return;}static intel3_rx(struct device *dev){	struct el3_private *lp = (struct el3_private *)dev->priv;	int ioaddr = dev->base_addr;	short rx_status;	if (el3_debug > 5)		printk("	   In rx_packet(), status %4.4x, rx_status %4.4x.\n",			   inw(ioaddr+EL3_STATUS), inw(ioaddr+RX_STATUS));	while ((rx_status = inw(ioaddr + RX_STATUS)) > 0) {		if (rx_status & 0x4000) { /* Error, update stats. */			short error = rx_status & 0x3800;			lp->stats.rx_errors++;			switch (error) {			case 0x0000:		lp->stats.rx_over_errors++; break;			case 0x0800:		lp->stats.rx_length_errors++; break;			case 0x1000:		lp->stats.rx_frame_errors++; break;			case 0x1800:		lp->stats.rx_length_errors++; break;			case 0x2000:		lp->stats.rx_frame_errors++; break;			case 0x2800:		lp->stats.rx_crc_errors++; break;			}		}		if ( (! (rx_status & 0x4000))			|| ! (rx_status & 0x1000)) { /* Dribble bits are OK. */			short pkt_len = rx_status & 0x7ff;			int sksize = sizeof(struct sk_buff) + pkt_len + 3;			struct sk_buff *skb;			skb = alloc_skb(sksize, GFP_ATOMIC);			if (el3_debug > 4)				printk("	   Receiving packet size %d status %4.4x.\n",					   pkt_len, rx_status);			if (skb != NULL) {				skb->mem_len = sksize;				skb->mem_addr = skb;				skb->len = pkt_len;				skb->dev = dev;				/* 'skb->data' points to the start of sk_buff data area. */				insl(ioaddr+RX_FIFO, skb->data,							(pkt_len + 3) >> 2);#ifdef HAVE_NETIF_RX				netif_rx(skb);				outw(0x4000, ioaddr + EL3_CMD); /* Rx discard */				continue;#else				skb->lock = 0;				if (dev_rint((unsigned char *)skb, pkt_len,							 IN_SKBUFF,dev)== 0){					if (el3_debug > 6)						printk("	 dev_rint() happy, status %4.4x.\n",						inb(ioaddr + EL3_STATUS));					outw(0x4000, ioaddr + EL3_CMD); /* Rx discard */					while (inw(ioaddr + EL3_STATUS) & 0x1000)					  printk("	Waiting for 3c509 to discard packet, status %x.\n",							 inw(ioaddr + EL3_STATUS) );					if (el3_debug > 6)						printk("	 discarded packet, status %4.4x.\n",						inb(ioaddr + EL3_STATUS));					continue;				} else {					printk("%s: receive buffers full.\n", dev->name);					kfree_s(skb, sksize);				}#endif			} else if (el3_debug)				printk("%s: Couldn't allocate a sk_buff of size %d.\n",					   dev->name, sksize);		}		lp->stats.rx_dropped++;		outw(0x4000, ioaddr + EL3_CMD); /* Rx discard */		while (inw(ioaddr + EL3_STATUS) & 0x1000)		  printk("	Waiting for 3c509 to discard packet, status %x.\n",				 inw(ioaddr + EL3_STATUS) );	}	if (el3_debug > 5)		printk("	   Exiting rx_packet(), status %4.4x, rx_status %4.4x.\n",			   inw(ioaddr+EL3_STATUS), inw(ioaddr+8));	return 0;}#ifdef HAVE_MULTICAST/* Set or clear the multicast filter for this adaptor.   num_addrs == -1		Promiscuous mode, receive all packets   num_addrs == 0		Normal mode, clear multicast list   num_addrs > 0		Multicast mode, receive normal and MC packets, and do						best-effort filtering. */static voidset_multicast_list(struct device *dev, int num_addrs, void *addrs){	short ioaddr = dev->base_addr;	if (num_addrs > 0) {		outw(0x8007, ioaddr + EL3_CMD);	} else if (num_addrs < 0) {		outw(0x8008, ioaddr + EL3_CMD);	} else		outw(0x8005, ioaddr + EL3_CMD);}#endifstatic intel3_close(struct device *dev){	int ioaddr = dev->base_addr;	if (el3_debug > 2)		printk("%s: Shutting down ethercard.\n", dev->name);	dev->tbusy = 1;	dev->start = 0;	/* Turn off statistics.	 We update lp->stats below. */	outw(0xB000, ioaddr + EL3_CMD);	/* Disable the receiver and transmitter. */	outw(0x1800, ioaddr + EL3_CMD);	outw(0x5000, ioaddr + EL3_CMD);	if (dev->if_port == 3)		/* Turn off thinnet power. */		outw(0xb800, ioaddr + EL3_CMD);	else if (dev->if_port == 0) {		/* Disable link beat and jabber, if_port may change ere next open(). */		EL3WINDOW(4);		outw(inw(ioaddr + WN4_MEDIA) & ~MEDIA_TP, ioaddr + WN4_MEDIA);	}	free_irq(dev->irq);	/* Switching back to window 0 disables the IRQ. */	EL3WINDOW(0);	/* But we explicitly zero the IRQ line select anyway. */	outw(0x0f00, ioaddr + 8);	irq2dev_map[dev->irq] = 0;	update_stats(ioaddr, dev);	return 0;}/* * Local variables: *  compile-command: "gcc -D__KERNEL__ -I/usr/src/linux/net/inet -Wall -Wstrict-prototypes -O6 -m486 -c 3c509.c" *  version-control: t *  kept-new-versions: 5 *  tab-width: 4 * End: */

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美影院一区二区| 国产精一区二区三区| 国产成人av一区二区三区在线观看| 91精品国产全国免费观看| 日韩黄色小视频| 久久av资源站| 91视频在线观看| 91.成人天堂一区| 日韩精品三区四区| 日韩一级在线观看| 国产精品一线二线三线精华| 国产精品免费观看视频| 色婷婷综合久色| 青青草一区二区三区| 国产女人aaa级久久久级| 99在线精品观看| 丝袜美腿亚洲色图| 久久看人人爽人人| 欧洲精品一区二区| 久久99久久99小草精品免视看| 中文字幕av一区二区三区高| 91成人免费在线视频| 麻豆成人久久精品二区三区小说| 久久久亚洲午夜电影| 色综合色综合色综合色综合色综合 | 国产欧美综合在线观看第十页| 成人黄色一级视频| 日本亚洲最大的色成网站www| 亚洲国产电影在线观看| 欧美人与性动xxxx| 成人精品小蝌蚪| 日韩av二区在线播放| 国产精品三级av在线播放| 欧美在线高清视频| 国产高清久久久久| 亚洲电影在线免费观看| 久久久91精品国产一区二区三区| 欧美三级三级三级| 国产成人亚洲综合a∨婷婷图片| 一区二区免费看| 国产色爱av资源综合区| 欧美浪妇xxxx高跟鞋交| 91香蕉视频污| 国产精品69毛片高清亚洲| 亚洲成人一区二区| 亚洲欧洲美洲综合色网| 日韩三级视频在线看| 色婷婷久久99综合精品jk白丝| 黄色精品一二区| 丝袜美腿亚洲色图| 一区二区免费视频| 亚洲人成亚洲人成在线观看图片| wwwwww.欧美系列| 91精品国产综合久久精品app| aaa欧美色吧激情视频| 国产剧情一区二区| 欧美a级理论片| 亚洲午夜精品一区二区三区他趣| 中文字幕一区二区三区四区| 久久久三级国产网站| 欧美一级片免费看| 欧美日韩国产在线播放网站| 91一区二区三区在线观看| 粉嫩13p一区二区三区| 精品一区二区日韩| 毛片一区二区三区| 免费欧美在线视频| 日本亚洲视频在线| 日本欧美肥老太交大片| 日韩va亚洲va欧美va久久| 亚洲国产aⅴ天堂久久| 一个色综合av| 亚洲一区二区三区中文字幕| 亚洲精品视频在线看| 亚洲天堂中文字幕| 亚洲欧美日韩国产综合| 亚洲美女偷拍久久| 亚洲精品乱码久久久久久| 亚洲九九爱视频| 亚洲小少妇裸体bbw| 亚洲高清免费视频| 五月婷婷激情综合网| 日韩精品高清不卡| 久久精品国产久精国产| 国产麻豆一精品一av一免费 | 日韩午夜电影av| 日韩女优电影在线观看| 精品88久久久久88久久久| 精品va天堂亚洲国产| 国产无遮挡一区二区三区毛片日本| 国产亚洲综合色| 综合在线观看色| 亚洲一区在线视频| 日韩av电影天堂| 黄色精品一二区| 不卡区在线中文字幕| 欧美日韩在线三区| 日韩精品专区在线影院重磅| 亚洲精品一区二区三区在线观看| 久久夜色精品一区| 亚洲欧美成aⅴ人在线观看| 亚洲猫色日本管| 蜜臀a∨国产成人精品| 久久91精品国产91久久小草 | 91浏览器在线视频| 欧美视频在线观看一区二区| 日韩欧美一级二级三级| 国产网站一区二区| 亚洲r级在线视频| 亚洲一卡二卡三卡四卡五卡| 日韩中文欧美在线| 国内外成人在线| 国产成人精品一区二区三区四区| 色综合久久综合| 欧美videossexotv100| 国产精品国产馆在线真实露脸 | 久久99精品国产91久久来源| 国产iv一区二区三区| 欧美日韩精品一区二区三区蜜桃| 久久亚洲精品国产精品紫薇| 亚洲人成亚洲人成在线观看图片 | 精品一区二区三区免费| 99久久久久久99| 这里只有精品99re| 欧美激情中文字幕一区二区| 天天综合色天天综合| 99久久综合99久久综合网站| 欧美视频你懂的| 国产欧美一区二区精品性色| 亚洲国产欧美日韩另类综合| 国产成人精品一区二| 欧美三区在线视频| 国产精品午夜春色av| 日韩国产欧美一区二区三区| 不卡大黄网站免费看| 久久日一线二线三线suv| 一区二区激情视频| 国产高清精品久久久久| 91精品欧美综合在线观看最新| 国产精品久久久久四虎| 日本不卡一二三区黄网| 91一区二区三区在线观看| 久久综合久久综合亚洲| 日韩精品每日更新| 波多野结衣精品在线| 欧美一区午夜视频在线观看| 亚洲精品综合在线| 成人激情黄色小说| 欧美mv和日韩mv国产网站| 午夜精品福利一区二区蜜股av| heyzo一本久久综合| 国产亚洲精品福利| 美女在线视频一区| 欧美日韩中文字幕一区| 亚洲视频香蕉人妖| 91色|porny| 中文字幕亚洲一区二区av在线| 国产一区激情在线| 久久综合av免费| 国产美女精品在线| 亚洲精品一线二线三线| 久久精品免费观看| 日韩精品中文字幕在线不卡尤物| 日本欧美韩国一区三区| 日韩一区二区精品葵司在线| 日韩国产精品久久| 日韩一区二区三区视频在线观看| 天使萌一区二区三区免费观看| 在线一区二区视频| 午夜视黄欧洲亚洲| 欧美一区二区三区小说| 免播放器亚洲一区| 亚洲精品一区二区三区四区高清| 国产在线国偷精品免费看| 2欧美一区二区三区在线观看视频 337p粉嫩大胆噜噜噜噜噜91av | 777午夜精品免费视频| 亚洲欧美日韩一区| 91九色最新地址| 三级一区在线视频先锋| 日韩亚洲欧美在线| 久久99最新地址| 国产欧美精品一区二区三区四区| 不卡av电影在线播放| 亚洲另类色综合网站| 欧美无乱码久久久免费午夜一区| 亚洲第一会所有码转帖| 日韩精品在线网站| 国产成人aaa| 亚洲欧美福利一区二区| 欧美日韩高清一区二区三区| 麻豆专区一区二区三区四区五区| 久久亚洲精精品中文字幕早川悠里| 大胆亚洲人体视频| 亚洲午夜精品在线| 精品国产百合女同互慰| av亚洲精华国产精华| 亚洲成年人网站在线观看| 日韩精品中午字幕| 97se亚洲国产综合自在线| 亚洲超碰精品一区二区|