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

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

?? smc-ultra.c

?? Linux Kernel 2.6.9 for OMAP1710
?? C
?? 第 1 頁 / 共 2 頁
字號:
		ei_status.block_output = &ultra_pio_output;		ei_status.get_8390_hdr = &ultra_pio_get_hdr;	} else {		printk(",%s IRQ %d memory %#lx-%#lx.\n", eeprom_irq ? "" : "assigned ",			   dev->irq, dev->mem_start, dev->mem_end-1);		ei_status.block_input = &ultra_block_input;		ei_status.block_output = &ultra_block_output;		ei_status.get_8390_hdr = &ultra_get_8390_hdr;	}	ei_status.reset_8390 = &ultra_reset_8390;	dev->open = &ultra_open;	dev->stop = &ultra_close_card;#ifdef CONFIG_NET_POLL_CONTROLLER	dev->poll_controller = ei_poll;#endif	NS8390_init(dev, 0);	return 0;out:	release_region(ioaddr, ULTRA_IO_EXTENT);	return retval;}#ifdef __ISAPNP__static int __init ultra_probe_isapnp(struct net_device *dev){        int i;        for (i = 0; ultra_device_ids[i].vendor != 0; i++) {		struct pnp_dev *idev = NULL;                while ((idev = pnp_find_dev(NULL,                                            ultra_device_ids[i].vendor,                                            ultra_device_ids[i].function,                                            idev))) {                        /* Avoid already found cards from previous calls */                        if (pnp_device_attach(idev) < 0)                        	continue;                        if (pnp_activate_dev(idev) < 0) {                              __again:                        	pnp_device_detach(idev);                        	continue;                        }			/* if no io and irq, search for next */			if (!pnp_port_valid(idev, 0) || !pnp_irq_valid(idev, 0))				goto __again;                        /* found it */			dev->base_addr = pnp_port_start(idev, 0);			dev->irq = pnp_irq(idev, 0);                        printk(KERN_INFO "smc-ultra.c: ISAPnP reports %s at i/o %#lx, irq %d.\n",                                (char *) ultra_device_ids[i].driver_data,                                dev->base_addr, dev->irq);                        if (ultra_probe1(dev, dev->base_addr) != 0) {      /* Shouldn't happen. */                                printk(KERN_ERR "smc-ultra.c: Probe of ISAPnP card at %#lx failed.\n", dev->base_addr);                                pnp_device_detach(idev);				return -ENXIO;                        }                        ei_status.priv = (unsigned long)idev;                        break;                }                if (!idev)                        continue;                return 0;        }        return -ENODEV;}#endifstatic intultra_open(struct net_device *dev){	int retval;	int ioaddr = dev->base_addr - ULTRA_NIC_OFFSET; /* ASIC addr */	unsigned char irq2reg[] = {0, 0, 0x04, 0x08, 0, 0x0C, 0, 0x40,				   0, 0x04, 0x44, 0x48, 0, 0, 0, 0x4C, };	retval = request_irq(dev->irq, ei_interrupt, 0, dev->name, dev);	if (retval)		return retval;	outb(0x00, ioaddr);	/* Disable shared memory for safety. */	outb(0x80, ioaddr + 5);	/* Set the IRQ line. */	outb(inb(ioaddr + 4) | 0x80, ioaddr + 4);	outb((inb(ioaddr + 13) & ~0x4C) | irq2reg[dev->irq], ioaddr + 13);	outb(inb(ioaddr + 4) & 0x7f, ioaddr + 4);	if (ei_status.block_input == &ultra_pio_input) {		outb(0x11, ioaddr + 6);		/* Enable interrupts and PIO. */		outb(0x01, ioaddr + 0x19);  	/* Enable ring read auto-wrap. */	} else		outb(0x01, ioaddr + 6);		/* Enable interrupts and memory. */	/* Set the early receive warning level in window 0 high enough not	   to receive ERW interrupts. */	outb_p(E8390_NODMA+E8390_PAGE0, dev->base_addr);	outb(0xff, dev->base_addr + EN0_ERWCNT);	ei_open(dev);	return 0;}static voidultra_reset_8390(struct net_device *dev){	int cmd_port = dev->base_addr - ULTRA_NIC_OFFSET; /* ASIC base addr */	outb(ULTRA_RESET, cmd_port);	if (ei_debug > 1) printk("resetting Ultra, t=%ld...", jiffies);	ei_status.txing = 0;	outb(0x00, cmd_port);	/* Disable shared memory for safety. */	outb(0x80, cmd_port + 5);	if (ei_status.block_input == &ultra_pio_input)		outb(0x11, cmd_port + 6);		/* Enable interrupts and PIO. */	else		outb(0x01, cmd_port + 6);		/* Enable interrupts and memory. */	if (ei_debug > 1) printk("reset done\n");	return;}/* 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 voidultra_get_8390_hdr(struct net_device *dev, struct e8390_pkt_hdr *hdr, int ring_page){	unsigned long hdr_start = dev->mem_start + ((ring_page - START_PG)<<8);	outb(ULTRA_MEMENB, dev->base_addr - ULTRA_NIC_OFFSET);	/* shmem on */#ifdef __BIG_ENDIAN	/* Officially this is what we are doing, but the readl() is faster */	/* unfortunately it isn't endian aware of the struct               */	isa_memcpy_fromio(hdr, hdr_start, sizeof(struct e8390_pkt_hdr));	hdr->count = le16_to_cpu(hdr->count);#else	((unsigned int*)hdr)[0] = isa_readl(hdr_start);#endif	outb(0x00, dev->base_addr - ULTRA_NIC_OFFSET); /* shmem off */}/* Block input and output are easy on shared memory ethercards, the only   complication is when the ring buffer wraps. */static voidultra_block_input(struct net_device *dev, int count, struct sk_buff *skb, int ring_offset){	unsigned long xfer_start = dev->mem_start + ring_offset - (START_PG<<8);	/* Enable shared memory. */	outb(ULTRA_MEMENB, dev->base_addr - ULTRA_NIC_OFFSET);	if (xfer_start + count > ei_status.rmem_end) {		/* We must wrap the input move. */		int semi_count = ei_status.rmem_end - xfer_start;		isa_memcpy_fromio(skb->data, xfer_start, semi_count);		count -= semi_count;		isa_memcpy_fromio(skb->data + semi_count, ei_status.rmem_start, count);	} else {		/* Packet is in one chunk -- we can copy + cksum. */		isa_eth_io_copy_and_sum(skb, xfer_start, count, 0);	}	outb(0x00, dev->base_addr - ULTRA_NIC_OFFSET);	/* Disable memory. */}static voidultra_block_output(struct net_device *dev, int count, const unsigned char *buf,				int start_page){	unsigned long shmem = dev->mem_start + ((start_page - START_PG)<<8);	/* Enable shared memory. */	outb(ULTRA_MEMENB, dev->base_addr - ULTRA_NIC_OFFSET);	isa_memcpy_toio(shmem, buf, count);	outb(0x00, dev->base_addr - ULTRA_NIC_OFFSET); /* Disable memory. */}/* The identical operations for programmed I/O cards.   The PIO model is trivial to use: the 16 bit start address is written   byte-sequentially to IOPA, with no intervening I/O operations, and the   data is read or written to the IOPD data port.   The only potential complication is that the address register is shared   and must be always be rewritten between each read/write direction change.   This is no problem for us, as the 8390 code ensures that we are single   threaded. */static void ultra_pio_get_hdr(struct net_device *dev, struct e8390_pkt_hdr *hdr,						int ring_page){	int ioaddr = dev->base_addr - ULTRA_NIC_OFFSET; /* ASIC addr */	outb(0x00, ioaddr + IOPA);	/* Set the address, LSB first. */	outb(ring_page, ioaddr + IOPA);	insw(ioaddr + IOPD, hdr, sizeof(struct e8390_pkt_hdr)>>1);}static void ultra_pio_input(struct net_device *dev, int count,						  struct sk_buff *skb, int ring_offset){	int ioaddr = dev->base_addr - ULTRA_NIC_OFFSET; /* ASIC addr */    char *buf = skb->data;	/* For now set the address again, although it should already be correct. */	outb(ring_offset, ioaddr + IOPA);	/* Set the address, LSB first. */	outb(ring_offset >> 8, ioaddr + IOPA);	/* We know skbuffs are padded to at least word alignment. */	insw(ioaddr + IOPD, buf, (count+1)>>1);}static void ultra_pio_output(struct net_device *dev, int count,							const unsigned char *buf, const int start_page){	int ioaddr = dev->base_addr - ULTRA_NIC_OFFSET; /* ASIC addr */	outb(0x00, ioaddr + IOPA);	/* Set the address, LSB first. */	outb(start_page, ioaddr + IOPA);	/* An extra odd byte is OK here as well. */	outsw(ioaddr + IOPD, buf, (count+1)>>1);}static intultra_close_card(struct net_device *dev){	int ioaddr = dev->base_addr - ULTRA_NIC_OFFSET; /* CMDREG */	netif_stop_queue(dev);	if (ei_debug > 1)		printk("%s: Shutting down ethercard.\n", dev->name);	outb(0x00, ioaddr + 6);		/* Disable interrupts. */	free_irq(dev->irq, dev);	NS8390_init(dev, 0);	/* We should someday disable shared memory and change to 8-bit mode	   "just in case"... */	return 0;}#ifdef MODULE#define MAX_ULTRA_CARDS	4	/* Max number of Ultra cards per module */static struct net_device *dev_ultra[MAX_ULTRA_CARDS];static int io[MAX_ULTRA_CARDS];static int irq[MAX_ULTRA_CARDS];MODULE_PARM(io, "1-" __MODULE_STRING(MAX_ULTRA_CARDS) "i");MODULE_PARM(irq, "1-" __MODULE_STRING(MAX_ULTRA_CARDS) "i");MODULE_PARM_DESC(io, "I/O base address(es)");MODULE_PARM_DESC(irq, "IRQ number(s) (assigned)");MODULE_DESCRIPTION("SMC Ultra/EtherEZ ISA/PnP Ethernet driver");MODULE_LICENSE("GPL");/* This is set up so that only a single autoprobe takes place per call.ISA device autoprobes on a running machine are not recommended. */intinit_module(void){	struct net_device *dev;	int this_dev, found = 0;	for (this_dev = 0; this_dev < MAX_ULTRA_CARDS; this_dev++) {		if (io[this_dev] == 0)  {			if (this_dev != 0) break; /* only autoprobe 1st one */			printk(KERN_NOTICE "smc-ultra.c: Presently autoprobing (not recommended) for a single card.\n");		}		dev = alloc_ei_netdev();		if (!dev)			break;		dev->irq = irq[this_dev];		dev->base_addr = io[this_dev];		if (do_ultra_probe(dev) == 0) {			if (register_netdev(dev) == 0) {				dev_ultra[found++] = dev;				continue;			}			cleanup_card(dev);		}		free_netdev(dev);		printk(KERN_WARNING "smc-ultra.c: No SMC Ultra card found (i/o = 0x%x).\n", io[this_dev]);		break;	}	if (found)		return 0;	return -ENXIO;}voidcleanup_module(void){	int this_dev;	for (this_dev = 0; this_dev < MAX_ULTRA_CARDS; this_dev++) {		struct net_device *dev = dev_ultra[this_dev];		if (dev) {			unregister_netdev(dev);			cleanup_card(dev);			free_netdev(dev);		}	}}#endif /* MODULE */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲日本韩国一区| 91精品国产色综合久久不卡蜜臀| 国产女人18水真多18精品一级做| 国产精品资源网| 欧美高清在线精品一区| 成人激情免费视频| 亚洲精品免费一二三区| 91精品国产综合久久久蜜臀粉嫩| 蜜臀av国产精品久久久久| 久久色在线观看| 99久久婷婷国产综合精品| 亚洲综合色网站| 精品国产乱码久久久久久1区2区| 国产精品一二三四区| 亚洲色欲色欲www| 制服.丝袜.亚洲.另类.中文| 国产自产v一区二区三区c| 综合久久久久久| 在线成人高清不卡| 高清在线观看日韩| 亚洲自拍都市欧美小说| 久久精品日韩一区二区三区| 一本色道久久综合精品竹菊| 美脚の诱脚舐め脚责91| 亚洲日穴在线视频| 日韩午夜在线播放| 91免费小视频| 国产在线精品一区二区三区不卡| 自拍偷自拍亚洲精品播放| 欧美日韩一级视频| 国产在线一区二区| 夜夜精品视频一区二区| 久久综合视频网| 欧洲一区二区三区在线| 国产成人在线网站| 调教+趴+乳夹+国产+精品| 国产精品视频一二| 91精品国产入口在线| 成人美女在线观看| 老鸭窝一区二区久久精品| 亚洲欧洲一区二区三区| 日韩免费一区二区| 色综合久久久久综合体桃花网| 精品一区二区在线视频| 亚洲综合激情小说| 国产精品久久网站| 欧美电影免费观看完整版| 欧美系列亚洲系列| 成人免费视频视频| 韩国一区二区视频| 亚洲成人午夜电影| 亚洲欧洲精品一区二区三区| 日韩欧美成人激情| 欧美日产国产精品| 日本韩国欧美在线| 成人av网站免费观看| 激情国产一区二区| 免费观看在线色综合| 日韩精品亚洲专区| 中文字幕综合网| 中文字幕不卡一区| 国产丝袜美腿一区二区三区| 日韩一区二区在线观看视频播放| 91久久精品国产91性色tv| 99在线热播精品免费| 国产不卡视频在线观看| 久草中文综合在线| 麻豆久久久久久久| 美国欧美日韩国产在线播放| 日韩一区精品视频| 天堂影院一区二区| 亚洲成a人片在线不卡一二三区| 亚洲人吸女人奶水| 专区另类欧美日韩| 亚洲裸体在线观看| 亚洲美女少妇撒尿| 亚洲一区二区三区视频在线播放| 中文字幕一区二区在线观看| 亚洲色图20p| 亚洲另类一区二区| 亚洲高清视频中文字幕| 午夜激情一区二区| 蜜臀av一区二区在线免费观看| 蜜臀久久99精品久久久久宅男| 日韩二区三区四区| 美腿丝袜在线亚洲一区| 麻豆精品视频在线| 韩国精品一区二区| 国产成人免费视频精品含羞草妖精| 韩国理伦片一区二区三区在线播放 | 国产拍欧美日韩视频二区| 国产无遮挡一区二区三区毛片日本| 久久久精品国产免大香伊| 日本一区二区免费在线| 自拍偷拍国产精品| 亚洲亚洲精品在线观看| 麻豆视频观看网址久久| 国产福利一区在线观看| 不卡一区在线观看| 91久久国产最好的精华液| 欧美二区乱c少妇| 久久亚区不卡日本| 亚洲天堂2014| 午夜精品福利在线| 国产一区不卡视频| 91亚洲国产成人精品一区二区三 | 美日韩黄色大片| 国产高清不卡一区二区| 91久久线看在观草草青青| 91精品婷婷国产综合久久| 精品成人a区在线观看| 中文字幕在线一区免费| 亚洲成人综合视频| 国产成人综合在线| 在线精品视频免费播放| 精品美女被调教视频大全网站| 中文字幕一区二区三区在线播放| 亚洲地区一二三色| 国产酒店精品激情| 欧美日本国产视频| 中文字幕不卡的av| 五月综合激情日本mⅴ| 国产老妇另类xxxxx| 欧美日韩另类国产亚洲欧美一级| 国产亚洲精品免费| 亚洲二区视频在线| 国产成人精品一区二区三区四区| 欧美亚洲日本一区| 国产欧美一区二区三区沐欲| 亚洲第一会所有码转帖| 成人av网站在线观看| 日韩精品中文字幕一区二区三区 | 国产亚洲一二三区| 亚洲成av人在线观看| youjizz久久| 精品噜噜噜噜久久久久久久久试看 | 国产精品一品二品| 欧美一级二级三级蜜桃| 夜色激情一区二区| www.性欧美| 久久亚洲捆绑美女| 蜜臀av性久久久久蜜臀aⅴ| 欧美系列亚洲系列| 亚洲视频一区二区在线观看| 国产精品一级片| 精品久久久久久综合日本欧美| 日韩精品成人一区二区在线| 色婷婷av一区| 亚洲欧美影音先锋| 成人免费毛片高清视频| 日韩欧美综合一区| 首页国产欧美日韩丝袜| 欧美午夜在线一二页| 亚洲精品videosex极品| 色综合一区二区三区| 日韩美女视频一区二区| 成人国产精品免费观看动漫| 国产亚洲一区二区三区| 国产精品一区久久久久| 久久久久97国产精华液好用吗| 美日韩黄色大片| 欧美大片一区二区三区| 国模娜娜一区二区三区| 久久久五月婷婷| 国产精品18久久久久久久久| 国产三级三级三级精品8ⅰ区| 国产制服丝袜一区| 久久九九影视网| 懂色av一区二区夜夜嗨| 中文在线一区二区| 91丨九色丨蝌蚪丨老版| 亚洲激情图片小说视频| 欧美亚一区二区| 婷婷久久综合九色综合绿巨人| 欧美精品第一页| 精品一区二区成人精品| 精品国产乱码久久久久久1区2区 | 成人国产电影网| 亚洲欧美日韩久久| 欧美日韩在线综合| 日韩二区三区四区| 久久精品亚洲一区二区三区浴池| 国产成人在线观看| **网站欧美大片在线观看| 欧美日韩国产一级| 麻豆一区二区三| 国产精品乱码人人做人人爱| 91蜜桃传媒精品久久久一区二区| 亚洲国产色一区| 欧美精品一区二区三区视频| 粉嫩在线一区二区三区视频| 亚洲六月丁香色婷婷综合久久 | 欧美精品一区二区三区蜜臀| 成人av小说网| 午夜伦欧美伦电影理论片| 欧美精品一区视频| 色88888久久久久久影院野外 | 国产精品视频线看| 欧美日韩一区三区四区| 韩国v欧美v日本v亚洲v|