139 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			139 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| 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)>;
 | |
| 	};
 |