[U-Boot] [RESENT PATCH 1/2] core: add uclass_get_device_by_phandle_id() api

Dr. Philipp Tomsich philipp.tomsich at theobroma-systems.com
Thu Feb 8 13:22:34 UTC 2018


> On 8 Feb 2018, at 14:13, Kever Yang <kever.yang at rock-chips.com> wrote:
> 
> Add api for who can not get phandle from a device property.
> 
> Signed-off-by: Kever Yang <kever.yang at rock-chips.com>

Reviewed-by: Philipp Tomsich <philipp.tomsich at theobroma-systems.com>

See below for comments.

> ---
> 
> drivers/core/uclass.c | 28 ++++++++++++++++++++++++++++
> include/dm/uclass.h   | 16 ++++++++++++++++
> 2 files changed, 44 insertions(+)
> 
> diff --git a/drivers/core/uclass.c b/drivers/core/uclass.c
> index f5e4067..dd7a89c 100644
> --- a/drivers/core/uclass.c
> +++ b/drivers/core/uclass.c
> @@ -443,6 +443,34 @@ int uclass_get_device_by_ofnode(enum uclass_id id, ofnode node,
> }
> 
> #if CONFIG_IS_ENABLED(OF_CONTROL)
> +int uclass_get_device_by_phandle_id(enum uclass_id id, int phandle_id,
> +				    struct udevice **devp)
> +{
> +	struct udevice *dev;
> +	struct uclass *uc;
> +	int ret;
> +
> +	*devp = NULL;
> +	ret = uclass_get(id, &uc);
> +	if (ret)
> +		return ret;
> +
> +	ret = -ENODEV;
> +	list_for_each_entry(dev, &uc->dev_head, uclass_node) {
> +		uint phandle;
> +
> +		phandle = dev_read_phandle(dev);
> +
> +		if (phandle == phandle_id) {
> +			*devp = dev;
> +			ret = 0;
> +			break;

I would prefer if you directly called into the tail here…
…and didn’t set "ret = -ENODEV” above and returned the -ENODEV directly from below.

In other words, you could have
	return uclass_get_device_tail(dev, 0, devp);
here.

> +		}
> +	}
> +
> +	return uclass_get_device_tail(dev, ret, devp);
> +}
> +
> int uclass_get_device_by_phandle(enum uclass_id id, struct udevice *parent,
> 				 const char *name, struct udevice **devp)
> {
> diff --git a/include/dm/uclass.h b/include/dm/uclass.h
> index 1818849..f6fe785 100644
> --- a/include/dm/uclass.h
> +++ b/include/dm/uclass.h
> @@ -203,6 +203,22 @@ int uclass_get_device_by_ofnode(enum uclass_id id, ofnode node,
> 				struct udevice **devp);
> 
> /**
> + * uclass_get_device_by_phandle_id() - Get a uclass device by phandle id
> + *
> + * This searches the devices in the uclass for one with the given phandle id.
> + *
> + * The device is probed to activate it ready for use.
> + *
> + * @id: uclass ID to look up
> + * @phandle_id: the phandle id to look up
> + * @devp: Returns pointer to device (there is only one for each node)
> + * @return 0 if OK, -ENODEV if there is no device match the phandle, other
> + *	-ve on error
> + */
> +int uclass_get_device_by_phandle_id(enum uclass_id id, int phandle_id,
> +				    struct udevice **devp);
> +
> +/**
>  * uclass_get_device_by_phandle() - Get a uclass device by phandle
>  *
>  * This searches the devices in the uclass for one with the given phandle.
> -- 
> 1.9.1
> 



More information about the U-Boot mailing list