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

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

?? at1700.c

?? LINUX1.0源代碼,代碼條理清晰
?? C
?? 第 1 頁 / 共 2 頁
字號:


static int net_open(struct device *dev)
{
	struct net_local *lp = (struct net_local *)dev->priv;
	int ioaddr = dev->base_addr;
	int i;

	/* Powerup the chip, initialize config register 1, and select bank 0. */
	outb(0xe0, ioaddr + CONFIG_1);

	/* Set the station address in bank zero. */
	for (i = 0; i < 6; i++)
		outb(dev->dev_addr[i], ioaddr + 8 + i);

	/* Switch to bank 1 and set the multicast table to accept none. */
	outb(0xe4, ioaddr + 7);
	for (i = 0; i < 8; i++)
		outb(0x00, ioaddr + 8 + i);

	/* Set the configuration register 0 to 32K 100ns. byte-wide memory, 16 bit
	   bus access, and two 4K Tx queues. */
	outb(0xda, ioaddr + CONFIG_0);

	/* Same config 0, except enable the Rx and Tx. */
	outb(0x5a, ioaddr + CONFIG_0);
	/* Switch to register bank 2 for the run-time registers. */
	outb(0xe8, ioaddr + CONFIG_1);

	/* Turn on Rx interrupts, leave Tx interrupts off until packet Tx. */
	outb(0x00, ioaddr + TX_INTR);
	outb(0x81, ioaddr + RX_INTR);

	lp->open_time = jiffies;

	dev->tbusy = 0;
	dev->interrupt = 0;
	dev->start = 1;

	return 0;
}

static int
net_send_packet(struct sk_buff *skb, struct device *dev)
{
	struct net_local *lp = (struct net_local *)dev->priv;
	int ioaddr = dev->base_addr;

	if (dev->tbusy) {
		/* If we get here, some higher level has decided we are broken.
		   There should really be a "kick me" function call instead. */
		int tickssofar = jiffies - dev->trans_start;
		if (tickssofar < 10)
			return 1;
		printk("%s: transmit timed out with status %04x, %s?\n", dev->name,
			   inw(ioaddr + STATUS), inb(ioaddr + TX_STATUS) & 0x80
			   ? "IRQ conflict" : "network cable problem");
		printk("%s: timeout registers: %04x %04x %04x %04x %04x %04x %04x %04x.\n",
			   dev->name, inw(ioaddr + 0), inw(ioaddr + 2), inw(ioaddr + 4),
			   inw(ioaddr + 6), inw(ioaddr + 8), inw(ioaddr + 10),
			   inw(ioaddr + 12), inw(ioaddr + 14));
		lp->stats.tx_errors++;
		/* ToDo: We should try to restart the adaptor... */
		outw(0xffff, ioaddr + 24);
		outw(0xffff, ioaddr + TX_STATUS);
		outw(0xe85a, ioaddr + CONFIG_0);
		outw(0x8100, ioaddr + TX_INTR);
		dev->tbusy=0;
		dev->trans_start = jiffies;
	}

	/* If some higher layer thinks we've missed an tx-done interrupt
	   we are passed NULL. Caution: dev_tint() handles the cli()/sti()
	   itself. */
	if (skb == NULL) {
		dev_tint(dev);
		return 0;
	}

	/* For ethernet, fill in the header.  This should really be done by a
	   higher level, rather than duplicated for each ethernet adaptor. */
	if (!skb->arp  &&  dev->rebuild_header(skb->data, dev)) {
		skb->dev = dev;
		arp_queue (skb);
		return 0;
	}
	skb->arp=1;

	/* Block a timer-based transmit from overlapping.  This could better be
	   done with atomic_swap(1, dev->tbusy), but set_bit() works as well. */
	if (set_bit(0, (void*)&dev->tbusy) != 0)
		printk("%s: Transmitter access conflict.\n", dev->name);
	else {
		short length = ETH_ZLEN < skb->len ? skb->len : ETH_ZLEN;
		unsigned char *buf = skb->data;

		/* Turn off the possible Tx interrupts. */
		outb(0x00, ioaddr + TX_INTR);
		
		outw(length, ioaddr + DATAPORT);
		outsw(ioaddr + DATAPORT, buf, (length + 1) >> 1);

		lp->tx_queue++;
		lp->tx_queue_len += length + 2;

		if (lp->tx_started == 0) {
			/* If the Tx is idle, always trigger a transmit. */
			outb(0x80 | lp->tx_queue, ioaddr + TX_START);
			lp->tx_queue = 0;
			lp->tx_queue_len = 0;
			dev->trans_start = jiffies;
			lp->tx_started = 1;
		} else if (lp->tx_queue_len < 4096 - 1502)	/* Room for one more packet? */
			dev->tbusy = 0;

		/* Turn on Tx interrupts back on. */
		outb(0x82, ioaddr + TX_INTR);
	}
	if (skb->free)
		kfree_skb (skb, FREE_WRITE);

	return 0;
}

