diff options
| author | Jiri Kosina <jkosina@suse.cz> | 2011-09-15 15:08:05 +0200 | 
|---|---|---|
| committer | Jiri Kosina <jkosina@suse.cz> | 2011-09-15 15:08:18 +0200 | 
| commit | e060c38434b2caa78efe7cedaff4191040b65a15 (patch) | |
| tree | 407361230bf6733f63d8e788e4b5e6566ee04818 /tools/power/cpupower/utils/helpers/pci.c | |
| parent | 10e4ac572eeffe5317019bd7330b6058a400dfc2 (diff) | |
| parent | cc39c6a9bbdebfcf1a7dee64d83bf302bc38d941 (diff) | |
| download | olio-linux-3.10-e060c38434b2caa78efe7cedaff4191040b65a15.tar.xz olio-linux-3.10-e060c38434b2caa78efe7cedaff4191040b65a15.zip  | |
Merge branch 'master' into for-next
Fast-forward merge with Linus to be able to merge patches
based on more recent version of the tree.
Diffstat (limited to 'tools/power/cpupower/utils/helpers/pci.c')
| -rw-r--r-- | tools/power/cpupower/utils/helpers/pci.c | 44 | 
1 files changed, 44 insertions, 0 deletions
diff --git a/tools/power/cpupower/utils/helpers/pci.c b/tools/power/cpupower/utils/helpers/pci.c new file mode 100644 index 00000000000..cd2eb6fe41c --- /dev/null +++ b/tools/power/cpupower/utils/helpers/pci.c @@ -0,0 +1,44 @@ +#if defined(__i386__) || defined(__x86_64__) + +#include <helpers/helpers.h> + +/* + * pci_acc_init + * + * PCI access helper function depending on libpci + * + * **pacc : if a valid pci_dev is returned + *         *pacc must be passed to pci_acc_cleanup to free it + * + * vendor_id : the pci vendor id matching the pci device to access + * dev_ids :   device ids matching the pci device to access + * + * Returns : + * struct pci_dev which can be used with pci_{read,write}_* functions + *                to access the PCI config space of matching pci devices + */ +struct pci_dev *pci_acc_init(struct pci_access **pacc, int vendor_id, +				    int *dev_ids) +{ +	struct pci_filter filter_nb_link = { -1, -1, -1, -1, vendor_id, 0}; +	struct pci_dev *device; +	unsigned int i; + +	*pacc = pci_alloc(); +	if (*pacc == NULL) +		return NULL; + +	pci_init(*pacc); +	pci_scan_bus(*pacc); + +	for (i = 0; dev_ids[i] != 0; i++) { +		filter_nb_link.device = dev_ids[i]; +		for (device = (*pacc)->devices; device; device = device->next) { +			if (pci_filter_match(&filter_nb_link, device)) +				return device; +		} +	} +	pci_cleanup(*pacc); +	return NULL; +} +#endif /* defined(__i386__) || defined(__x86_64__) */  |