From: Rajendra Nayak <rnayak@ti.com>
To: Axel Lin <axel.lin@gmail.com>
Cc: Mark Brown <broonie@opensource.wolfsonmicro.com>,
Peter Ujfalusi <peter.ujfalusi@ti.com>,
Liam Girdwood <lrg@ti.com>,
linux-kernel@vger.kernel.org, loml <linux-omap@vger.kernel.org>,
Graeme Gregory <gg@slimlogic.co.uk>
Subject: Re: [PATCH RFT] regulator: twl: Fix list_voltate for twl6030ldo_ops
Date: Mon, 16 Jul 2012 17:38:32 +0530 [thread overview]
Message-ID: <50040440.80703@ti.com> (raw)
In-Reply-To: <1342434670.4717.6.camel@phoenix>
Axel,
On Monday 16 July 2012 04:01 PM, Axel Lin wrote:
> According to the datasheet, the voltage for twl6030ldo_ops is not linear for
> all cases. Linear mapping is only for the selection code from
> 00000001 to 00011000.
>
> Table 9. LDO Output Voltage Selection Code
> CODE VOUT(V) COD VOUT(V) CODE VOUT(V) CODE VOUT(V)
> 00000000 0 00001000 1.7 00010000 2.5 00011000 3.3
> 00000001 1.0 00001001 1.8 00010001 2.6 00011001 Reserved
> 00000010 1.1 00001010 1.9 00010010 2.7 00011010 Reserved
> 00000011 1.2 00001011 2.0 00010011 2.8 00011011 Reserved
> 00000100 1.3 00001100 2.1 00010100 2.9 00011100 Reserved
> 00000101 1.4 00001101 2.2 00010101 3.0 00011101 Reserved
> 00000110 1.5 00001110 2.3 00010110 3.1 00011110 Reserved
> 00000111 1.6 00001111 2.4 00010111 3.2 00011111 2.75
>
> This patch implements the list_voltage callback based on above table.
>
> Signed-off-by: Axel Lin<axel.lin@gmail.com>
Seems to work fine on my 4460 Panda.
Without this fix..
[ 0.337341] V1V8: 1800 mV normal standby
[ 0.338531] V2V1: 2100 mV normal standby
[ 0.339813] VMMC: 1200 <--> 3000 mV at 3100 mV normal standby
^^^^^^^^
[ 0.341278] VPP: 1800 <--> 2500 mV at 2000 mV normal standby
^^^^^^^^^
[ 0.343505] VCXIO: 1800 mV normal standby
[ 0.343597] VCXIO: supplied by V2V1
[ 0.345855] VDAC: 1800 mV normal standby
[ 0.345947] VDAC: supplied by V2V1
[ 0.347717] VAUX2_6030: 1200 <--> 2800 mV at 1900 mV normal standby
^^^^^^^^
[ 0.349212] VAUX3_6030: 1000 <--> 3000 mV at 1300 mV normal standby
^^^^^^^^
And with the fix..
[ 0.337707] V1V8: 1800 mV normal standby
[ 0.338897] V2V1: 2100 mV normal standby
[ 0.340179] VMMC: 1200 <--> 3000 mV at 3000 mV normal standby
[ 0.341674] VPP: 1800 <--> 2500 mV at 1900 mV normal standby
[ 0.343383] VCXIO: 1800 mV normal standby
[ 0.343475] VCXIO: supplied by V2V1
[ 0.345764] VDAC: 1800 mV normal standby
[ 0.345825] VDAC: supplied by V2V1
[ 0.347656] VAUX2_6030: 1200 <--> 2800 mV at 1800 mV normal standby
[ 0.349121] VAUX3_6030: 1000 <--> 3000 mV at 1200 mV normal standby
Thanks for the patch.
Tested-by: Rajendra Nayak <rnayak@ti.com>
> ---
> drivers/regulator/twl-regulator.c | 31 ++++++++++++++++++++++++-------
> 1 file changed, 24 insertions(+), 7 deletions(-)
>
> diff --git a/drivers/regulator/twl-regulator.c b/drivers/regulator/twl-regulator.c
> index de99b78..242fe90 100644
> --- a/drivers/regulator/twl-regulator.c
> +++ b/drivers/regulator/twl-regulator.c
> @@ -559,6 +559,27 @@ static struct regulator_ops twl6030coresmps_ops = {
> .get_voltage = twl6030coresmps_get_voltage,
> };
>
> +static int twl6030ldo_list_voltage(struct regulator_dev *rdev, unsigned sel)
> +{
> + struct twlreg_info *info = rdev_get_drvdata(rdev);
> +
> + switch (sel) {
> + case 0:
> + return 0;
> + case 1 ... 24:
> + /* Linear mapping from 00000001 to 00011000:
> + * Absolute voltage value = 1.0 V + 0.1 V × (sel – 00000001)
> + */
> + return (info->min_mV + 100 * (sel - 1)) * 1000;
> + case 25 ... 30:
> + return -EINVAL;
> + case 31:
> + return 2750000;
> + default:
> + return -EINVAL;
> + }
> +}
> +
> static int
> twl6030ldo_set_voltage_sel(struct regulator_dev *rdev, unsigned selector)
> {
> @@ -577,7 +598,7 @@ static int twl6030ldo_get_voltage_sel(struct regulator_dev *rdev)
> }
>
> static struct regulator_ops twl6030ldo_ops = {
> - .list_voltage = regulator_list_voltage_linear,
> + .list_voltage = twl6030ldo_list_voltage,
>
> .set_voltage_sel = twl6030ldo_set_voltage_sel,
> .get_voltage_sel = twl6030ldo_get_voltage_sel,
> @@ -906,12 +927,10 @@ static struct twlreg_info TWL6030_INFO_##label = { \
> .desc = { \
> .name = #label, \
> .id = TWL6030_REG_##label, \
> - .n_voltages = (max_mVolts - min_mVolts)/100 + 1, \
> + .n_voltages = 32, \
> .ops =&twl6030ldo_ops, \
> .type = REGULATOR_VOLTAGE, \
> .owner = THIS_MODULE, \
> - .min_uV = min_mVolts * 1000, \
> - .uV_step = 100 * 1000, \
> }, \
> }
>
> @@ -923,12 +942,10 @@ static struct twlreg_info TWL6025_INFO_##label = { \
> .desc = { \
> .name = #label, \
> .id = TWL6025_REG_##label, \
> - .n_voltages = ((max_mVolts - min_mVolts)/100) + 1, \
> + .n_voltages = 32, \
> .ops =&twl6030ldo_ops, \
> .type = REGULATOR_VOLTAGE, \
> .owner = THIS_MODULE, \
> - .min_uV = min_mVolts * 1000, \
> - .uV_step = 100 * 1000, \
> }, \
> }
>
next prev parent reply other threads:[~2012-07-16 12:08 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-07-16 10:31 [PATCH RFT] regulator: twl: Fix list_voltate for twl6030ldo_ops Axel Lin
2012-07-16 12:08 ` Rajendra Nayak [this message]
2012-07-16 12:11 ` Rajendra Nayak
2012-07-16 19:58 ` Mark Brown
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=50040440.80703@ti.com \
--to=rnayak@ti.com \
--cc=axel.lin@gmail.com \
--cc=broonie@opensource.wolfsonmicro.com \
--cc=gg@slimlogic.co.uk \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-omap@vger.kernel.org \
--cc=lrg@ti.com \
--cc=peter.ujfalusi@ti.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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.