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

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

?? ne2k-pci.c

?? 嵌入式系統的TCP/IP源代碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* ne2k-pci.c: A NE2000 clone on PCI bus driver for Linux. */
/*
	A Linux device driver for PCI NE2000 clones.

	Authorship and other copyrights:
	1992-1998 by Donald Becker, NE2000 core and various modifications.
	1995-1998 by Paul Gortmaker, core modifications and PCI support.

	Copyright 1993 assigned to the United States Government as represented
	by the Director, National Security Agency.

	This software may be used and distributed according to the terms
	of the GNU Public License, incorporated herein by reference.

	The author may be reached as becker@CESDIS.gsfc.nasa.gov, or C/O
	Center of Excellence in Space Data and Information Sciences
	Code 930.5, Goddard Space Flight Center, Greenbelt MD 20771

	People are making PCI ne2000 clones! Oh the horror, the horror...

	Issues remaining:
	No full-duplex support.
*/

/* Our copyright info must remain in the binary. */
static const char *version =
"ne2k-pci.c:vpre-1.00e 5/27/99 D. Becker/P. Gortmaker http://cesdis.gsfc.nasa.gov/linux/drivers/ne2k-pci.html\n";

#include <linux/module.h>
#include <linux/kernel.h>
#include <linux/sched.h>
#include <linux/errno.h>
#include <linux/pci.h>
#include <linux/init.h>

#include <asm/system.h>
#include <asm/io.h>
#include <asm/irq.h>

#include <linux/netdevice.h>
#include <linux/etherdevice.h>
#include "8390.h"

#if defined(__powerpc__)
#define inl_le(addr)  le32_to_cpu(inl(addr))
#define inw_le(addr)  le16_to_cpu(inw(addr))
#define insl insl_ns
#define outsl outsl_ns
#endif

/* Set statically or when loading the driver module. */
static int debug = 1;

/* Some defines that people can play with if so inclined. */

/* Use 32 bit data-movement operations instead of 16 bit. */
#define USE_LONGIO

/* Do we implement the read before write bugfix ? */
/* #define NE_RW_BUGFIX */

/* Do we have a non std. amount of memory? (in units of 256 byte pages) */
/* #define PACKETBUF_MEMSIZE	0x40 */

#define ne2k_flags reg0			/* Rename an existing field to store flags! */

/* Only the low 8 bits are usable for non-init-time flags! */
enum {
	HOLTEK_FDX=1, 		/* Full duplex -> set 0x80 at offset 0x20. */
	ONLY_16BIT_IO=2, ONLY_32BIT_IO=4,	/* Chip can do only 16/32-bit xfers. */
	STOP_PG_0x60=0x100,
};

/* This will eventually be converted to the standard PCI probe table. */

static struct {
	unsigned short vendor, dev_id;
	char *name;
	int flags;
}
pci_clone_list[] __initdata = {
	{0x10ec, 0x8029, "RealTek RTL-8029", 0},
	{0x1050, 0x0940, "Winbond 89C940", 0},
	{0x11f6, 0x1401, "Compex RL2000", 0},
	{0x8e2e, 0x3000, "KTI ET32P2", 0},
	{0x4a14, 0x5000, "NetVin NV5000SC", 0},
	{0x1106, 0x0926, "Via 86C926", ONLY_16BIT_IO},
	{0x10bd, 0x0e34, "SureCom NE34", 0},
	{0x1050, 0x5a5a, "Winbond", 0},
	{0x12c3, 0x0058, "Holtek HT80232", ONLY_16BIT_IO | HOLTEK_FDX},
	{0x12c3, 0x5598, "Holtek HT80229",
	 ONLY_32BIT_IO | HOLTEK_FDX | STOP_PG_0x60 },
	{0,}
};

/* ---- No user-serviceable parts below ---- */

#define NE_BASE	 (dev->base_addr)
#define NE_CMD	 	0x00
#define NE_DATAPORT	0x10	/* NatSemi-defined port window offset. */
#define NE_RESET	0x1f	/* Issue a read to reset, a write to clear. */
#define NE_IO_EXTENT	0x20

#define NESM_START_PG	0x40	/* First page of TX buffer */
#define NESM_STOP_PG	0x80	/* Last page +1 of RX ring */

int ne2k_pci_probe(struct device *dev);
static struct device *ne2k_pci_probe1(struct device *dev, long ioaddr, int irq,
									  int chip_idx);

static int ne2k_pci_open(struct device *dev);
static int ne2k_pci_close(struct device *dev);

static void ne2k_pci_reset_8390(struct device *dev);
static void ne2k_pci_get_8390_hdr(struct device *dev, struct e8390_pkt_hdr *hdr,
			  int ring_page);
