[U-Boot] [PATCH 1/7] dm: pci: Move pci_bus_to_hose() to compatibility

Bin Meng bmeng.cn at gmail.com
Tue Dec 8 14:22:04 CET 2015


Hi Simon,

On Tue, Dec 1, 2015 at 12:11 PM, Simon Glass <sjg at chromium.org> wrote:
> This function should not be used by driver-model code, so move it to the
> compatibility portion.
>
> Signed-off-by: Simon Glass <sjg at chromium.org>
> ---
>
>  drivers/pci/pci-uclass.c   | 16 +---------------
>  drivers/pci/pci_compat.c   | 15 +++++++++++++++
>  drivers/pci/pci_internal.h | 11 +++++++++++
>  3 files changed, 27 insertions(+), 15 deletions(-)
>
> diff --git a/drivers/pci/pci-uclass.c b/drivers/pci/pci-uclass.c
> index 54b5dbc..77d5300 100644
> --- a/drivers/pci/pci-uclass.c
> +++ b/drivers/pci/pci-uclass.c
> @@ -22,7 +22,7 @@
>
>  DECLARE_GLOBAL_DATA_PTR;
>
> -static int pci_get_bus(int busnum, struct udevice **busp)
> +int pci_get_bus(int busnum, struct udevice **busp)
>  {
>         int ret;
>
> @@ -41,20 +41,6 @@ static int pci_get_bus(int busnum, struct udevice **busp)
>         return ret;
>  }
>
> -struct pci_controller *pci_bus_to_hose(int busnum)
> -{
> -       struct udevice *bus;
> -       int ret;
> -
> -       ret = pci_get_bus(busnum, &bus);
> -       if (ret) {
> -               debug("%s: Cannot get bus %d: ret=%d\n", __func__, busnum, ret);
> -               return NULL;
> -       }
> -
> -       return dev_get_uclass_priv(bus);
> -}
> -
>  struct udevice *pci_get_controller(struct udevice *dev)
>  {
>         while (device_is_on_pci_bus(dev))
> diff --git a/drivers/pci/pci_compat.c b/drivers/pci/pci_compat.c
> index dd15eb1..ddaf358 100644
> --- a/drivers/pci/pci_compat.c
> +++ b/drivers/pci/pci_compat.c
> @@ -12,6 +12,7 @@
>  #include <pci.h>
>  #include <dm/device-internal.h>
>  #include <dm/lists.h>
> +#include "pci_internal.h"
>
>  #define PCI_HOSE_OP(rw, name, size, type)                              \
>  int pci_hose_##rw##_config_##name(struct pci_controller *hose,         \
> @@ -36,3 +37,17 @@ pci_dev_t pci_find_devices(struct pci_device_id *ids, int index)
>                 return -1;
>         return dm_pci_get_bdf(dev);
>  }
> +
> +struct pci_controller *pci_bus_to_hose(int busnum)
> +{
> +       struct udevice *bus;
> +       int ret;
> +
> +       ret = pci_get_bus(busnum, &bus);
> +       if (ret) {
> +               debug("%s: Cannot get bus %d: ret=%d\n", __func__, busnum, ret);
> +               return NULL;
> +       }
> +
> +       return dev_get_uclass_priv(bus);
> +}
> diff --git a/drivers/pci/pci_internal.h b/drivers/pci/pci_internal.h
> index 0867575..c5069f0 100644
> --- a/drivers/pci/pci_internal.h
> +++ b/drivers/pci/pci_internal.h
> @@ -47,4 +47,15 @@ void dm_pciauto_postscan_setup_bridge(struct udevice *dev, int sub_bus);
>   */
>  int dm_pciauto_config_device(struct udevice *dev);
>
> +/**
> + * pci_get_bus() - Get a pointer to a bus, given its number
> + *
> + * The bus is probed before use

This comment looks confusing. Could you please describe it in more detail?

> + *
> + * @busnum:    PCI bus number to look up
> + * @busp:      Returns PCI bus on success
> + * @return 0 on success, or -ve error
> + */
> +int pci_get_bus(int busnum, struct udevice **busp);
> +
>  #endif
> --

Regards,
Bin


More information about the U-Boot mailing list