diff options
author | Stuart Menefy <stuart.menefy@st.com> | 2013-06-26 07:48:38 -0400 |
---|---|---|
committer | Daniel Lezcano <daniel.lezcano@linaro.org> | 2013-07-03 11:30:57 -0400 |
commit | c1b40e447af8695666d4c11cfec4a7407e6a124d (patch) | |
tree | 813182806167d481396812928fec503b84e39cab /Documentation | |
parent | 0c1dcfd53b1066c411d3885cf8156abf59694360 (diff) |
clocksource: arm_global_timer: Add ARM global timer support
This is a simple driver for the global timer module found in the Cortex
A9-MP cores from revision r1p0 onwards. This should be able to perform
the functions of the system timer and the local timer in an SMP system.
The global timer has the following features:
The global timer is a 64-bit incrementing counter with an
auto-incrementing feature. It continues incrementing after sending
interrupts. The global timer is memory mapped in the private memory
region.
The global timer is accessible to all Cortex-A9 processors in the
cluster. Each Cortex-A9 processor has a private 64-bit comparator that
is used to assert a private interrupt when the global timer has reached
the comparator value. All the Cortex-A9 processors in a design use the
banked ID, ID27, for this interrupt. ID27 is sent to the Interrupt
Controller as a Private Peripheral Interrupt. The global timer is
clocked by PERIPHCLK.
Signed-off-by: Stuart Menefy <stuart.menefy@st.com>
Signed-off-by: Srinivas Kandagatla <srinivas.kandagatla@st.com>
CC: Arnd Bergmann <arnd@arndb.de>
CC: Rob Herring <robherring2@gmail.com>
CC: Linus Walleij <linus.walleij@linaro.org>
CC: Will Deacon <will.deacon@arm.com>
CC: Thomas Gleixner <tglx@linutronix.de>
Signed-off-by: Daniel Lezcano <daniel.lezcano@linaro.org>
Diffstat (limited to 'Documentation')
-rw-r--r-- | Documentation/devicetree/bindings/arm/global_timer.txt | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/Documentation/devicetree/bindings/arm/global_timer.txt b/Documentation/devicetree/bindings/arm/global_timer.txt new file mode 100644 index 000000000000..1e548981eda4 --- /dev/null +++ b/Documentation/devicetree/bindings/arm/global_timer.txt | |||
@@ -0,0 +1,24 @@ | |||
1 | |||
2 | * ARM Global Timer | ||
3 | Cortex-A9 are often associated with a per-core Global timer. | ||
4 | |||
5 | ** Timer node required properties: | ||
6 | |||
7 | - compatible : Should be "arm,cortex-a9-global-timer" | ||
8 | Driver supports versions r2p0 and above. | ||
9 | |||
10 | - interrupts : One interrupt to each core | ||
11 | |||
12 | - reg : Specify the base address and the size of the GT timer | ||
13 | register window. | ||
14 | |||
15 | - clocks : Should be phandle to a clock. | ||
16 | |||
17 | Example: | ||
18 | |||
19 | timer@2c000600 { | ||
20 | compatible = "arm,cortex-a9-global-timer"; | ||
21 | reg = <0x2c000600 0x20>; | ||
22 | interrupts = <1 13 0xf01>; | ||
23 | clocks = <&arm_periph_clk>; | ||
24 | }; | ||