All of lore.kernel.org
 help / color / mirror / Atom feed
* [U-Boot] [PATCH] power: regulator: Add limits checking while setting voltage and current
@ 2016-09-15  8:54 ` Keerthy
  2016-09-15 10:56   ` Przemyslaw Marczak
  0 siblings, 1 reply; 7+ messages in thread
From: Keerthy @ 2016-09-15  8:54 UTC (permalink / raw)
  To: u-boot

Currently the specific set ops functions are directly
called without any check for voltage/current limits for a regulator.
Check for them and proceed.

Signed-off-by: Keerthy <j-keerthy@ti.com>
---
 drivers/power/regulator/regulator-uclass.c | 10 ++++++++++
 1 file changed, 10 insertions(+)

diff --git a/drivers/power/regulator/regulator-uclass.c b/drivers/power/regulator/regulator-uclass.c
index 4434e36..089455e 100644
--- a/drivers/power/regulator/regulator-uclass.c
+++ b/drivers/power/regulator/regulator-uclass.c
@@ -41,6 +41,11 @@ int regulator_get_value(struct udevice *dev)
 int regulator_set_value(struct udevice *dev, int uV)
 {
 	const struct dm_regulator_ops *ops = dev_get_driver_ops(dev);
+	struct dm_regulator_uclass_platdata *uc_pdata;
+
+	uc_pdata = dev_get_uclass_platdata(dev);
+	if (uV < uc_pdata->min_uV || uV > uc_pdata->max_uV)
+		return -EINVAL;
 
 	if (!ops || !ops->set_value)
 		return -ENOSYS;
@@ -61,6 +66,11 @@ int regulator_get_current(struct udevice *dev)
 int regulator_set_current(struct udevice *dev, int uA)
 {
 	const struct dm_regulator_ops *ops = dev_get_driver_ops(dev);
+	struct dm_regulator_uclass_platdata *uc_pdata;
+
+	uc_pdata = dev_get_uclass_platdata(dev);
+	if (uA < uc_pdata->min_uA || uA > uc_pdata->max_uA)
+		return -EINVAL;
 
 	if (!ops || !ops->set_current)
 		return -ENOSYS;
-- 
1.9.1

^ permalink raw reply related	[flat|nested] 7+ messages in thread

* [U-Boot] [PATCH] power: regulator: Add limits checking while setting voltage and current
  2016-09-15  8:54 ` [U-Boot] [PATCH] power: regulator: Add limits checking while setting voltage and current Keerthy
@ 2016-09-15 10:56   ` Przemyslaw Marczak
  2016-09-15 11:08     ` Keerthy
  0 siblings, 1 reply; 7+ messages in thread
From: Przemyslaw Marczak @ 2016-09-15 10:56 UTC (permalink / raw)
  To: u-boot

Hello Keerthy,

On 09/15/2016 10:54 AM, Keerthy wrote:
> Currently the specific set ops functions are directly
> called without any check for voltage/current limits for a regulator.
> Check for them and proceed.
>
> Signed-off-by: Keerthy <j-keerthy@ti.com>
> ---
>   drivers/power/regulator/regulator-uclass.c | 10 ++++++++++
>   1 file changed, 10 insertions(+)
>
> diff --git a/drivers/power/regulator/regulator-uclass.c b/drivers/power/regulator/regulator-uclass.c
> index 4434e36..089455e 100644
> --- a/drivers/power/regulator/regulator-uclass.c
> +++ b/drivers/power/regulator/regulator-uclass.c
> @@ -41,6 +41,11 @@ int regulator_get_value(struct udevice *dev)
>   int regulator_set_value(struct udevice *dev, int uV)
>   {
>   	const struct dm_regulator_ops *ops = dev_get_driver_ops(dev);
> +	struct dm_regulator_uclass_platdata *uc_pdata;
> +
> +	uc_pdata = dev_get_uclass_platdata(dev);
> +	if (uV < uc_pdata->min_uV || uV > uc_pdata->max_uV)
> +		return -EINVAL;
>   
>   	if (!ops || !ops->set_value)
>   		return -ENOSYS;
> @@ -61,6 +66,11 @@ int regulator_get_current(struct udevice *dev)
>   int regulator_set_current(struct udevice *dev, int uA)
>   {
>   	const struct dm_regulator_ops *ops = dev_get_driver_ops(dev);
> +	struct dm_regulator_uclass_platdata *uc_pdata;
> +
> +	uc_pdata = dev_get_uclass_platdata(dev);
> +	if (uA < uc_pdata->min_uA || uA > uc_pdata->max_uA)
> +		return -EINVAL;
>   
>   	if (!ops || !ops->set_current)
>   		return -ENOSYS;

Adding those two checks will conflict with "force" option for 
cmd/regulator.c:283.
There was value range checking in the command's code, but it was left 
unchecked
for regulator direct calls.

This change is good, but then maybe the "force" option should be removed 
from command,
or API's prototypes should be updated by force flag argument?

I assumed that this option could be useful for quick over-voltage 
setting (until reboot),
since usually (min_uV == max_uV) - the voltage can't be changed in any 
range.

The driver should take care about ignore it or not, however probably 
nobody used this.

Of course this could potentially damage the device by wrong use,
which can be also made by passing the force flag as an argument - by 
mistake.

What do you thing about, update the dm_regulator_ops by:

  - int (*set_value)(struct udevice *dev, int uV, int flag);
  - int (*set_current)(struct udevice *dev, int uA, int flag);

and also new flag to the present defined:

  - REGULATOR_FLAG_FORCE = 1 << 2

This requires more work, but will provide the functionality in a proper way.

Best regards,

-- 
Przemyslaw Marczak
Samsung R&D Institute Poland
Samsung Electronics
p.marczak@samsung.com

^ permalink raw reply	[flat|nested] 7+ messages in thread

* [U-Boot] [PATCH] power: regulator: Add limits checking while setting voltage and current
  2016-09-15 10:56   ` Przemyslaw Marczak
@ 2016-09-15 11:08     ` Keerthy
  2016-09-15 11:16       ` Keerthy
  0 siblings, 1 reply; 7+ messages in thread
From: Keerthy @ 2016-09-15 11:08 UTC (permalink / raw)
  To: u-boot



On Thursday 15 September 2016 04:26 PM, Przemyslaw Marczak wrote:
> Hello Keerthy,
>
> On 09/15/2016 10:54 AM, Keerthy wrote:
>> Currently the specific set ops functions are directly
>> called without any check for voltage/current limits for a regulator.
>> Check for them and proceed.
>>
>> Signed-off-by: Keerthy <j-keerthy@ti.com>
>> ---
>>   drivers/power/regulator/regulator-uclass.c | 10 ++++++++++
>>   1 file changed, 10 insertions(+)
>>
>> diff --git a/drivers/power/regulator/regulator-uclass.c
>> b/drivers/power/regulator/regulator-uclass.c
>> index 4434e36..089455e 100644
>> --- a/drivers/power/regulator/regulator-uclass.c
>> +++ b/drivers/power/regulator/regulator-uclass.c
>> @@ -41,6 +41,11 @@ int regulator_get_value(struct udevice *dev)
>>   int regulator_set_value(struct udevice *dev, int uV)
>>   {
>>       const struct dm_regulator_ops *ops = dev_get_driver_ops(dev);
>> +    struct dm_regulator_uclass_platdata *uc_pdata;
>> +
>> +    uc_pdata = dev_get_uclass_platdata(dev);
>> +    if (uV < uc_pdata->min_uV || uV > uc_pdata->max_uV)
>> +        return -EINVAL;
>>         if (!ops || !ops->set_value)
>>           return -ENOSYS;
>> @@ -61,6 +66,11 @@ int regulator_get_current(struct udevice *dev)
>>   int regulator_set_current(struct udevice *dev, int uA)
>>   {
>>       const struct dm_regulator_ops *ops = dev_get_driver_ops(dev);
>> +    struct dm_regulator_uclass_platdata *uc_pdata;
>> +
>> +    uc_pdata = dev_get_uclass_platdata(dev);
>> +    if (uA < uc_pdata->min_uA || uA > uc_pdata->max_uA)
>> +        return -EINVAL;
>>         if (!ops || !ops->set_current)
>>           return -ENOSYS;
>
> Adding those two checks will conflict with "force" option for
> cmd/regulator.c:283.
> There was value range checking in the command's code, but it was left
> unchecked
> for regulator direct calls.
>
> This change is good, but then maybe the "force" option should be removed
> from command,
> or API's prototypes should be updated by force flag argument?
>
> I assumed that this option could be useful for quick over-voltage
> setting (until reboot),
> since usually (min_uV == max_uV) - the voltage can't be changed in any
> range.
>
> The driver should take care about ignore it or not, however probably
> nobody used this.
>
> Of course this could potentially damage the device by wrong use,
> which can be also made by passing the force flag as an argument - by
> mistake.
>
> What do you thing about, update the dm_regulator_ops by:
>
>  - int (*set_value)(struct udevice *dev, int uV, int flag);
>  - int (*set_current)(struct udevice *dev, int uA, int flag);
>
> and also new flag to the present defined:
>
>  - REGULATOR_FLAG_FORCE = 1 << 2
>
> This requires more work, but will provide the functionality in a proper
> way.

I do not know cmd_regulator is the right place to check for min_uV and 
max_uV. dm_regulator_uclass_platdata has both the limits and this i feel 
is a perfectly valid check in generic place else we would be again 
checking for the same condition in every possible regulator specific 
drivers.

As far as the force option is concerned that i believe is more for 
testing and like you said can be implemented by setting a flag.

Just take a simple case of say a driver like mmc which unknowingly 
requests a wrong voltage and the base driver has no check against min 
and max voltages and assuming the regulator driver goes ahead and sets a 
very high voltage. That can be catastrophic right?

>
> Best regards,
>

^ permalink raw reply	[flat|nested] 7+ messages in thread

* [U-Boot] [PATCH] power: regulator: Add limits checking while setting voltage and current
  2016-09-15 11:08     ` Keerthy
@ 2016-09-15 11:16       ` Keerthy
  2016-10-11  0:19         ` Simon Glass
  0 siblings, 1 reply; 7+ messages in thread
From: Keerthy @ 2016-09-15 11:16 UTC (permalink / raw)
  To: u-boot



On Thursday 15 September 2016 04:38 PM, Keerthy wrote:
>
>
> On Thursday 15 September 2016 04:26 PM, Przemyslaw Marczak wrote:
>> Hello Keerthy,
>>
>> On 09/15/2016 10:54 AM, Keerthy wrote:
>>> Currently the specific set ops functions are directly
>>> called without any check for voltage/current limits for a regulator.
>>> Check for them and proceed.
>>>
>>> Signed-off-by: Keerthy <j-keerthy@ti.com>
>>> ---
>>>   drivers/power/regulator/regulator-uclass.c | 10 ++++++++++
>>>   1 file changed, 10 insertions(+)
>>>
>>> diff --git a/drivers/power/regulator/regulator-uclass.c
>>> b/drivers/power/regulator/regulator-uclass.c
>>> index 4434e36..089455e 100644
>>> --- a/drivers/power/regulator/regulator-uclass.c
>>> +++ b/drivers/power/regulator/regulator-uclass.c
>>> @@ -41,6 +41,11 @@ int regulator_get_value(struct udevice *dev)
>>>   int regulator_set_value(struct udevice *dev, int uV)
>>>   {
>>>       const struct dm_regulator_ops *ops = dev_get_driver_ops(dev);
>>> +    struct dm_regulator_uclass_platdata *uc_pdata;
>>> +
>>> +    uc_pdata = dev_get_uclass_platdata(dev);
>>> +    if (uV < uc_pdata->min_uV || uV > uc_pdata->max_uV)
>>> +        return -EINVAL;
>>>         if (!ops || !ops->set_value)
>>>           return -ENOSYS;
>>> @@ -61,6 +66,11 @@ int regulator_get_current(struct udevice *dev)
>>>   int regulator_set_current(struct udevice *dev, int uA)
>>>   {
>>>       const struct dm_regulator_ops *ops = dev_get_driver_ops(dev);
>>> +    struct dm_regulator_uclass_platdata *uc_pdata;
>>> +
>>> +    uc_pdata = dev_get_uclass_platdata(dev);
>>> +    if (uA < uc_pdata->min_uA || uA > uc_pdata->max_uA)
>>> +        return -EINVAL;
>>>         if (!ops || !ops->set_current)
>>>           return -ENOSYS;
>>
>> Adding those two checks will conflict with "force" option for
>> cmd/regulator.c:283.
>> There was value range checking in the command's code, but it was left
>> unchecked
>> for regulator direct calls.
>>
>> This change is good, but then maybe the "force" option should be removed
>> from command,
>> or API's prototypes should be updated by force flag argument?
>>
>> I assumed that this option could be useful for quick over-voltage
>> setting (until reboot),
>> since usually (min_uV == max_uV) - the voltage can't be changed in any
>> range.
>>
>> The driver should take care about ignore it or not, however probably
>> nobody used this.
>>
>> Of course this could potentially damage the device by wrong use,
>> which can be also made by passing the force flag as an argument - by
>> mistake.
>>
>> What do you thing about, update the dm_regulator_ops by:
>>
>>  - int (*set_value)(struct udevice *dev, int uV, int flag);
>>  - int (*set_current)(struct udevice *dev, int uA, int flag);

I personally do not like setting an extra flag everywhere just because 
we want to support force option.

I would rather have 2 functions like:

int (*force_set_value)(struct udevice *dev, int uV);
int (*force_set_current)(struct udevice *dev, int uA);

Where we can set the value ignoring the limits. But again that must be 
used with at most caution as setting higher voltages might end up 
damaging the device.

>>
>> and also new flag to the present defined:
>>
>>  - REGULATOR_FLAG_FORCE = 1 << 2
>>
>> This requires more work, but will provide the functionality in a proper
>> way.
>
> I do not know cmd_regulator is the right place to check for min_uV and
> max_uV. dm_regulator_uclass_platdata has both the limits and this i feel
> is a perfectly valid check in generic place else we would be again
> checking for the same condition in every possible regulator specific
> drivers.
>
> As far as the force option is concerned that i believe is more for
> testing and like you said can be implemented by setting a flag.
>
> Just take a simple case of say a driver like mmc which unknowingly
> requests a wrong voltage and the base driver has no check against min
> and max voltages and assuming the regulator driver goes ahead and sets a
> very high voltage. That can be catastrophic right?
>
>>
>> Best regards,
>>

^ permalink raw reply	[flat|nested] 7+ messages in thread

* [U-Boot] [PATCH] power: regulator: Add limits checking while setting voltage and current
  2016-09-15 11:16       ` Keerthy
@ 2016-10-11  0:19         ` Simon Glass
  2016-10-12  5:44           ` Keerthy
  0 siblings, 1 reply; 7+ messages in thread
From: Simon Glass @ 2016-10-11  0:19 UTC (permalink / raw)
  To: u-boot

Hi Keerthy,

On 15 September 2016 at 05:16, Keerthy <a0393675@ti.com> wrote:
>
>
> On Thursday 15 September 2016 04:38 PM, Keerthy wrote:
>>
>>
>>
>> On Thursday 15 September 2016 04:26 PM, Przemyslaw Marczak wrote:
>>>
>>> Hello Keerthy,
>>>
>>> On 09/15/2016 10:54 AM, Keerthy wrote:
>>>>
>>>> Currently the specific set ops functions are directly
>>>> called without any check for voltage/current limits for a regulator.
>>>> Check for them and proceed.
>>>>
>>>> Signed-off-by: Keerthy <j-keerthy@ti.com>
>>>> ---
>>>>   drivers/power/regulator/regulator-uclass.c | 10 ++++++++++
>>>>   1 file changed, 10 insertions(+)
>>>>
>>>> diff --git a/drivers/power/regulator/regulator-uclass.c
>>>> b/drivers/power/regulator/regulator-uclass.c
>>>> index 4434e36..089455e 100644
>>>> --- a/drivers/power/regulator/regulator-uclass.c
>>>> +++ b/drivers/power/regulator/regulator-uclass.c
>>>> @@ -41,6 +41,11 @@ int regulator_get_value(struct udevice *dev)
>>>>   int regulator_set_value(struct udevice *dev, int uV)
>>>>   {
>>>>       const struct dm_regulator_ops *ops = dev_get_driver_ops(dev);
>>>> +    struct dm_regulator_uclass_platdata *uc_pdata;
>>>> +
>>>> +    uc_pdata = dev_get_uclass_platdata(dev);
>>>> +    if (uV < uc_pdata->min_uV || uV > uc_pdata->max_uV)
>>>> +        return -EINVAL;
>>>>         if (!ops || !ops->set_value)
>>>>           return -ENOSYS;
>>>> @@ -61,6 +66,11 @@ int regulator_get_current(struct udevice *dev)
>>>>   int regulator_set_current(struct udevice *dev, int uA)
>>>>   {
>>>>       const struct dm_regulator_ops *ops = dev_get_driver_ops(dev);
>>>> +    struct dm_regulator_uclass_platdata *uc_pdata;
>>>> +
>>>> +    uc_pdata = dev_get_uclass_platdata(dev);
>>>> +    if (uA < uc_pdata->min_uA || uA > uc_pdata->max_uA)
>>>> +        return -EINVAL;
>>>>         if (!ops || !ops->set_current)
>>>>           return -ENOSYS;
>>>
>>>
>>> Adding those two checks will conflict with "force" option for
>>> cmd/regulator.c:283.
>>> There was value range checking in the command's code, but it was left
>>> unchecked
>>> for regulator direct calls.
>>>
>>> This change is good, but then maybe the "force" option should be removed
>>> from command,
>>> or API's prototypes should be updated by force flag argument?
>>>
>>> I assumed that this option could be useful for quick over-voltage
>>> setting (until reboot),
>>> since usually (min_uV == max_uV) - the voltage can't be changed in any
>>> range.
>>>
>>> The driver should take care about ignore it or not, however probably
>>> nobody used this.
>>>
>>> Of course this could potentially damage the device by wrong use,
>>> which can be also made by passing the force flag as an argument - by
>>> mistake.
>>>
>>> What do you thing about, update the dm_regulator_ops by:
>>>
>>>  - int (*set_value)(struct udevice *dev, int uV, int flag);
>>>  - int (*set_current)(struct udevice *dev, int uA, int flag);
>
>
> I personally do not like setting an extra flag everywhere just because we
> want to support force option.
>
> I would rather have 2 functions like:
>
> int (*force_set_value)(struct udevice *dev, int uV);
> int (*force_set_current)(struct udevice *dev, int uA);
>
> Where we can set the value ignoring the limits. But again that must be used
> with at most caution as setting higher voltages might end up damaging the
> device.

That seems OK to me.

>
>
>>>
>>> and also new flag to the present defined:
>>>
>>>  - REGULATOR_FLAG_FORCE = 1 << 2
>>>
>>> This requires more work, but will provide the functionality in a proper
>>> way.
>>
>>
>> I do not know cmd_regulator is the right place to check for min_uV and
>> max_uV. dm_regulator_uclass_platdata has both the limits and this i feel
>> is a perfectly valid check in generic place else we would be again
>> checking for the same condition in every possible regulator specific
>> drivers.
>>
>> As far as the force option is concerned that i believe is more for
>> testing and like you said can be implemented by setting a flag.
>>
>> Just take a simple case of say a driver like mmc which unknowingly
>> requests a wrong voltage and the base driver has no check against min
>> and max voltages and assuming the regulator driver goes ahead and sets a
>> very high voltage. That can be catastrophic right?

What is the status of this patch please?

Also it breaks tests (make tests) - can you please take a  look?

Regards,
Simon

^ permalink raw reply	[flat|nested] 7+ messages in thread

* [U-Boot] [PATCH] power: regulator: Add limits checking while setting voltage and current
  2016-10-11  0:19         ` Simon Glass
@ 2016-10-12  5:44           ` Keerthy
  2016-10-26  9:58             ` Keerthy
  0 siblings, 1 reply; 7+ messages in thread
From: Keerthy @ 2016-10-12  5:44 UTC (permalink / raw)
  To: u-boot



On Tuesday 11 October 2016 05:49 AM, Simon Glass wrote:
> Hi Keerthy,
>
> On 15 September 2016 at 05:16, Keerthy <a0393675@ti.com> wrote:
>>
>>
>> On Thursday 15 September 2016 04:38 PM, Keerthy wrote:
>>>
>>>
>>>
>>> On Thursday 15 September 2016 04:26 PM, Przemyslaw Marczak wrote:
>>>>
>>>> Hello Keerthy,
>>>>
>>>> On 09/15/2016 10:54 AM, Keerthy wrote:
>>>>>
>>>>> Currently the specific set ops functions are directly
>>>>> called without any check for voltage/current limits for a regulator.
>>>>> Check for them and proceed.
>>>>>
>>>>> Signed-off-by: Keerthy <j-keerthy@ti.com>
>>>>> ---
>>>>>   drivers/power/regulator/regulator-uclass.c | 10 ++++++++++
>>>>>   1 file changed, 10 insertions(+)
>>>>>
>>>>> diff --git a/drivers/power/regulator/regulator-uclass.c
>>>>> b/drivers/power/regulator/regulator-uclass.c
>>>>> index 4434e36..089455e 100644
>>>>> --- a/drivers/power/regulator/regulator-uclass.c
>>>>> +++ b/drivers/power/regulator/regulator-uclass.c
>>>>> @@ -41,6 +41,11 @@ int regulator_get_value(struct udevice *dev)
>>>>>   int regulator_set_value(struct udevice *dev, int uV)
>>>>>   {
>>>>>       const struct dm_regulator_ops *ops = dev_get_driver_ops(dev);
>>>>> +    struct dm_regulator_uclass_platdata *uc_pdata;
>>>>> +
>>>>> +    uc_pdata = dev_get_uclass_platdata(dev);
>>>>> +    if (uV < uc_pdata->min_uV || uV > uc_pdata->max_uV)
>>>>> +        return -EINVAL;
>>>>>         if (!ops || !ops->set_value)
>>>>>           return -ENOSYS;
>>>>> @@ -61,6 +66,11 @@ int regulator_get_current(struct udevice *dev)
>>>>>   int regulator_set_current(struct udevice *dev, int uA)
>>>>>   {
>>>>>       const struct dm_regulator_ops *ops = dev_get_driver_ops(dev);
>>>>> +    struct dm_regulator_uclass_platdata *uc_pdata;
>>>>> +
>>>>> +    uc_pdata = dev_get_uclass_platdata(dev);
>>>>> +    if (uA < uc_pdata->min_uA || uA > uc_pdata->max_uA)
>>>>> +        return -EINVAL;
>>>>>         if (!ops || !ops->set_current)
>>>>>           return -ENOSYS;
>>>>
>>>>
>>>> Adding those two checks will conflict with "force" option for
>>>> cmd/regulator.c:283.
>>>> There was value range checking in the command's code, but it was left
>>>> unchecked
>>>> for regulator direct calls.
>>>>
>>>> This change is good, but then maybe the "force" option should be removed
>>>> from command,
>>>> or API's prototypes should be updated by force flag argument?
>>>>
>>>> I assumed that this option could be useful for quick over-voltage
>>>> setting (until reboot),
>>>> since usually (min_uV == max_uV) - the voltage can't be changed in any
>>>> range.
>>>>
>>>> The driver should take care about ignore it or not, however probably
>>>> nobody used this.
>>>>
>>>> Of course this could potentially damage the device by wrong use,
>>>> which can be also made by passing the force flag as an argument - by
>>>> mistake.
>>>>
>>>> What do you thing about, update the dm_regulator_ops by:
>>>>
>>>>  - int (*set_value)(struct udevice *dev, int uV, int flag);
>>>>  - int (*set_current)(struct udevice *dev, int uA, int flag);
>>
>>
>> I personally do not like setting an extra flag everywhere just because we
>> want to support force option.
>>
>> I would rather have 2 functions like:
>>
>> int (*force_set_value)(struct udevice *dev, int uV);
>> int (*force_set_current)(struct udevice *dev, int uA);
>>
>> Where we can set the value ignoring the limits. But again that must be used
>> with at most caution as setting higher voltages might end up damaging the
>> device.
>
> That seems OK to me.
>
>>
>>
>>>>
>>>> and also new flag to the present defined:
>>>>
>>>>  - REGULATOR_FLAG_FORCE = 1 << 2
>>>>
>>>> This requires more work, but will provide the functionality in a proper
>>>> way.
>>>
>>>
>>> I do not know cmd_regulator is the right place to check for min_uV and
>>> max_uV. dm_regulator_uclass_platdata has both the limits and this i feel
>>> is a perfectly valid check in generic place else we would be again
>>> checking for the same condition in every possible regulator specific
>>> drivers.
>>>
>>> As far as the force option is concerned that i believe is more for
>>> testing and like you said can be implemented by setting a flag.
>>>
>>> Just take a simple case of say a driver like mmc which unknowingly
>>> requests a wrong voltage and the base driver has no check against min
>>> and max voltages and assuming the regulator driver goes ahead and sets a
>>> very high voltage. That can be catastrophic right?
>
> What is the status of this patch please?
>
> Also it breaks tests (make tests) - can you please take a  look?

Sure Simon. It was hanging somehow. I will redo and repost it.

>
> Regards,
> Simon
>

^ permalink raw reply	[flat|nested] 7+ messages in thread

* [U-Boot] [PATCH] power: regulator: Add limits checking while setting voltage and current
  2016-10-12  5:44           ` Keerthy
@ 2016-10-26  9:58             ` Keerthy
  0 siblings, 0 replies; 7+ messages in thread
From: Keerthy @ 2016-10-26  9:58 UTC (permalink / raw)
  To: u-boot



On Wednesday 12 October 2016 11:14 AM, Keerthy wrote:
>
>
> On Tuesday 11 October 2016 05:49 AM, Simon Glass wrote:
>> Hi Keerthy,
>>
>> On 15 September 2016 at 05:16, Keerthy <a0393675@ti.com> wrote:
>>>
>>>
>>> On Thursday 15 September 2016 04:38 PM, Keerthy wrote:
>>>>
>>>>
>>>>
>>>> On Thursday 15 September 2016 04:26 PM, Przemyslaw Marczak wrote:
>>>>>
>>>>> Hello Keerthy,
>>>>>
>>>>> On 09/15/2016 10:54 AM, Keerthy wrote:
>>>>>>
>>>>>> Currently the specific set ops functions are directly
>>>>>> called without any check for voltage/current limits for a regulator.
>>>>>> Check for them and proceed.
>>>>>>
>>>>>> Signed-off-by: Keerthy <j-keerthy@ti.com>
>>>>>> ---
>>>>>>   drivers/power/regulator/regulator-uclass.c | 10 ++++++++++
>>>>>>   1 file changed, 10 insertions(+)
>>>>>>
>>>>>> diff --git a/drivers/power/regulator/regulator-uclass.c
>>>>>> b/drivers/power/regulator/regulator-uclass.c
>>>>>> index 4434e36..089455e 100644
>>>>>> --- a/drivers/power/regulator/regulator-uclass.c
>>>>>> +++ b/drivers/power/regulator/regulator-uclass.c
>>>>>> @@ -41,6 +41,11 @@ int regulator_get_value(struct udevice *dev)
>>>>>>   int regulator_set_value(struct udevice *dev, int uV)
>>>>>>   {
>>>>>>       const struct dm_regulator_ops *ops = dev_get_driver_ops(dev);
>>>>>> +    struct dm_regulator_uclass_platdata *uc_pdata;
>>>>>> +
>>>>>> +    uc_pdata = dev_get_uclass_platdata(dev);
>>>>>> +    if (uV < uc_pdata->min_uV || uV > uc_pdata->max_uV)
>>>>>> +        return -EINVAL;
>>>>>>         if (!ops || !ops->set_value)
>>>>>>           return -ENOSYS;
>>>>>> @@ -61,6 +66,11 @@ int regulator_get_current(struct udevice *dev)
>>>>>>   int regulator_set_current(struct udevice *dev, int uA)
>>>>>>   {
>>>>>>       const struct dm_regulator_ops *ops = dev_get_driver_ops(dev);
>>>>>> +    struct dm_regulator_uclass_platdata *uc_pdata;
>>>>>> +
>>>>>> +    uc_pdata = dev_get_uclass_platdata(dev);
>>>>>> +    if (uA < uc_pdata->min_uA || uA > uc_pdata->max_uA)
>>>>>> +        return -EINVAL;
>>>>>>         if (!ops || !ops->set_current)
>>>>>>           return -ENOSYS;
>>>>>
>>>>>
>>>>> Adding those two checks will conflict with "force" option for
>>>>> cmd/regulator.c:283.
>>>>> There was value range checking in the command's code, but it was left
>>>>> unchecked
>>>>> for regulator direct calls.
>>>>>
>>>>> This change is good, but then maybe the "force" option should be
>>>>> removed
>>>>> from command,
>>>>> or API's prototypes should be updated by force flag argument?
>>>>>
>>>>> I assumed that this option could be useful for quick over-voltage
>>>>> setting (until reboot),
>>>>> since usually (min_uV == max_uV) - the voltage can't be changed in any
>>>>> range.
>>>>>
>>>>> The driver should take care about ignore it or not, however probably
>>>>> nobody used this.
>>>>>
>>>>> Of course this could potentially damage the device by wrong use,
>>>>> which can be also made by passing the force flag as an argument - by
>>>>> mistake.
>>>>>
>>>>> What do you thing about, update the dm_regulator_ops by:
>>>>>
>>>>>  - int (*set_value)(struct udevice *dev, int uV, int flag);
>>>>>  - int (*set_current)(struct udevice *dev, int uA, int flag);
>>>
>>>
>>> I personally do not like setting an extra flag everywhere just
>>> because we
>>> want to support force option.
>>>
>>> I would rather have 2 functions like:
>>>
>>> int (*force_set_value)(struct udevice *dev, int uV);
>>> int (*force_set_current)(struct udevice *dev, int uA);
>>>
>>> Where we can set the value ignoring the limits. But again that must
>>> be used
>>> with at most caution as setting higher voltages might end up damaging
>>> the
>>> device.
>>
>> That seems OK to me.
>>
>>>
>>>
>>>>>
>>>>> and also new flag to the present defined:
>>>>>
>>>>>  - REGULATOR_FLAG_FORCE = 1 << 2
>>>>>
>>>>> This requires more work, but will provide the functionality in a
>>>>> proper
>>>>> way.
>>>>
>>>>
>>>> I do not know cmd_regulator is the right place to check for min_uV and
>>>> max_uV. dm_regulator_uclass_platdata has both the limits and this i
>>>> feel
>>>> is a perfectly valid check in generic place else we would be again
>>>> checking for the same condition in every possible regulator specific
>>>> drivers.
>>>>
>>>> As far as the force option is concerned that i believe is more for
>>>> testing and like you said can be implemented by setting a flag.
>>>>
>>>> Just take a simple case of say a driver like mmc which unknowingly
>>>> requests a wrong voltage and the base driver has no check against min
>>>> and max voltages and assuming the regulator driver goes ahead and
>>>> sets a
>>>> very high voltage. That can be catastrophic right?
>>
>> What is the status of this patch please?
>>
>> Also it breaks tests (make tests) - can you please take a  look?
>
> Sure Simon. It was hanging somehow. I will redo and repost it.
Simon,

https://patchwork.ozlabs.org/patch/686932/
https://patchwork.ozlabs.org/patch/686933/
https://patchwork.ozlabs.org/patch/686934/

Posted the above 3 as a rework for this patch. Let me know if these are 
fine.

Regards,
Keerthy

>
>>
>> Regards,
>> Simon
>>

^ permalink raw reply	[flat|nested] 7+ messages in thread

end of thread, other threads:[~2016-10-26  9:58 UTC | newest]

Thread overview: 7+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
     [not found] <CGME20160915085454eucas1p2af402cce6038a3845fbc2fbf1b2986ba@eucas1p2.samsung.com>
2016-09-15  8:54 ` [U-Boot] [PATCH] power: regulator: Add limits checking while setting voltage and current Keerthy
2016-09-15 10:56   ` Przemyslaw Marczak
2016-09-15 11:08     ` Keerthy
2016-09-15 11:16       ` Keerthy
2016-10-11  0:19         ` Simon Glass
2016-10-12  5:44           ` Keerthy
2016-10-26  9:58             ` Keerthy

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.