[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <c83f7297-f3da-2b49-bc1a-42bffe7faabd@nvidia.com>
Date: Tue, 26 May 2020 13:44:40 +0100
From: Jon Hunter <jonathanh@...dia.com>
To: Sandipan Patra <spatra@...dia.com>, <treding@...dia.com>,
<u.kleine-koenig@...gutronix.de>
CC: <bbasu@...dia.com>, <ldewangan@...dia.com>,
<kyarlagadda@...dia.com>, <linux-pwm@...r.kernel.org>,
<linux-tegra@...r.kernel.org>, <linux-kernel@...r.kernel.org>
Subject: Re: [PATCH V3] pwm: tegra: dynamic clk freq configuration by PWM
driver
On 26/05/2020 13:05, Jon Hunter wrote:
>
> On 26/05/2020 12:25, Sandipan Patra wrote:
>> Added support for dynamic clock freq configuration in pwm kernel driver.
>> Earlier the pwm driver used to cache boot time clock rate by pwm clock
>> parent during probe. Hence dynamically changing pwm frequency was not
>> possible for all the possible ranges. With this change, dynamic calculation
>> is enabled and it is able to set the requested period from sysfs knob
>> provided the value is supported by clock source.
>>
>> Changes mainly have 2 parts:
>> - T186 and later chips [1]
>> - T210 and prior chips [2]
>>
>> For [1] - Changes implemented to set pwm period dynamically and
>> also checks added to allow only if requested period(ns) is
>> below or equals to higher range.
>>
>> For [2] - Only checks if the requested period(ns) is below or equals
>> to higher range defined by max clock limit. The limitation
>> in T210 or prior chips are due to the reason of having only
>> one pwm-controller supporting multiple channels. But later
>> chips have multiple pwm controller instances each having
>> single channel support.
>>
>> Signed-off-by: Sandipan Patra <spatra@...dia.com>
...
>> /*
>> + * Period in nano second has to be <= highest allowed period
>> + * based on max clock rate of the pwm controller.
>> + *
>> + * higher limit = max clock limit >> PWM_DUTY_WIDTH
>> + * lower limit = min clock limit >> PWM_DUTY_WIDTH >> PWM_SCALE_WIDTH
>
> Not sure why we mention the lower limit if we are not testing this
> condition. Does not appear to be relevant here. Or should we be checking
> this as well?
The above comment appears to be incorrect. Looking further at the code,
the code seems fine but the comment is confusing. I think you mean to
say that 'the period needs to be greater than the minimum period' and
that ...
min period = max clock limit >> PWM_DUTY_WIDTH
max period = min clock limit >> PWM_DUTY_WIDTH >> PWM_SCALE_WIDTH
>
>> + */
>> + if (period_ns < pc->min_period_ns)
>> + return -EINVAL;
>
> Something does not seem right here. If this is the highest allowed
> period, shouldn't this variable be called 'max_period_ns'?
Jon
--
nvpublic
Powered by blists - more mailing lists