i2c-qup.txt 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. Qualcomm I2C controller
  2. Required properties:
  3. - reg : Offset and length of the register region(s) for the device
  4. For GSBI based controller, GSBI and QUP regions are expected
  5. For BLSP based controller, QUP region offset is expected
  6. - reg-names : Register region name(s) referenced in reg above
  7. BLSP based controller expects QUP region name ("qup_phys_addr")
  8. GSBI controller expects QUP region name and GSBI region name
  9. ("gsbi_qup_i2c_addr")
  10. - compatible : should be "qcom,i2c-qup"
  11. - cell-index : I2C bus number used for this controller
  12. - interrupts : QUP core interrupt(s). Core may have 1 error interrupt and flags
  13. for input/output service, or 3 separate interrupts for the 3 services
  14. - interrupt-names: QUP core interrupt name(s) referenced in interrupts above
  15. Expected interrupt resource name(s) are: "qup_err_irq", "qup_in_irq",
  16. and "qup_out_irq"
  17. - qcom,i2c-bus-freq : desired I2C bus clock frequency is Hz
  18. Optional property:
  19. - qcom,i2c-src-freq : Frequency of the source clocking this bus in Hz.
  20. Divider value is set based on soruce-frequency and
  21. desired I2C bus frequency. If this value is not
  22. provided, the source clock is assumed to be running
  23. at 19.2 MHz.
  24. - qcom,scl-gpio : I2C clock GPIO number. Required for execution of bus
  25. recovery procedure.
  26. - qcom,sda-gpio : I2C data GPIO number. Required for execution of bus
  27. recovery procedure.
  28. - qcom,active-only : Vote for core clock when the application processor goes
  29. to active state and remove that vote when it goes to idle
  30. state. This flag may improve service time of first i2c
  31. request at the expense of power consumption. When this
  32. entry is not present, voting is done by the runtime-pm
  33. callbacks.
  34. - qcom,master-id : Master endpoint number used for voting on clocks using
  35. bus-scaling driver.
  36. - qcom,clk-ctl-xfer : When present, the clocks's state (prepare_enable/
  37. unprepare_disable) is controlled by i2c-transaction's
  38. begining and ending. When missing, the clock's state
  39. is controlled by runtime-pm events.
  40. Example:
  41. i2c_3: i2c@f9966000 {
  42. cell-index = <3>;
  43. compatible = "qcom,i2c-qup";
  44. reg = <0xf9966000 0x1000>;
  45. reg-names = "qup_phys_addr";
  46. interrupts = <0 104 0>;
  47. interrupt-names = "qup_err_intr";
  48. qcom,i2c-bus-freq = <100000>;
  49. qcom,i2c-src-freq = <24000000>;
  50. qcom,clk-ctl-xfer;
  51. qcom,scl-gpio = <&msmgpio 7 0>;
  52. qcom,sda-gpio = <&msmgpio 6 0>;
  53. };