- Renesas R-Car Compare Match Timer (CMT)
The CMT is a multi-channel 16/32/48-bit timer/counter with configurable clock
inputs and programmable compare match.
Channels share hardware resources but their counter and compare match value
are independent. A particular CMT instance can implement only a subset of the
channels supported by the CMT model. Channel indices represent the hardware
position of the channel in the CMT and don’t match the channel numbers in the
datasheets.
Required Properties:
compatible: must contain one or more of the following:
“renesas,cmt-48-sh73a0” for the sh73A0 48-bit CMT
(CMT1)“renesas,cmt-48-r8a7740” for the r8a7740 48-bit CMT
(CMT1)“renesas,cmt-48” for all non-second generation 48-bit CMT
(CMT1 on sh73a0 and r8a7740)
This is a fallback for the above renesas,cmt-48-* entries.“renesas,r8a73a4-cmt0” for the 32-bit CMT0 device included in r8a73a4.
“renesas,r8a73a4-cmt1” for the 48-bit CMT1 device included in r8a73a4.
“renesas,r8a7743-cmt0” for the 32-bit CMT0 device included in r8a7743.
“renesas,r8a7743-cmt1” for the 48-bit CMT1 device included in r8a7743.
“renesas,r8a7745-cmt0” for the 32-bit CMT0 device included in r8a7745.
“renesas,r8a7745-cmt1” for the 48-bit CMT1 device included in r8a7745.
“renesas,r8a7790-cmt0” for the 32-bit CMT0 device included in r8a7790.
“renesas,r8a7790-cmt1” for the 48-bit CMT1 device included in r8a7790.
“renesas,r8a7791-cmt0” for the 32-bit CMT0 device included in r8a7791.
“renesas,r8a7791-cmt1” for the 48-bit CMT1 device included in r8a7791.
“renesas,r8a7793-cmt0” for the 32-bit CMT0 device included in r8a7793.
“renesas,r8a7793-cmt1” for the 48-bit CMT1 device included in r8a7793.
“renesas,r8a7794-cmt0” for the 32-bit CMT0 device included in r8a7794.
“renesas,r8a7794-cmt1” for the 48-bit CMT1 device included in r8a7794.
“renesas,rcar-gen2-cmt0” for 32-bit CMT0 devices included in R-Car Gen2
and RZ/G1.“renesas,rcar-gen2-cmt1” for 48-bit CMT1 devices included in R-Car Gen2
and RZ/G1.
These are fallbacks for r8a73a4, R-Car Gen2 and RZ/G1 entries
listed above.
reg: base address and length of the registers block for the timer module.
interrupts: interrupt-specifier for the timer, one per channel.
clocks: a list of phandle + clock-specifier pairs, one for each entry
in clock-names.clock-names: must contain “fck” for the functional clock.
Example: R8A7790 (R-Car H2) CMT0 and CMT1 nodes
cmt0: timer@ffca0000 {
compatible = "renesas,r8a7790-cmt0", "renesas,rcar-gen2-cmt0";
reg = <0 0xffca0000 0 0x1004>;
interrupts = <0 142 IRQ_TYPE_LEVEL_HIGH>,
<0 142 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&mstp1_clks R8A7790_CLK_CMT0>;
clock-names = "fck";
};
cmt1: timer@e6130000 {
compatible = "renesas,r8a7790-cmt1", "renesas,rcar-gen2-cmt1";
reg = <0 0xe6130000 0 0x1004>;
interrupts = <0 120 IRQ_TYPE_LEVEL_HIGH>,
<0 121 IRQ_TYPE_LEVEL_HIGH>,
<0 122 IRQ_TYPE_LEVEL_HIGH>,
<0 123 IRQ_TYPE_LEVEL_HIGH>,
<0 124 IRQ_TYPE_LEVEL_HIGH>,
<0 125 IRQ_TYPE_LEVEL_HIGH>,
<0 126 IRQ_TYPE_LEVEL_HIGH>,
<0 127 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&mstp3_clks R8A7790_CLK_CMT1>;
clock-names = "fck";
};