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

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

?? ne2k-pci.c

?? GNU Mach 微內(nèi)核源代碼, 基于美國卡內(nèi)基美隆大學的 Mach 研究項目
?? C
?? 第 1 頁 / 共 2 頁
字號:
	}#if defined(LOAD_8390_BY_KERNELD)	/* We are now certain the 8390 module is required. */	if (request_module("8390")) {		printk("ne2k-pci: Failed to load the 8390 core module.\n");		return 0;	}	if ((Lethdev_init = (void*)get_module_symbol(0, "ethdev_init")) == 0 ||		(LNS8390_init = (void*)get_module_symbol(0, "NS8390_init")) == 0 ||		(Lei_open = (void*)get_module_symbol(0, "ei_open")) == 0 ||		(Lei_close = (void*)get_module_symbol(0, "ei_close")) == 0 ||		(Lei_interrupt = (void*)get_module_symbol(0, "ei_interrupt")) == 0 ) {		printk("ne2k-pci: Failed to resolve an 8390 symbol.\n");		release_module("8390", 0);		return 0;	}#endif	/* Read the 16 bytes of station address PROM.	   We must first initialize registers, similar to NS8390_init(eifdev, 0).	   We can't reliably read the SAPROM address without this.	   (I learned the hard way!). */	{		struct {unsigned char value, offset; } program_seq[] = {			{E8390_NODMA+E8390_PAGE0+E8390_STOP, E8390_CMD}, /* Select page 0*/			{0x49,	EN0_DCFG},	/* Set word-wide access. */			{0x00,	EN0_RCNTLO},	/* Clear the count regs. */			{0x00,	EN0_RCNTHI},			{0x00,	EN0_IMR},	/* Mask completion irq. */			{0xFF,	EN0_ISR},			{E8390_RXOFF, EN0_RXCR},	/* 0x20  Set to monitor */			{E8390_TXOFF, EN0_TXCR},	/* 0x02  and loopback mode. */			{32,	EN0_RCNTLO},			{0x00,	EN0_RCNTHI},			{0x00,	EN0_RSARLO},	/* DMA starting at 0x0000. */			{0x00,	EN0_RSARHI},			{E8390_RREAD+E8390_START, E8390_CMD},		};		for (i = 0; i < sizeof(program_seq)/sizeof(program_seq[0]); i++)			outb(program_seq[i].value, ioaddr + program_seq[i].offset);	}#ifdef notdef	/* Some broken PCI cards don't respect the byte-wide	   request in program_seq above, and hence don't have doubled up values.	*/	for(i = 0; i < 32 /*sizeof(SA_prom)*/; i+=2) {		SA_prom[i] = inb(ioaddr + NE_DATAPORT);		SA_prom[i+1] = inb(ioaddr + NE_DATAPORT);		if (SA_prom[i] != SA_prom[i+1])			sa_prom_doubled = 0;	}	if (sa_prom_doubled)		for (i = 0; i < 16; i++)			SA_prom[i] = SA_prom[i+i];#else	for(i = 0; i < 32 /*sizeof(SA_prom)*/; i++)		SA_prom[i] = inb(ioaddr + NE_DATAPORT);#endif	/* We always set the 8390 registers for word mode. */	outb(0x49, ioaddr + EN0_DCFG);	start_page = NESM_START_PG;	stop_page = NESM_STOP_PG;	/* Set up the rest of the parameters. */	name = "PCI NE2000";	dev->irq = irq;	dev->base_addr = ioaddr;	/* Allocate dev->priv and fill in 8390 specific dev fields. */	if (Lethdev_init(dev)) {		printk ("%s: unable to get memory for dev->priv.\n", dev->name);		return 0;	}	request_region(ioaddr, NE_IO_EXTENT, dev->name);	printk("%s: %s found at %#x, IRQ %d, ",		   dev->name, name, ioaddr, dev->irq);	for(i = 0; i < 6; i++) {		printk("%2.2X%s", SA_prom[i], i == 5 ? ".\n": ":");		dev->dev_addr[i] = SA_prom[i];	}	ei_status.name = name;	ei_status.tx_start_page = start_page;	ei_status.stop_page = stop_page;	ei_status.word16 = 1;	ei_status.rx_start_page = start_page + TX_PAGES;#ifdef PACKETBUF_MEMSIZE	/* Allow the packet buffer size to be overridden by know-it-alls. */	ei_status.stop_page = ei_status.tx_start_page + PACKETBUF_MEMSIZE;#endif	ei_status.reset_8390 = &ne_reset_8390;	ei_status.block_input = &ne_block_input;	ei_status.block_output = &ne_block_output;	ei_status.get_8390_hdr = &ne_get_8390_hdr;	dev->open = &ne_open;	dev->stop = &ne_close;	LNS8390_init(dev, 0);	return dev;}static intne_open(struct device *dev){	if (request_irq(dev->irq, Lei_interrupt, SA_SHIRQ, dev->name, dev))		return -EAGAIN;	Lei_open(dev);	MOD_INC_USE_COUNT;	return 0;}static intne_close(struct device *dev){	Lei_close(dev);	free_irq(dev->irq, dev);	MOD_DEC_USE_COUNT;	return 0;}/* Hard reset the card.  This used to pause for the same period that a   8390 reset command required, but that shouldn't be necessary. */static voidne_reset_8390(struct device *dev){	unsigned long reset_start_time = jiffies;	if (debug > 1) printk("%s: Resetting the 8390 t=%ld...",						  dev->name, jiffies);	outb(inb(NE_BASE + NE_RESET), NE_BASE + NE_RESET);	ei_status.txing = 0;	ei_status.dmaing = 0;	/* This check _should_not_ be necessary, omit eventually. */	while ((inb(NE_BASE+EN0_ISR) & ENISR_RESET) == 0)		if (jiffies - reset_start_time > 2) {			printk("%s: ne_reset_8390() did not complete.\n", dev->name);			break;		}	outb(ENISR_RESET, NE_BASE + EN0_ISR);	/* Ack intr. */}/* Grab the 8390 specific header. Similar to the block_input routine, but   we don't need to be concerned with ring wrap as the header will be at   the start of a page, so we optimize accordingly. */static voidne_get_8390_hdr(struct device *dev, struct e8390_pkt_hdr *hdr, int ring_page){	int nic_base = dev->base_addr;	/* This *shouldn't* happen. If it does, it's the last thing you'll see */	if (ei_status.dmaing) {		printk("%s: DMAing conflict in ne_get_8390_hdr "			   "[DMAstat:%d][irqlock:%d][intr:%d].\n",			   dev->name, ei_status.dmaing, ei_status.irqlock,			   dev->interrupt);		return;	}	ei_status.dmaing |= 0x01;	outb(E8390_NODMA+E8390_PAGE0+E8390_START, nic_base+ NE_CMD);	outb(sizeof(struct e8390_pkt_hdr), nic_base + EN0_RCNTLO);	outb(0, nic_base + EN0_RCNTHI);	outb(0, nic_base + EN0_RSARLO);		/* On page boundary */	outb(ring_page, nic_base + EN0_RSARHI);	outb(E8390_RREAD+E8390_START, nic_base + NE_CMD);#if defined(USE_LONGIO)	*(u32*)hdr = inl(NE_BASE + NE_DATAPORT);#else	insw(NE_BASE + NE_DATAPORT, hdr, sizeof(struct e8390_pkt_hdr)>>1);#endif	outb(ENISR_RDC, nic_base + EN0_ISR);	/* Ack intr. */	ei_status.dmaing &= ~0x01;}/* Block input and output, similar to the Crynwr packet driver.  If you   are porting to a new ethercard, look at the packet driver source for hints.   The NEx000 doesn't share the on-board packet memory -- you have to put   the packet out through the "remote DMA" dataport using outb. */static voidne_block_input(struct device *dev, int count, struct sk_buff *skb, int ring_offset){	int nic_base = dev->base_addr;	char *buf = skb->data;	/* This *shouldn't* happen. If it does, it's the last thing you'll see */	if (ei_status.dmaing) {		printk("%s: DMAing conflict in ne_block_input "			   "[DMAstat:%d][irqlock:%d][intr:%d].\n",			   dev->name, ei_status.dmaing, ei_status.irqlock,			   dev->interrupt);		return;	}	ei_status.dmaing |= 0x01;	outb(E8390_NODMA+E8390_PAGE0+E8390_START, nic_base+ NE_CMD);	outb(count & 0xff, nic_base + EN0_RCNTLO);	outb(count >> 8, nic_base + EN0_RCNTHI);	outb(ring_offset & 0xff, nic_base + EN0_RSARLO);	outb(ring_offset >> 8, nic_base + EN0_RSARHI);	outb(E8390_RREAD+E8390_START, nic_base + NE_CMD);#if defined(USE_LONGIO)	insl(NE_BASE + NE_DATAPORT, buf, count>>2);	if (count & 3) {		buf += count & ~3;		if (count & 2)			*((u16*)buf)++ = inw(NE_BASE + NE_DATAPORT);		if (count & 1)			*buf = inb(NE_BASE + NE_DATAPORT);	}#else	insw(NE_BASE + NE_DATAPORT,buf,count>>1);	if (count & 0x01) {		buf[count-1] = inb(NE_BASE + NE_DATAPORT);	}#endif	outb(ENISR_RDC, nic_base + EN0_ISR);	/* Ack intr. */	ei_status.dmaing &= ~0x01;}static voidne_block_output(struct device *dev, int count,		const unsigned char *buf, const int start_page){	int nic_base = NE_BASE;	unsigned long dma_start;	/* On little-endian it's always safe to round the count up for	   word writes. */	if (count & 0x01)		count++;	/* This *shouldn't* happen. If it does, it's the last thing you'll see */	if (ei_status.dmaing) {		printk("%s: DMAing conflict in ne_block_output."			   "[DMAstat:%d][irqlock:%d][intr:%d]\n",			   dev->name, ei_status.dmaing, ei_status.irqlock,			   dev->interrupt);		return;	}	ei_status.dmaing |= 0x01;	/* We should already be in page 0, but to be safe... */	outb(E8390_PAGE0+E8390_START+E8390_NODMA, nic_base + NE_CMD);#ifdef NE8390_RW_BUGFIX	/* Handle the read-before-write bug the same way as the	   Crynwr packet driver -- the NatSemi method doesn't work.	   Actually this doesn't always work either, but if you have	   problems with your NEx000 this is better than nothing! */	outb(0x42, nic_base + EN0_RCNTLO);	outb(0x00, nic_base + EN0_RCNTHI);	outb(0x42, nic_base + EN0_RSARLO);	outb(0x00, nic_base + EN0_RSARHI);	outb(E8390_RREAD+E8390_START, nic_base + NE_CMD);#endif	outb(ENISR_RDC, nic_base + EN0_ISR);   /* Now the normal output. */	outb(count & 0xff, nic_base + EN0_RCNTLO);	outb(count >> 8,   nic_base + EN0_RCNTHI);	outb(0x00, nic_base + EN0_RSARLO);	outb(start_page, nic_base + EN0_RSARHI);	outb(E8390_RWRITE+E8390_START, nic_base + NE_CMD);#if defined(USE_LONGIO)	outsl(NE_BASE + NE_DATAPORT, buf, count>>2);	if (count & 3) {		buf += count & ~3;		if (count & 2)			outw(*((u16*)buf)++, NE_BASE + NE_DATAPORT);	}#else	outsw(NE_BASE + NE_DATAPORT, buf, count>>1);#endif	dma_start = jiffies;	while ((inb(nic_base + EN0_ISR) & ENISR_RDC) == 0)		if (jiffies - dma_start > 2) { 			/* Avoid clock roll-over. */			printk("%s: timeout waiting for Tx RDC.\n", dev->name);			ne_reset_8390(dev);			LNS8390_init(dev,1);			break;		}	outb(ENISR_RDC, nic_base + EN0_ISR);	/* Ack intr. */	ei_status.dmaing &= ~0x01;	return;}/* * Local variables: *  compile-command: "gcc -DMODVERSIONS  -DMODULE -D__KERNEL__ -Wall -Wstrict-prototypes -O6 -fomit-frame-pointer -I/usr/src/linux/drivers/net/ -c ne2k-pci.c" *  alt-compile-command: "gcc -DMODULE -D__KERNEL__ -Wall -Wstrict-prototypes -O6 -fomit-frame-pointer -I/usr/src/linux/drivers/net/ -c ne2k-pci.c" *  c-indent-level: 4 *  c-basic-offset: 4 *  tab-width: 4 *  version-control: t *  kept-new-versions: 5 * End: */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久97超碰国产精品超碰| 国产欧美一区二区三区鸳鸯浴| 国产精品高潮呻吟| 99久久综合精品| 亚洲人吸女人奶水| 色av一区二区| 亚洲不卡一区二区三区| 在线播放中文字幕一区| 毛片av一区二区三区| 2020日本不卡一区二区视频| 国产一区二区三区四区在线观看| 久久久五月婷婷| 成人免费高清视频| 亚洲免费观看高清完整版在线观看 | 成人精品鲁一区一区二区| 日本一区二区电影| 色哟哟日韩精品| 石原莉奈在线亚洲二区| 精品国产露脸精彩对白| bt欧美亚洲午夜电影天堂| 亚洲图片欧美综合| 精品国产凹凸成av人网站| 成人性生交大合| 午夜精品影院在线观看| 亚洲精品在线三区| 日本福利一区二区| 精品一区二区三区在线播放| 国产精品亲子乱子伦xxxx裸| 色噜噜狠狠色综合中国| 国产综合色视频| 亚洲精品中文字幕在线观看| 8x8x8国产精品| 菠萝蜜视频在线观看一区| 视频一区欧美精品| 国产精品动漫网站| 欧美一区二区三区白人| 成人av在线观| 久久国产精品99久久人人澡| 日韩美女视频一区二区| 欧美大白屁股肥臀xxxxxx| 91影视在线播放| 国产一区二区三区免费播放| 亚洲夂夂婷婷色拍ww47| 国产欧美一区二区精品性| 正在播放亚洲一区| 色狠狠av一区二区三区| 成人免费的视频| 韩国av一区二区三区在线观看| 一区二区三区免费看视频| 久久九九久精品国产免费直播| 欧美丰满高潮xxxx喷水动漫| 91视频一区二区| 国产福利一区在线| 免费在线观看日韩欧美| 一区二区三区在线视频观看| 国产精品私人影院| 精品99一区二区| 欧美一区二区三区小说| 欧美日韩一二区| 日本韩国一区二区| 99re亚洲国产精品| 成人污污视频在线观看| 国产一区二区视频在线| 蜜桃精品视频在线| 日韩福利视频网| 午夜不卡在线视频| 亚洲成a人片在线不卡一二三区 | 青娱乐精品在线视频| 一级精品视频在线观看宜春院| 国产精品免费丝袜| 欧美激情一区二区三区蜜桃视频| 欧美成人性福生活免费看| 9191久久久久久久久久久| 欧美日韩视频第一区| 欧美性猛交xxxxxxxx| 色94色欧美sute亚洲线路一久| 99精品热视频| 99久久婷婷国产综合精品| 成人一级黄色片| av不卡免费在线观看| 成人精品免费视频| 91视频91自| 色狠狠一区二区| 欧美色男人天堂| 在线电影一区二区三区| 欧美一级二级三级蜜桃| 日韩欧美一二三区| 精品国产a毛片| 国产丝袜美腿一区二区三区| 国产蜜臀av在线一区二区三区| 国产欧美va欧美不卡在线| 国产精品视频第一区| 国产精品视频免费| 亚洲综合无码一区二区| 亚洲成人在线免费| 九一九一国产精品| 福利一区福利二区| 97久久超碰国产精品| 在线亚洲一区二区| 在线播放一区二区三区| 久久综合久久综合久久| 国产精品久久久久毛片软件| 1024亚洲合集| 日韩高清一级片| 国产精品一卡二卡在线观看| 成人网在线免费视频| 在线观看一区日韩| 欧美成人伊人久久综合网| 国产人久久人人人人爽| 亚洲精品国产a| 男男视频亚洲欧美| 成人av网址在线| 欧美日韩国产在线播放网站| 欧美成人艳星乳罩| 亚洲美女在线国产| 日韩精品亚洲专区| 丰满岳乱妇一区二区三区| 欧美中文字幕不卡| 久久久不卡影院| 亚洲电影第三页| 国产成人精品网址| 欧美日韩一区二区三区四区| 久久久激情视频| 偷窥国产亚洲免费视频| 大尺度一区二区| 91精品国产综合久久蜜臀| 欧美国产一区二区| 日本午夜精品一区二区三区电影| 大胆欧美人体老妇| 日韩午夜激情视频| 亚洲一区二区不卡免费| 国产一区视频在线看| 欧美三级乱人伦电影| 国产日产欧产精品推荐色 | 国产成人在线视频播放| 欧美专区在线观看一区| 久久久www免费人成精品| 亚洲6080在线| 色先锋久久av资源部| 久久精品一区二区三区av| 日日夜夜精品视频免费 | 欧洲人成人精品| 久久精品人人做人人爽人人| 午夜久久福利影院| 色嗨嗨av一区二区三区| 亚洲国产精品v| 激情五月婷婷综合| 欧美一区日韩一区| 亚洲成av人片www| 色婷婷精品久久二区二区蜜臂av| 国产丝袜在线精品| 国产乱对白刺激视频不卡| 91麻豆精品国产综合久久久久久| 亚洲人成7777| 99久久综合狠狠综合久久| 久久先锋影音av鲁色资源| 日本aⅴ精品一区二区三区| 欧美视频你懂的| 亚洲国产欧美日韩另类综合| 91丨porny丨中文| 亚洲视频电影在线| av激情亚洲男人天堂| 国产精品视频一二三区| 国产精品综合一区二区| 久久综合色之久久综合| 国内精品写真在线观看| 欧美电视剧免费全集观看| 日韩电影在线观看电影| 7777精品伊人久久久大香线蕉完整版| 亚洲精品成人少妇| 在线视频亚洲一区| 亚洲二区在线视频| 欧美精品久久99| 蜜臀av性久久久久蜜臀aⅴ| 欧美一级片在线| 久久国产日韩欧美精品| 337p粉嫩大胆色噜噜噜噜亚洲| 国产乱人伦偷精品视频不卡| 精品区一区二区| 粉嫩av一区二区三区| 国产精品对白交换视频| 一本一道波多野结衣一区二区| 尤物在线观看一区| 欧美丝袜第三区| 蜜桃视频在线一区| 国产欧美日韩一区二区三区在线观看| 成人永久免费视频| 亚洲色图都市小说| 欧美日韩激情在线| 蜜桃av一区二区| 国产精品国产三级国产普通话99 | 久久99热狠狠色一区二区| 久久亚洲欧美国产精品乐播| 国产99久久久精品| 一区二区久久久久| 精品国产一区二区在线观看| 懂色av中文一区二区三区| 一区二区免费在线播放| 精品久久久久一区| 97久久精品人人做人人爽 |