Merge tag 'iwlwifi-next-for-kalle-2014-12-30' of https://git.kernel.org/pub/scm/linux...
[cascardo/linux.git] / Documentation / devicetree / bindings / interrupt-controller / mips-gic.txt
1 MIPS Global Interrupt Controller (GIC)
2
3 The MIPS GIC routes external interrupts to individual VPEs and IRQ pins.
4 It also supports local (per-processor) interrupts and software-generated
5 interrupts which can be used as IPIs.  The GIC also includes a free-running
6 global timer, per-CPU count/compare timers, and a watchdog.
7
8 Required properties:
9 - compatible : Should be "mti,gic".
10 - interrupt-controller : Identifies the node as an interrupt controller
11 - #interrupt-cells : Specifies the number of cells needed to encode an
12   interrupt specifier.  Should be 3.
13   - The first cell is the type of interrupt, local or shared.
14     See <include/dt-bindings/interrupt-controller/mips-gic.h>.
15   - The second cell is the GIC interrupt number.
16   - The third cell encodes the interrupt flags.
17     See <include/dt-bindings/interrupt-controller/irq.h> for a list of valid
18     flags.
19
20 Optional properties:
21 - reg : Base address and length of the GIC registers.  If not present,
22   the base address reported by the hardware GCR_GIC_BASE will be used.
23 - mti,reserved-cpu-vectors : Specifies the list of CPU interrupt vectors
24   to which the GIC may not route interrupts.  Valid values are 2 - 7.
25   This property is ignored if the CPU is started in EIC mode.
26
27 Required properties for timer sub-node:
28 - compatible : Should be "mti,gic-timer".
29 - interrupts : Interrupt for the GIC local timer.
30 - clock-frequency : Clock frequency at which the GIC timers operate.
31
32 Example:
33
34         gic: interrupt-controller@1bdc0000 {
35                 compatible = "mti,gic";
36                 reg = <0x1bdc0000 0x20000>;
37
38                 interrupt-controller;
39                 #interrupt-cells = <3>;
40
41                 mti,reserved-cpu-vectors = <7>;
42
43                 timer {
44                         compatible = "mti,gic-timer";
45                         interrupts = <GIC_LOCAL 1 IRQ_TYPE_NONE>;
46                         clock-frequency = <50000000>;
47                 };
48         };
49
50         uart@18101400 {
51                 ...
52                 interrupt-parent = <&gic>;
53                 interrupts = <GIC_SHARED 24 IRQ_TYPE_LEVEL_HIGH>;
54                 ...
55         };