34#ifndef LIBBSP_ARM_STM32F4_RCC_H
35#define LIBBSP_ARM_STM32F4_RCC_H
51#define STM32F4_RCC_INDEX(reg, idx) (((reg) << 5) | (idx))
54#ifdef STM32F4_FAMILY_F4XXXX
61 STM32F4_RCC_OTGHS = STM32F4_RCC_INDEX(0, 29),
62 STM32F4_RCC_ETHMAC = STM32F4_RCC_INDEX(0, 25),
63 STM32F4_RCC_DMA2 = STM32F4_RCC_INDEX(0, 22),
64 STM32F4_RCC_DMA1 = STM32F4_RCC_INDEX(0, 21),
65 STM32F4_RCC_CRC = STM32F4_RCC_INDEX(0, 12),
66 STM32F4_RCC_GPIOI = STM32F4_RCC_INDEX(0, 8),
67 STM32F4_RCC_GPIOH = STM32F4_RCC_INDEX(0, 7),
68 STM32F4_RCC_GPIOG = STM32F4_RCC_INDEX(0, 6),
69 STM32F4_RCC_GPIOF = STM32F4_RCC_INDEX(0, 5),
70 STM32F4_RCC_GPIOE = STM32F4_RCC_INDEX(0, 4),
71 STM32F4_RCC_GPIOD = STM32F4_RCC_INDEX(0, 3),
72 STM32F4_RCC_GPIOC = STM32F4_RCC_INDEX(0, 2),
73 STM32F4_RCC_GPIOB = STM32F4_RCC_INDEX(0, 1),
74 STM32F4_RCC_GPIOA = STM32F4_RCC_INDEX(0, 0),
76 STM32F4_RCC_OTGFS = STM32F4_RCC_INDEX(1, 7),
77 STM32F4_RCC_RNG = STM32F4_RCC_INDEX(1, 6),
78 STM32F4_RCC_HASH = STM32F4_RCC_INDEX(1, 5),
79 STM32F4_RCC_CRYP = STM32F4_RCC_INDEX(1, 4),
80 STM32F4_RCC_DCMI = STM32F4_RCC_INDEX(1, 0),
82 STM32F4_RCC_FSMCR = STM32F4_RCC_INDEX(2, 0),
84 STM32F4_RCC_DAC = STM32F4_RCC_INDEX(4, 29),
85 STM32F4_RCC_PWR = STM32F4_RCC_INDEX(4, 28),
86 STM32F4_RCC_CAN2 = STM32F4_RCC_INDEX(4, 26),
87 STM32F4_RCC_CAN1 = STM32F4_RCC_INDEX(4, 25),
88 STM32F4_RCC_I2C3 = STM32F4_RCC_INDEX(4, 23),
89 STM32F4_RCC_I2C2 = STM32F4_RCC_INDEX(4, 22),
90 STM32F4_RCC_I2C1 = STM32F4_RCC_INDEX(4, 21),
91 STM32F4_RCC_UART5 = STM32F4_RCC_INDEX(4, 20),
92 STM32F4_RCC_UART4 = STM32F4_RCC_INDEX(4, 19),
93 STM32F4_RCC_USART3 = STM32F4_RCC_INDEX(4, 18),
94 STM32F4_RCC_USART2 = STM32F4_RCC_INDEX(4, 17),
95 STM32F4_RCC_SPI3 = STM32F4_RCC_INDEX(4, 15),
96 STM32F4_RCC_SPI2 = STM32F4_RCC_INDEX(4, 14),
97 STM32F4_RCC_WWDG = STM32F4_RCC_INDEX(4, 11),
98 STM32F4_RCC_TIM14 = STM32F4_RCC_INDEX(4, 8),
99 STM32F4_RCC_TIM13 = STM32F4_RCC_INDEX(4, 7),
100 STM32F4_RCC_TIM12 = STM32F4_RCC_INDEX(4, 6),
101 STM32F4_RCC_TIM7 = STM32F4_RCC_INDEX(4, 5),
102 STM32F4_RCC_TIM6 = STM32F4_RCC_INDEX(4, 4),
103 STM32F4_RCC_TIM5 = STM32F4_RCC_INDEX(4, 3),
104 STM32F4_RCC_TIM4 = STM32F4_RCC_INDEX(4, 2),
105 STM32F4_RCC_TIM3 = STM32F4_RCC_INDEX(4, 1),
106 STM32F4_RCC_TIM2 = STM32F4_RCC_INDEX(4, 0),
108 STM32F4_RCC_TIM11 = STM32F4_RCC_INDEX(5, 18),
109 STM32F4_RCC_TIM10 = STM32F4_RCC_INDEX(5, 17),
110 STM32F4_RCC_TIM9 = STM32F4_RCC_INDEX(5, 16),
111 STM32F4_RCC_SYSCFG = STM32F4_RCC_INDEX(5, 14),
112 STM32F4_RCC_SPI1 = STM32F4_RCC_INDEX(5, 12),
113 STM32F4_RCC_SDIO = STM32F4_RCC_INDEX(5, 11),
114 STM32F4_RCC_ADC3 = STM32F4_RCC_INDEX(5, 10),
115 STM32F4_RCC_ADC2 = STM32F4_RCC_INDEX(5, 9),
116 STM32F4_RCC_ADC1 = STM32F4_RCC_INDEX(5, 8),
117 STM32F4_RCC_USART6 = STM32F4_RCC_INDEX(5, 5),
118 STM32F4_RCC_USART1 = STM32F4_RCC_INDEX(5, 4),
119 STM32F4_RCC_TIM8 = STM32F4_RCC_INDEX(5, 1),
120 STM32F4_RCC_TIM1 = STM32F4_RCC_INDEX(5, 0),
125#ifdef STM32F4_FAMILY_F10XXX
132 STM32F4_RCC_DMA1 = STM32F4_RCC_INDEX(0, 0),
133 STM32F4_RCC_DMA2 = STM32F4_RCC_INDEX(0, 1),
134 STM32F4_RCC_SRAM = STM32F4_RCC_INDEX(0, 2),
135 STM32F4_RCC_FLITF = STM32F4_RCC_INDEX(0, 4),
136 STM32F4_RCC_CRCEN = STM32F4_RCC_INDEX(0, 6),
137 STM32F4_RCC_FSMC = STM32F4_RCC_INDEX(0, 8),
138 STM32F4_RCC_SDIO = STM32F4_RCC_INDEX(0, 10),
139 STM32F4_RCC_OTGFS = STM32F4_RCC_INDEX(0, 12),
140 STM32F4_RCC_ETHMAC = STM32F4_RCC_INDEX(0, 14),
141 STM32F4_RCC_ETHMACTX = STM32F4_RCC_INDEX(0, 15),
142 STM32F4_RCC_ETHMACRX = STM32F4_RCC_INDEX(0, 16),
144 STM32F4_RCC_AFIO = STM32F4_RCC_INDEX(1, 0),
145 STM32F4_RCC_GPIOA = STM32F4_RCC_INDEX(1, 2),
146 STM32F4_RCC_GPIOB = STM32F4_RCC_INDEX(1, 3),
147 STM32F4_RCC_GPIOC = STM32F4_RCC_INDEX(1, 4),
148 STM32F4_RCC_GPIOD = STM32F4_RCC_INDEX(1, 5),
149 STM32F4_RCC_GPIOE = STM32F4_RCC_INDEX(1, 6),
150 STM32F4_RCC_GPIOF = STM32F4_RCC_INDEX(1, 7),
151 STM32F4_RCC_GPIOG = STM32F4_RCC_INDEX(1, 8),
152 STM32F4_RCC_ADC1 = STM32F4_RCC_INDEX(1, 9),
153 STM32F4_RCC_ADC2 = STM32F4_RCC_INDEX(1, 10),
154 STM32F4_RCC_TIM1 = STM32F4_RCC_INDEX(1, 11),
155 STM32F4_RCC_SPI1 = STM32F4_RCC_INDEX(1, 12),
156 STM32F4_RCC_TIM8 = STM32F4_RCC_INDEX(1, 13),
157 STM32F4_RCC_USART1 = STM32F4_RCC_INDEX(1, 14),
158 STM32F4_RCC_ADC3 = STM32F4_RCC_INDEX(1, 15),
159 STM32F4_RCC_TIM9 = STM32F4_RCC_INDEX(1, 19),
160 STM32F4_RCC_TIM10 = STM32F4_RCC_INDEX(1, 20),
161 STM32F4_RCC_TIM11 = STM32F4_RCC_INDEX(1, 21),
163 STM32F4_RCC_TIM2 = STM32F4_RCC_INDEX(2, 0),
164 STM32F4_RCC_TIM3 = STM32F4_RCC_INDEX(2, 1),
165 STM32F4_RCC_TIM4 = STM32F4_RCC_INDEX(2, 2),
166 STM32F4_RCC_TIM5 = STM32F4_RCC_INDEX(2, 3),
167 STM32F4_RCC_TIM6 = STM32F4_RCC_INDEX(2, 4),
168 STM32F4_RCC_TIM7 = STM32F4_RCC_INDEX(2, 5),
169 STM32F4_RCC_TIM12 = STM32F4_RCC_INDEX(2, 6),
170 STM32F4_RCC_TIM13 = STM32F4_RCC_INDEX(2, 7),
171 STM32F4_RCC_TIM14 = STM32F4_RCC_INDEX(2, 8),
172 STM32F4_RCC_WWDG = STM32F4_RCC_INDEX(2, 11),
173 STM32F4_RCC_SPI2 = STM32F4_RCC_INDEX(2, 14),
174 STM32F4_RCC_SPI3 = STM32F4_RCC_INDEX(2, 15),
175 STM32F4_RCC_USART2 = STM32F4_RCC_INDEX(2, 17),
176 STM32F4_RCC_USART3 = STM32F4_RCC_INDEX(2, 18),
177 STM32F4_RCC_UART4 = STM32F4_RCC_INDEX(2, 19),
178 STM32F4_RCC_UART5 = STM32F4_RCC_INDEX(2, 20),
179 STM32F4_RCC_I2C1 = STM32F4_RCC_INDEX(2, 21),
180 STM32F4_RCC_I2C2 = STM32F4_RCC_INDEX(2, 22),
181 STM32F4_RCC_USB = STM32F4_RCC_INDEX(2, 23),
182 STM32F4_RCC_CAN1 = STM32F4_RCC_INDEX(2, 24),
183 STM32F4_RCC_CAN2 = STM32F4_RCC_INDEX(2, 25),
184 STM32F4_RCC_BKP = STM32F4_RCC_INDEX(2, 27),
185 STM32F4_RCC_PWR = STM32F4_RCC_INDEX(2, 28),
186 STM32F4_RCC_DAC = STM32F4_RCC_INDEX(2, 29),
193void stm32f4_rcc_reset(stm32f4_rcc_index index);
195void stm32f4_rcc_set_reset(stm32f4_rcc_index index,
bool set);
197void stm32f4_rcc_set_clock(stm32f4_rcc_index index,
bool set);
199#ifdef STM32F4_FAMILY_F4XXXX
200void stm32f4_rcc_set_low_power_clock(stm32f4_rcc_index index,
bool set);