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

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

?? r8180_pci_init.c

?? linux 下的 PCI-RLT8180 driver module
?? C
字號:
/* r8180_pci_init.c: Part of Linux wireless lan driver for RTL8180. *//*        Written 2002-2003 by ShuChen.        This software may be used and distributed according to the terms of        the GNU General Public License (GPL), incorporated herein by reference.        Drivers based on or derived from this code fall under the GPL and must        retain the authorship, copyright and license notice.  This file is not        a complete program and may only be used when the entire operating        system is licensed under the GPL.        The original author may be reached as shuchen@realtek.com.tw 		Versions:		1.0 - first release		1.1 - second release		1.2 - 2003-06-10*/#include <linux/module.h>#include <linux/kernel.h>#include <linux/config.h>#include <linux/init.h>#include <linux/ioport.h>#include <linux/sched.h>#include <linux/types.h>#include <linux/slab.h>#include <linux/netdevice.h>#include <linux/pci.h>#include <linux/etherdevice.h>#include <linux/delay.h>#include <linux/rtnetlink.h>	//for rtnl_lock()#include <linux/wireless.h>#include <linux/timer.h>#include <linux/proc_fs.h>	// Necessary because we use the proc fs#include <asm/io.h>#include "r8180_type.h"#include "r8180_pci_init.h"#include "r8180_if.h"#define RTL8180_DRIVER_DATE "2003-11-24"#define RTL8180_MODULE_NAME "RTL8180"#define RTL8180_DRIVER_NAME "RTL8180 Wireless Lan Driver " RTL8180_DRIVER_DATE//----------------------------------------------------------------------------------------// Driver name//----------------------------------------------------------------------------------------char rtl8180_driver_name[] = "rtl8180";//----------------------------------------------------------------------------------------// PCI Device_ID table//----------------------------------------------------------------------------------------static struct pci_device_id rtl8180_pci_id_tbl[] = {	{ 0x10EC, 0x8180 /*0x8139*/, PCI_ANY_ID, PCI_ANY_ID, 0, 0, 0 },	{0,},};//----------------------------------------------------------------------------------------// rtl8180 probe function *///----------------------------------------------------------------------------------------static int __devinit rtl8180_pci_probe(struct pci_dev *pdev, const struct pci_device_id *id);static void __devexit rtl8180_pci_remove(struct pci_dev *pdev);//----------------------------------------------------------------------------------------// PCI_driver table//----------------------------------------------------------------------------------------static struct pci_driver rtl8180_pci_driver = {	name:		"rtl8180",		/* Driver name */	id_table:	rtl8180_pci_id_tbl,	/* PCI_ID table */	probe:		rtl8180_pci_probe,	/* probe function */	remove:		rtl8180_pci_remove,	/* remove function */	suspend:	NULL,			/* suspend function */	resume:		NULL,			/* resume function */};MODULE_LICENSE("GPL");MODULE_DEVICE_TABLE(pci, rtl8180_pci_id_tbl);/***************************************************************************************************************************************************************************************/static int __devinit rtl8180_pci_probe(struct pci_dev *pdev, const struct pci_device_id *id){	unsigned long ioaddr = 0;	struct net_device *dev = NULL;	struct rtl8180_priv *priv = NULL;#ifdef RTL_IO_MAP	unsigned long pio_start, pio_len, pio_flags;#else	unsigned long pmem_start, pmem_len, pmem_flags;#endif //end #ifdef RTL_IO_MAP	//-----------------------------------------------------------------------------	// PCI Enable device	//-----------------------------------------------------------------------------	if( pci_enable_device (pdev) ){		DPRINTK_OUTINFO("pci_enable_device() failed!\n");		return -EIO;	}	//-----------------------------------------------------------------------------	// Enable PCI bus-mastering	//-----------------------------------------------------------------------------	pci_set_master(pdev);	//-----------------------------------------------------------------------------	// Enable net_device	//	(1)Allocate net_device and rtl8180 private area.	//	(2)Initialize net_device	//	(3)Register net_device	//-----------------------------------------------------------------------------	dev = rtl_alloc_wlandev( dev, sizeof(struct rtl8180_priv));	if( dev == NULL ){		DPRINTK_OUTINFO("Initialize net_device failed!\n");		goto fail;	}	SET_MODULE_OWNER(dev);	//-----------------------------------------------------------------------------	// Set private driver data pointer(dev) for a pci_dev	//-----------------------------------------------------------------------------	pci_set_drvdata(pdev, dev);	//	pdev->driver_data = data;	//-----------------------------------------------------------------------------	// PCI resources: including PCI configuration space and IRQ number.	//-----------------------------------------------------------------------------#ifdef RTL_IO_MAP	pio_start = (unsigned long)pci_resource_start (pdev, 0);	pio_len = (unsigned long)pci_resource_len (pdev, 0);	pio_flags = (unsigned long)pci_resource_flags (pdev, 0);	if (!(pio_flags & IORESOURCE_IO)) {		DPRINTK_OUTINFO("%s: region #0 not a PIO resource, aborting\n", pdev->slot_name);		goto fail;	}	else{		DPRINTK_OUTINFO("%s: region #0 IS a PIO resource!\n", pdev->slot_name);	}	DPRINTK_OUTINFO("request_region(0x%08lx,0x%08lx) !\n", pio_start,pio_len );	if( ! request_region( pio_start, pio_len, rtl8180_driver_name ) ){		DPRINTK_OUTINFO("request_region failed!\n");		goto fail;	}	ioaddr = pio_start;	dev->base_addr = ioaddr; // device I/O address#else	pmem_start = pci_resource_start(pdev, 1);	pmem_len = pci_resource_len(pdev, 1);	pmem_flags = pci_resource_flags (pdev, 1);	if (!(pmem_flags & IORESOURCE_MEM)) {		DPRINTK_OUTINFO("%s: region #1 not a MMIO resource, aborting\n", pdev->slot_name);		goto fail;	}	else{		DPRINTK_OUTINFO("%s: region #0 IS a MMIO resource!\n", pdev->slot_name);	}	DPRINTK_OUTINFO("request_mem_region(0x%08lx,0x%08lx) !\n", pmem_start,pmem_len );	if( ! request_mem_region( pmem_start, pmem_len, rtl8180_driver_name ) ) {		DPRINTK_OUTINFO("request_mem_region failed!\n");		goto fail;	}	DPRINTK_OUTINFO("ioremap(0x%08lx,0x%08lx) !\n", pmem_start, pmem_len );	ioaddr = (unsigned long)ioremap( pmem_start, pmem_len);	//in prism2 pio_len=1K	if( ioaddr == (unsigned long)NULL ){		DPRINTK_OUTINFO("ioremap failed!  release_mem_region(0x%08lx,0x%08lx)\n", pmem_start, pmem_len);	        release_mem_region( pmem_start, pmem_len );		goto fail;	}	dev->mem_start = ioaddr; // shared mem start	dev->mem_end = ioaddr + pci_resource_len(pdev, 0); // shared mem end#endif //end #ifdef RTL_IO_MAP	//-----------------------------------------------------------------------------	// Set fields in net_device	//-----------------------------------------------------------------------------    dev->irq = pdev->irq;	// callbacks //	dev->open = rtl8180_open;	dev->stop = rtl8180_close;	dev->hard_start_xmit = rtl8180_xmit;	dev->get_stats = rtl8180_get_stats;	//dev->get_wireless_stats = rtl8180_get_wireless_stats;	dev->do_ioctl = rtl8180_ioctl;	dev->set_multicast_list = rtl8180_set_multicast_list;		//dev->change_mtu = rtl8180_change_mtu;	//dev->tx_timeout = rtl8180_tx_timeout;	//dev->watchdog_timeo = TX_TIMEOUT;	priv = dev->priv;	strcpy(priv->name,"rtl8180_pci_driver");	//priv->pdev = pdev;	priv->ioaddr = ioaddr;	//-----------------------------------------------------------------------------	// Disable Debugging message on PC.	//-----------------------------------------------------------------------------	wlan_debug = RTL_DDEBUG_NONE;	//-----------------------------------------------------------------------------	// Wireless Lan MAC initialization (Rx, Tx, Mlme) 	//-----------------------------------------------------------------------------	rtl8180_init( dev );	//-----------------------------------------------------------------------------	// Register IRQ handler in rtl8180_init() in r8180_if.c	//-----------------------------------------------------------------------------		//-----------------------------------------------------------------------------	// Register the net device once everything initializes.	//-----------------------------------------------------------------------------	rtl_register_netdev(dev);	//-----------------------------------------------------------------------------	// Print card information, io-memory address and irq number.	//-----------------------------------------------------------------------------	DPRINTK_OUTINFO("wlan driver loaded. ioaddr=0x%lx, irq=%d, MAC_addr=%x:%x:%x:%x:%x:%x\n",						ioaddr, dev->irq,						dev->dev_addr[0], dev->dev_addr[1], dev->dev_addr[2],						dev->dev_addr[3], dev->dev_addr[4], dev->dev_addr[5]  );	return 0;	// return if rtl8180_pci_probe succeed!//-----------------------------------------------------------------------------fail:	if(dev){		//-----------------------------------------------------------------------------		// Free resources: PCI configuration space and IRQ <in rtl8180_remove() in r8180_if.c>.		//-----------------------------------------------------------------------------#ifdef RTL_IO_MAP		if( dev->base_addr != 0 ){			DPRINTK_OUTINFO("release_region(0x%08lx,0x%08lx) !\n", dev->base_addr, pci_resource_len(pdev, 0) );			release_region( dev->base_addr, pci_resource_len(pdev, 0) );		}#else		if( dev->mem_start != (unsigned long)NULL ){	        	iounmap( (void *)dev->mem_start );			DPRINTK_OUTINFO("release_region(0x%08lx,0x%08lx) !\n", pci_resource_start(pdev, 1), pci_resource_len(pdev, 1) );        		release_mem_region( pci_resource_start(pdev, 1), pci_resource_len(pdev, 1) );		}#endif //end #ifdef RTL_IO_MAP		rtl_unregister_netdev(dev);		//-----------------------------------------------------------------------------		// Free net_device and rtl8180 private area		//-----------------------------------------------------------------------------		kfree(dev);	}	DPRINTK_OUTINFO("wlan driver load failed\n");	return -ENOMEM;}//end of rtl8180_pci_probe()/***************************************************************************************************************************************************************************************/static void __devexit rtl8180_pci_remove(struct pci_dev *pdev){	//-----------------------------------------------------------------------------	// Return private driver data pointer(dev) for a pci_dev	//-----------------------------------------------------------------------------	struct net_device *dev = pci_get_drvdata(pdev);         	assert( dev != NULL );    assert( priv != NULL );	//-----------------------------------------------------------------------------	// Unregister the net device.	//-----------------------------------------------------------------------------	rtl_unregister_netdev(dev);	//-----------------------------------------------------------------------------	// disable rtl8180_hw_interrupt, free rtl8180 memory	//-----------------------------------------------------------------------------	rtl8180_remove( dev );#ifdef RTL_IO_MAP	if( dev->base_addr != 0 ){		DPRINTK_OUTINFO("release_region(0x%08lx,0x%08lx) !\n", dev->base_addr, pci_resource_len(pdev, 0) );		release_region( dev->base_addr, pci_resource_len(pdev, 0) );	}#else	if( dev->mem_start != (unsigned long)NULL ){		iounmap( (void *)dev->mem_start );		DPRINTK_OUTINFO("release_region(0x%08lx,0x%08lx) !\n", pci_resource_start(pdev, 1), pci_resource_len(pdev, 1) );		release_mem_region( pci_resource_start(pdev, 1), pci_resource_len(pdev, 1) );	}#endif //end #ifdef RTL_IO_MAP	//-----------------------------------------------------------------------------	// Free resources: IRQ <in rtl8180_remove() in r8180_if.c>	//-----------------------------------------------------------------------------	//-----------------------------------------------------------------------------	// Free net_device and rtl8180 private area	//-----------------------------------------------------------------------------	kfree(dev);	DPRINTK_OUTINFO("wlan driver removed\n");	//-----------------------------------------------------------------------------	// PCI Disable device	//-----------------------------------------------------------------------------//	pci_disable_device(pdev);}/***************************************************************************************************************************************************************************************/static int __init rtl8180_pci_module_init(void){	printk(KERN_INFO "\n\n******** "RTL8180_DRIVER_NAME " loaded********\n");	if (pci_register_driver(&rtl8180_pci_driver) <= 0) {		printk("rtl8180: No devices found, " RTL8180_DRIVER_NAME " unregistered\n");		pci_unregister_driver (&rtl8180_pci_driver);		return -ENODEV;	}	return 0;}/***************************************************************************************************************************************************************************************/static void __exit rtl8180_pci_module_exit(void){	pci_unregister_driver (&rtl8180_pci_driver);	printk(KERN_INFO "******** "RTL8180_DRIVER_NAME " removed ********\n\n");}/***************************************************************************************************************************************************************************************/module_init(rtl8180_pci_module_init);module_exit(rtl8180_pci_module_exit);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91亚洲国产成人精品一区二区三| 蜜臀av性久久久久蜜臀aⅴ| 成人白浆超碰人人人人| 美美哒免费高清在线观看视频一区二区 | 成人欧美一区二区三区白人| 亚洲综合区在线| 成人午夜在线免费| 欧美xxxx在线观看| 爽爽淫人综合网网站| 97久久精品人人做人人爽| 久久综合九色综合97婷婷女人 | 成人精品电影在线观看| 欧美一卡2卡3卡4卡| 亚洲一区二区在线观看视频| 9i在线看片成人免费| 国产欧美一区二区精品性色| 麻豆极品一区二区三区| 欧美在线色视频| 综合久久久久久| 成人精品视频一区二区三区尤物| 日韩一级片在线播放| 丝袜亚洲另类欧美| 欧美三级电影在线看| 亚洲精品成人少妇| 91美女精品福利| 亚洲人午夜精品天堂一二香蕉| 国产成人精品影院| 国产欧美精品一区| 国产不卡免费视频| 亚洲国产精品成人综合| 国产suv精品一区二区6| 久久精品人人做人人综合| 国产精品1024| 国产精品污www在线观看| 粉嫩av一区二区三区粉嫩 | 欧美精品免费视频| 午夜久久电影网| 欧美一区二区三区免费在线看| 午夜激情久久久| 日韩欧美一区二区不卡| 激情成人综合网| 国产欧美日韩在线看| 99天天综合性| 夜夜嗨av一区二区三区网页| 欧美日韩一区二区三区免费看| 亚洲成人一区在线| 欧美一区二区日韩| 国产精品一区二区在线播放| 亚洲国产精品成人综合| 色综合视频一区二区三区高清| 亚洲狼人国产精品| 91精品国产综合久久久蜜臀粉嫩| 日本欧美在线看| 国产欧美一区二区精品秋霞影院| av成人免费在线| 亚洲v精品v日韩v欧美v专区| 精品三级av在线| kk眼镜猥琐国模调教系列一区二区| 亚洲丝袜另类动漫二区| 精品视频在线免费看| 精品无码三级在线观看视频| 国产精品久99| 欧美一区二区三区日韩| 成人精品视频一区二区三区 | 精品国产乱子伦一区| 成人短视频下载| 午夜av区久久| 欧美高清一级片在线观看| 国产精品三级av| 在线播放中文一区| 国产精品18久久久久久久久久久久| 国产精品国产三级国产aⅴ中文| 欧美视频三区在线播放| 久久精工是国产品牌吗| 亚洲女性喷水在线观看一区| 欧美一区二区三区日韩| 91视频免费播放| 国产在线观看免费一区| 午夜精品久久久久| 国产精品人人做人人爽人人添| 欧美日韩一区二区三区高清| www.亚洲免费av| 久久精品国产第一区二区三区| 综合亚洲深深色噜噜狠狠网站| 欧美三级日韩在线| av一二三不卡影片| 国产一区二区美女诱惑| 亚洲一区在线观看网站| 欧美国产1区2区| 精品99999| 884aa四虎影成人精品一区| 色综合久久88色综合天天免费| 国产一区二区三区精品欧美日韩一区二区三区 | 免费的国产精品| 一区二区三区精品在线| 国产精品午夜电影| 精品粉嫩超白一线天av| 欧洲av一区二区嗯嗯嗯啊| eeuss鲁片一区二区三区在线观看| 日韩国产高清在线| 午夜视频在线观看一区| 亚洲精品日韩综合观看成人91| 久久免费视频一区| 精品国产一区二区三区不卡 | 久久激情综合网| 青青草成人在线观看| 亚洲国产wwwccc36天堂| 亚洲色图欧美在线| 国产精品成人一区二区三区夜夜夜| 日韩免费观看高清完整版| 日韩一区和二区| 日韩欧美www| 2020国产精品自拍| 欧美xxxx在线观看| 精品欧美乱码久久久久久| 日韩一级欧美一级| 日韩精品在线网站| 精品久久人人做人人爰| 欧美成人精品1314www| 精品国产欧美一区二区| 国产丝袜欧美中文另类| 国产欧美一区二区精品忘忧草| 久久久电影一区二区三区| 国产精品女主播av| 亚洲女厕所小便bbb| 亚洲综合av网| 午夜精品久久久久久久99樱桃| 日韩精品欧美成人高清一区二区| 午夜欧美一区二区三区在线播放| 亚洲国产精品一区二区久久恐怖片 | 欧美大度的电影原声| 亚洲精品一区二区三区香蕉 | 日本道在线观看一区二区| 欧美日韩中文字幕一区二区| 欧美视频一区在线| 日韩欧美一区在线| 亚洲国产电影在线观看| 一区二区三区不卡在线观看 | 在线观看日韩高清av| 91精品国产91综合久久蜜臀| 久久久久久电影| 亚洲老妇xxxxxx| 久久99在线观看| 9色porny自拍视频一区二区| 欧美男人的天堂一二区| 国产欧美精品一区| 偷拍日韩校园综合在线| 国产成人免费av在线| 色视频一区二区| 欧美精品一区二区三区蜜臀| 亚洲免费资源在线播放| 日本系列欧美系列| www.色综合.com| 777色狠狠一区二区三区| 国产欧美精品一区二区色综合| 亚洲成av人片在线| 成人国产视频在线观看| 精品国产污污免费网站入口| 亚洲高清免费观看 | 99在线精品视频| 欧美片在线播放| 国产精品乱码一区二区三区软件 | 久久成人免费日本黄色| 一本到不卡免费一区二区| 精品1区2区在线观看| 亚洲一区二区三区美女| 成人高清视频免费观看| 日韩欧美亚洲一区二区| 亚洲最大成人综合| 不卡的av电影| 日韩精品一区二区三区四区视频| 一区二区三区丝袜| 成人精品在线视频观看| 26uuu欧美| 免费观看在线综合| 欧美女孩性生活视频| 亚洲精品国产视频| 成人亚洲精品久久久久软件| 日韩午夜电影在线观看| 亚洲精品国久久99热| 日韩欧美高清dvd碟片| 亚洲综合丁香婷婷六月香| 国产jizzjizz一区二区| 精品免费视频一区二区| 日日摸夜夜添夜夜添亚洲女人| 日本韩国欧美在线| 国产精品久久久久久一区二区三区 | 久久99深爱久久99精品| 91麻豆精品久久久久蜜臀| 亚洲午夜私人影院| 色域天天综合网| 国产精品成人网| 成人小视频免费在线观看| 亚洲品质自拍视频| 99久久久无码国产精品| 国产精品剧情在线亚洲| 97久久超碰国产精品| 最新不卡av在线| 不卡一区二区三区四区| 成人欧美一区二区三区黑人麻豆 |