[PATCH 04/10] timer: cadence-ttc: Add timer_early functions
Stefan Roese
sr at denx.de
Mon Sep 26 16:11:30 CEST 2022
Hi Simon,
Hi Michal,
On 25.09.22 16:15, Simon Glass wrote:
> Hi Stefan,
>
> On Wed, 21 Sept 2022 at 08:06, Stefan Roese <sr at denx.de> wrote:
>>
>> Currently this timer driver provides timer_get_boot_us() to support the
>> BOOTSTAGE functionality. This patch adds the timer_early functions so
>> that the "normal" timer functions can be used, when CONFIG_TIMER_EARLY
>> is enabled.
>>
>> timer_get_boot_us() will get removed in a follow-up patch, once the
>> BOOTSTAGE interface is migrated to timer_get_us().
>>
>> Signed-off-by: Stefan Roese <sr at denx.de>
>> Cc: Michal Simek <michal.simek at xilinx.com>
>> ---
>> drivers/timer/cadence-ttc.c | 25 +++++++++++++++++++++++++
>> 1 file changed, 25 insertions(+)
>>
>> diff --git a/drivers/timer/cadence-ttc.c b/drivers/timer/cadence-ttc.c
>> index 2eff45060ad6..e26c7923a140 100644
>> --- a/drivers/timer/cadence-ttc.c
>> +++ b/drivers/timer/cadence-ttc.c
>> @@ -58,6 +58,31 @@ ulong timer_get_boot_us(void)
>> }
>> #endif
>>
>> +unsigned long notrace timer_early_get_rate(void)
>> +{
>> + return 1;
>> +}
>> +
>> +u64 notrace timer_early_get_count(void)
>> +{
>> + u64 ticks = 0;
>> + u32 rate = 1;
>> + u64 us;
>> + int ret;
>> +
>> + ret = dm_timer_init();
>
> I don't think you can call this if you want to support bootstage,
> since driver model may not be inited.
Yes, thanks for noticing. Still, this code is copied from the original
timer_get_boot_us() function in this driver. Which also has problems
with early timer access AFAICT.
Michal, you are the author of the timer_get_boot_us() implementation
in commit 56c0e646c4f6a ("timer: cadence: Implement timer_get_boot_us").
How is this supposed to work in the early boot phase, before DM is
initialized?
Thanks,
Stefan
>> + if (!ret) {
>> + /* The timer is available */
>> + rate = timer_get_rate(gd->timer);
>> + timer_get_count(gd->timer, &ticks);
>> + } else {
>> + return 0;
>> + }
>> +
>> + us = (ticks * 1000) / rate;
>> + return us;
>> +}
>> +
>> static u64 cadence_ttc_get_count(struct udevice *dev)
>> {
>> struct cadence_ttc_priv *priv = dev_get_priv(dev);
>> --
>> 2.37.3
>>
>
> REgards,
> Simon
Viele Grüße,
Stefan Roese
--
DENX Software Engineering GmbH, Managing Director: Wolfgang Denk
HRB 165235 Munich, Office: Kirchenstr.5, D-82194 Groebenzell, Germany
Phone: (+49)-8142-66989-51 Fax: (+49)-8142-66989-80 Email: sr at denx.de
More information about the U-Boot
mailing list