/* The typical workload of the driver:
   Handle the network interface interrupts. */
static void
net_interrupt(int reg_ptr)
{
	int irq = -(((struct pt_regs *)reg_ptr)->orig_eax+2);
	struct device *dev = (struct device *)(irq2dev_map[irq]);
	struct net_local *lp;
	int ioaddr, status;

	if (dev == NULL) {
		printk ("at1700_interrupt(): irq %d for unknown device.\n", irq);
		return;
	}
	dev->interrupt = 1;

	ioaddr = dev->base_addr;
	lp = (struct net_local *)dev->priv;
	status = inw(ioaddr + TX_STATUS);
	outw(status, ioaddr + TX_STATUS);

	if (net_debug > 4)
		printk("%s: Interrupt with status %04x.\n", dev->name, status);
	if (status & 0xff00
		||  (inb(ioaddr + RX_MODE) & 0x40) == 0) {			/* Got a packet(s). */
		net_rx(dev);
	}
	if (status & 0x00ff) {
		if (status & 0x80) {
			lp->stats.tx_packets++;
			if (lp->tx_queue) {
				outb(0x80 | lp->tx_queue, ioaddr + TX_START);
				lp->tx_queue = 0;
				lp->tx_queue_len = 0;
				dev->trans_start = jiffies;
				dev->tbusy = 0;
				mark_bh(INET_BH);	/* Inform upper layers. */
			} else {
				lp->tx_started = 0;
				/* Turn on Tx interrupts off. */
				outb(0x00, ioaddr + TX_INTR);
				dev->tbusy = 0;
			}
		}
	}

	return;
}

/* We have a good packet(s), get it/them out of the buffers. */
static void
net_rx(struct device *dev)
{
	struct net_local *lp = (struct net_local *)dev->priv;
	int ioaddr = dev->base_addr;
	int boguscount = 5;

	while ((inb(ioaddr + RX_MODE) & 0x40) == 0) {
		ushort status = inw(ioaddr + DATAPORT);

		if (net_debug > 4)
			printk("%s: Rxing packet mode %02x status %04x.\n",
				   dev->name, inb(ioaddr + RX_MODE), status);
#ifndef final_version
		if (status == 0) {
			outb(0x05, ioaddr + 14);
			break;
		}
#endif

		if ((status & 0xF0) != 0x20) {	/* There was an error. */
			lp->stats.rx_errors++;
			if (status & 0x08) lp->stats.rx_length_errors++;
			if (status & 0x04) lp->stats.rx_frame_errors++;
			if (status & 0x02) lp->stats.rx_crc_errors++;
			if (status & 0x01) lp->stats.rx_over_errors++;
		} else {
			ushort pkt_len = inw(ioaddr + DATAPORT);
			/* Malloc up new buffer. */
			int sksize = sizeof(struct sk_buff) + pkt_len;
			struct sk_buff *skb;

			if (pkt_len > 1550) {
				printk("%s: The AT1700 claimed a very large packet, size %d.\n",
					   dev->name, pkt_len);
				outb(0x05, ioaddr + 14);
				lp->stats.rx_errors++;
				break;
			}
			skb = alloc_skb(sksize, GFP_ATOMIC);
			if (skb == NULL) {
				printk("%s: Memory squeeze, dropping packet (len %d).\n",
					   dev->name, pkt_len);
				outb(0x05, ioaddr + 14);
				lp->stats.rx_dropped++;
				break;
			}
			skb->mem_len = sksize;
			skb->mem_addr = skb;
			skb->len = pkt_len;
			skb->dev = dev;

			insw(ioaddr + DATAPORT, skb->data, (pkt_len + 1) >> 1);

			if (net_debug > 5) {
				int i;
				printk("%s: Rxed packet of length %d: ", dev->name, pkt_len);
				for (i = 0; i < 14; i++)
					printk(" %02x", skb->data[i]);
				printk(".\n");
			}

#ifdef HAVE_NETIF_RX
			netif_rx(skb);
#else
			skb->lock = 0;
			if (dev_rint((unsigned char*)skb, pkt_len, IN_SKBUFF, dev) != 0) {
				kfree_s(skb, sksize);
				lp->stats.rx_dropped++;
				break;
			}
#endif
			lp->stats.rx_packets++;
		}
		if (--boguscount <= 0)
			break;
	}

	/* If any worth-while packets have been received, dev_rint()
	   has done a mark_bh(INET_BH) for us and will work on them
	   when we get to the bottom-half routine. */
	{
		int i;
		for (i = 0; i < 20; i++) {
			if ((inb(ioaddr + RX_MODE) & 0x40) == 0x40)
				break;
			outb(0x05, ioaddr + 14);
		}

		if (net_debug > 5)
			printk("%s: Exint Rx packet with mode %02x after %d ticks.\n", 
				   dev->name, inb(ioaddr + RX_MODE), i);
	}
	return;
}

