mirror of
https://github.com/linux-sunxi/u-boot-sunxi.git
synced 2024-02-12 11:16:03 +08:00
dm: pci: Add a driver-model version of pci_find_device()
Add a function which scans the driver model device information rather than scanning the PCI bus again. Signed-off-by: Simon Glass <sjg@chromium.org> Reviewed-by: Bin Meng <bmeng.cn@gmail.com> Tested-by: Bin Meng <bmeng.cn@gmail.com>
This commit is contained in:
@ -195,6 +195,45 @@ int pci_find_device_id(struct pci_device_id *ids, int index,
|
|||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int dm_pci_bus_find_device(struct udevice *bus, unsigned int vendor,
|
||||||
|
unsigned int device, int *indexp,
|
||||||
|
struct udevice **devp)
|
||||||
|
{
|
||||||
|
struct pci_child_platdata *pplat;
|
||||||
|
struct udevice *dev;
|
||||||
|
|
||||||
|
for (device_find_first_child(bus, &dev);
|
||||||
|
dev;
|
||||||
|
device_find_next_child(&dev)) {
|
||||||
|
pplat = dev_get_parent_platdata(dev);
|
||||||
|
if (pplat->vendor == vendor && pplat->device == device) {
|
||||||
|
if (!(*indexp)--) {
|
||||||
|
*devp = dev;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return -ENODEV;
|
||||||
|
}
|
||||||
|
|
||||||
|
int dm_pci_find_device(unsigned int vendor, unsigned int device, int index,
|
||||||
|
struct udevice **devp)
|
||||||
|
{
|
||||||
|
struct udevice *bus;
|
||||||
|
|
||||||
|
/* Scan all known buses */
|
||||||
|
for (uclass_first_device(UCLASS_PCI, &bus);
|
||||||
|
bus;
|
||||||
|
uclass_next_device(&bus)) {
|
||||||
|
if (!dm_pci_bus_find_device(bus, vendor, device, &index, devp))
|
||||||
|
return device_probe(*devp);
|
||||||
|
}
|
||||||
|
*devp = NULL;
|
||||||
|
|
||||||
|
return -ENODEV;
|
||||||
|
}
|
||||||
|
|
||||||
int pci_bus_write_config(struct udevice *bus, pci_dev_t bdf, int offset,
|
int pci_bus_write_config(struct udevice *bus, pci_dev_t bdf, int offset,
|
||||||
unsigned long value, enum pci_size_t size)
|
unsigned long value, enum pci_size_t size)
|
||||||
{
|
{
|
||||||
|
@ -1166,6 +1166,18 @@ struct udevice *pci_get_controller(struct udevice *dev);
|
|||||||
int pci_get_regions(struct udevice *dev, struct pci_region **iop,
|
int pci_get_regions(struct udevice *dev, struct pci_region **iop,
|
||||||
struct pci_region **memp, struct pci_region **prefp);
|
struct pci_region **memp, struct pci_region **prefp);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* dm_pci_find_device() - find a device by vendor/device ID
|
||||||
|
*
|
||||||
|
* @vendor: Vendor ID
|
||||||
|
* @device: Device ID
|
||||||
|
* @index: 0 to find the first match, 1 for second, etc.
|
||||||
|
* @devp: Returns pointer to the device, if found
|
||||||
|
* @return 0 if found, -ve on error
|
||||||
|
*/
|
||||||
|
int dm_pci_find_device(unsigned int vendor, unsigned int device, int index,
|
||||||
|
struct udevice **devp);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* struct dm_pci_emul_ops - PCI device emulator operations
|
* struct dm_pci_emul_ops - PCI device emulator operations
|
||||||
*/
|
*/
|
||||||
|
Reference in New Issue
Block a user