xref: /rk3399_rockchip-uboot/drivers/pci/pci_compat.c (revision 0675f992dbf4a785a05a1baf149c2bce6aa5fe90)
1ff3e077bSSimon Glass /*
2ff3e077bSSimon Glass  * Compatibility functions for pre-driver-model code
3ff3e077bSSimon Glass  *
4ff3e077bSSimon Glass  * Copyright (C) 2014 Google, Inc
5ff3e077bSSimon Glass  *
6ff3e077bSSimon Glass  * SPDX-License-Identifier:	GPL-2.0+
7ff3e077bSSimon Glass  */
8ff3e077bSSimon Glass #include <common.h>
9ff3e077bSSimon Glass #include <dm.h>
10ff3e077bSSimon Glass #include <errno.h>
11ff3e077bSSimon Glass #include <malloc.h>
12ff3e077bSSimon Glass #include <pci.h>
13ff3e077bSSimon Glass #include <dm/device-internal.h>
14ff3e077bSSimon Glass #include <dm/lists.h>
15a6eb93b3SSimon Glass #include "pci_internal.h"
16ff3e077bSSimon Glass 
17ff3e077bSSimon Glass #define PCI_HOSE_OP(rw, name, size, type)				\
18ff3e077bSSimon Glass int pci_hose_##rw##_config_##name(struct pci_controller *hose,		\
19ff3e077bSSimon Glass 				  pci_dev_t dev,			\
20ff3e077bSSimon Glass 				  int offset, type value)		\
21ff3e077bSSimon Glass {									\
22ff3e077bSSimon Glass 	return pci_##rw##_config##size(dev, offset, value);		\
23ff3e077bSSimon Glass }
24ff3e077bSSimon Glass 
25ff3e077bSSimon Glass PCI_HOSE_OP(read, byte, 8, u8 *)
26ff3e077bSSimon Glass PCI_HOSE_OP(read, word, 16, u16 *)
27ff3e077bSSimon Glass PCI_HOSE_OP(read, dword, 32, u32 *)
28ff3e077bSSimon Glass PCI_HOSE_OP(write, byte, 8, u8)
29ff3e077bSSimon Glass PCI_HOSE_OP(write, word, 16, u16)
30ff3e077bSSimon Glass PCI_HOSE_OP(write, dword, 32, u32)
31ff3e077bSSimon Glass 
pci_find_devices(struct pci_device_id * ids,int index)32ff3e077bSSimon Glass pci_dev_t pci_find_devices(struct pci_device_id *ids, int index)
33ff3e077bSSimon Glass {
344b515e4fSSimon Glass 	struct udevice *dev;
35ff3e077bSSimon Glass 
36ff3e077bSSimon Glass 	if (pci_find_device_id(ids, index, &dev))
37ff3e077bSSimon Glass 		return -1;
3821ccce1bSSimon Glass 	return dm_pci_get_bdf(dev);
39ff3e077bSSimon Glass }
40a6eb93b3SSimon Glass 
pci_bus_to_hose(int busnum)41a6eb93b3SSimon Glass struct pci_controller *pci_bus_to_hose(int busnum)
42a6eb93b3SSimon Glass {
43a6eb93b3SSimon Glass 	struct udevice *bus;
44a6eb93b3SSimon Glass 	int ret;
45a6eb93b3SSimon Glass 
46a6eb93b3SSimon Glass 	ret = pci_get_bus(busnum, &bus);
47a6eb93b3SSimon Glass 	if (ret) {
48a6eb93b3SSimon Glass 		debug("%s: Cannot get bus %d: ret=%d\n", __func__, busnum, ret);
49a6eb93b3SSimon Glass 		return NULL;
50a6eb93b3SSimon Glass 	}
51a6eb93b3SSimon Glass 
52*d7482ca4SMinghuan Lian 	return dev_get_uclass_priv(pci_get_controller(bus));
53a6eb93b3SSimon Glass }
54