/* The inverse routine to net_open(). */
static int net_close(struct device *dev)
{
	struct net_local *lp = (struct net_local *)dev->priv;
	int ioaddr = dev->base_addr;

	lp->open_time = 0;

	dev->tbusy = 1;
	dev->start = 0;

	/* Set configuration register 0 to disable Tx and Rx. */
	outb(0xda, ioaddr + CONFIG_0);

	/* Update the statistics -- ToDo. */

	/* Power-down the chip.  Green, green, green! */
	outb(0x00, ioaddr + CONFIG_1);

	return 0;
}

/* Get the current statistics.	This may be called with the card open or
   closed. */
static struct enet_statistics *
net_get_stats(struct device *dev)
{
	struct net_local *lp = (struct net_local *)dev->priv;

	cli();
	/* ToDo: Update the statistics from the device registers. */
	sti();

	return &lp->stats;
}

#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 void
set_multicast_list(struct device *dev, int num_addrs, void *addrs)
{
	short ioaddr = dev->base_addr;
	if (num_addrs) {
		outw(3, ioaddr + RX_MODE);	/* Enable promiscuous mode */
	} else
		outw(2, ioaddr + RX_MODE);	/* Disable promiscuous, use normal mode */
}
#endif

/*
 * Local variables:
 *  compile-command: "gcc -D__KERNEL__ -I/usr/src/linux/net/inet -Wall -Wstrict-prototypes -O6 -m486 -c at1700.c"
 *  version-control: t
 *  kept-new-versions: 5
 *  tab-width: 4
 * End:
 */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产成a人无v码亚洲福利| 成人午夜视频免费看| 欧美aaaaa成人免费观看视频| 亚洲综合成人在线视频| 亚洲柠檬福利资源导航| 欧美国产日产图区| 亚洲免费观看视频| 亚洲制服丝袜av| 日本视频在线一区| 国产一区二区三区精品视频| 国产成人亚洲综合a∨婷婷 | 亚洲国产视频一区| 国产91高潮流白浆在线麻豆 | eeuss鲁片一区二区三区在线观看 eeuss鲁片一区二区三区在线看 | 国产在线精品一区二区不卡了| 国产高清久久久久| 国产高清精品在线| 欧美一区二区在线观看| 欧美日韩国产综合一区二区三区| 欧美videofree性高清杂交| 专区另类欧美日韩| 高清av一区二区| 欧美年轻男男videosbes| 国产精品高潮呻吟| 蜜臀精品久久久久久蜜臀 | 久99久精品视频免费观看| 国产东北露脸精品视频| 欧美亚洲国产一区二区三区va| 欧美一级二级三级蜜桃| 中文子幕无线码一区tr| www.日韩av| 久久天天做天天爱综合色| 亚洲精品在线免费观看视频| 日韩免费电影一区| 中文字幕五月欧美| 高清在线成人网| 国产精品全国免费观看高清 | 一本一本久久a久久精品综合麻豆| www国产成人| 国产在线精品一区二区三区不卡| 51精品久久久久久久蜜臀| 日韩av电影天堂| 欧美一区国产二区| 韩国v欧美v日本v亚洲v| 日本一区二区三区四区| 欧美高清dvd| 久久综合精品国产一区二区三区| 亚洲三级在线播放| 国产精品亚洲综合一区在线观看| 日韩一区国产二区欧美三区| 亚洲午夜久久久久| 在线这里只有精品| 日韩精品欧美精品| 亚洲免费观看在线观看| 在线观看日韩av先锋影音电影院| 亚洲午夜激情网站| 欧美日韩久久久| 看国产成人h片视频| 精品国产sm最大网站| 国产91精品欧美| 亚洲一区二区三区美女| 亚洲精品一区二区三区福利| 色综合久久88色综合天天免费| 日韩不卡一区二区三区| 亚洲天堂精品在线观看| 欧美一区二区三区的| 国模冰冰炮一区二区| 亚洲丝袜精品丝袜在线| 日韩欧美色电影| 日本高清不卡视频| 国产精品一区三区| 蜜臀国产一区二区三区在线播放| 一区二区三区在线播放| 国产精品视频在线看| 26uuu成人网一区二区三区| 欧美色电影在线| 成人性生交大片免费看视频在线 | 亚洲一区二区四区蜜桃| 亚洲人成网站在线| 亚洲国产精品精华液ab| 久久一二三国产| 久久综合久久综合九色| 精品少妇一区二区三区视频免付费| 制服丝袜一区二区三区| 在线观看三级视频欧美| 91美女蜜桃在线| 在线亚洲欧美专区二区| aaa欧美色吧激情视频| 国内久久精品视频| 国产精品亚洲第一| 99久久精品免费看| 色诱视频网站一区| 6080午夜不卡| 国产精品国产三级国产aⅴ入口| 亚洲久本草在线中文字幕| 久久九九久久九九| 国产精品国产三级国产| 亚洲精品欧美激情| 青草av.久久免费一区| 国产精品一级片在线观看| jvid福利写真一区二区三区| 欧美三级视频在线播放| 欧美tickling挠脚心丨vk| 亚洲综合激情小说| 激情成人午夜视频| 99国产欧美久久久精品| 欧美精品电影在线播放| 久久你懂得1024| 午夜久久电影网| 成人欧美一区二区三区| 亚洲一区二区在线视频| 福利一区福利二区| 日韩视频中午一区| 同产精品九九九| 色综合久久久久久久久久久| 久久午夜电影网| 午夜精品成人在线视频| 成人av在线影院| 日韩一区二区在线看| 亚洲精品自拍动漫在线| 成人性生交大合| 国产精品不卡一区| 成人手机在线视频| 亚洲国产精品t66y| 日本二三区不卡| 国产精品午夜在线| 99久久99久久精品免费看蜜桃| 久久久久99精品国产片| 国产精品伊人色| 国产精品看片你懂得 | 91黄色免费版| 视频一区视频二区中文| 成人黄色片在线观看| 国产精品国产三级国产有无不卡 | 在线观看日韩国产| 亚洲成va人在线观看| 欧美老肥妇做.爰bbww视频| 日日摸夜夜添夜夜添亚洲女人| 国产成人免费视频一区| 欧美国产一区二区在线观看 | 欧美妇女性影城| 久久精品国产77777蜜臀| 日韩免费看的电影| 色综合天天在线| 五月天激情综合网| 国产日产欧产精品推荐色| 色婷婷香蕉在线一区二区| 青青国产91久久久久久| 国产精品久久一卡二卡| 欧美日韩精品一区视频| 九色综合国产一区二区三区| 2023国产精品| 欧美在线看片a免费观看| 日韩国产一二三区| 国产免费久久精品| 欧美一区二区三区男人的天堂| 日本乱人伦aⅴ精品| 国产精品66部| 美女在线一区二区| 午夜视频在线观看一区二区| 中文字幕乱码亚洲精品一区| 欧美一区二区三区在线| 99精品欧美一区二区蜜桃免费| 日韩中文字幕一区二区三区| 亚洲色欲色欲www| 欧美激情一区不卡| 欧美激情一区二区三区四区| 欧美大片拔萝卜| 欧美精品丝袜中出| 欧美视频三区在线播放| 欧美日韩在线播| 欧美日本在线播放| 欧美福利视频一区| 日韩一区国产二区欧美三区| 欧美羞羞免费网站| 在线亚洲人成电影网站色www| 国产成人免费av在线| 国产精品99久久久久久有的能看| 理论电影国产精品| 美女视频黄 久久| 国产一区二区三区| 成人蜜臀av电影| 欧洲国内综合视频| 精品日韩在线观看| 久久欧美一区二区| 18欧美亚洲精品| 日韩激情视频网站| 懂色av一区二区三区免费观看 | 日韩视频在线一区二区| 国产视频在线观看一区二区三区| 国产嫩草影院久久久久| 一区二区三区在线看| 午夜电影网一区| 国产毛片精品一区| 色婷婷综合视频在线观看| 欧美高清视频不卡网| 日韩免费高清电影| 最新不卡av在线| 精品一区二区三区视频在线观看| 99re在线精品|