xref: /openbmc/linux/Documentation/devicetree/bindings/arm/syna.txt (revision 4f2c0a4acffbec01079c28f839422e64ddeff004)
13da29379SJisheng ZhangSynaptics SoC Device Tree Bindings
23da29379SJisheng Zhang
33da29379SJisheng ZhangAccording to https://www.synaptics.com/company/news/conexant-marvell
43da29379SJisheng ZhangSynaptics has acquired the Multimedia Solutions Business of Marvell, so
53da29379SJisheng Zhangberlin SoCs are now Synaptics' SoCs now.
63da29379SJisheng Zhang
710c3a0b7SJisheng Zhang---------------------------------------------------------------
810c3a0b7SJisheng Zhang
910c3a0b7SJisheng ZhangWork in progress statement:
1010c3a0b7SJisheng Zhang
1110c3a0b7SJisheng ZhangDevice tree files and bindings applying to Marvell Berlin SoCs and boards are
1210c3a0b7SJisheng Zhangconsidered "unstable". Any Marvell Berlin device tree binding may change at any
1310c3a0b7SJisheng Zhangtime. Be sure to use a device tree binary and a kernel image generated from the
1410c3a0b7SJisheng Zhangsame source tree.
1510c3a0b7SJisheng Zhang
16*56516a9fSMauro Carvalho ChehabPlease refer to Documentation/devicetree/bindings/ABI.rst for a definition of a
1710c3a0b7SJisheng Zhangstable binding/ABI.
1810c3a0b7SJisheng Zhang
1910c3a0b7SJisheng Zhang---------------------------------------------------------------
2010c3a0b7SJisheng Zhang
2110c3a0b7SJisheng ZhangBoards with a SoC of the Marvell Berlin family, e.g. Armada 1500
2210c3a0b7SJisheng Zhangshall have the following properties:
2310c3a0b7SJisheng Zhang
2410c3a0b7SJisheng Zhang* Required root node properties:
2510c3a0b7SJisheng Zhangcompatible: must contain "marvell,berlin"
2610c3a0b7SJisheng Zhang
2710c3a0b7SJisheng ZhangIn addition, the above compatible shall be extended with the specific
2810c3a0b7SJisheng ZhangSoC and board used. Currently known SoC compatibles are:
2910c3a0b7SJisheng Zhang    "marvell,berlin2"      for Marvell Armada 1500 (BG2, 88DE3100),
3010c3a0b7SJisheng Zhang    "marvell,berlin2cd"    for Marvell Armada 1500-mini (BG2CD, 88DE3005)
3110c3a0b7SJisheng Zhang    "marvell,berlin2ct"    for Marvell Armada ? (BG2CT, 88DE????)
3210c3a0b7SJisheng Zhang    "marvell,berlin2q"     for Marvell Armada 1500-pro (BG2Q, 88DE3114)
3310c3a0b7SJisheng Zhang    "marvell,berlin3"      for Marvell Armada ? (BG3, 88DE????)
3410c3a0b7SJisheng Zhang
3510c3a0b7SJisheng Zhang* Example:
3610c3a0b7SJisheng Zhang
3710c3a0b7SJisheng Zhang/ {
3810c3a0b7SJisheng Zhang	model = "Sony NSZ-GS7";
3910c3a0b7SJisheng Zhang	compatible = "sony,nsz-gs7", "marvell,berlin2", "marvell,berlin";
4010c3a0b7SJisheng Zhang
4110c3a0b7SJisheng Zhang	...
4210c3a0b7SJisheng Zhang}
4310c3a0b7SJisheng Zhang
4410c3a0b7SJisheng Zhang* Marvell Berlin CPU control bindings
4510c3a0b7SJisheng Zhang
4610c3a0b7SJisheng ZhangCPU control register allows various operations on CPUs, like resetting them
4710c3a0b7SJisheng Zhangindependently.
4810c3a0b7SJisheng Zhang
4910c3a0b7SJisheng ZhangRequired properties:
5010c3a0b7SJisheng Zhang- compatible: should be "marvell,berlin-cpu-ctrl"
5110c3a0b7SJisheng Zhang- reg: address and length of the register set
5210c3a0b7SJisheng Zhang
5310c3a0b7SJisheng ZhangExample:
5410c3a0b7SJisheng Zhang
5510c3a0b7SJisheng Zhangcpu-ctrl@f7dd0000 {
5610c3a0b7SJisheng Zhang	compatible = "marvell,berlin-cpu-ctrl";
5710c3a0b7SJisheng Zhang	reg = <0xf7dd0000 0x10000>;
5810c3a0b7SJisheng Zhang};
5910c3a0b7SJisheng Zhang
6010c3a0b7SJisheng Zhang* Marvell Berlin2 chip control binding
6110c3a0b7SJisheng Zhang
6210c3a0b7SJisheng ZhangMarvell Berlin SoCs have a chip control register set providing several
6310c3a0b7SJisheng Zhangindividual registers dealing with pinmux, padmux, clock, reset, and secondary
6410c3a0b7SJisheng ZhangCPU boot address. Unfortunately, the individual registers are spread among the
6510c3a0b7SJisheng Zhangchip control registers, so there should be a single DT node only providing the
6610c3a0b7SJisheng Zhangdifferent functions which are described below.
6710c3a0b7SJisheng Zhang
6810c3a0b7SJisheng ZhangRequired properties:
6910c3a0b7SJisheng Zhang- compatible:
7010c3a0b7SJisheng Zhang	* the first and second values must be:
7110c3a0b7SJisheng Zhang		"simple-mfd", "syscon"
7210c3a0b7SJisheng Zhang- reg: address and length of following register sets for
7310c3a0b7SJisheng Zhang  BG2/BG2CD: chip control register set
7410c3a0b7SJisheng Zhang  BG2Q: chip control register set and cpu pll registers
7510c3a0b7SJisheng Zhang
7610c3a0b7SJisheng Zhang* Marvell Berlin2 system control binding
7710c3a0b7SJisheng Zhang
7810c3a0b7SJisheng ZhangMarvell Berlin SoCs have a system control register set providing several
7910c3a0b7SJisheng Zhangindividual registers dealing with pinmux, padmux, and reset.
8010c3a0b7SJisheng Zhang
8110c3a0b7SJisheng ZhangRequired properties:
8210c3a0b7SJisheng Zhang- compatible:
8310c3a0b7SJisheng Zhang	* the first and second values must be:
8410c3a0b7SJisheng Zhang		"simple-mfd", "syscon"
8510c3a0b7SJisheng Zhang- reg: address and length of the system control register set
8610c3a0b7SJisheng Zhang
8710c3a0b7SJisheng ZhangExample:
8810c3a0b7SJisheng Zhang
8910c3a0b7SJisheng Zhangchip: chip-control@ea0000 {
9010c3a0b7SJisheng Zhang	compatible = "simple-mfd", "syscon";
9110c3a0b7SJisheng Zhang	reg = <0xea0000 0x400>;
9210c3a0b7SJisheng Zhang
9310c3a0b7SJisheng Zhang	/* sub-device nodes */
9410c3a0b7SJisheng Zhang};
9510c3a0b7SJisheng Zhang
9610c3a0b7SJisheng Zhangsysctrl: system-controller@d000 {
9710c3a0b7SJisheng Zhang	compatible = "simple-mfd", "syscon";
9810c3a0b7SJisheng Zhang	reg = <0xd000 0x100>;
9910c3a0b7SJisheng Zhang
10010c3a0b7SJisheng Zhang	/* sub-device nodes */
10110c3a0b7SJisheng Zhang};
102