1f8bbde72SMaxime Ripard# SPDX-License-Identifier: GPL-2.0 2f8bbde72SMaxime Ripard%YAML 1.2 3f8bbde72SMaxime Ripard--- 4f8bbde72SMaxime Ripard$id: http://devicetree.org/schemas/i2c/marvell,mv64xxx-i2c.yaml# 5f8bbde72SMaxime Ripard$schema: http://devicetree.org/meta-schemas/core.yaml# 6f8bbde72SMaxime Ripard 7f8bbde72SMaxime Ripardtitle: Marvell MV64XXX I2C Controller Device Tree Bindings 8f8bbde72SMaxime Ripard 9f8bbde72SMaxime Ripardmaintainers: 10f8bbde72SMaxime Ripard - Gregory CLEMENT <gregory.clement@bootlin.com> 11f8bbde72SMaxime Ripard 12f8bbde72SMaxime Ripardproperties: 13f8bbde72SMaxime Ripard compatible: 14f8bbde72SMaxime Ripard oneOf: 15f8bbde72SMaxime Ripard - const: allwinner,sun4i-a10-i2c 16f8bbde72SMaxime Ripard - items: 17f8bbde72SMaxime Ripard - const: allwinner,sun7i-a20-i2c 18f8bbde72SMaxime Ripard - const: allwinner,sun4i-a10-i2c 19f8bbde72SMaxime Ripard - const: allwinner,sun6i-a31-i2c 20f8bbde72SMaxime Ripard - items: 213567932cSAndre Przywara - enum: 223567932cSAndre Przywara - allwinner,sun8i-a23-i2c 233567932cSAndre Przywara - allwinner,sun8i-a83t-i2c 24*e01f242aSSamuel Holland - allwinner,sun8i-v536-i2c 253567932cSAndre Przywara - allwinner,sun50i-a64-i2c 263567932cSAndre Przywara - allwinner,sun50i-h6-i2c 27*e01f242aSSamuel Holland - const: allwinner,sun6i-a31-i2c 28*e01f242aSSamuel Holland - description: Allwinner SoCs with offload support 29*e01f242aSSamuel Holland items: 30*e01f242aSSamuel Holland - enum: 31*e01f242aSSamuel Holland - allwinner,sun20i-d1-i2c 32*e01f242aSSamuel Holland - allwinner,sun50i-a100-i2c 333567932cSAndre Przywara - allwinner,sun50i-h616-i2c 34*e01f242aSSamuel Holland - allwinner,sun50i-r329-i2c 35*e01f242aSSamuel Holland - const: allwinner,sun8i-v536-i2c 36f8bbde72SMaxime Ripard - const: allwinner,sun6i-a31-i2c 37f8bbde72SMaxime Ripard - const: marvell,mv64xxx-i2c 38f8bbde72SMaxime Ripard - const: marvell,mv78230-i2c 39f8bbde72SMaxime Ripard - const: marvell,mv78230-a0-i2c 40f8bbde72SMaxime Ripard 41f8bbde72SMaxime Ripard description: 42f8bbde72SMaxime Ripard Only use "marvell,mv78230-a0-i2c" for a very rare, initial 43f8bbde72SMaxime Ripard version of the SoC which had broken offload support. Linux 44f8bbde72SMaxime Ripard auto-detects this and sets it appropriately. 45f8bbde72SMaxime Ripard 46f8bbde72SMaxime Ripard reg: 47f8bbde72SMaxime Ripard maxItems: 1 48f8bbde72SMaxime Ripard 49f8bbde72SMaxime Ripard interrupts: 50f8bbde72SMaxime Ripard maxItems: 1 51f8bbde72SMaxime Ripard 52f8bbde72SMaxime Ripard clocks: 53f8bbde72SMaxime Ripard minItems: 1 54f8bbde72SMaxime Ripard items: 55f8bbde72SMaxime Ripard - description: Reference clock for the I2C bus 56f8bbde72SMaxime Ripard - description: Bus clock (Only for Armada 7K/8K) 57f8bbde72SMaxime Ripard 58f8bbde72SMaxime Ripard clock-names: 59f8bbde72SMaxime Ripard minItems: 1 60f8bbde72SMaxime Ripard items: 61f8bbde72SMaxime Ripard - const: core 62f8bbde72SMaxime Ripard - const: reg 63f8bbde72SMaxime Ripard description: 64f8bbde72SMaxime Ripard Mandatory if two clocks are used (only for Armada 7k and 8k). 65f8bbde72SMaxime Ripard 66f8bbde72SMaxime Ripard resets: 67f8bbde72SMaxime Ripard maxItems: 1 68f8bbde72SMaxime Ripard 69f8bbde72SMaxime Ripardrequired: 70f8bbde72SMaxime Ripard - compatible 71f8bbde72SMaxime Ripard - reg 72f8bbde72SMaxime Ripard - interrupts 73f8bbde72SMaxime Ripard 74f8bbde72SMaxime RipardallOf: 75f8bbde72SMaxime Ripard - $ref: /schemas/i2c/i2c-controller.yaml# 76f8bbde72SMaxime Ripard - if: 77f8bbde72SMaxime Ripard properties: 78f8bbde72SMaxime Ripard compatible: 79f8bbde72SMaxime Ripard contains: 80f8bbde72SMaxime Ripard enum: 81f8bbde72SMaxime Ripard - allwinner,sun4i-a10-i2c 82f8bbde72SMaxime Ripard - allwinner,sun6i-a31-i2c 83f8bbde72SMaxime Ripard 84f8bbde72SMaxime Ripard then: 85f8bbde72SMaxime Ripard required: 86f8bbde72SMaxime Ripard - clocks 87f8bbde72SMaxime Ripard 88f8bbde72SMaxime Ripard - if: 89f8bbde72SMaxime Ripard properties: 90f8bbde72SMaxime Ripard compatible: 91f8bbde72SMaxime Ripard contains: 92f8bbde72SMaxime Ripard const: allwinner,sun6i-a31-i2c 93f8bbde72SMaxime Ripard 94f8bbde72SMaxime Ripard then: 95f8bbde72SMaxime Ripard required: 96f8bbde72SMaxime Ripard - resets 97f8bbde72SMaxime Ripard 98454f5d9dSMaxime RipardunevaluatedProperties: false 99f8bbde72SMaxime Ripard 100f8bbde72SMaxime Ripardexamples: 101f8bbde72SMaxime Ripard - | 102f8bbde72SMaxime Ripard i2c@11000 { 103f8bbde72SMaxime Ripard compatible = "marvell,mv64xxx-i2c"; 104f8bbde72SMaxime Ripard reg = <0x11000 0x20>; 105f8bbde72SMaxime Ripard interrupts = <29>; 106f8bbde72SMaxime Ripard clock-frequency = <100000>; 107f8bbde72SMaxime Ripard }; 108f8bbde72SMaxime Ripard 109f8bbde72SMaxime Ripard - | 110f8bbde72SMaxime Ripard i2c@11000 { 111166f28c3SMaxime Ripard compatible = "marvell,mv78230-i2c"; 112f8bbde72SMaxime Ripard reg = <0x11000 0x100>; 113f8bbde72SMaxime Ripard interrupts = <29>; 114f8bbde72SMaxime Ripard clock-frequency = <100000>; 115f8bbde72SMaxime Ripard }; 116f8bbde72SMaxime Ripard 117f8bbde72SMaxime Ripard - | 118f8bbde72SMaxime Ripard i2c@701000 { 119f8bbde72SMaxime Ripard compatible = "marvell,mv78230-i2c"; 120f8bbde72SMaxime Ripard reg = <0x701000 0x20>; 121f8bbde72SMaxime Ripard interrupts = <29>; 122f8bbde72SMaxime Ripard clock-frequency = <100000>; 123f8bbde72SMaxime Ripard clock-names = "core", "reg"; 124f8bbde72SMaxime Ripard clocks = <&core_clock>, <®_clock>; 125f8bbde72SMaxime Ripard }; 126f8bbde72SMaxime Ripard 127f8bbde72SMaxime Ripard... 128