[Uboot-stm32] [PATCH 1/5] dm: pwm: Check if duty_ns is lower than period_ns
Patrice CHOTARD
patrice.chotard at foss.st.com
Mon Mar 10 13:35:57 CET 2025
On 3/10/25 11:00, Patrice CHOTARD wrote:
>
>
> On 3/6/25 15:13, Patrice CHOTARD wrote:
>>
>>
>> On 3/6/25 11:56, Cheick Traore wrote:
>>> It was possible to provide a duty_ns greater than period_ns to
>>> "pwm config" command. The framework must check the values before
>>> providing them to drivers.
>>>
>>> Signed-off-by: Cheick Traore <cheick.traore at foss.st.com>
>>> ---
>>>
>>> drivers/pwm/pwm-uclass.c | 3 +++
>>> 1 file changed, 3 insertions(+)
>>>
>>> diff --git a/drivers/pwm/pwm-uclass.c b/drivers/pwm/pwm-uclass.c
>>> index 6543db1d623..b4491f7dcd4 100644
>>> --- a/drivers/pwm/pwm-uclass.c
>>> +++ b/drivers/pwm/pwm-uclass.c
>>> @@ -27,6 +27,9 @@ int pwm_set_config(struct udevice *dev, uint channel, uint period_ns,
>>> if (!ops->set_config)
>>> return -ENOSYS;
>>>
>>> + if (duty_ns > period_ns)
>>> + return -EINVAL;
>>> +
>>> return ops->set_config(dev, channel, period_ns, duty_ns);
>>> }
>>>
>> Reviewed-by: Patrice Chotard <patrice.chotard at foss.st.com>
>>
>> Thanks
>> Patrice
> Applied to u-boot-stm32/next
>
> Thanks
> Patrice
Hi Cheick
Unfortunately, this patch is causing U-Boot CI test failed:
see https://source.denx.de/u-boot/custodians/u-boot-stm/-/jobs/1054426
More precisely ut_dm_dm_test_cros_ec_pwm, see test/dm/cros_ec_pwm.c
Either update test/dm/cros_ec_pwm.c or another solution is simply to
clamp duty_ns to period_ns as following ?
+ if (duty_ns > period_ns)
+ duty_ns = period_ns;
+
Patrice
> _______________________________________________
> Uboot-stm32 mailing list
> Uboot-stm32 at st-md-mailman.stormreply.com
> https://st-md-mailman.stormreply.com/mailman/listinfo/uboot-stm32
More information about the U-Boot
mailing list