hc
2024-08-14 865dc85cff0c170305dc18e865d2cb0b537a47ec
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
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
STMicroelectronics STM32 Reset and Clock Controller
===================================================
 
The RCC IP is both a reset and a clock controller.
 
Please refer to clock-bindings.txt for common clock controller binding usage.
Please also refer to reset.txt for common reset controller binding usage.
 
Required properties:
- compatible: Should be:
  "st,stm32f42xx-rcc"
  "st,stm32f469-rcc"
  "st,stm32f746-rcc"
  "st,stm32f769-rcc"
 
- reg: should be register base and length as documented in the
  datasheet
- #reset-cells: 1, see below
- #clock-cells: 2, device nodes should specify the clock in their "clocks"
  property, containing a phandle to the clock device node, an index selecting
  between gated clocks and other clocks and an index specifying the clock to
  use.
- clocks: External oscillator clock phandle
  - high speed external clock signal (HSE)
  - external I2S clock (I2S_CKIN)
 
Example:
 
   rcc: rcc@40023800 {
       #reset-cells = <1>;
       #clock-cells = <2>
       compatible = "st,stm32f42xx-rcc", "st,stm32-rcc";
       reg = <0x40023800 0x400>;
       clocks = <&clk_hse>, <&clk_i2s_ckin>;
   };
 
Specifying gated clocks
=======================
 
The primary index must be set to 0.
 
The secondary index is the bit number within the RCC register bank, starting
from the first RCC clock enable register (RCC_AHB1ENR, address offset 0x30).
 
It is calculated as: index = register_offset / 4 * 32 + bit_offset.
Where bit_offset is the bit offset within the register (LSB is 0, MSB is 31).
 
To simplify the usage and to share bit definition with the reset and clock
drivers of the RCC IP, macros are available to generate the index in
human-readble format.
 
For STM32F4 series, the macro are available here:
 - include/dt-bindings/mfd/stm32f4-rcc.h
 
Example:
 
   /* Gated clock, AHB1 bit 0 (GPIOA) */
   ... {
       clocks = <&rcc 0 STM32F4_AHB1_CLOCK(GPIOA)>
   };
 
   /* Gated clock, AHB2 bit 4 (CRYP) */
   ... {
       clocks = <&rcc 0 STM32F4_AHB2_CLOCK(CRYP)>
   };
 
Specifying other clocks
=======================
 
The primary index must be set to 1.
 
The secondary index is bound with the following magic numbers:
 
   0    SYSTICK
   1    FCLK
   2    CLK_LSI        (low-power clock source)
   3    CLK_LSE        (generated from a 32.768 kHz low-speed external
                crystal or ceramic resonator)
   4    CLK_HSE_RTC    (HSE division factor for RTC clock)
   5    CLK_RTC        (real-time clock)
   6    PLL_VCO_I2S    (vco frequency of I2S pll)
   7    PLL_VCO_SAI    (vco frequency of SAI pll)
   8    CLK_LCD        (LCD-TFT)
   9    CLK_I2S        (I2S clocks)
   10    CLK_SAI1    (audio clocks)
   11    CLK_SAI2
   12    CLK_I2SQ_PDIV    (post divisor of pll i2s q divisor)
   13    CLK_SAIQ_PDIV    (post divisor of pll sai q divisor)
 
   14    CLK_HSI        (Internal ocscillator clock)
   15    CLK_SYSCLK    (System Clock)
   16    CLK_HDMI_CEC    (HDMI-CEC clock)
   17    CLK_SPDIF    (SPDIF-Rx clock)
   18    CLK_USART1    (U(s)arts clocks)
   19    CLK_USART2
   20    CLK_USART3
   21    CLK_UART4
   22    CLK_UART5
   23    CLK_USART6
   24    CLK_UART7
   25    CLK_UART8
   26    CLK_I2C1    (I2S clocks)
   27    CLK_I2C2
   28    CLK_I2C3
   29    CLK_I2C4
   30    CLK_LPTIMER    (LPTimer1 clock)
   31    CLK_PLL_SRC
   32    CLK_DFSDM1
   33    CLK_ADFSDM1
   34    CLK_F769_DSI
)
 
Example:
 
   /* Misc clock, FCLK */
   ... {
       clocks = <&rcc 1 STM32F4_APB1_CLOCK(TIM2)>
   };
 
 
Specifying softreset control of devices
=======================================
 
Device nodes should specify the reset channel required in their "resets"
property, containing a phandle to the reset device node and an index specifying
which channel to use.
The index is the bit number within the RCC registers bank, starting from RCC
base address.
It is calculated as: index = register_offset / 4 * 32 + bit_offset.
Where bit_offset is the bit offset within the register.
For example, for CRC reset:
  crc = AHB1RSTR_offset / 4 * 32 + CRCRST_bit_offset = 0x10 / 4 * 32 + 12 = 140
 
example:
 
   timer2 {
       resets    = <&rcc STM32F4_APB1_RESET(TIM2)>;
   };