xref: /linux/Documentation/devicetree/bindings/i2c/st,stm32-i2c.yaml (revision 001821b0e79716c4e17c71d8e053a23599a7a508)
1# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
2%YAML 1.2
3---
4$id: http://devicetree.org/schemas/i2c/st,stm32-i2c.yaml#
5$schema: http://devicetree.org/meta-schemas/core.yaml#
6
7title: I2C controller embedded in STMicroelectronics STM32 I2C platform
8
9maintainers:
10  - Pierre-Yves MORDRET <pierre-yves.mordret@foss.st.com>
11
12allOf:
13  - $ref: /schemas/i2c/i2c-controller.yaml#
14  - if:
15      properties:
16        compatible:
17          contains:
18            enum:
19              - st,stm32f7-i2c
20              - st,stm32mp13-i2c
21              - st,stm32mp15-i2c
22              - st,stm32mp25-i2c
23    then:
24      properties:
25        i2c-scl-rising-time-ns:
26          default: 25
27
28        i2c-scl-falling-time-ns:
29          default: 10
30    else:
31      properties:
32        st,syscfg-fmp: false
33
34  - if:
35      properties:
36        compatible:
37          contains:
38            enum:
39              - st,stm32f4-i2c
40    then:
41      properties:
42        clock-frequency:
43          enum: [100000, 400000]
44
45  - if:
46      properties:
47        compatible:
48          contains:
49            enum:
50              - st,stm32f4-i2c
51              - st,stm32f7-i2c
52              - st,stm32mp13-i2c
53              - st,stm32mp15-i2c
54    then:
55      properties:
56        interrupts:
57          minItems: 2
58
59        interrupt-names:
60          minItems: 2
61    else:
62      properties:
63        interrupts:
64          maxItems: 1
65
66        interrupt-names:
67          maxItems: 1
68
69properties:
70  compatible:
71    enum:
72      - st,stm32f4-i2c
73      - st,stm32f7-i2c
74      - st,stm32mp13-i2c
75      - st,stm32mp15-i2c
76      - st,stm32mp25-i2c
77
78  reg:
79    maxItems: 1
80
81  interrupts:
82    items:
83      - description: interrupt ID for I2C event
84      - description: interrupt ID for I2C error
85    minItems: 1
86
87  interrupt-names:
88    items:
89      - const: event
90      - const: error
91    minItems: 1
92
93  resets:
94    maxItems: 1
95
96  clocks:
97    maxItems: 1
98
99  dmas:
100    items:
101      - description: RX DMA Channel phandle
102      - description: TX DMA Channel phandle
103
104  dma-names:
105    items:
106      - const: rx
107      - const: tx
108
109  clock-frequency:
110    description: Desired I2C bus clock frequency in Hz. If not specified,
111                 the default 100 kHz frequency will be used.
112                 For STM32F7, STM32H7 and STM32MP1 SoCs, if timing parameters
113                 match, the bus clock frequency can be from 1Hz to 1MHz.
114    default: 100000
115    minimum: 1
116    maximum: 1000000
117
118  st,syscfg-fmp:
119    description: Use to set Fast Mode Plus bit within SYSCFG when Fast Mode
120      Plus speed is selected by slave.
121    $ref: /schemas/types.yaml#/definitions/phandle-array
122    items:
123      - items:
124          - description: phandle to syscfg
125          - description: register offset within syscfg
126          - description: register bitmask for FMP bit
127
128  wakeup-source: true
129
130  access-controllers:
131    minItems: 1
132    maxItems: 2
133
134required:
135  - compatible
136  - reg
137  - interrupts
138  - resets
139  - clocks
140
141unevaluatedProperties: false
142
143examples:
144  - |
145    #include <dt-bindings/mfd/stm32f7-rcc.h>
146    #include <dt-bindings/clock/stm32fx-clock.h>
147    //Example 1 (with st,stm32f4-i2c compatible)
148      i2c@40005400 {
149          compatible = "st,stm32f4-i2c";
150          #address-cells = <1>;
151          #size-cells = <0>;
152          reg = <0x40005400 0x400>;
153          interrupts = <31>,
154                       <32>;
155          resets = <&rcc 277>;
156          clocks = <&rcc 0 149>;
157      };
158
159  - |
160    #include <dt-bindings/mfd/stm32f7-rcc.h>
161    #include <dt-bindings/clock/stm32fx-clock.h>
162    //Example 2 (with st,stm32f7-i2c compatible)
163      i2c@40005800 {
164          compatible = "st,stm32f7-i2c";
165          #address-cells = <1>;
166          #size-cells = <0>;
167          reg = <0x40005800 0x400>;
168          interrupts = <31>,
169                       <32>;
170          resets = <&rcc STM32F7_APB1_RESET(I2C1)>;
171          clocks = <&rcc 1 CLK_I2C1>;
172      };
173
174  - |
175    #include <dt-bindings/mfd/stm32f7-rcc.h>
176    #include <dt-bindings/clock/stm32fx-clock.h>
177    //Example 3 (with st,stm32mp15-i2c compatible on stm32mp)
178    #include <dt-bindings/interrupt-controller/arm-gic.h>
179    #include <dt-bindings/clock/stm32mp1-clks.h>
180    #include <dt-bindings/reset/stm32mp1-resets.h>
181      i2c@40013000 {
182          compatible = "st,stm32mp15-i2c";
183          #address-cells = <1>;
184          #size-cells = <0>;
185          reg = <0x40013000 0x400>;
186          interrupts = <GIC_SPI 33 IRQ_TYPE_LEVEL_HIGH>,
187                       <GIC_SPI 34 IRQ_TYPE_LEVEL_HIGH>;
188          clocks = <&rcc I2C2_K>;
189          resets = <&rcc I2C2_R>;
190          i2c-scl-rising-time-ns = <185>;
191          i2c-scl-falling-time-ns = <20>;
192          st,syscfg-fmp = <&syscfg 0x4 0x2>;
193      };
194