Merge tag 'v3.3.7' into 3.3/master
[zen-stable.git] / Documentation / devicetree / bindings / marvell.txt
blobf1533d91953a9fe160145f58da488ef979492ac8
1 Marvell Discovery mv64[345]6x System Controller chips
2 ===========================================================
4 The Marvell mv64[345]60 series of system controller chips contain
5 many of the peripherals needed to implement a complete computer
6 system.  In this section, we define device tree nodes to describe
7 the system controller chip itself and each of the peripherals
8 which it contains.  Compatible string values for each node are
9 prefixed with the string "marvell,", for Marvell Technology Group Ltd.
11 1) The /system-controller node
13   This node is used to represent the system-controller and must be
14   present when the system uses a system controller chip. The top-level
15   system-controller node contains information that is global to all
16   devices within the system controller chip. The node name begins
17   with "system-controller" followed by the unit address, which is
18   the base address of the memory-mapped register set for the system
19   controller chip.
21   Required properties:
23     - ranges : Describes the translation of system controller addresses
24       for memory mapped registers.
25     - clock-frequency: Contains the main clock frequency for the system
26       controller chip.
27     - reg : This property defines the address and size of the
28       memory-mapped registers contained within the system controller
29       chip.  The address specified in the "reg" property should match
30       the unit address of the system-controller node.
31     - #address-cells : Address representation for system controller
32       devices.  This field represents the number of cells needed to
33       represent the address of the memory-mapped registers of devices
34       within the system controller chip.
35     - #size-cells : Size representation for the memory-mapped
36       registers within the system controller chip.
37     - #interrupt-cells : Defines the width of cells used to represent
38       interrupts.
40   Optional properties:
42     - model : The specific model of the system controller chip.  Such
43       as, "mv64360", "mv64460", or "mv64560".
44     - compatible : A string identifying the compatibility identifiers
45       of the system controller chip.
47   The system-controller node contains child nodes for each system
48   controller device that the platform uses.  Nodes should not be created
49   for devices which exist on the system controller chip but are not used
51   Example Marvell Discovery mv64360 system-controller node:
53     system-controller@f1000000 { /* Marvell Discovery mv64360 */
54             #address-cells = <1>;
55             #size-cells = <1>;
56             model = "mv64360";                      /* Default */
57             compatible = "marvell,mv64360";
58             clock-frequency = <133333333>;
59             reg = <0xf1000000 0x10000>;
60             virtual-reg = <0xf1000000>;
61             ranges = <0x88000000 0x88000000 0x1000000 /* PCI 0 I/O Space */
62                     0x80000000 0x80000000 0x8000000 /* PCI 0 MEM Space */
63                     0xa0000000 0xa0000000 0x4000000 /* User FLASH */
64                     0x00000000 0xf1000000 0x0010000 /* Bridge's regs */
65                     0xf2000000 0xf2000000 0x0040000>;/* Integrated SRAM */
67             [ child node definitions... ]
68     }
70 2) Child nodes of /system-controller
72    a) Marvell Discovery MDIO bus
74    The MDIO is a bus to which the PHY devices are connected.  For each
75    device that exists on this bus, a child node should be created.  See
76    the definition of the PHY node below for an example of how to define
77    a PHY.
79    Required properties:
80      - #address-cells : Should be <1>
81      - #size-cells : Should be <0>
82      - device_type : Should be "mdio"
83      - compatible : Should be "marvell,mv64360-mdio"
85    Example:
87      mdio {
88              #address-cells = <1>;
89              #size-cells = <0>;
90              device_type = "mdio";
91              compatible = "marvell,mv64360-mdio";
93              ethernet-phy@0 {
94                      ......
95              };
96      };
99    b) Marvell Discovery ethernet controller
101    The Discover ethernet controller is described with two levels
102    of nodes.  The first level describes an ethernet silicon block
103    and the second level describes up to 3 ethernet nodes within
104    that block.  The reason for the multiple levels is that the
105    registers for the node are interleaved within a single set
106    of registers.  The "ethernet-block" level describes the
107    shared register set, and the "ethernet" nodes describe ethernet
108    port-specific properties.
110    Ethernet block node
112    Required properties:
113      - #address-cells : <1>
114      - #size-cells : <0>
115      - compatible : "marvell,mv64360-eth-block"
116      - reg : Offset and length of the register set for this block
118    Example Discovery Ethernet block node:
119      ethernet-block@2000 {
120              #address-cells = <1>;
121              #size-cells = <0>;
122              compatible = "marvell,mv64360-eth-block";
123              reg = <0x2000 0x2000>;
124              ethernet@0 {
125                      .......
126              };
127      };
129    Ethernet port node
131    Required properties:
132      - device_type : Should be "network".
133      - compatible : Should be "marvell,mv64360-eth".
134      - reg : Should be <0>, <1>, or <2>, according to which registers
135        within the silicon block the device uses.
136      - interrupts : <a> where a is the interrupt number for the port.
137      - interrupt-parent : the phandle for the interrupt controller
138        that services interrupts for this device.
139      - phy : the phandle for the PHY connected to this ethernet
140        controller.
141      - local-mac-address : 6 bytes, MAC address
143    Example Discovery Ethernet port node:
144      ethernet@0 {
145              device_type = "network";
146              compatible = "marvell,mv64360-eth";
147              reg = <0>;
148              interrupts = <32>;
149              interrupt-parent = <&PIC>;
150              phy = <&PHY0>;
151              local-mac-address = [ 00 00 00 00 00 00 ];
152      };
156    c) Marvell Discovery PHY nodes
158    Required properties:
159      - device_type : Should be "ethernet-phy"
160      - interrupts : <a> where a is the interrupt number for this phy.
161      - interrupt-parent : the phandle for the interrupt controller that
162        services interrupts for this device.
163      - reg : The ID number for the phy, usually a small integer
165    Example Discovery PHY node:
166      ethernet-phy@1 {
167              device_type = "ethernet-phy";
168              compatible = "broadcom,bcm5421";
169              interrupts = <76>;      /* GPP 12 */
170              interrupt-parent = <&PIC>;
171              reg = <1>;
172      };
175    d) Marvell Discovery SDMA nodes
177    Represent DMA hardware associated with the MPSC (multiprotocol
178    serial controllers).
180    Required properties:
181      - compatible : "marvell,mv64360-sdma"
182      - reg : Offset and length of the register set for this device
183      - interrupts : <a> where a is the interrupt number for the DMA
184        device.
185      - interrupt-parent : the phandle for the interrupt controller
186        that services interrupts for this device.
188    Example Discovery SDMA node:
189      sdma@4000 {
190              compatible = "marvell,mv64360-sdma";
191              reg = <0x4000 0xc18>;
192              virtual-reg = <0xf1004000>;
193              interrupts = <36>;
194              interrupt-parent = <&PIC>;
195      };
198    e) Marvell Discovery BRG nodes
200    Represent baud rate generator hardware associated with the MPSC
201    (multiprotocol serial controllers).
203    Required properties:
204      - compatible : "marvell,mv64360-brg"
205      - reg : Offset and length of the register set for this device
206      - clock-src : A value from 0 to 15 which selects the clock
207        source for the baud rate generator.  This value corresponds
208        to the CLKS value in the BRGx configuration register.  See
209        the mv64x60 User's Manual.
210      - clock-frequence : The frequency (in Hz) of the baud rate
211        generator's input clock.
212      - current-speed : The current speed setting (presumably by
213        firmware) of the baud rate generator.
215    Example Discovery BRG node:
216      brg@b200 {
217              compatible = "marvell,mv64360-brg";
218              reg = <0xb200 0x8>;
219              clock-src = <8>;
220              clock-frequency = <133333333>;
221              current-speed = <9600>;
222      };
225    f) Marvell Discovery CUNIT nodes
227    Represent the Serial Communications Unit device hardware.
229    Required properties:
230      - reg : Offset and length of the register set for this device
232    Example Discovery CUNIT node:
233      cunit@f200 {
234              reg = <0xf200 0x200>;
235      };
238    g) Marvell Discovery MPSCROUTING nodes
240    Represent the Discovery's MPSC routing hardware
242    Required properties:
243      - reg : Offset and length of the register set for this device
245    Example Discovery CUNIT node:
246      mpscrouting@b500 {
247              reg = <0xb400 0xc>;
248      };
251    h) Marvell Discovery MPSCINTR nodes
253    Represent the Discovery's MPSC DMA interrupt hardware registers
254    (SDMA cause and mask registers).
256    Required properties:
257      - reg : Offset and length of the register set for this device
259    Example Discovery MPSCINTR node:
260      mpsintr@b800 {
261              reg = <0xb800 0x100>;
262      };
265    i) Marvell Discovery MPSC nodes
267    Represent the Discovery's MPSC (Multiprotocol Serial Controller)
268    serial port.
270    Required properties:
271      - device_type : "serial"
272      - compatible : "marvell,mv64360-mpsc"
273      - reg : Offset and length of the register set for this device
274      - sdma : the phandle for the SDMA node used by this port
275      - brg : the phandle for the BRG node used by this port
276      - cunit : the phandle for the CUNIT node used by this port
277      - mpscrouting : the phandle for the MPSCROUTING node used by this port
278      - mpscintr : the phandle for the MPSCINTR node used by this port
279      - cell-index : the hardware index of this cell in the MPSC core
280      - max_idle : value needed for MPSC CHR3 (Maximum Frame Length)
281        register
282      - interrupts : <a> where a is the interrupt number for the MPSC.
283      - interrupt-parent : the phandle for the interrupt controller
284        that services interrupts for this device.
286    Example Discovery MPSCINTR node:
287      mpsc@8000 {
288              device_type = "serial";
289              compatible = "marvell,mv64360-mpsc";
290              reg = <0x8000 0x38>;
291              virtual-reg = <0xf1008000>;
292              sdma = <&SDMA0>;
293              brg = <&BRG0>;
294              cunit = <&CUNIT>;
295              mpscrouting = <&MPSCROUTING>;
296              mpscintr = <&MPSCINTR>;
297              cell-index = <0>;
298              max_idle = <40>;
299              interrupts = <40>;
300              interrupt-parent = <&PIC>;
301      };
304    j) Marvell Discovery Watch Dog Timer nodes
306    Represent the Discovery's watchdog timer hardware
308    Required properties:
309      - compatible : "marvell,mv64360-wdt"
310      - reg : Offset and length of the register set for this device
312    Example Discovery Watch Dog Timer node:
313      wdt@b410 {
314              compatible = "marvell,mv64360-wdt";
315              reg = <0xb410 0x8>;
316      };
319    k) Marvell Discovery I2C nodes
321    Represent the Discovery's I2C hardware
323    Required properties:
324      - device_type : "i2c"
325      - compatible : "marvell,mv64360-i2c"
326      - reg : Offset and length of the register set for this device
327      - interrupts : <a> where a is the interrupt number for the I2C.
328      - interrupt-parent : the phandle for the interrupt controller
329        that services interrupts for this device.
331    Example Discovery I2C node:
332              compatible = "marvell,mv64360-i2c";
333              reg = <0xc000 0x20>;
334              virtual-reg = <0xf100c000>;
335              interrupts = <37>;
336              interrupt-parent = <&PIC>;
337      };
340    l) Marvell Discovery PIC (Programmable Interrupt Controller) nodes
342    Represent the Discovery's PIC hardware
344    Required properties:
345      - #interrupt-cells : <1>
346      - #address-cells : <0>
347      - compatible : "marvell,mv64360-pic"
348      - reg : Offset and length of the register set for this device
349      - interrupt-controller
351    Example Discovery PIC node:
352      pic {
353              #interrupt-cells = <1>;
354              #address-cells = <0>;
355              compatible = "marvell,mv64360-pic";
356              reg = <0x0 0x88>;
357              interrupt-controller;
358      };
361    m) Marvell Discovery MPP (Multipurpose Pins) multiplexing nodes
363    Represent the Discovery's MPP hardware
365    Required properties:
366      - compatible : "marvell,mv64360-mpp"
367      - reg : Offset and length of the register set for this device
369    Example Discovery MPP node:
370      mpp@f000 {
371              compatible = "marvell,mv64360-mpp";
372              reg = <0xf000 0x10>;
373      };
376    n) Marvell Discovery GPP (General Purpose Pins) nodes
378    Represent the Discovery's GPP hardware
380    Required properties:
381      - compatible : "marvell,mv64360-gpp"
382      - reg : Offset and length of the register set for this device
384    Example Discovery GPP node:
385      gpp@f000 {
386              compatible = "marvell,mv64360-gpp";
387              reg = <0xf100 0x20>;
388      };
391    o) Marvell Discovery PCI host bridge node
393    Represents the Discovery's PCI host bridge device.  The properties
394    for this node conform to Rev 2.1 of the PCI Bus Binding to IEEE
395    1275-1994.  A typical value for the compatible property is
396    "marvell,mv64360-pci".
398    Example Discovery PCI host bridge node
399      pci@80000000 {
400              #address-cells = <3>;
401              #size-cells = <2>;
402              #interrupt-cells = <1>;
403              device_type = "pci";
404              compatible = "marvell,mv64360-pci";
405              reg = <0xcf8 0x8>;
406              ranges = <0x01000000 0x0        0x0
407                              0x88000000 0x0 0x01000000
408                        0x02000000 0x0 0x80000000
409                              0x80000000 0x0 0x08000000>;
410              bus-range = <0 255>;
411              clock-frequency = <66000000>;
412              interrupt-parent = <&PIC>;
413              interrupt-map-mask = <0xf800 0x0 0x0 0x7>;
414              interrupt-map = <
415                      /* IDSEL 0x0a */
416                      0x5000 0 0 1 &PIC 80
417                      0x5000 0 0 2 &PIC 81
418                      0x5000 0 0 3 &PIC 91
419                      0x5000 0 0 4 &PIC 93
421                      /* IDSEL 0x0b */
422                      0x5800 0 0 1 &PIC 91
423                      0x5800 0 0 2 &PIC 93
424                      0x5800 0 0 3 &PIC 80
425                      0x5800 0 0 4 &PIC 81
427                      /* IDSEL 0x0c */
428                      0x6000 0 0 1 &PIC 91
429                      0x6000 0 0 2 &PIC 93
430                      0x6000 0 0 3 &PIC 80
431                      0x6000 0 0 4 &PIC 81
433                      /* IDSEL 0x0d */
434                      0x6800 0 0 1 &PIC 93
435                      0x6800 0 0 2 &PIC 80
436                      0x6800 0 0 3 &PIC 81
437                      0x6800 0 0 4 &PIC 91
438              >;
439      };
442    p) Marvell Discovery CPU Error nodes
444    Represent the Discovery's CPU error handler device.
446    Required properties:
447      - compatible : "marvell,mv64360-cpu-error"
448      - reg : Offset and length of the register set for this device
449      - interrupts : the interrupt number for this device
450      - interrupt-parent : the phandle for the interrupt controller
451        that services interrupts for this device.
453    Example Discovery CPU Error node:
454      cpu-error@0070 {
455              compatible = "marvell,mv64360-cpu-error";
456              reg = <0x70 0x10 0x128 0x28>;
457              interrupts = <3>;
458              interrupt-parent = <&PIC>;
459      };
462    q) Marvell Discovery SRAM Controller nodes
464    Represent the Discovery's SRAM controller device.
466    Required properties:
467      - compatible : "marvell,mv64360-sram-ctrl"
468      - reg : Offset and length of the register set for this device
469      - interrupts : the interrupt number for this device
470      - interrupt-parent : the phandle for the interrupt controller
471        that services interrupts for this device.
473    Example Discovery SRAM Controller node:
474      sram-ctrl@0380 {
475              compatible = "marvell,mv64360-sram-ctrl";
476              reg = <0x380 0x80>;
477              interrupts = <13>;
478              interrupt-parent = <&PIC>;
479      };
482    r) Marvell Discovery PCI Error Handler nodes
484    Represent the Discovery's PCI error handler device.
486    Required properties:
487      - compatible : "marvell,mv64360-pci-error"
488      - reg : Offset and length of the register set for this device
489      - interrupts : the interrupt number for this device
490      - interrupt-parent : the phandle for the interrupt controller
491        that services interrupts for this device.
493    Example Discovery PCI Error Handler node:
494      pci-error@1d40 {
495              compatible = "marvell,mv64360-pci-error";
496              reg = <0x1d40 0x40 0xc28 0x4>;
497              interrupts = <12>;
498              interrupt-parent = <&PIC>;
499      };
502    s) Marvell Discovery Memory Controller nodes
504    Represent the Discovery's memory controller device.
506    Required properties:
507      - compatible : "marvell,mv64360-mem-ctrl"
508      - reg : Offset and length of the register set for this device
509      - interrupts : the interrupt number for this device
510      - interrupt-parent : the phandle for the interrupt controller
511        that services interrupts for this device.
513    Example Discovery Memory Controller node:
514      mem-ctrl@1400 {
515              compatible = "marvell,mv64360-mem-ctrl";
516              reg = <0x1400 0x60>;
517              interrupts = <17>;
518              interrupt-parent = <&PIC>;
519      };