2. 君正 JZ47xx SoC 定时器/计数器单元硬件¶
君正 JZ47xx SoC 中的定时器/计数器单元 (TCU) 是一个多功能硬件模块。它具有多达八个通道,可以用作计数器、定时器或 PWM。
JZ4725B、JZ4750 和 JZ4755 只有六个 TCU 通道。其他 SoC 都有八个通道。
JZ4725B 引入了一个单独的通道,称为操作系统定时器 (OST)。它是一个 32 位可编程定时器。在 JZ4760B 及以上版本中,它是 64 位的。
每个 TCU 通道都有自己的时钟,可以通过其 TCSR 寄存器重新连接到三个不同的时钟(pclk、ext、rtc),进行门控和重新计时。
看门狗和 OST 硬件模块在其寄存器空间中也具有相同格式的 TCSR 寄存器。
用于门控/解除门控的 TCU 寄存器还可以门控/解除门控看门狗和 OST 时钟。
每个 TCU 通道在两种模式之一中工作
模式 TCU1:通道不能在睡眠模式下工作,但操作起来更容易。
模式 TCU2:通道可以在睡眠模式下工作,但操作比 TCU1 通道稍微复杂一些。
每个 TCU 通道的模式取决于所使用的 SoC
在最老的 SoC(直到 JZ4740)上,所有八个通道都以 TCU1 模式运行。
在 JZ4725B 上,通道 5 作为 TCU2 运行,其他通道作为 TCU1 运行。
在最新的 SoC(JZ4750 及以上)上,通道 1-2 作为 TCU2 运行,其他通道作为 TCU1 运行。
每个通道都可以生成一个中断。一些通道共享一条中断线,一些不共享,并且这在 SoC 版本之间会发生变化
在较旧的 SoC(JZ4740 及以下)上,通道 0 和通道 1 有自己的中断线;通道 2-7 共享最后一条中断线。
在 JZ4725B 上,通道 0 有自己的中断;通道 1-5 共享一条中断线;OST 使用最后一条中断线。
在较新的 SoC(JZ4750 及以上)上,通道 5 有自己的中断;通道 0-4 和(如果有八个通道)6-7 都共享一条中断线;OST 使用最后一条中断线。
2.1. 实现¶
TCU 硬件的功能分布在多个驱动程序中
时钟 |
drivers/clk/ingenic/tcu.c |
中断 |
drivers/irqchip/irq-ingenic-tcu.c |
定时器 |
drivers/clocksource/ingenic-timer.c |
OST |
drivers/clocksource/ingenic-ost.c |
PWM |
drivers/pwm/pwm-jz4740.c |
看门狗 |
drivers/watchdog/jz4740_wdt.c |
由于属于不同驱动程序和框架的 TCU 的各种功能可以从相同的寄存器进行控制,因此所有这些驱动程序都通过相同的 regmap 访问其寄存器。
有关 TCU 驱动程序的设备树绑定的更多信息,请查看 Documentation/devicetree/bindings/timer/ingenic,tcu.yaml。