1 * MediaTek's I2C controller
3 The MediaTek's I2C controller is used to interface with I2C devices.
6 - compatible: value should be either of the following.
7 "mediatek,mt2701-i2c", "mediatek,mt6577-i2c": for MediaTek MT2701
8 "mediatek,mt2712-i2c": for MediaTek MT2712
9 "mediatek,mt6577-i2c": for MediaTek MT6577
10 "mediatek,mt6589-i2c": for MediaTek MT6589
11 "mediatek,mt7622-i2c": for MediaTek MT7622
12 "mediatek,mt7623-i2c", "mediatek,mt6577-i2c": for MediaTek MT7623
13 "mediatek,mt7629-i2c", "mediatek,mt2712-i2c": for MediaTek MT7629
14 "mediatek,mt8173-i2c": for MediaTek MT8173
15 "mediatek,mt8183-i2c": for MediaTek MT8183
16 "mediatek,mt8516-i2c", "mediatek,mt2712-i2c": for MediaTek MT8516
17 - reg: physical base address of the controller and dma base, length of memory
19 - interrupts: interrupt number to the cpu.
20 - clock-div: the fixed value for frequency divider of clock source in i2c
21 module. Each IC may be different.
22 - clocks: clock name from clock manager
23 - clock-names: Must include "main" and "dma", "arb" is for multi-master that
24 one bus has more than two i2c controllers, if enable have-pmic need include
28 - clock-frequency: Frequency in Hz of the bus when transfer, the default value
30 - mediatek,have-pmic: platform can control i2c form special pmic side.
31 Only mt6589 and mt8135 support this feature.
32 - mediatek,use-push-pull: IO config use push-pull mode.
37 compatible = "mediatek,mt6577-i2c";
38 reg = <0x1100d000 0x70>,
40 interrupts = <GIC_SPI 44 IRQ_TYPE_LEVEL_LOW>;
41 clock-frequency = <400000>;
44 clocks = <&i2c0_ck>, <&ap_dma_ck>;
45 clock-names = "main", "dma";