static void ne2k_pci_block_input(struct device *dev, int count,
			  struct sk_buff *skb, int ring_offset);
static void ne2k_pci_block_output(struct device *dev, const int count,
		const unsigned char *buf, const int start_page);



/* No room in the standard 8390 structure for extra info we need. */
struct ne2k_pci_card {
	struct ne2k_pci_card *next;
	struct device *dev;
	struct pci_dev *pci_dev;
};
/* A list of all installed devices, for removing the driver module. */
static struct ne2k_pci_card *ne2k_card_list = NULL;

#ifdef MODULE

int
init_module(void)
{
	/* We must emit version information. */
	if (debug)
		printk(KERN_INFO "%s", version);

	if (ne2k_pci_probe(0)) {
		printk(KERN_NOTICE "ne2k-pci.c: No useable cards found, driver NOT installed.\n");
		return -ENODEV;
	}
	lock_8390_module();
	return 0;
}

void
cleanup_module(void)
{
	struct device *dev;
	struct ne2k_pci_card *this_card;

	/* No need to check MOD_IN_USE, as sys_delete_module() checks. */
	while (ne2k_card_list) {
		dev = ne2k_card_list->dev;
		unregister_netdev(dev);
		release_region(dev->base_addr, NE_IO_EXTENT);
		kfree(dev);
		this_card = ne2k_card_list;
		ne2k_card_list = ne2k_card_list->next;
		kfree(this_card);
	}
	unlock_8390_module();
}

#endif  /* MODULE */

/*
  NEx000-clone boards have a Station Address (SA) PROM (SAPROM) in the packet
  buffer memory space.  By-the-spec NE2000 clones have 0x57,0x57 in bytes
  0x0e,0x0f of the SAPROM, while other supposed NE2000 clones must be
  detected by their SA prefix.

  Reading the SAPROM from a word-wide card with the 8390 set in byte-wide
  mode results in doubled values, which can be detected and compensated for.

  The probe is also responsible for initializing the card and filling
  in the 'dev' and 'ei_status' structures.
*/

#ifdef HAVE_DEVLIST
struct netdev_entry netcard_drv =
{"ne2k_pci", ne2k_pci_probe1, NE_IO_EXTENT, 0};
#endif

__initfunc (int ne2k_pci_probe(struct device *dev))
{
	struct pci_dev *pdev = NULL;
	int cards_found = 0;
	int i;

	if ( ! pci_present())
		return -ENODEV;

	while ((pdev = pci_find_class(PCI_CLASS_NETWORK_ETHERNET << 8, pdev)) != NULL) {
		int pci_irq_line;
		u16 pci_command, new_command;
		unsigned long pci_ioaddr;

		/* Note: some vendor IDs (RealTek) have non-NE2k cards as well. */
		for (i = 0; pci_clone_list[i].vendor != 0; i++)
			if (pci_clone_list[i].vendor == pdev->vendor
				&& pci_clone_list[i].dev_id == pdev->device)
				break;
		if (pci_clone_list[i].vendor == 0)
			continue;

		pci_ioaddr = pdev->base_address[0] & PCI_BASE_ADDRESS_IO_MASK;
		pci_irq_line = pdev->irq;
		pci_read_config_word(pdev, PCI_COMMAND, &pci_command);

		/* Avoid already found cards from previous calls */
		if (check_region(pci_ioaddr, NE_IO_EXTENT))
			continue;

#ifndef MODULE
		{
			static unsigned version_printed = 0;
			if (version_printed++ == 0)
				printk(KERN_INFO "%s", version);
		}
#endif

		/* Activate the card: fix for brain-damaged Win98 BIOSes. */
		new_command = pci_command | PCI_COMMAND_IO;
		if (pci_command != new_command) {
			printk(KERN_INFO "  The PCI BIOS has not enabled this"
				   " NE2k clone!  Updating PCI command %4.4x->%4.4x.\n",
				   pci_command, new_command);
			pci_write_config_word(pdev, PCI_COMMAND, new_command);
		}
#ifndef __sparc__
		if (pci_irq_line <= 0 || pci_irq_line >= NR_IRQS)
			printk(KERN_WARNING "  WARNING: The PCI BIOS assigned this PCI NE2k"
				   " card to IRQ %d, which is unlikely to work!.\n"
				   KERN_WARNING " You should use the PCI BIOS setup to assign"
				   " a valid IRQ line.\n", pci_irq_line);
#endif
		printk("ne2k-pci.c: PCI NE2000 clone '%s' at I/O %#lx, IRQ %d.\n",
			   pci_clone_list[i].name, pci_ioaddr, pci_irq_line);
		dev = ne2k_pci_probe1(dev, pci_ioaddr, pci_irq_line, i);
		if (dev == 0) {
			/* Should not happen. */
			printk(KERN_ERR "ne2k-pci: Probe of PCI card at %#lx failed.\n",
				   pci_ioaddr);
			continue;
		} else {
			struct ne2k_pci_card *ne2k_card =
				kmalloc(sizeof(struct ne2k_pci_card), GFP_KERNEL);
			ne2k_card->next = ne2k_card_list;
			ne2k_card_list = ne2k_card;
			ne2k_card->dev = dev;
			ne2k_card->pci_dev = pdev;
		}
		dev = 0;

		cards_found++;
	}

	return cards_found ? 0 : -ENODEV;
}

