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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? hostap_plx.c

?? linux-2.6.15.6
?? C
?? 第 1 頁 / 共 2 頁
字號:
		mdelay(10);	}}static struct prism2_helper_functions prism2_plx_funcs ={	.card_present	= NULL,	.cor_sreset	= prism2_plx_cor_sreset,	.genesis_reset	= prism2_plx_genesis_reset,	.hw_type	= HOSTAP_HW_PLX,};static int prism2_plx_check_cis(void __iomem *attr_mem, int attr_len,				unsigned int *cor_offset,				unsigned int *cor_index){#define CISTPL_CONFIG 0x1A#define CISTPL_MANFID 0x20#define CISTPL_END 0xFF#define CIS_MAX_LEN 256	u8 *cis;	int i, pos;	unsigned int rmsz, rasz, manfid1, manfid2;	struct prism2_plx_manfid *manfid;	cis = kmalloc(CIS_MAX_LEN, GFP_KERNEL);	if (cis == NULL)		return -ENOMEM;	/* read CIS; it is in even offsets in the beginning of attr_mem */	for (i = 0; i < CIS_MAX_LEN; i++)		cis[i] = readb(attr_mem + 2 * i);	printk(KERN_DEBUG "%s: CIS: %02x %02x %02x %02x %02x %02x ...\n",	       dev_info, cis[0], cis[1], cis[2], cis[3], cis[4], cis[5]);	/* set reasonable defaults for Prism2 cards just in case CIS parsing	 * fails */	*cor_offset = 0x3e0;	*cor_index = 0x01;	manfid1 = manfid2 = 0;	pos = 0;	while (pos < CIS_MAX_LEN - 1 && cis[pos] != CISTPL_END) {		if (pos + cis[pos + 1] >= CIS_MAX_LEN)			goto cis_error;		switch (cis[pos]) {		case CISTPL_CONFIG:			if (cis[pos + 1] < 1)				goto cis_error;			rmsz = (cis[pos + 2] & 0x3c) >> 2;			rasz = cis[pos + 2] & 0x03;			if (4 + rasz + rmsz > cis[pos + 1])				goto cis_error;			*cor_index = cis[pos + 3] & 0x3F;			*cor_offset = 0;			for (i = 0; i <= rasz; i++)				*cor_offset += cis[pos + 4 + i] << (8 * i);			printk(KERN_DEBUG "%s: cor_index=0x%x "			       "cor_offset=0x%x\n", dev_info,			       *cor_index, *cor_offset);			if (*cor_offset > attr_len) {				printk(KERN_ERR "%s: COR offset not within "				       "attr_mem\n", dev_info);				kfree(cis);				return -1;			}			break;		case CISTPL_MANFID:			if (cis[pos + 1] < 4)				goto cis_error;			manfid1 = cis[pos + 2] + (cis[pos + 3] << 8);			manfid2 = cis[pos + 4] + (cis[pos + 5] << 8);			printk(KERN_DEBUG "%s: manfid=0x%04x, 0x%04x\n",			       dev_info, manfid1, manfid2);			break;		}		pos += cis[pos + 1] + 2;	}	if (pos >= CIS_MAX_LEN || cis[pos] != CISTPL_END)		goto cis_error;	for (manfid = prism2_plx_known_manfids; manfid->manfid1 != 0; manfid++)		if (manfid1 == manfid->manfid1 && manfid2 == manfid->manfid2) {			kfree(cis);			return 0;		}	printk(KERN_INFO "%s: unknown manfid 0x%04x, 0x%04x - assuming this is"	       " not supported card\n", dev_info, manfid1, manfid2);	goto fail; cis_error:	printk(KERN_WARNING "%s: invalid CIS data\n", dev_info); fail:	kfree(cis);	if (ignore_cis) {		printk(KERN_INFO "%s: ignore_cis parameter set - ignoring "		       "errors during CIS verification\n", dev_info);		return 0;	}	return -1;}static int prism2_plx_probe(struct pci_dev *pdev,			    const struct pci_device_id *id){	unsigned int pccard_ioaddr, plx_ioaddr;	unsigned long pccard_attr_mem;	unsigned int pccard_attr_len;	void __iomem *attr_mem = NULL;	unsigned int cor_offset, cor_index;	u32 reg;	local_info_t *local = NULL;	struct net_device *dev = NULL;	struct hostap_interface *iface;	static int cards_found /* = 0 */;	int irq_registered = 0;	int tmd7160;	struct hostap_plx_priv *hw_priv;	hw_priv = kmalloc(sizeof(*hw_priv), GFP_KERNEL);	if (hw_priv == NULL)		return -ENOMEM;	memset(hw_priv, 0, sizeof(*hw_priv));	if (pci_enable_device(pdev))		return -EIO;	/* National Datacomm NCP130 based on TMD7160, not PLX9052. */	tmd7160 = (pdev->vendor == 0x15e8) && (pdev->device == 0x0131);	plx_ioaddr = pci_resource_start(pdev, 1);	pccard_ioaddr = pci_resource_start(pdev, tmd7160 ? 2 : 3);	if (tmd7160) {		/* TMD7160 */		attr_mem = NULL; /* no access to PC Card attribute memory */		printk(KERN_INFO "TMD7160 PCI/PCMCIA adapter: io=0x%x, "		       "irq=%d, pccard_io=0x%x\n",		       plx_ioaddr, pdev->irq, pccard_ioaddr);		cor_offset = plx_ioaddr;		cor_index = 0x04;		outb(cor_index | COR_LEVLREQ | COR_ENABLE_FUNC, plx_ioaddr);		mdelay(1);		reg = inb(plx_ioaddr);		if (reg != (cor_index | COR_LEVLREQ | COR_ENABLE_FUNC)) {			printk(KERN_ERR "%s: Error setting COR (expected="			       "0x%02x, was=0x%02x)\n", dev_info,			       cor_index | COR_LEVLREQ | COR_ENABLE_FUNC, reg);			goto fail;		}	} else {		/* PLX9052 */		pccard_attr_mem = pci_resource_start(pdev, 2);		pccard_attr_len = pci_resource_len(pdev, 2);		if (pccard_attr_len < PLX_MIN_ATTR_LEN)			goto fail;		attr_mem = ioremap(pccard_attr_mem, pccard_attr_len);		if (attr_mem == NULL) {			printk(KERN_ERR "%s: cannot remap attr_mem\n",			       dev_info);			goto fail;		}		printk(KERN_INFO "PLX9052 PCI/PCMCIA adapter: "		       "mem=0x%lx, plx_io=0x%x, irq=%d, pccard_io=0x%x\n",		       pccard_attr_mem, plx_ioaddr, pdev->irq, pccard_ioaddr);		if (prism2_plx_check_cis(attr_mem, pccard_attr_len,					 &cor_offset, &cor_index)) {			printk(KERN_INFO "Unknown PC Card CIS - not a "			       "Prism2/2.5 card?\n");			goto fail;		}		printk(KERN_DEBUG "Prism2/2.5 PC Card detected in PLX9052 "		       "adapter\n");		/* Write COR to enable PC Card */		writeb(cor_index | COR_LEVLREQ | COR_ENABLE_FUNC,		       attr_mem + cor_offset);		/* Enable PCI interrupts if they are not already enabled */		reg = inl(plx_ioaddr + PLX_INTCSR);		printk(KERN_DEBUG "PLX_INTCSR=0x%x\n", reg);		if (!(reg & PLX_INTCSR_PCI_INTEN)) {			outl(reg | PLX_INTCSR_PCI_INTEN,			     plx_ioaddr + PLX_INTCSR);			if (!(inl(plx_ioaddr + PLX_INTCSR) &			      PLX_INTCSR_PCI_INTEN)) {				printk(KERN_WARNING "%s: Could not enable "				       "Local Interrupts\n", dev_info);				goto fail;			}		}		reg = inl(plx_ioaddr + PLX_CNTRL);		printk(KERN_DEBUG "PLX_CNTRL=0x%x (Serial EEPROM "		       "present=%d)\n",		       reg, (reg & PLX_CNTRL_SERIAL_EEPROM_PRESENT) != 0);		/* should set PLX_PCIIPR to 0x01 (INTA#) if Serial EEPROM is		 * not present; but are there really such cards in use(?) */	}	dev = prism2_init_local_data(&prism2_plx_funcs, cards_found,				     &pdev->dev);	if (dev == NULL)		goto fail;	iface = netdev_priv(dev);	local = iface->local;	local->hw_priv = hw_priv;	cards_found++;	dev->irq = pdev->irq;	dev->base_addr = pccard_ioaddr;	hw_priv->attr_mem = attr_mem;	hw_priv->cor_offset = cor_offset;	pci_set_drvdata(pdev, dev);	if (request_irq(dev->irq, prism2_interrupt, SA_SHIRQ, dev->name,			dev)) {		printk(KERN_WARNING "%s: request_irq failed\n", dev->name);		goto fail;	} else		irq_registered = 1;	if (prism2_hw_config(dev, 1)) {		printk(KERN_DEBUG "%s: hardware initialization failed\n",		       dev_info);		goto fail;	}	return hostap_hw_ready(dev); fail:	prism2_free_local_data(dev);	kfree(hw_priv);	if (irq_registered && dev)		free_irq(dev->irq, dev);	if (attr_mem)		iounmap(attr_mem);	pci_disable_device(pdev);	return -ENODEV;}static void prism2_plx_remove(struct pci_dev *pdev){	struct net_device *dev;	struct hostap_interface *iface;	struct hostap_plx_priv *hw_priv;	dev = pci_get_drvdata(pdev);	iface = netdev_priv(dev);	hw_priv = iface->local->hw_priv;	/* Reset the hardware, and ensure interrupts are disabled. */	prism2_plx_cor_sreset(iface->local);	hfa384x_disable_interrupts(dev);	if (hw_priv->attr_mem)		iounmap(hw_priv->attr_mem);	if (dev->irq)		free_irq(dev->irq, dev);	prism2_free_local_data(dev);	kfree(hw_priv);	pci_disable_device(pdev);}MODULE_DEVICE_TABLE(pci, prism2_plx_id_table);static struct pci_driver prism2_plx_drv_id = {	.name		= "hostap_plx",	.id_table	= prism2_plx_id_table,	.probe		= prism2_plx_probe,	.remove		= prism2_plx_remove,	.suspend	= NULL,	.resume		= NULL,	.enable_wake	= NULL};static int __init init_prism2_plx(void){	printk(KERN_INFO "%s: %s\n", dev_info, version);	return pci_register_driver(&prism2_plx_drv_id);}static void __exit exit_prism2_plx(void){	pci_unregister_driver(&prism2_plx_drv_id);	printk(KERN_INFO "%s: Driver unloaded\n", dev_info);}module_init(init_prism2_plx);module_exit(exit_prism2_plx);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人免费看视频| 亚洲福利视频一区| 亚洲免费观看视频| 偷窥少妇高潮呻吟av久久免费| 琪琪一区二区三区| 国产呦精品一区二区三区网站| 91色porny在线视频| 717成人午夜免费福利电影| 久久亚洲私人国产精品va媚药| 国产精品美女久久久久久| 亚洲成av人片| 久久99精品久久久| 色悠悠亚洲一区二区| 欧美一区二区三区公司| 国产精品你懂的| 爽好多水快深点欧美视频| 国产成人精品午夜视频免费| 欧洲亚洲国产日韩| 国产亚洲欧美激情| 亚洲国产综合人成综合网站| 国产精品一区三区| 欧美色综合影院| 欧美国产乱子伦 | 成人免费三级在线| 欧美色图在线观看| 欧美国产欧美综合| 美女诱惑一区二区| 欧美亚一区二区| 国产喷白浆一区二区三区| 日韩精品一二三四| 91玉足脚交白嫩脚丫在线播放| 日韩免费福利电影在线观看| 亚洲精品综合在线| 国产主播一区二区| 欧美日韩中文字幕一区| 国产精品青草综合久久久久99| 日韩国产在线一| 色就色 综合激情| 久久九九久久九九| 美日韩一区二区| 欧美日韩在线一区二区| 亚洲欧洲精品一区二区三区| 国产在线一区二区综合免费视频| 精品视频免费在线| 亚洲男人天堂一区| 国产99精品视频| 精品成a人在线观看| 天天av天天翘天天综合网| 色94色欧美sute亚洲线路一ni| 欧美国产精品一区二区三区| 激情都市一区二区| 日韩欧美在线不卡| 日韩和欧美一区二区| 欧美网站大全在线观看| 亚洲靠逼com| 91天堂素人约啪| 国产精品乱码一区二区三区软件| 另类小说一区二区三区| 在线播放/欧美激情| 午夜精品一区在线观看| 欧美视频中文字幕| 一区二区三区久久| 99re视频这里只有精品| 亚洲欧洲成人精品av97| 不卡电影一区二区三区| 国产精品高清亚洲| 99久久99久久综合| 成人免费一区二区三区视频 | 亚洲欧美一区二区视频| 成人黄动漫网站免费app| 国产婷婷色一区二区三区在线| 国产老肥熟一区二区三区| 欧美精品一区二区三区一线天视频| 麻豆精品新av中文字幕| 日韩免费观看高清完整版在线观看| 日本女优在线视频一区二区| 欧美一区二区私人影院日本| 日韩av中文字幕一区二区三区| 337p亚洲精品色噜噜| 青草国产精品久久久久久| 日韩免费看的电影| 国产精华液一区二区三区| 国产精品美女久久久久av爽李琼 | 亚洲美女视频在线观看| 色综合天天狠狠| 亚洲在线视频免费观看| 欧美三级视频在线| 日本色综合中文字幕| 欧美mv日韩mv亚洲| 国产.欧美.日韩| 亚洲丝袜美腿综合| 欧美日韩综合不卡| 麻豆国产欧美日韩综合精品二区| 精品国产免费人成在线观看| 国产成人免费9x9x人网站视频| 国产精品拍天天在线| 91片在线免费观看| 亚洲成人午夜电影| 欧美一级精品大片| 国产精品性做久久久久久| 国产精品国产三级国产| 欧美日韩综合在线免费观看| 久久精品99国产精品| 国产精品嫩草影院com| 欧美日韩日日夜夜| 狠狠狠色丁香婷婷综合激情| 亚洲婷婷综合色高清在线| 欧美日韩精品福利| 国产一区二区0| 亚洲欧美一区二区三区极速播放 | 蜜臀91精品一区二区三区| 国产欧美久久久精品影院| 色婷婷久久久久swag精品 | 精品粉嫩aⅴ一区二区三区四区| 国产毛片精品一区| 亚洲精品水蜜桃| 日韩一区和二区| 成人免费看黄yyy456| 亚洲电影第三页| 久久久久久**毛片大全| 日本道精品一区二区三区| 蜜桃av一区二区| 亚洲视频在线一区观看| 欧美一区二区三区在线看| 成人黄色免费短视频| 午夜不卡av免费| 中文字幕国产一区| 欧美日本韩国一区二区三区视频| 国产精品亚洲а∨天堂免在线| 亚洲午夜在线电影| 国产日韩av一区二区| 精品视频资源站| 国产ts人妖一区二区| 天天做天天摸天天爽国产一区| 国产欧美一区二区三区网站| 欧美日韩一二三区| 成人免费视频app| 另类专区欧美蜜桃臀第一页| 一区二区三国产精华液| 中文字幕乱码一区二区免费| 91精品国产综合久久久久| 91在线一区二区| 国产一区二区三区电影在线观看 | 欧美一级片免费看| 91免费看片在线观看| 国产一区二区精品久久| 三级一区在线视频先锋| 亚洲欧美韩国综合色| 国产欧美日韩在线观看| 日韩一区二区三区免费看| 色综合中文字幕| 成人一区二区三区视频| 韩国精品在线观看| 日本女人一区二区三区| 一区二区三区日韩欧美精品| 国产精品视频一区二区三区不卡| 日韩免费看的电影| 91精品国产高清一区二区三区蜜臀| 成人午夜又粗又硬又大| 国产在线看一区| 麻豆国产精品官网| 日韩高清在线一区| 亚洲va欧美va国产va天堂影院| 亚洲免费伊人电影| 亚洲婷婷在线视频| 自拍偷拍亚洲激情| 亚洲图片激情小说| 亚洲视频在线一区| 亚洲人妖av一区二区| 日本一区二区视频在线| 国产日本欧洲亚洲| 久久精品人人做| 久久久午夜电影| 国产午夜精品一区二区三区四区| 精品电影一区二区| 欧美成人伊人久久综合网| 欧美一区二区三区播放老司机| 欧美四级电影网| 欧美三级在线看| 欧美精品在线一区二区三区| 欧美精品久久久久久久多人混战| 欧美无砖专区一中文字| 欧美日韩高清一区二区三区| 欧美精三区欧美精三区| 日韩欧美一卡二卡| 精品美女被调教视频大全网站| 日韩欧美一级二级三级| 欧美成人免费网站| 久久婷婷久久一区二区三区| 国产日韩成人精品| 国产精品成人免费精品自在线观看| 亚洲国产精品av| 国产精品久久久久久久浪潮网站| 亚洲图片激情小说| 亚洲第一会所有码转帖| 视频一区二区不卡| 国产在线看一区| 不卡的av网站| 在线亚洲欧美专区二区| 欧美女孩性生活视频|