hc
2023-03-13 25c72f09e887f85fcff4a3f978d294da97ab1420
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
* Synopsys DesignWare I2C
 
Required properties :
 
 - compatible : should be "snps,designware-i2c"
 - reg : Offset and length of the register set for the device
 - interrupts : <IRQ> where IRQ is the interrupt number.
 
Recommended properties :
 
 - clock-frequency : desired I2C bus clock frequency in Hz.
 
Optional properties :
 - i2c-sda-hold-time-ns : should contain the SDA hold time in nanoseconds.
   This option is only supported in hardware blocks version 1.11a or newer.
 
 - i2c-scl-falling-time-ns : should contain the SCL falling time in nanoseconds.
   This value which is by default 300ns is used to compute the tLOW period.
 
 - i2c-sda-falling-time-ns : should contain the SDA falling time in nanoseconds.
   This value which is by default 300ns is used to compute the tHIGH period.
 
Examples :
 
   i2c@f0000 {
       #address-cells = <1>;
       #size-cells = <0>;
       compatible = "snps,designware-i2c";
       reg = <0xf0000 0x1000>;
       interrupts = <11>;
       clock-frequency = <400000>;
   };
 
   i2c@1120000 {
       #address-cells = <1>;
       #size-cells = <0>;
       compatible = "snps,designware-i2c";
       reg = <0x1120000 0x1000>;
       interrupt-parent = <&ictl>;
       interrupts = <12 1>;
       clock-frequency = <400000>;
       i2c-sda-hold-time-ns = <300>;
       i2c-sda-falling-time-ns = <300>;
       i2c-scl-falling-time-ns = <300>;
   };
 
   i2c@1120000 {
       #address-cells = <1>;
       #size-cells = <0>;
       reg = <0x2000 0x100>;
       clock-frequency = <400000>;
       clocks = <&i2cclk>;
       interrupts = <0>;
 
       eeprom@64 {
           compatible = "linux,slave-24c02";
           reg = <0x40000064>;
       };
   };