i2c-st.txt 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. ST SSC binding, for I2C mode operation
  2. Required properties :
  3. - compatible : Must be "st,comms-ssc-i2c" or "st,comms-ssc4-i2c"
  4. - reg : Offset and length of the register set for the device
  5. - interrupts : the interrupt specifier
  6. - clock-names: Must contain "ssc".
  7. - clocks: Must contain an entry for each name in clock-names. See the common
  8. clock bindings.
  9. - A pinctrl state named "default" must be defined to set pins in mode of
  10. operation for I2C transfer.
  11. Optional properties :
  12. - clock-frequency : Desired I2C bus clock frequency in Hz. If not specified,
  13. the default 100 kHz frequency will be used. As only Normal and Fast modes
  14. are supported, possible values are 100000 and 400000.
  15. - st,i2c-min-scl-pulse-width-us : The minimum valid SCL pulse width that is
  16. allowed through the deglitch circuit. In units of us.
  17. - st,i2c-min-sda-pulse-width-us : The minimum valid SDA pulse width that is
  18. allowed through the deglitch circuit. In units of us.
  19. - A pinctrl state named "idle" could be defined to set pins in idle state
  20. when I2C instance is not performing a transfer.
  21. - A pinctrl state named "sleep" could be defined to set pins in sleep state
  22. when driver enters in suspend.
  23. Example :
  24. i2c0: i2c@fed40000 {
  25. compatible = "st,comms-ssc4-i2c";
  26. reg = <0xfed40000 0x110>;
  27. interrupts = <GIC_SPI 187 IRQ_TYPE_LEVEL_HIGH>;
  28. clocks = <&clk_s_a0_ls CLK_ICN_REG>;
  29. clock-names = "ssc";
  30. clock-frequency = <400000>;
  31. pinctrl-names = "default";
  32. pinctrl-0 = <&pinctrl_i2c0_default>;
  33. st,i2c-min-scl-pulse-width-us = <0>;
  34. st,i2c-min-sda-pulse-width-us = <5>;
  35. };