__initfunc (static struct device *ne2k_pci_probe1(struct device *dev, long ioaddr, int irq,
									  int chip_idx))
{
	int i;
	unsigned char SA_prom[32];
	int start_page, stop_page;
	int reg0 = inb(ioaddr);

	if (reg0 == 0xFF)
		return 0;

	/* Do a preliminary verification that we have a 8390. */
	{
		int regd;
		outb(E8390_NODMA+E8390_PAGE1+E8390_STOP, ioaddr + E8390_CMD);
		regd = inb(ioaddr + 0x0d);
		outb(0xff, ioaddr + 0x0d);
		outb(E8390_NODMA+E8390_PAGE0, ioaddr + E8390_CMD);
		inb(ioaddr + EN0_COUNTER0); /* Clear the counter by reading. */
		if (inb(ioaddr + EN0_COUNTER0) != 0) {
			outb(reg0, ioaddr);
			outb(regd, ioaddr + 0x0d);	/* Restore the old values. */
			return 0;
		}
	}

	dev = init_etherdev(dev, 0);

	/* Reset card. Who knows what dain-bramaged state it was left in. */
	{
		unsigned long reset_start_time = jiffies;

		outb(inb(ioaddr + NE_RESET), ioaddr + NE_RESET);

		/* This looks like a horrible timing loop, but it should never take
		   more than a few cycles.
		*/
		while ((inb(ioaddr + EN0_ISR) & ENISR_RESET) == 0)
			/* Limit wait: '2' avoids jiffy roll-over. */
			if (jiffies - reset_start_time > 2) {
				printk("ne2k-pci: Card failure (no reset ack).\n");
				return 0;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91亚洲精品一区二区乱码| 欧美电影影音先锋| 欧美巨大另类极品videosbest| 精品福利在线导航| 亚洲福利国产精品| 成人福利电影精品一区二区在线观看| 欧美日韩视频在线一区二区| 国产欧美一区二区精品秋霞影院| 丝袜美腿亚洲一区二区图片| av一区二区三区黑人| 久久久亚洲高清| 久久精品国产77777蜜臀| 色欧美片视频在线观看在线视频| 久久久亚洲精品一区二区三区| 日本中文字幕一区| 日本韩国欧美在线| ...中文天堂在线一区| 国产成人自拍在线| 精品免费视频一区二区| 三级久久三级久久久| 欧美日韩国产一级片| 亚洲另类春色校园小说| 99久久精品免费观看| 国产亚洲精品久| 国产麻豆精品在线| 337p粉嫩大胆噜噜噜噜噜91av| 日韩av一区二区三区四区| 欧美日韩美女一区二区| 亚洲综合在线免费观看| 91免费看片在线观看| 国产精品九色蝌蚪自拍| 97精品久久久久中文字幕| 国产精品欧美一区喷水| 成人美女在线观看| 国产精品久久久久四虎| 91蜜桃免费观看视频| 亚洲欧洲日韩在线| 色婷婷综合久久久久中文一区二区 | 国产欧美精品一区| 粉嫩aⅴ一区二区三区四区五区| 久久久99久久| 不卡av电影在线播放| 综合激情成人伊人| 91高清视频免费看| 日韩福利视频网| 精品国产sm最大网站| 粉嫩高潮美女一区二区三区| 国产精品美女久久久久av爽李琼| 成人免费毛片a| 一区av在线播放| 91精品国产91久久久久久最新毛片| 日本人妖一区二区| 国产三级欧美三级日产三级99| 国产电影精品久久禁18| 亚洲人成亚洲人成在线观看图片| 色噜噜偷拍精品综合在线| 亚洲va欧美va国产va天堂影院| 欧美精品一二三| 国产成人午夜99999| 亚洲人午夜精品天堂一二香蕉| 欧美色图第一页| 国内精品不卡在线| 自拍视频在线观看一区二区| 欧美三级午夜理伦三级中视频| 久久av资源网| 亚洲天天做日日做天天谢日日欢 | 国产不卡视频一区二区三区| 国产精品久久久久久久第一福利| 欧美日韩一区久久| 国产一区久久久| 亚洲综合免费观看高清在线观看| 精品欧美久久久| 91久久精品一区二区二区| 九九热在线视频观看这里只有精品| 国产精品九色蝌蚪自拍| 欧美一级日韩不卡播放免费| 国产91精品精华液一区二区三区| 亚洲bt欧美bt精品| 国产片一区二区| 91精品欧美综合在线观看最新| 国产在线不卡一卡二卡三卡四卡| 亚洲乱码国产乱码精品精的特点| 欧美一级xxx| 欧洲一区在线电影| 国产黄人亚洲片| 日本亚洲欧美天堂免费| 亚洲人成网站影音先锋播放| 久久久久久久久久久久久夜| 欧美午夜片在线观看| 成人毛片老司机大片| 韩日精品视频一区| 香港成人在线视频| 亚洲美女偷拍久久| 国产欧美一区二区精品性色| 日韩视频一区二区三区在线播放| 91小视频免费看| 国产99久久精品| 激情综合色综合久久| 日日夜夜免费精品| 亚洲电影第三页| 一卡二卡三卡日韩欧美| 亚洲欧美乱综合| 国产精品拍天天在线| 国产农村妇女毛片精品久久麻豆| 欧美精品一区二区蜜臀亚洲| 91精品视频网| 日韩视频免费观看高清完整版 | 日本不卡123| 91精品国产免费| 日本久久一区二区| 国产福利一区在线| 五月天国产精品| 成人欧美一区二区三区黑人麻豆 | 欧美亚洲综合在线| 国产成人在线色| 久久99精品久久久久久国产越南 | 久久久不卡网国产精品一区| 欧美丝袜第三区| 国产成人av影院| 精品一区二区三区免费播放| 午夜不卡av在线| 亚洲线精品一区二区三区| 中文成人av在线| 精品精品国产高清a毛片牛牛| 7799精品视频| 5566中文字幕一区二区电影| 91久久线看在观草草青青| 国产成人精品一区二区三区四区 | 久久久www免费人成精品| 久久久久国产精品麻豆ai换脸| 在线综合视频播放| 欧美日韩一级二级| 欧美日韩国产小视频| 91福利视频在线| 欧美伊人久久大香线蕉综合69| 宅男在线国产精品| 欧美一级日韩免费不卡| 日韩欧美一级二级三级| 91精品国产综合久久福利软件| 欧美裸体一区二区三区| 欧美曰成人黄网| 欧美一区日本一区韩国一区| 91精品国产综合久久精品图片| 欧美日韩极品在线观看一区| 欧美精品在欧美一区二区少妇| 欧美剧在线免费观看网站| 91精品国产福利在线观看| 日韩欧美亚洲一区二区| 精品电影一区二区三区| 久久久久久麻豆| ●精品国产综合乱码久久久久| 亚洲欧美在线高清| 亚洲一区在线看| 日本中文字幕一区二区视频| 韩国午夜理伦三级不卡影院| 国产一区在线精品| 99热99精品| 欧美日韩aaa| 精品国产欧美一区二区| 国产欧美久久久精品影院| 亚洲裸体xxx| 美国三级日本三级久久99| 极品少妇一区二区| 波多野结衣亚洲| 92精品国产成人观看免费| 欧美不卡一区二区三区| 国产精品入口麻豆九色| 亚洲一区免费视频| 黄页视频在线91| 波多野结衣中文字幕一区二区三区 | 岛国精品在线观看| 在线一区二区三区四区| 欧美国产97人人爽人人喊| 舔着乳尖日韩一区| av不卡在线播放| 日韩午夜在线观看视频| 《视频一区视频二区| 日本亚洲免费观看| 欧美日韩一区二区三区免费看| 精品国产91九色蝌蚪| 亚洲国产成人porn| 成人的网站免费观看| 久久久精品国产99久久精品芒果| 一区二区三区在线观看国产| 激情综合网av| 91.成人天堂一区| 日韩一区欧美一区| 日韩高清电影一区| 91精品国产一区二区人妖| 亚洲欧洲综合另类在线| 国产麻豆精品在线| 欧美一区二区三区视频免费播放 | 国产精品一区2区| 欧美日韩日本视频| 国产精品网站导航| 久久66热re国产| 99久久免费国产| www精品美女久久久tv| 日本va欧美va欧美va精品| 欧洲生活片亚洲生活在线观看|