From: Jonathan Cameron <jic23@kernel.org>
To: Quentin Schulz <quentin.schulz@free-electrons.com>,
knaack.h@gmx.de, lars@metafoo.de, pmeerw@pmeerw.net,
robh+dt@kernel.org, mark.rutland@arm.com, wens@csie.org,
sre@kernel.org, linux@armlinux.org.uk,
maxime.ripard@free-electrons.com, lee.jones@linaro.org
Cc: linux-iio@vger.kernel.org, devicetree@vger.kernel.org,
linux-kernel@vger.kernel.org, linux-pm@vger.kernel.org,
linux-arm-kernel@lists.infradead.org,
thomas.petazzoni@free-electrons.com, icenowy@aosc.xyz,
bonbons@linux-vserver.org
Subject: Re: [PATCH v2 03/25] power: supply: axp20x_usb_power: use IIO channels when available
Date: Sat, 28 Jan 2017 14:36:49 +0000 [thread overview]
Message-ID: <625df2b3-3296-e7ac-b842-c104c7ea5907@kernel.org> (raw)
In-Reply-To: <20170127085458.18270-4-quentin.schulz@free-electrons.com>
On 27/01/17 08:54, Quentin Schulz wrote:
> The X-Powers AXP20X PMIC exposes the current current and voltage
> measures via an internal ADC.
>
> This adds the possibility to read IIO channels directly for processed
> values rather than reading the registers and computing the value.
>
> For backward compatibility purpose, if the IIO driver is not compiled,
> this driver will fall back on previous behaviour which is direct
> register readings.
>
> Signed-off-by: Quentin Schulz <quentin.schulz@free-electrons.com>
Acked-by: Jonathan Cameron <jic23@kernel.org>
I (or someone else) really needs to find time to deal with deferred probing
properly in the IIO core. It's a mess as we need to revisit how the
channel map stuff works to make sure it's always there...
Anyhow, it's still on the todo list and we can tidy this up if it ever
happens!
Jonathan
> ---
>
> added in v2
>
> drivers/power/supply/axp20x_usb_power.c | 70 +++++++++++++++++++++++++++++++--
> 1 file changed, 66 insertions(+), 4 deletions(-)
>
> diff --git a/drivers/power/supply/axp20x_usb_power.c b/drivers/power/supply/axp20x_usb_power.c
> index 1bcb025..d8b1dc6 100644
> --- a/drivers/power/supply/axp20x_usb_power.c
> +++ b/drivers/power/supply/axp20x_usb_power.c
> @@ -22,6 +22,7 @@
> #include <linux/power_supply.h>
> #include <linux/regmap.h>
> #include <linux/slab.h>
> +#include <linux/iio/consumer.h>
>
> #define DRVNAME "axp20x-usb-power-supply"
>
> @@ -49,6 +50,8 @@ struct axp20x_usb_power {
> struct regmap *regmap;
> struct power_supply *supply;
> int axp20x_id;
> + struct iio_channel *vbus_v;
> + struct iio_channel *vbus_i;
> };
>
> static irqreturn_t axp20x_usb_power_irq(int irq, void *devid)
> @@ -76,6 +79,20 @@ static int axp20x_usb_power_get_property(struct power_supply *psy,
> val->intval = AXP20X_VBUS_VHOLD_uV(v);
> return 0;
> case POWER_SUPPLY_PROP_VOLTAGE_NOW:
> + if (IS_ENABLED(CONFIG_AXP20X_ADC)) {
> + ret = iio_read_channel_processed(power->vbus_v,
> + &val->intval);
> + if (ret)
> + return ret;
> +
> + /*
> + * IIO framework gives mV but Power Supply framework
> + * gives uV.
> + */
> + val->intval *= 1000;
> + return 0;
> + }
> +
> ret = axp20x_read_variable_width(power->regmap,
> AXP20X_VBUS_V_ADC_H, 12);
> if (ret < 0)
> @@ -107,6 +124,20 @@ static int axp20x_usb_power_get_property(struct power_supply *psy,
> }
> return 0;
> case POWER_SUPPLY_PROP_CURRENT_NOW:
> + if (IS_ENABLED(CONFIG_AXP20X_ADC)) {
> + ret = iio_read_channel_processed(power->vbus_i,
> + &val->intval);
> + if (ret)
> + return ret;
> +
> + /*
> + * IIO framework gives mA but Power Supply framework
> + * gives uA.
> + */
> + val->intval *= 1000;
> + return 0;
> + }
> +
> ret = axp20x_read_variable_width(power->regmap,
> AXP20X_VBUS_I_ADC_H, 12);
> if (ret < 0)
> @@ -269,6 +300,36 @@ static const struct power_supply_desc axp22x_usb_power_desc = {
> .set_property = axp20x_usb_power_set_property,
> };
>
> +static int configure_iio_channels(struct platform_device *pdev,
> + struct axp20x_usb_power *power)
> +{
> + power->vbus_v = devm_iio_channel_get(&pdev->dev, "vbus_v");
> + if (IS_ERR(power->vbus_v)) {
> + if (PTR_ERR(power->vbus_v) == -ENODEV)
> + return -EPROBE_DEFER;
> + return PTR_ERR(power->vbus_v);
> + }
> +
> + power->vbus_i = devm_iio_channel_get(&pdev->dev, "vbus_i");
> + if (IS_ERR(power->vbus_i)) {
> + if (PTR_ERR(power->vbus_i) == -ENODEV)
> + return -EPROBE_DEFER;
> + return PTR_ERR(power->vbus_i);
> + }
> +
> + return 0;
> +}
> +
> +static int configure_adc_registers(struct axp20x_usb_power *power)
> +{
> + /* Enable vbus voltage and current measurement */
> + return regmap_update_bits(power->regmap, AXP20X_ADC_EN1,
> + AXP20X_ADC_EN1_VBUS_CURR |
> + AXP20X_ADC_EN1_VBUS_VOLT,
> + AXP20X_ADC_EN1_VBUS_CURR |
> + AXP20X_ADC_EN1_VBUS_VOLT);
> +}
> +
> static int axp20x_usb_power_probe(struct platform_device *pdev)
> {
> struct axp20x_dev *axp20x = dev_get_drvdata(pdev->dev.parent);
> @@ -307,10 +368,11 @@ static int axp20x_usb_power_probe(struct platform_device *pdev)
> if (ret)
> return ret;
>
> - /* Enable vbus voltage and current measurement */
> - ret = regmap_update_bits(power->regmap, AXP20X_ADC_EN1,
> - AXP20X_ADC_EN1_VBUS_CURR | AXP20X_ADC_EN1_VBUS_VOLT,
> - AXP20X_ADC_EN1_VBUS_CURR | AXP20X_ADC_EN1_VBUS_VOLT);
> + if (IS_ENABLED(CONFIG_AXP20X_ADC))
> + ret = configure_iio_channels(pdev, power);
> + else
> + ret = configure_adc_registers(power);
> +
> if (ret)
> return ret;
>
>
next prev parent reply other threads:[~2017-01-28 14:45 UTC|newest]
Thread overview: 51+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-01-27 8:54 [PATCH v2 00/25] add support for AXP20X and AXP22X power supply drivers Quentin Schulz
2017-01-27 8:54 ` [PATCH v2 01/25] dt-bindings: iio: adc: add AXP20X/AXP22X ADC DT binding Quentin Schulz
2017-01-27 8:54 ` [PATCH v2 02/25] mfd: axp20x: correct name of temperature data ADC registers Quentin Schulz
2017-01-27 9:30 ` Chen-Yu Tsai
2017-02-08 9:26 ` Lee Jones
2017-01-27 8:54 ` [PATCH v2 03/25] power: supply: axp20x_usb_power: use IIO channels when available Quentin Schulz
2017-01-28 14:36 ` Jonathan Cameron [this message]
2017-01-29 16:21 ` Sebastian Reichel
2017-01-27 8:54 ` [PATCH v2 04/25] iio: adc: add support for X-Powers AXP20X and AXP22X PMICs ADCs Quentin Schulz
2017-01-28 14:49 ` Jonathan Cameron
2017-01-28 15:12 ` Quentin Schulz
2017-01-28 15:34 ` Jonathan Cameron
2017-01-27 8:54 ` [PATCH v2 05/25] mfd: axp20x: add ADC cells for AXP20X and AXP22X PMICs Quentin Schulz
2017-01-27 8:54 ` [PATCH v2 06/25] ARM: dtsi: axp209: add AXP209 ADC subnode Quentin Schulz
2017-01-31 4:08 ` Chen-Yu Tsai
2017-01-27 8:54 ` [PATCH v2 07/25] ARM: dtsi: axp22x: add AXP22X " Quentin Schulz
2017-01-27 8:54 ` [PATCH v2 08/25] dt-bindings: power: supply: add AXP20X/AXP22X AC power supply Quentin Schulz
2017-01-29 16:22 ` Sebastian Reichel
2017-01-27 8:54 ` [PATCH v2 09/25] iio: adc: axp20x_adc: map acin_i and acin_v Quentin Schulz
2017-01-28 14:51 ` Jonathan Cameron
2017-01-29 16:31 ` Sebastian Reichel
2017-01-27 8:54 ` [PATCH v2 10/25] power: supply: add AC power supply driver for AXP20X and AXP22X PMICs Quentin Schulz
2017-01-29 16:25 ` Sebastian Reichel
2017-01-27 8:54 ` [PATCH v2 11/25] mfd: axp20x: add AC power supply cells for " Quentin Schulz
2017-01-29 16:35 ` Sebastian Reichel
2017-01-31 4:11 ` Chen-Yu Tsai
2017-01-27 8:54 ` [PATCH v2 12/25] ARM: dtsi: axp209: add AC power supply subnode Quentin Schulz
2017-01-31 4:12 ` Chen-Yu Tsai
2017-01-27 8:54 ` [PATCH v2 13/25] ARM: dtsi: axp22x: " Quentin Schulz
2017-01-31 4:13 ` Chen-Yu Tsai
2017-01-27 8:54 ` [PATCH v2 14/25] ARM: dts: sun8i: sina33: enable ACIN " Quentin Schulz
2017-01-31 5:03 ` Chen-Yu Tsai
2017-01-27 8:54 ` [PATCH v2 15/25] ARM: sun5i: chip: " Quentin Schulz
2017-01-31 5:03 ` Chen-Yu Tsai
2017-01-27 8:54 ` [PATCH v2 16/25] dt-bindings: power: supply: add AXP20X/AXP22X battery DT binding Quentin Schulz
2017-01-29 16:47 ` Sebastian Reichel
2017-01-31 7:59 ` Quentin Schulz
2017-01-27 8:54 ` [PATCH v2 17/25] mfd: axp20x: add CHRG_CTRL1/2/3 to writeable regs for AXP20X/AXP22X Quentin Schulz
2017-01-31 5:05 ` Chen-Yu Tsai
2017-01-27 8:54 ` [PATCH v2 18/25] mfd: axp20x: add V_OFF to writeable regs for AXP20X and AXP22X Quentin Schulz
2017-01-27 8:54 ` [PATCH v2 19/25] iio: adc: axp20x_adc: map battery IIO channels Quentin Schulz
2017-01-28 14:52 ` Jonathan Cameron
2017-01-31 5:06 ` Chen-Yu Tsai
2017-01-27 8:54 ` [PATCH v2 20/25] power: supply: add battery driver for AXP20X and AXP22X PMICs Quentin Schulz
2017-01-28 14:54 ` Jonathan Cameron
2017-01-27 8:54 ` [PATCH v2 21/25] mfd: axp20x: add MFD cells for AXP20X and AXP22X battery driver Quentin Schulz
2017-01-27 8:54 ` [PATCH v2 22/25] ARM: dtsi: axp209: add battery power supply subnode Quentin Schulz
2017-01-27 8:54 ` [PATCH v2 23/25] ARM: dtsi: axp22x: " Quentin Schulz
2017-01-27 8:54 ` [PATCH v2 24/25] ARM: dts: sun8i: sina33: enable " Quentin Schulz
2017-01-27 8:54 ` [PATCH v2 25/25] ARM: sun5i: chip: " Quentin Schulz
2017-01-27 9:19 ` [PATCH v2 00/25] add support for AXP20X and AXP22X power supply drivers Maxime Ripard
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=625df2b3-3296-e7ac-b842-c104c7ea5907@kernel.org \
--to=jic23@kernel.org \
--cc=bonbons@linux-vserver.org \
--cc=devicetree@vger.kernel.org \
--cc=icenowy@aosc.xyz \
--cc=knaack.h@gmx.de \
--cc=lars@metafoo.de \
--cc=lee.jones@linaro.org \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-iio@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-pm@vger.kernel.org \
--cc=linux@armlinux.org.uk \
--cc=mark.rutland@arm.com \
--cc=maxime.ripard@free-electrons.com \
--cc=pmeerw@pmeerw.net \
--cc=quentin.schulz@free-electrons.com \
--cc=robh+dt@kernel.org \
--cc=sre@kernel.org \
--cc=thomas.petazzoni@free-electrons.com \
--cc=wens@csie.org \
/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