[U-Boot] [PATCH 14/25] power domain: Add support for multiple powerdomains per device

Lokesh Vutla lokeshvutla at ti.com
Wed Aug 22 09:21:35 UTC 2018



On Tuesday 21 August 2018 08:01 PM, Lokesh Vutla wrote:
> There are cases where there are more than one power domain
> attached to the device inorder to get the device functional.
> So add support for enabling power domain based on the index.
> 
> Signed-off-by: Lokesh Vutla <lokeshvutla at ti.com>
> ---
>  drivers/power/domain/power-domain-uclass.c | 11 +++++++++--
>  include/power-domain.h                     | 19 +++++++++++++++++++
>  2 files changed, 28 insertions(+), 2 deletions(-)
> 
> diff --git a/drivers/power/domain/power-domain-uclass.c b/drivers/power/domain/power-domain-uclass.c
> index 9e9ec4f419..2ea0ff24c7 100644
> --- a/drivers/power/domain/power-domain-uclass.c
> +++ b/drivers/power/domain/power-domain-uclass.c
> @@ -28,7 +28,8 @@ static int power_domain_of_xlate_default(struct power_domain *power_domain,
>  	return 0;
>  }
>  
> -int power_domain_get(struct udevice *dev, struct power_domain *power_domain)
> +int power_domain_get_by_index(struct udevice *dev,
> +			      struct power_domain *power_domain, int index)
>  {
>  	struct ofnode_phandle_args args;
>  	int ret;
> @@ -38,7 +39,8 @@ int power_domain_get(struct udevice *dev, struct power_domain *power_domain)
>  	debug("%s(dev=%p, power_domain=%p)\n", __func__, dev, power_domain);
>  
>  	ret = dev_read_phandle_with_args(dev, "power-domains",
> -					 "#power-domain-cells", 0, 0, &args);
> +					 "#power-domain-cells", 0, index,
> +					 &args);
>  	if (ret) {
>  		debug("%s: dev_read_phandle_with_args failed: %d\n",
>  		      __func__, ret);
> @@ -73,6 +75,11 @@ int power_domain_get(struct udevice *dev, struct power_domain *power_domain)
>  	return 0;
>  }
>  
> +int power_domain_get(struct udevice *dev, struct power_domain *power_domain)
> +{
> +	return power_domain_get_by_index(dev, power_domain, 0);
> +}
> +
>  int power_domain_free(struct power_domain *power_domain)
>  {
>  	struct power_domain_ops *ops = power_domain_dev_ops(power_domain->dev);
> diff --git a/include/power-domain.h b/include/power-domain.h
> index a558fbbdb2..0c6d77e813 100644
> --- a/include/power-domain.h
> +++ b/include/power-domain.h
> @@ -97,6 +97,25 @@ int power_domain_get(struct udevice *dev, struct power_domain *power_domain)
>  }
>  #endif
>  
> +/**
> + * power_domain_get_by_index - Get the indexed power domain for a device.
> + *
> + * @dev:		The client device.
> + * @power_domain:	A pointer to a power domain struct to initialize.
> + * @index:		Power domain index to be powered on.
> + *
> + * @return 0 if OK, or a negative error code.
> + */
> +#if CONFIG_IS_ENABLED(POWER_DOMAIN)
> +int power_domain_get_by_index(struct udevice *dev,
> +			      struct power_domain *power_domain, int index);
> +#else
> +int power_domain_get_by_index(struct udevice *dev,
> +			      struct power_domain *power_domain, int index)

Looks like I missed open braces "{" here. Will wait for some more time
and post a v2.

Thanks and regards,
Lokesh

> +	return -ENOSYS;
> +}
> +#endif
> +
>  /**
>   * power_domain_free - Free a previously requested power domain.
>   *
> 


More information about the U-Boot mailing list