st,stm32-lptimer.yaml 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177
  1. # SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
  2. %YAML 1.2
  3. ---
  4. $id: http://devicetree.org/schemas/mfd/st,stm32-lptimer.yaml#
  5. $schema: http://devicetree.org/meta-schemas/core.yaml#
  6. title: STMicroelectronics STM32 Low-Power Timers
  7. description: |
  8. The STM32 Low-Power Timer (LPTIM) is a 16-bit timer that provides several
  9. functions
  10. - PWM output (with programmable prescaler, configurable polarity)
  11. - Trigger source for STM32 ADC/DAC (LPTIM_OUT)
  12. - Several counter modes:
  13. - quadrature encoder to detect angular position and direction of rotary
  14. elements, from IN1 and IN2 input signals.
  15. - simple counter from IN1 input signal.
  16. maintainers:
  17. - Fabrice Gasnier <fabrice.gasnier@foss.st.com>
  18. properties:
  19. compatible:
  20. oneOf:
  21. - items:
  22. - const: st,stm32mp25-lptimer
  23. - const: st,stm32-lptimer
  24. - items:
  25. - const: st,stm32-lptimer
  26. reg:
  27. maxItems: 1
  28. clocks:
  29. maxItems: 1
  30. clock-names:
  31. items:
  32. - const: mux
  33. interrupts:
  34. maxItems: 1
  35. "#address-cells":
  36. const: 1
  37. "#size-cells":
  38. const: 0
  39. wakeup-source: true
  40. access-controllers:
  41. minItems: 1
  42. maxItems: 2
  43. power-domains:
  44. maxItems: 1
  45. pwm:
  46. type: object
  47. additionalProperties: false
  48. properties:
  49. compatible:
  50. oneOf:
  51. - items:
  52. - const: st,stm32mp25-pwm-lp
  53. - const: st,stm32-pwm-lp
  54. - items:
  55. - const: st,stm32-pwm-lp
  56. "#pwm-cells":
  57. const: 3
  58. required:
  59. - "#pwm-cells"
  60. - compatible
  61. counter:
  62. type: object
  63. additionalProperties: false
  64. properties:
  65. compatible:
  66. oneOf:
  67. - items:
  68. - const: st,stm32mp25-lptimer-counter
  69. - const: st,stm32-lptimer-counter
  70. - items:
  71. - const: st,stm32-lptimer-counter
  72. required:
  73. - compatible
  74. timer:
  75. type: object
  76. additionalProperties: false
  77. properties:
  78. compatible:
  79. oneOf:
  80. - items:
  81. - const: st,stm32mp25-lptimer-timer
  82. - const: st,stm32-lptimer-timer
  83. - items:
  84. - const: st,stm32-lptimer-timer
  85. required:
  86. - compatible
  87. patternProperties:
  88. "^trigger@[0-9]+$":
  89. type: object
  90. additionalProperties: false
  91. properties:
  92. compatible:
  93. oneOf:
  94. - items:
  95. - const: st,stm32mp25-lptimer-trigger
  96. - const: st,stm32-lptimer-trigger
  97. - items:
  98. - const: st,stm32-lptimer-trigger
  99. reg:
  100. description: Identify trigger hardware block.
  101. items:
  102. minimum: 0
  103. maximum: 4
  104. required:
  105. - compatible
  106. - reg
  107. required:
  108. - "#address-cells"
  109. - "#size-cells"
  110. - compatible
  111. - reg
  112. - clocks
  113. - clock-names
  114. additionalProperties: false
  115. examples:
  116. - |
  117. #include <dt-bindings/clock/stm32mp1-clks.h>
  118. #include <dt-bindings/interrupt-controller/arm-gic.h>
  119. timer@40002400 {
  120. compatible = "st,stm32-lptimer";
  121. reg = <0x40002400 0x400>;
  122. clocks = <&timer_clk>;
  123. clock-names = "mux";
  124. interrupts-extended = <&exti 47 IRQ_TYPE_LEVEL_HIGH>;
  125. #address-cells = <1>;
  126. #size-cells = <0>;
  127. pwm {
  128. compatible = "st,stm32-pwm-lp";
  129. #pwm-cells = <3>;
  130. };
  131. trigger@0 {
  132. compatible = "st,stm32-lptimer-trigger";
  133. reg = <0>;
  134. };
  135. counter {
  136. compatible = "st,stm32-lptimer-counter";
  137. };
  138. timer {
  139. compatible = "st,stm32-lptimer-timer";
  140. };
  141. };
  142. ...