1 # SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
4 $id: http://devicetree.org/schemas/i2c/opencores,i2c-ocores.yaml#
5 $schema: http://devicetree.org/meta-schemas/core.yaml#
7 title: OpenCores I2C controller
10 - Peter Korsgaard <peter@korsgaard.com>
11 - Andrew Lunn <andrew@lunn.ch>
14 - $ref: /schemas/i2c/i2c-controller.yaml#
21 - sifive,fu740-c000-i2c # Opencore based IP block FU740-C000 SoC
22 - sifive,fu540-c000-i2c # Opencore based IP block FU540-C000 SoC
25 - opencores,i2c-ocores
26 - aeroflexgaisler,i2cmst
39 clock-frequency property is meant to control the bus frequency for i2c bus
40 drivers, but it was incorrectly used to specify i2c controller input clock
41 frequency. So the following rules are set to fix this situation:
42 - if clock-frequency is present and neither opencores,ip-clock-frequency nor
43 clocks are, then clock-frequency specifies i2c controller clock frequency.
44 This is to keep backwards compatibility with setups using old DTB. i2c bus
45 frequency is fixed at 100 KHz.
46 - if clocks is present it specifies i2c controller clock. clock-frequency
47 property specifies i2c bus frequency.
48 - if opencores,ip-clock-frequency is present it specifies i2c controller
49 clock frequency. clock-frequency property specifies i2c bus frequency.
54 io register width in bytes
59 device register offsets are shifted by this value
63 $ref: /schemas/types.yaml#/definitions/uint32
65 deprecated, use reg-shift above
68 opencores,ip-clock-frequency:
69 $ref: /schemas/types.yaml#/definitions/uint32
71 Frequency of the controller clock in Hz. Mutually exclusive with clocks.
82 - opencores,ip-clock-frequency
86 unevaluatedProperties: false
91 compatible = "opencores,i2c-ocores";
92 reg = <0xa0000000 0x8>;
96 opencores,ip-clock-frequency = <20000000>;
98 reg-shift = <0>; /* 8 bit registers */
99 reg-io-width = <1>; /* 8 bit read/write */
103 compatible = "opencores,i2c-ocores";
104 reg = <0xa0000000 0x8>;
105 #address-cells = <1>;
109 clock-frequency = <400000>; /* i2c bus frequency 400 KHz */
111 reg-shift = <0>; /* 8 bit registers */
112 reg-io-width = <1>; /* 8 bit read/write */