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