libpci 3.3.0 introduced an additional member in the pci_filter struct which needs to be initialized to -1 to get the same behavior as before the API change. The libpci internal helpers got updated accordingly, but as the cpupower pci helpers initialized the struct themselves the behavior changed. Use the libpci helper pci_filter_init() to fix this and guard against similar breakages in the future. This fixes probing of the AMD fam12h/14h cpuidle monitor on systems with libpci >= 3.3.0. Signed-off-by: Lucas Stach <dev@lynxeye.de> Acked-by: Thomas Renninger <trenn@suse.de> Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
63 lines
1.5 KiB
C
63 lines
1.5 KiB
C
#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
|
|
*
|
|
* domain: domain
|
|
* bus: bus
|
|
* slot: slot
|
|
* func: func
|
|
* vendor: vendor
|
|
* device: device
|
|
* Pass -1 for one of the six above to match any
|
|
*
|
|
* 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 domain, int bus,
|
|
int slot, int func, int vendor, int dev)
|
|
{
|
|
struct pci_filter filter_nb_link;
|
|
struct pci_dev *device;
|
|
|
|
*pacc = pci_alloc();
|
|
if (*pacc == NULL)
|
|
return NULL;
|
|
|
|
pci_filter_init(*pacc, &filter_nb_link);
|
|
filter_nb_link.domain = domain;
|
|
filter_nb_link.bus = bus;
|
|
filter_nb_link.slot = slot;
|
|
filter_nb_link.func = func;
|
|
filter_nb_link.vendor = vendor;
|
|
filter_nb_link.device = dev;
|
|
|
|
pci_init(*pacc);
|
|
pci_scan_bus(*pacc);
|
|
|
|
for (device = (*pacc)->devices; device; device = device->next) {
|
|
if (pci_filter_match(&filter_nb_link, device))
|
|
return device;
|
|
}
|
|
pci_cleanup(*pacc);
|
|
return NULL;
|
|
}
|
|
|
|
/* Typically one wants to get a specific slot(device)/func of the root domain
|
|
and bus */
|
|
struct pci_dev *pci_slot_func_init(struct pci_access **pacc, int slot,
|
|
int func)
|
|
{
|
|
return pci_acc_init(pacc, 0, 0, slot, func, -1, -1);
|
|
}
|
|
|
|
#endif /* defined(__i386__) || defined(__x86_64__) */
|