linux-pm.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Hans de Goede <hdegoede@redhat.com>
To: Liam Breck <liam@networkimprov.net>,
	Sebastian Reichel <sre@kernel.org>,
	linux-pm@vger.kernel.org
Cc: Tony Lindgren <tony@atomide.com>, Liam Breck <kernel@networkimprov.net>
Subject: Re: [PATCH v3 3/5] power: bq24190_charger: Enable devicetree config
Date: Mon, 28 Aug 2017 14:13:05 +0200	[thread overview]
Message-ID: <5087e892-e90f-5868-9b3d-01edba6f101b@redhat.com> (raw)
In-Reply-To: <20170826051413.24569-4-liam@networkimprov.net>

Hi,

On 26-08-17 07:14, Liam Breck wrote:
> From: Liam Breck <kernel@networkimprov.net>
> 
> Add get_config(). Rename set_mode_host() to set_config().
> Call get_config() and hw_init() after power_supply_register().
> No functional changes.

Doing hw_init after power_supply_register() means that userspace
can get/set power_supply properties before hw_init has run, this
generally is not a good idea.

> 
> Cc: Tony Lindgren <tony@atomide.com>
> Cc: Hans de Goede <hdegoede@redhat.com>
> Signed-off-by: Liam Breck <kernel@networkimprov.net>
> ---
>   drivers/power/supply/bq24190_charger.c | 63 +++++++++++++++++++++++-----------
>   1 file changed, 43 insertions(+), 20 deletions(-)
> 
> diff --git a/drivers/power/supply/bq24190_charger.c b/drivers/power/supply/bq24190_charger.c
> index 40b4bba7..c6be00d7 100644
> --- a/drivers/power/supply/bq24190_charger.c
> +++ b/drivers/power/supply/bq24190_charger.c
> @@ -504,15 +504,7 @@ static int bq24190_sysfs_create_group(struct bq24190_dev_info *bdi)
>   static inline void bq24190_sysfs_remove_group(struct bq24190_dev_info *bdi) {}
>   #endif
>   
> -/*
> - * According to the "Host Mode and default Mode" section of the
> - * manual, a write to any register causes the bq24190 to switch
> - * from default mode to host mode.  It will switch back to default
> - * mode after a WDT timeout unless the WDT is turned off as well.
> - * So, by simply turning off the WDT, we accomplish both with the
> - * same write.
> - */
> -static int bq24190_set_mode_host(struct bq24190_dev_info *bdi)
> +static int bq24190_set_config(struct bq24190_dev_info *bdi)
>   {
>   	int ret;
>   	u8 v;
> @@ -523,9 +515,22 @@ static int bq24190_set_mode_host(struct bq24190_dev_info *bdi)
>   
>   	bdi->watchdog = ((v & BQ24190_REG_CTTC_WATCHDOG_MASK) >>
>   					BQ24190_REG_CTTC_WATCHDOG_SHIFT);
> +
> +	/*
> +	 * According to the "Host Mode and default Mode" section of the
> +	 * manual, a write to any register causes the bq24190 to switch
> +	 * from default mode to host mode.  It will switch back to default
> +	 * mode after a WDT timeout unless the WDT is turned off as well.
> +	 * So, by simply turning off the WDT, we accomplish both with the
> +	 * same write.
> +	 */
>   	v &= ~BQ24190_REG_CTTC_WATCHDOG_MASK;
>   
> -	return bq24190_write(bdi, BQ24190_REG_CTTC, v);
> +	ret = bq24190_write(bdi, BQ24190_REG_CTTC, v);
> +	if (ret < 0)
> +		return ret;
> +
> +	return 0;
>   }
>   
>   static int bq24190_register_reset(struct bq24190_dev_info *bdi)
> @@ -1456,13 +1461,25 @@ static int bq24190_hw_init(struct bq24190_dev_info *bdi)
>   	if (ret < 0)
>   		return ret;
>   
> -	ret = bq24190_set_mode_host(bdi);
> +	ret = bq24190_set_config(bdi);
>   	if (ret < 0)
>   		return ret;
>   
>   	return bq24190_read(bdi, BQ24190_REG_SS, &bdi->ss_reg);
>   }
>   
> +static int bq24190_get_config(struct bq24190_dev_info *bdi)
> +{
> +#ifdef CONFIG_OF
> +	int v;

This variable is unused (in this patch)

> +
> +	if (!bdi->dev->of_node)
> +		return -EINVAL;

I don't think that this is a good idea, at least on ARM
(AFAIK) a kernel can be configured to support both DT and
ACPI, just having CONFIG_OF enabled as such is not a good
reason to fail to probe when there is no of_node.

IMHO it would be better to instead put the reading of the
"ti,system-minimum-microvolt" property introduced in the next
patch inside a: if (bdi->dev->of_node) { ... } block.

> +
> +#endif
> +	return 0;
> +}
> +
>   static int bq24190_probe(struct i2c_client *client,
>   		const struct i2c_device_id *id)
>   {
> @@ -1493,7 +1510,7 @@ static int bq24190_probe(struct i2c_client *client,
>   
>   	i2c_set_clientdata(client, bdi);
>   
> -	if (!client->irq) {
> +	if (client->irq <= 0) {
>   		dev_err(dev, "Can't get irq info\n");
>   		return -EINVAL;
>   	}
> @@ -1526,12 +1543,6 @@ static int bq24190_probe(struct i2c_client *client,
>   		goto out_pmrt;
>   	}
>   
> -	ret = bq24190_hw_init(bdi);
> -	if (ret < 0) {
> -		dev_err(dev, "Hardware init failed\n");
> -		goto out_pmrt;
> -	}
> -
>   	charger_cfg.drv_data = bdi;
>   	charger_cfg.supplied_to = bq24190_charger_supplied_to;
>   	charger_cfg.num_supplicants = ARRAY_SIZE(bq24190_charger_supplied_to),
> @@ -1556,8 +1567,20 @@ static int bq24190_probe(struct i2c_client *client,
>   		}
>   	}
>   
> +	ret = bq24190_get_config(bdi);
> +	if (ret < 0) {
> +		dev_err(dev, "Can't get devicetree config\n");
> +		goto out_charger;
> +	}
> +
> +	ret = bq24190_hw_init(bdi);
> +	if (ret < 0) {
> +		dev_err(dev, "Hardware init failed\n");
> +		goto out_charger;
> +	}
> +
>   	ret = bq24190_sysfs_create_group(bdi);
> -	if (ret) {
> +	if (ret < 0) {
>   		dev_err(dev, "Can't create sysfs entries\n");
>   		goto out_charger;
>   	}
> @@ -1700,7 +1723,7 @@ static __maybe_unused int bq24190_pm_resume(struct device *dev)
>   	}
>   
>   	bq24190_register_reset(bdi);
> -	bq24190_set_mode_host(bdi);
> +	bq24190_set_config(bdi);
>   	bq24190_read(bdi, BQ24190_REG_SS, &bdi->ss_reg);
>   
>   	if (error >= 0) {
> 

Regards,

Hans

  reply	other threads:[~2017-08-28 12:13 UTC|newest]

Thread overview: 13+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2017-08-26  5:14 [PATCH v3 0/5] BQ24190 devicetree config Liam Breck
2017-08-26  5:14 ` [PATCH v3 1/5] power: bq24190_charger: Add ti,bq24192i to devicetree table Liam Breck
2017-08-28 15:59   ` Tony Lindgren
     [not found] ` <20170826051413.24569-1-liam-RYWXG+zxWwBdeoIcmNTgJF6hYfS7NtTn@public.gmane.org>
2017-08-26  5:14   ` [PATCH v3 2/5] devicetree: power: Add docs for TI BQ24190 battery charger Liam Breck
2017-08-28 16:00     ` Tony Lindgren
2017-08-26  5:14 ` [PATCH v3 3/5] power: bq24190_charger: Enable devicetree config Liam Breck
2017-08-28 12:13   ` Hans de Goede [this message]
2017-08-28 17:59     ` Liam Breck
2017-08-28 19:09       ` Hans de Goede
2017-08-26  5:14 ` [PATCH v3 4/5] power: bq24190_charger: Add property system-minimum-microvolt Liam Breck
2017-08-28 16:01   ` Tony Lindgren
2017-08-26  5:14 ` [PATCH v3 5/5] power: bq24190_charger: Add power_supply_battery_info support Liam Breck
2017-08-28 16:02   ` Tony Lindgren

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=5087e892-e90f-5868-9b3d-01edba6f101b@redhat.com \
    --to=hdegoede@redhat.com \
    --cc=kernel@networkimprov.net \
    --cc=liam@networkimprov.net \
    --cc=linux-pm@vger.kernel.org \
    --cc=sre@kernel.org \
    --cc=tony@atomide.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).