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

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

?? pci.c

?? 基于組件方式開發操作系統的OSKIT源代碼
?? C
字號:
/* *	$Id: pci.c,v 1.91 1999/01/21 13:34:01 davem Exp $ * *	PCI Bus Services, see include/linux/pci.h for further explanation. * *	Copyright 1993 -- 1997 Drew Eckhardt, Frederic Potter, *	David Mosberger-Tang * *	Copyright 1997 -- 1999 Martin Mares <mj@atrey.karlin.mff.cuni.cz> */#include <linux/config.h>#include <linux/types.h>#include <linux/kernel.h>#include <linux/pci.h>#include <linux/string.h>#include <linux/init.h>#include <linux/malloc.h>#include <asm/page.h>#undef DEBUG#ifdef DEBUG#define DBG(x...) printk(x)#else#define DBG(x...)#endifstruct pci_bus pci_root;struct pci_dev *pci_devices = NULL;static struct pci_dev **pci_last_dev_p = &pci_devices;static int pci_reverse __initdata = 0;struct pci_dev *pci_find_slot(unsigned int bus, unsigned int devfn){	struct pci_dev *dev;	for(dev=pci_devices; dev; dev=dev->next)		if (dev->bus->number == bus && dev->devfn == devfn)			break;	return dev;}struct pci_dev *pci_find_device(unsigned int vendor, unsigned int device, struct pci_dev *from){	if (!from)		from = pci_devices;	else		from = from->next;	while (from && (from->vendor != vendor || from->device != device))		from = from->next;	return from;}struct pci_dev *pci_find_class(unsigned int class, struct pci_dev *from){	if (!from)		from = pci_devices;	else		from = from->next;	while (from && from->class != class)		from = from->next;	return from;}intpci_read_config_byte(struct pci_dev *dev, u8 where, u8 *val){	return pcibios_read_config_byte(dev->bus->number, dev->devfn, where, val);}intpci_read_config_word(struct pci_dev *dev, u8 where, u16 *val){	return pcibios_read_config_word(dev->bus->number, dev->devfn, where, val);}intpci_read_config_dword(struct pci_dev *dev, u8 where, u32 *val){	return pcibios_read_config_dword(dev->bus->number, dev->devfn, where, val);}intpci_write_config_byte(struct pci_dev *dev, u8 where, u8 val){	return pcibios_write_config_byte(dev->bus->number, dev->devfn, where, val);}intpci_write_config_word(struct pci_dev *dev, u8 where, u16 val){	return pcibios_write_config_word(dev->bus->number, dev->devfn, where, val);}intpci_write_config_dword(struct pci_dev *dev, u8 where, u32 val){	return pcibios_write_config_dword(dev->bus->number, dev->devfn, where, val);}voidpci_set_master(struct pci_dev *dev){	u16 cmd;	u8 lat;	pci_read_config_word(dev, PCI_COMMAND, &cmd);	if (! (cmd & PCI_COMMAND_MASTER)) {		printk("PCI: Enabling bus mastering for device %02x:%02x\n",			dev->bus->number, dev->devfn);		cmd |= PCI_COMMAND_MASTER;		pci_write_config_word(dev, PCI_COMMAND, cmd);	}	pci_read_config_byte(dev, PCI_LATENCY_TIMER, &lat);	if (lat < 16) {		printk("PCI: Increasing latency timer of device %02x:%02x to 64\n",			dev->bus->number, dev->devfn);		pci_write_config_byte(dev, PCI_LATENCY_TIMER, 64);	}}__initfunc(void pci_read_bases(struct pci_dev *dev, unsigned int howmany)){	unsigned int reg;	u32 l;	for(reg=0; reg<howmany; reg++) {		pci_read_config_dword(dev, PCI_BASE_ADDRESS_0 + (reg << 2), &l);		if (l == 0xffffffff)			continue;		dev->base_address[reg] = l;		if ((l & (PCI_BASE_ADDRESS_SPACE | PCI_BASE_ADDRESS_MEM_TYPE_MASK))		    == (PCI_BASE_ADDRESS_SPACE_MEMORY | PCI_BASE_ADDRESS_MEM_TYPE_64)) {			reg++;			pci_read_config_dword(dev, PCI_BASE_ADDRESS_0 + (reg << 2), &l);			if (l) {#if BITS_PER_LONG == 64				dev->base_address[reg-1] |= ((unsigned long) l) << 32;#else				printk("PCI: Unable to handle 64-bit address for device %02x:%02x\n",					dev->bus->number, dev->devfn);				dev->base_address[reg-1] = 0;#endif			}		}	}}__initfunc(unsigned int pci_scan_bus(struct pci_bus *bus)){	unsigned int devfn, l, max, class;	unsigned char cmd, irq, tmp, hdr_type, is_multi = 0;	struct pci_dev *dev, **bus_last;	struct pci_bus *child;	DBG("pci_scan_bus for bus %d\n", bus->number);	bus_last = &bus->devices;	max = bus->secondary;	for (devfn = 0; devfn < 0xff; ++devfn) {		if (PCI_FUNC(devfn) && !is_multi) {			/* not a multi-function device */			continue;		}		if (pcibios_read_config_byte(bus->number, devfn, PCI_HEADER_TYPE, &hdr_type))			continue;		if (!PCI_FUNC(devfn))			is_multi = hdr_type & 0x80;		if (pcibios_read_config_dword(bus->number, devfn, PCI_VENDOR_ID, &l) ||		    /* some broken boards return 0 if a slot is empty: */		    l == 0xffffffff || l == 0x00000000 || l == 0x0000ffff || l == 0xffff0000) {			is_multi = 0;			continue;		}		dev = kmalloc(sizeof(*dev), GFP_ATOMIC);		if(dev==NULL)		{			printk(KERN_ERR "pci: out of memory.\n");			continue;		}		memset(dev, 0, sizeof(*dev));		dev->bus = bus;		dev->devfn  = devfn;		dev->vendor = l & 0xffff;		dev->device = (l >> 16) & 0xffff;		/* non-destructively determine if device can be a master: */		pcibios_read_config_byte(bus->number, devfn, PCI_COMMAND, &cmd);		pcibios_write_config_byte(bus->number, devfn, PCI_COMMAND, cmd | PCI_COMMAND_MASTER);		pcibios_read_config_byte(bus->number, devfn, PCI_COMMAND, &tmp);		dev->master = ((tmp & PCI_COMMAND_MASTER) != 0);		pcibios_write_config_byte(bus->number, devfn, PCI_COMMAND, cmd);		pcibios_read_config_dword(bus->number, devfn, PCI_CLASS_REVISION, &class);		class >>= 8;				    /* upper 3 bytes */		dev->class = class;		class >>= 8;		dev->hdr_type = hdr_type;		switch (hdr_type & 0x7f) {		    /* header type */		case PCI_HEADER_TYPE_NORMAL:		    /* standard header */			if (class == PCI_CLASS_BRIDGE_PCI)				goto bad;			/*			 * If the card generates interrupts, read IRQ number			 * (some architectures change it during pcibios_fixup())			 */			pcibios_read_config_byte(bus->number, dev->devfn, PCI_INTERRUPT_PIN, &irq);			if (irq)				pcibios_read_config_byte(bus->number, dev->devfn, PCI_INTERRUPT_LINE, &irq);			dev->irq = irq;			/*			 * read base address registers, again pcibios_fixup() can			 * tweak these			 */			pci_read_bases(dev, 6);			pcibios_read_config_dword(bus->number, devfn, PCI_ROM_ADDRESS, &l);			dev->rom_address = (l == 0xffffffff) ? 0 : l;			break;		case PCI_HEADER_TYPE_BRIDGE:		    /* bridge header */			if (class != PCI_CLASS_BRIDGE_PCI)				goto bad;			pci_read_bases(dev, 2);			pcibios_read_config_dword(bus->number, devfn, PCI_ROM_ADDRESS1, &l);			dev->rom_address = (l == 0xffffffff) ? 0 : l;			break;		case PCI_HEADER_TYPE_CARDBUS:		    /* CardBus bridge header */			if (class != PCI_CLASS_BRIDGE_CARDBUS)				goto bad;			pci_read_bases(dev, 1);			break;		default:				    /* unknown header */		bad:			printk(KERN_ERR "PCI: %02x:%02x [%04x/%04x/%06x] has unknown header type %02x, ignoring.\n",			       bus->number, dev->devfn, dev->vendor, dev->device, class, hdr_type);			continue;		}		DBG("PCI: %02x:%02x [%04x/%04x]\n", bus->number, dev->devfn, dev->vendor, dev->device);		/*		 * Put it into the global PCI device chain. It's used to		 * find devices once everything is set up.		 */		if (!pci_reverse) {			*pci_last_dev_p = dev;			pci_last_dev_p = &dev->next;		} else {			dev->next = pci_devices;			pci_devices = dev;		}		/*		 * Now insert it into the list of devices held		 * by the parent bus.		 */		*bus_last = dev;		bus_last = &dev->sibling;#if 0		/*		 * Setting of latency timer in case it was less than 32 was		 * a great idea, but it confused several broken devices. Grrr.		 */		pcibios_read_config_byte(bus->number, dev->devfn, PCI_LATENCY_TIMER, &tmp);		if (tmp < 32)			pcibios_write_config_byte(bus->number, dev->devfn, PCI_LATENCY_TIMER, 32);#endif	}	/*	 * After performing arch-dependent fixup of the bus, look behind	 * all PCI-to-PCI bridges on this bus.	 */	pcibios_fixup_bus(bus);	for(dev=bus->devices; dev; dev=dev->sibling)		/*		 * If it's a bridge, scan the bus behind it.		 */		if ((dev->class >> 8) == PCI_CLASS_BRIDGE_PCI) {			unsigned int buses;			unsigned int devfn = dev->devfn;			unsigned short cr;			/*			 * Insert it into the tree of buses.			 */			child = kmalloc(sizeof(*child), GFP_ATOMIC);			if(child==NULL)			{				printk(KERN_ERR "pci: out of memory for bridge.\n");				continue;			}			memset(child, 0, sizeof(*child));			child->next = bus->children;			bus->children = child;			child->self = dev;			child->parent = bus;			/*			 * Set up the primary, secondary and subordinate			 * bus numbers.			 */			child->number = child->secondary = ++max;			child->primary = bus->secondary;			child->subordinate = 0xff;			/*			 * Clear all status bits and turn off memory,			 * I/O and master enables.			 */			pcibios_read_config_word(bus->number, devfn, PCI_COMMAND, &cr);			pcibios_write_config_word(bus->number, devfn, PCI_COMMAND, 0x0000);			pcibios_write_config_word(bus->number, devfn, PCI_STATUS, 0xffff);			/*			 * Read the existing primary/secondary/subordinate bus			 * number configuration to determine if the PCI bridge			 * has already been configured by the system.  If so,			 * do not modify the configuration, merely note it.			 */			pcibios_read_config_dword(bus->number, devfn, PCI_PRIMARY_BUS, &buses);			if ((buses & 0xFFFFFF) != 0)			  {			    unsigned int cmax;			    child->primary = buses & 0xFF;			    child->secondary = (buses >> 8) & 0xFF;			    child->subordinate = (buses >> 16) & 0xFF;			    child->number = child->secondary;			    cmax = pci_scan_bus(child);			    if (cmax > max) max = cmax;			  }			else			  {			    /*			     * Configure the bus numbers for this bridge:			     */			    buses &= 0xff000000;			    buses |=			      (((unsigned int)(child->primary)     <<  0) |			       ((unsigned int)(child->secondary)   <<  8) |			       ((unsigned int)(child->subordinate) << 16));			    pcibios_write_config_dword(bus->number, devfn, PCI_PRIMARY_BUS, buses);			    /*			     * Now we can scan all subordinate buses:			     */			    max = pci_scan_bus(child);			    /*			     * Set the subordinate bus number to its real			     * value:			     */			    child->subordinate = max;			    buses = (buses & 0xff00ffff)			      | ((unsigned int)(child->subordinate) << 16);			    pcibios_write_config_dword(bus->number, devfn, PCI_PRIMARY_BUS, buses);			  }			pcibios_write_config_word(bus->number, devfn, PCI_COMMAND, cr);		}	/*	 * We've scanned the bus and so we know all about what's on	 * the other side of any bridges that may be on this bus plus	 * any devices.	 *	 * Return how far we've got finding sub-buses.	 */	DBG("PCI: pci_scan_bus returning with max=%02x\n", max);	return max;}struct pci_bus * __init pci_scan_peer_bridge(int bus){	struct pci_bus *b;	b = kmalloc(sizeof(*b), GFP_KERNEL);	memset(b, 0, sizeof(*b));	b->next = pci_root.next;	pci_root.next = b;	b->number = b->secondary = bus;	b->subordinate = pci_scan_bus(b);	return b;}__initfunc(void pci_init(void)){	pcibios_init();	if (!pci_present()) {		printk("PCI: No PCI bus detected\n");		return;	}	printk("PCI: Probing PCI hardware\n");	memset(&pci_root, 0, sizeof(pci_root));	pci_root.subordinate = pci_scan_bus(&pci_root);	/* give BIOS a chance to apply platform specific fixes: */	pcibios_fixup();#ifdef CONFIG_PCI_QUIRKS	pci_quirks_init();#endif#ifdef CONFIG_PROC_FS	pci_proc_init();#endif}__initfunc(void pci_setup (char *str, int *ints)){	while (str) {		char *k = strchr(str, ',');		if (k)			*k++ = 0;		if (*str && (str = pcibios_setup(str)) && *str) {			if (!strcmp(str, "reverse"))				pci_reverse = 1;			else printk(KERN_ERR "PCI: Unknown option `%s'\n", str);		}		str = k;	}}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一级在线视频| 久久精品欧美日韩精品 | 亚洲综合清纯丝袜自拍| 精品欧美一区二区久久 | 顶级嫩模精品视频在线看| 亚欧色一区w666天堂| 国产精品视频一区二区三区不卡| 欧美情侣在线播放| 91蝌蚪porny成人天涯| 国模套图日韩精品一区二区| 亚洲成av人综合在线观看| 国产精品久久久久影视| 欧美一区二区人人喊爽| 色综合久久综合网欧美综合网| 国产原创一区二区| 婷婷丁香久久五月婷婷| 亚洲乱码国产乱码精品精98午夜| 久久色视频免费观看| 3atv在线一区二区三区| 91国模大尺度私拍在线视频| 国产成人免费9x9x人网站视频| 日韩黄色小视频| 五月综合激情网| 亚洲一区二区在线免费观看视频| 国产精品天天摸av网| 欧美sm美女调教| 制服丝袜国产精品| 91麻豆精品国产91久久久久久久久 | 中文字幕av一区 二区| 欧美大片国产精品| 欧美一区二区精品| 3751色影院一区二区三区| 欧美日韩午夜影院| 在线亚洲精品福利网址导航| 91在线码无精品| 成人黄色国产精品网站大全在线免费观看| 精品亚洲aⅴ乱码一区二区三区| 免费成人在线影院| 美女网站一区二区| 国产在线视频一区二区三区| 久久99深爱久久99精品| 精品一区二区三区视频在线观看| 久久精品72免费观看| 精品中文字幕一区二区| 国产最新精品免费| 国产精品资源在线| 国产ts人妖一区二区| 成人午夜碰碰视频| 99久久精品免费精品国产| 91欧美一区二区| 91国偷自产一区二区三区观看| 欧美系列一区二区| 欧美麻豆精品久久久久久| 欧美日韩一区国产| 欧美精品日日鲁夜夜添| 91精品久久久久久蜜臀| 精品久久久久久最新网址| 久久麻豆一区二区| 亚洲丝袜另类动漫二区| 一区二区三区精品| 天天色 色综合| 韩国一区二区三区| 成人免费福利片| 日本韩国欧美一区二区三区| 欧美日韩国产在线观看| 日韩视频一区在线观看| 久久九九国产精品| 亚洲精品精品亚洲| 偷拍一区二区三区| 国产麻豆视频一区二区| 91亚洲大成网污www| 欧美日韩色综合| 精品国产乱码久久久久久1区2区 | 日韩精品每日更新| 激情五月播播久久久精品| 成人黄色在线看| 欧美老女人在线| 欧美激情一区三区| 午夜精品久久久久久久久| 国产在线精品一区二区夜色| av一区二区三区黑人| 欧美高清激情brazzers| 国产亚洲欧美色| 一区二区久久久久久| 久久97超碰色| 91在线播放网址| 精品国产精品一区二区夜夜嗨| 国产精品成人网| 久久99精品国产麻豆婷婷洗澡| 成人av网站大全| 日韩欧美成人午夜| 亚洲精品伦理在线| 国产麻豆午夜三级精品| 欧美高清视频www夜色资源网| 国产精品免费av| 免费成人在线观看视频| 色综合久久综合网| 国产欧美日韩精品a在线观看| 亚洲1区2区3区4区| av在线播放成人| 精品国产乱码久久久久久1区2区| 亚洲综合视频在线观看| 成人三级在线视频| 日韩一区二区三区四区五区六区| 亚洲欧美另类图片小说| 国产成人自拍高清视频在线免费播放| 欧美三级电影精品| 成人免费一区二区三区在线观看| 老司机午夜精品| 欧美精品色综合| 亚洲自拍偷拍欧美| 99精品视频在线观看免费| 久久久午夜电影| 蜜桃一区二区三区在线| 欧美日韩三级一区| 一区二区三区四区蜜桃| 成人激情小说乱人伦| 久久综合av免费| 久久精品国产免费| 日韩一区二区视频在线观看| 亚洲午夜一区二区三区| 91在线国产福利| 国产精品久久久久久久浪潮网站 | 精品视频123区在线观看| 国产精品久久午夜| 丁香六月综合激情| 中文字幕第一区综合| 国产一区欧美二区| 久久久不卡网国产精品一区| 极品销魂美女一区二区三区| 日韩欧美自拍偷拍| 男女男精品视频| 日韩写真欧美这视频| 免费在线看成人av| 精品国产免费久久| 国产精品88av| 国产午夜精品福利| 国产91丝袜在线播放0| 欧美国产激情一区二区三区蜜月| 国产福利视频一区二区三区| 久久精品亚洲精品国产欧美kt∨| 国产一区二区久久| 国产精品久久久久久久久免费樱桃 | 亚洲bt欧美bt精品| 欧美在线观看视频在线| 亚洲国产裸拍裸体视频在线观看乱了| 在线观看日产精品| 亚洲国产精品久久艾草纯爱| 717成人午夜免费福利电影| 男女男精品网站| 国产亚洲一区二区三区在线观看| 国产激情偷乱视频一区二区三区 | 国产精品毛片久久久久久久| 成人app下载| 亚洲精品高清视频在线观看| 在线观看免费视频综合| 天天综合网天天综合色| 亚洲精品一线二线三线| 丰满少妇久久久久久久 | 国模套图日韩精品一区二区| 国产精品天干天干在观线| 99精品国产热久久91蜜凸| 一卡二卡三卡日韩欧美| 91精品国产乱码| 国产精品影视天天线| 一区二区三区中文字幕| 欧美一区午夜视频在线观看| 国产美女在线精品| 亚洲精品中文字幕在线观看| 欧美日韩国产天堂| 国产在线视频精品一区| 亚洲免费色视频| 日韩一区二区精品葵司在线| 国产精品911| 午夜不卡在线视频| 欧美激情一区在线观看| 欧美无砖专区一中文字| 久久国产精品72免费观看| 亚洲视频1区2区| 日韩精品中文字幕在线不卡尤物| 成人av影视在线观看| 香蕉久久一区二区不卡无毒影院| 2014亚洲片线观看视频免费| 欧洲国产伦久久久久久久| 国产一区二区三区四| 亚洲午夜日本在线观看| 中文字幕第一页久久| 91精品午夜视频| 99这里只有久久精品视频| 美女精品自拍一二三四| 一区二区三区在线视频观看58| 精品国产sm最大网站| 欧美日韩久久一区二区| 成人精品小蝌蚪| 免费欧美日韩国产三级电影| 一级做a爱片久久| 国产精品网友自拍| 欧美精品一区二区三区高清aⅴ | 久久久久久电影| 91麻豆精品国产91|