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: 21*3567932cSAndre Przywara - enum: 22*3567932cSAndre Przywara - allwinner,sun8i-a23-i2c 23*3567932cSAndre Przywara - allwinner,sun8i-a83t-i2c 24*3567932cSAndre Przywara - allwinner,sun50i-a64-i2c 25*3567932cSAndre Przywara - allwinner,sun50i-a100-i2c 26*3567932cSAndre Przywara - allwinner,sun50i-h6-i2c 27*3567932cSAndre Przywara - allwinner,sun50i-h616-i2c 28f8bbde72SMaxime Ripard - const: allwinner,sun6i-a31-i2c 29f8bbde72SMaxime Ripard - const: marvell,mv64xxx-i2c 30f8bbde72SMaxime Ripard - const: marvell,mv78230-i2c 31f8bbde72SMaxime Ripard - const: marvell,mv78230-a0-i2c 32f8bbde72SMaxime Ripard 33f8bbde72SMaxime Ripard description: 34f8bbde72SMaxime Ripard Only use "marvell,mv78230-a0-i2c" for a very rare, initial 35f8bbde72SMaxime Ripard version of the SoC which had broken offload support. Linux 36f8bbde72SMaxime Ripard auto-detects this and sets it appropriately. 37f8bbde72SMaxime Ripard 38f8bbde72SMaxime Ripard reg: 39f8bbde72SMaxime Ripard maxItems: 1 40f8bbde72SMaxime Ripard 41f8bbde72SMaxime Ripard interrupts: 42f8bbde72SMaxime Ripard maxItems: 1 43f8bbde72SMaxime Ripard 44f8bbde72SMaxime Ripard clocks: 45f8bbde72SMaxime Ripard minItems: 1 46f8bbde72SMaxime Ripard maxItems: 2 47f8bbde72SMaxime Ripard items: 48f8bbde72SMaxime Ripard - description: Reference clock for the I2C bus 49f8bbde72SMaxime Ripard - description: Bus clock (Only for Armada 7K/8K) 50f8bbde72SMaxime Ripard 51f8bbde72SMaxime Ripard clock-names: 52f8bbde72SMaxime Ripard minItems: 1 53f8bbde72SMaxime Ripard maxItems: 2 54f8bbde72SMaxime Ripard items: 55f8bbde72SMaxime Ripard - const: core 56f8bbde72SMaxime Ripard - const: reg 57f8bbde72SMaxime Ripard description: 58f8bbde72SMaxime Ripard Mandatory if two clocks are used (only for Armada 7k and 8k). 59f8bbde72SMaxime Ripard 60f8bbde72SMaxime Ripard resets: 61f8bbde72SMaxime Ripard maxItems: 1 62f8bbde72SMaxime Ripard 63f8bbde72SMaxime Ripardrequired: 64f8bbde72SMaxime Ripard - compatible 65f8bbde72SMaxime Ripard - reg 66f8bbde72SMaxime Ripard - interrupts 67f8bbde72SMaxime Ripard 68f8bbde72SMaxime RipardallOf: 69f8bbde72SMaxime Ripard - $ref: /schemas/i2c/i2c-controller.yaml# 70f8bbde72SMaxime Ripard - if: 71f8bbde72SMaxime Ripard properties: 72f8bbde72SMaxime Ripard compatible: 73f8bbde72SMaxime Ripard contains: 74f8bbde72SMaxime Ripard enum: 75f8bbde72SMaxime Ripard - allwinner,sun4i-a10-i2c 76f8bbde72SMaxime Ripard - allwinner,sun6i-a31-i2c 77f8bbde72SMaxime Ripard 78f8bbde72SMaxime Ripard then: 79f8bbde72SMaxime Ripard required: 80f8bbde72SMaxime Ripard - clocks 81f8bbde72SMaxime Ripard 82f8bbde72SMaxime Ripard - if: 83f8bbde72SMaxime Ripard properties: 84f8bbde72SMaxime Ripard compatible: 85f8bbde72SMaxime Ripard contains: 86f8bbde72SMaxime Ripard const: allwinner,sun6i-a31-i2c 87f8bbde72SMaxime Ripard 88f8bbde72SMaxime Ripard then: 89f8bbde72SMaxime Ripard required: 90f8bbde72SMaxime Ripard - resets 91f8bbde72SMaxime Ripard 92454f5d9dSMaxime RipardunevaluatedProperties: false 93f8bbde72SMaxime Ripard 94f8bbde72SMaxime Ripardexamples: 95f8bbde72SMaxime Ripard - | 96f8bbde72SMaxime Ripard i2c@11000 { 97f8bbde72SMaxime Ripard compatible = "marvell,mv64xxx-i2c"; 98f8bbde72SMaxime Ripard reg = <0x11000 0x20>; 99f8bbde72SMaxime Ripard interrupts = <29>; 100f8bbde72SMaxime Ripard clock-frequency = <100000>; 101f8bbde72SMaxime Ripard }; 102f8bbde72SMaxime Ripard 103f8bbde72SMaxime Ripard - | 104f8bbde72SMaxime Ripard i2c@11000 { 105166f28c3SMaxime Ripard compatible = "marvell,mv78230-i2c"; 106f8bbde72SMaxime Ripard reg = <0x11000 0x100>; 107f8bbde72SMaxime Ripard interrupts = <29>; 108f8bbde72SMaxime Ripard clock-frequency = <100000>; 109f8bbde72SMaxime Ripard }; 110f8bbde72SMaxime Ripard 111f8bbde72SMaxime Ripard - | 112f8bbde72SMaxime Ripard i2c@701000 { 113f8bbde72SMaxime Ripard compatible = "marvell,mv78230-i2c"; 114f8bbde72SMaxime Ripard reg = <0x701000 0x20>; 115f8bbde72SMaxime Ripard interrupts = <29>; 116f8bbde72SMaxime Ripard clock-frequency = <100000>; 117f8bbde72SMaxime Ripard clock-names = "core", "reg"; 118f8bbde72SMaxime Ripard clocks = <&core_clock>, <®_clock>; 119f8bbde72SMaxime Ripard }; 120f8bbde72SMaxime Ripard 121f8bbde72SMaxime Ripard... 122