[PATCH v2] pwm: atmel: add missing clk_disable_unprepare()
Hari.PrasathGE at microchip.com
Hari.PrasathGE at microchip.com
Tue Sep 5 23:15:36 PDT 2023
Hello Christophe,
On 02/09/23 9:57 pm, Christophe JAILLET wrote:
> EXTERNAL EMAIL: Do not click links or open attachments unless you know
> the content is safe
>
> Le 02/09/2023 à 08:32, Hari Prasath Gujulan Elango a écrit :
>> Fix the below smatch warning:
>>
>> drivers/pwm/pwm-atmel-hlcdc.c:167 atmel_hlcdc_pwm_apply() warn:
>> 'new_clk' from clk_prepare_enable() not released on lines:
>> 112,137,142,149.
>>
>> 'Fixes: 2b4984bef47a5 ("pwm: atmel-hlcdc: Convert to the atomic PWM
>> API")'
>
> Hi,
>
> There shouldn't be ' before Fixes:, neither at the end.
> Commit id should be 12 chars, not 13.
> There shouldn't be a blank line between Fixes and Signed-off-by.
>
> I think that the Fixes tag should be 2b4984bef47a ("pwm: add support for
> atmel-hlcdc-pwm device".
> The commit you point you have touched this code, be part of what you
> change was already there before that.
>
Thank you, I admit that I have messes up this part. Its been quite a
while sending patches upstream and I seem to have forgotten the basics.
I will take time to send the v3 paying more attention to these small
details.
>>
>> Signed-off-by: Hari Prasath Gujulan Elango <Hari.PrasathGE at microchip.com>
>>
>
> There should be a --- between the signed-of-by and the below changelog,
> so that the changelog will not be merged in the git history.
>
> Also, it is also useful to add the link at lore.kernel.org of previous
> versions.
>
> Here, it would be something like:
> v1:
> https://lore.kernel.org/all/20230822070441.22170-1-Hari.PrasathGE@microchip.com/
>
>> changelog of v2:
>>
>> - moved the clk_disable_unprepare to single point of return.
>> - cur_clk set to NULL before return.
>> ---
>> drivers/pwm/pwm-atmel-hlcdc.c | 12 +++++++-----
>> 1 file changed, 7 insertions(+), 5 deletions(-)
>>
>> diff --git a/drivers/pwm/pwm-atmel-hlcdc.c
>> b/drivers/pwm/pwm-atmel-hlcdc.c
>> index 96a709a9d49a..4d35b838203f 100644
>> --- a/drivers/pwm/pwm-atmel-hlcdc.c
>> +++ b/drivers/pwm/pwm-atmel-hlcdc.c
>> @@ -44,7 +44,7 @@ static int atmel_hlcdc_pwm_apply(struct pwm_chip *c,
>> struct pwm_device *pwm,
>> struct atmel_hlcdc_pwm *chip = to_atmel_hlcdc_pwm(c);
>> struct atmel_hlcdc *hlcdc = chip->hlcdc;
>> unsigned int status;
>> - int ret;
>> + int ret = 0;
>
> This initialization looks un-needed and un-related to your changes.
>
Though the kernel API's used below return 0 upon success but just
thought I will initialize it to 0.
>>
>> if (state->enabled) {
>> struct clk *new_clk = hlcdc->slow_clk;
>> @@ -109,7 +109,7 @@ static int atmel_hlcdc_pwm_apply(struct pwm_chip
>> *c, struct pwm_device *pwm,
>> ATMEL_HLCDC_CLKPWMSEL,
>> gencfg);
>> if (ret)
>> - return ret;
>> + goto disable_new_clk;
>> }
>>
>> do_div(pwmcval, state->period);
>> @@ -134,18 +134,20 @@ static int atmel_hlcdc_pwm_apply(struct pwm_chip
>> *c, struct pwm_device *pwm,
>> ATMEL_HLCDC_PWMPOL,
>> pwmcfg);
>> if (ret)
>> - return ret;
>> + goto disable_new_clk;
>>
>> ret = regmap_write(hlcdc->regmap, ATMEL_HLCDC_EN,
>> ATMEL_HLCDC_PWM);
>> if (ret)
>> - return ret;
>> + goto disable_new_clk;
>>
>> ret = regmap_read_poll_timeout(hlcdc->regmap,
>> ATMEL_HLCDC_SR,
>> status,
>> status & ATMEL_HLCDC_PWM,
>> 10, 0);
>> - if (ret)
>
> Removing this test looks wrong.
Will add it back and include a 'goto'
>
>> +disable_new_clk:
>> + clk_disable_unprepare(new_clk);
>> + chip->cur_clk = NULL;
>> return ret;
>
> This is a really unusual pattern.
> Usually, an error handling path is added at the end of the function, not
> in the middle.
>
> CJ
I will move this towards the end as it's done usually.
-Hari
>
>> } else {
>> ret = regmap_write(hlcdc->regmap, ATMEL_HLCDC_DIS,
>
More information about the linux-arm-kernel
mailing list