xref: /linux/Documentation/devicetree/bindings/i2c/st,stm32-i2c.yaml (revision 15a1fbdcfb519c2bd291ed01c6c94e0b89537a77)
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@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    then:
21      properties:
22        i2c-scl-rising-time-ns:
23          default: 25
24
25        i2c-scl-falling-time-ns:
26          default: 10
27
28        st,syscfg-fmp:
29          description: Use to set Fast Mode Plus bit within SYSCFG when
30                       Fast Mode Plus speed is selected by slave.
31                       Format is phandle to syscfg / register offset within
32                       syscfg / register bitmask for FMP bit.
33          allOf:
34            - $ref: "/schemas/types.yaml#/definitions/phandle-array"
35            - items:
36                minItems: 3
37                maxItems: 3
38
39  - if:
40      properties:
41        compatible:
42          contains:
43            enum:
44              - st,stm32f4-i2c
45    then:
46      properties:
47        clock-frequency:
48          enum: [100000, 400000]
49
50properties:
51  compatible:
52    enum:
53      - st,stm32f4-i2c
54      - st,stm32f7-i2c
55
56  reg:
57    maxItems: 1
58
59  interrupts:
60    items:
61      - description: interrupt ID for I2C event
62      - description: interrupt ID for I2C error
63
64  resets:
65    maxItems: 1
66
67  clocks:
68    maxItems: 1
69
70  dmas:
71    items:
72      - description: RX DMA Channel phandle
73      - description: TX DMA Channel phandle
74
75  dma-names:
76    items:
77      - const: rx
78      - const: tx
79
80  clock-frequency:
81    description: Desired I2C bus clock frequency in Hz. If not specified,
82                 the default 100 kHz frequency will be used.
83                 For STM32F7, STM32H7 and STM32MP1 SoCs, Standard-mode,
84                 Fast-mode and Fast-mode Plus are supported, possible
85                 values are 100000, 400000 and 1000000.
86    default: 100000
87    enum: [100000, 400000, 1000000]
88
89required:
90  - compatible
91  - reg
92  - interrupts
93  - resets
94  - clocks
95
96examples:
97  - |
98    #include <dt-bindings/mfd/stm32f7-rcc.h>
99    #include <dt-bindings/clock/stm32fx-clock.h>
100    //Example 1 (with st,stm32f4-i2c compatible)
101      i2c@40005400 {
102          compatible = "st,stm32f4-i2c";
103          #address-cells = <1>;
104          #size-cells = <0>;
105          reg = <0x40005400 0x400>;
106          interrupts = <31>,
107                       <32>;
108          resets = <&rcc 277>;
109          clocks = <&rcc 0 149>;
110      };
111
112    //Example 2 (with st,stm32f7-i2c compatible)
113      i2c@40005800 {
114          compatible = "st,stm32f7-i2c";
115          #address-cells = <1>;
116          #size-cells = <0>;
117          reg = <0x40005800 0x400>;
118          interrupts = <31>,
119                       <32>;
120          resets = <&rcc STM32F7_APB1_RESET(I2C1)>;
121          clocks = <&rcc 1 CLK_I2C1>;
122      };
123
124    //Example 3 (with st,stm32f7-i2c compatible on stm32mp)
125    #include <dt-bindings/interrupt-controller/arm-gic.h>
126    #include <dt-bindings/clock/stm32mp1-clks.h>
127    #include <dt-bindings/reset/stm32mp1-resets.h>
128      i2c@40013000 {
129          compatible = "st,stm32f7-i2c";
130          #address-cells = <1>;
131          #size-cells = <0>;
132          reg = <0x40013000 0x400>;
133          interrupts = <GIC_SPI 33 IRQ_TYPE_LEVEL_HIGH>,
134                       <GIC_SPI 34 IRQ_TYPE_LEVEL_HIGH>;
135          clocks = <&rcc I2C2_K>;
136          resets = <&rcc I2C2_R>;
137          i2c-scl-rising-time-ns = <185>;
138          i2c-scl-falling-time-ns = <20>;
139          st,syscfg-fmp = <&syscfg 0x4 0x2>;
140      };
141...
142