Mercurial > public > ostc4
annotate Discovery/Inc/stm32f4xx_hal_conf.h @ 238:a9d798e8c11f div-fixes-5
cleanup, bugfix: do not mask I2C_SystemStatus with local variable
This commit is partly cleanup, and partly possible bugfix. Masking
the global I2C_SystemStatus with a local variable is (very) bad practice,
but more importantly, dangerous, as other code uses this I2C_SystemStatus
to base decisions on. So, this is definitely non-trivial, as it can
possibly change the flow of control. This said, its tested and seems to
have no negative effects (but also no positive, as I sort of hoped for),
so that is why I mark it cleanup as well. Constructs like this shall
be heavily documented in the code, when there is a reason to do things
like this.
Further, remove a 2nd rather useless construct. There is no reason
to & 0x03 the output of I2C_SystemStatus. This is the only location
in the entire code base where this is done, so, its not only useless
but also inconsistent and confusing the true intentions here.
Finally, littered to code with todo's that I will take care of in
next commits.
Signed-off-by: Jan Mulder <jlmulder@xs4all.nl>
author | Jan Mulder <jlmulder@xs4all.nl> |
---|---|
date | Mon, 08 Apr 2019 10:16:17 +0200 |
parents | f35e53ef04e0 |
children | bc6c90e20d9e |
rev | line source |
---|---|
38 | 1 /////////////////////////////////////////////////////////////////////////////// |
2 /// -*- coding: UTF-8 -*- | |
3 /// | |
4 /// \file Discovery/Inc/stm32f4xx_hal_conf.h | |
5 /// \brief The assert_param macro is used for function's parameters check. | |
6 /// \author Heinrichs Weikamp | |
7 /// \date 2018 | |
8 /// | |
9 /// $Id$ | |
10 /////////////////////////////////////////////////////////////////////////////// | |
11 /// \par Copyright (c) 2014-2018 Heinrichs Weikamp gmbh | |
12 /// | |
13 /// This program is free software: you can redistribute it and/or modify | |
14 /// it under the terms of the GNU General Public License as published by | |
15 /// the Free Software Foundation, either version 3 of the License, or | |
16 /// (at your option) any later version. | |
17 /// | |
18 /// This program is distributed in the hope that it will be useful, | |
19 /// but WITHOUT ANY WARRANTY; without even the implied warranty of | |
20 /// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
21 /// GNU General Public License for more details. | |
22 /// | |
23 /// You should have received a copy of the GNU General Public License | |
24 /// along with this program. If not, see <http://www.gnu.org/licenses/>. | |
25 ////////////////////////////////////////////////////////////////////////////// | |
26 /// \par COPYRIGHT(c) 2014 STMicroelectronics | |
27 /// | |
28 /// Redistribution and use in source and binary forms, with or without modification, | |
29 /// are permitted provided that the following conditions are met: | |
30 /// 1. Redistributions of source code must retain the above copyright notice, | |
31 /// this list of conditions and the following disclaimer. | |
32 /// 2. Redistributions in binary form must reproduce the above copyright notice, | |
33 /// this list of conditions and the following disclaimer in the documentation | |
34 /// and/or other materials provided with the distribution. | |
35 /// 3. Neither the name of STMicroelectronics nor the names of its contributors | |
36 /// may be used to endorse or promote products derived from this software | |
37 /// without specific prior written permission. | |
38 /// | |
39 /// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | |
40 /// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | |
41 /// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | |
42 /// DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | |
43 /// FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | |
44 /// DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | |
45 /// SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER | |
46 /// CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | |
47 /// OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | |
48 /// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | |
49 ////////////////////////////////////////////////////////////////////////////// | |
50 | |
51 /* Define to prevent recursive inclusion -------------------------------------*/ | |
52 #ifndef STM32F4xx_HAL_CONF_H | |
53 #define STM32F4xx_HAL_CONF_H | |
54 | |
55 /* Exported constants --------------------------------------------------------*/ | |
56 | |
57 /* ######################### Hardware Selection ############################## */ | |
131
f35e53ef04e0
Update of configuration and projectfiles to support new library folder structure
Ideenmodellierer
parents:
38
diff
changeset
|
58 /* #define STM32F429xx definition is now done in preprocessor*/ |
38 | 59 |
60 /* ########################## Module Selection ############################## */ | |
61 /** | |
62 * @brief This is the list of modules to be used in the HAL driver | |
63 */ | |
64 #define HAL_MODULE_ENABLED | |
65 //#define HAL_ADC_MODULE_ENABLED | |
66 //#define HAL_CAN_MODULE_ENABLED | |
67 //#define HAL_CRC_MODULE_ENABLED | |
68 //#define HAL_CRYP_MODULE_ENABLED | |
69 //#define HAL_DAC_MODULE_ENABLED | |
70 //#define HAL_DCMI_MODULE_ENABLED | |
71 //#define HAL_ETH_MODULE_ENABLED | |
72 //#define HAL_NAND_MODULE_ENABLED | |
73 //#define HAL_NOR_MODULE_ENABLED | |
74 //#define HAL_PCCARD_MODULE_ENABLED | |
75 //#define HAL_SRAM_MODULE_ENABLED | |
76 //#define HAL_HASH_MODULE_ENABLED | |
77 //#define HAL_I2C_MODULE_ENABLED | |
78 //#define HAL_I2S_MODULE_ENABLED | |
79 //#define HAL_IWDG_MODULE_ENABLED | |
80 //#define HAL_RNG_MODULE_ENABLED | |
81 //#define HAL_SAI_MODULE_ENABLED | |
82 //#define HAL_SD_MODULE_ENABLED | |
83 //#define HAL_USART_MODULE_ENABLED | |
84 //#define HAL_IRDA_MODULE_ENABLED | |
85 //#define HAL_SMARTCARD_MODULE_ENABLED | |
86 //#define HAL_WWDG_MODULE_ENABLED | |
87 //#define HAL_PCD_MODULE_ENABLED | |
88 //#define HAL_HCD_MODULE_ENABLED | |
89 #define HAL_SDRAM_MODULE_ENABLED | |
90 #define HAL_GPIO_MODULE_ENABLED | |
91 #define HAL_LTDC_MODULE_ENABLED | |
92 #define HAL_DMA_MODULE_ENABLED | |
93 #define HAL_DMA2D_MODULE_ENABLED | |
94 #define HAL_RCC_MODULE_ENABLED | |
95 #define HAL_RTC_MODULE_ENABLED | |
96 #define HAL_SPI_MODULE_ENABLED | |
97 #define HAL_TIM_MODULE_ENABLED | |
98 #define HAL_UART_MODULE_ENABLED | |
99 #define HAL_FLASH_MODULE_ENABLED | |
100 #define HAL_PWR_MODULE_ENABLED | |
101 #define HAL_CORTEX_MODULE_ENABLED | |
102 | |
103 /* ########################## HSE/HSI Values adaptation ##################### */ | |
104 /** | |
105 * @brief Adjust the value of External High Speed oscillator (HSE) used in your application. | |
106 * This value is used by the RCC HAL module to compute the system frequency | |
107 * (when HSE is used as system clock source, directly or through the PLL). | |
108 */ | |
109 #if !defined (HSE_VALUE) | |
131
f35e53ef04e0
Update of configuration and projectfiles to support new library folder structure
Ideenmodellierer
parents:
38
diff
changeset
|
110 #define HSE_VALUE ((uint32_t)8000000U) /*!< Value of the External oscillator in Hz */ |
38 | 111 #endif /* HSE_VALUE */ |
112 | |
113 #if !defined (HSE_STARTUP_TIMEOUT) | |
131
f35e53ef04e0
Update of configuration and projectfiles to support new library folder structure
Ideenmodellierer
parents:
38
diff
changeset
|
114 #define HSE_STARTUP_TIMEOUT ((uint32_t)5000U) /*!< Time out for HSE start up, in ms */ |
38 | 115 #endif /* HSE_STARTUP_TIMEOUT */ |
116 | |
117 /** | |
118 * @brief Internal High Speed oscillator (HSI) value. | |
119 * This value is used by the RCC HAL module to compute the system frequency | |
120 * (when HSI is used as system clock source, directly or through the PLL). | |
121 */ | |
122 #if !defined (HSI_VALUE) | |
131
f35e53ef04e0
Update of configuration and projectfiles to support new library folder structure
Ideenmodellierer
parents:
38
diff
changeset
|
123 #define HSI_VALUE ((uint32_t)16000000U) /*!< Value of the Internal oscillator in Hz*/ |
38 | 124 #endif /* HSI_VALUE */ |
125 | |
126 /** | |
127 * @brief Internal Low Speed oscillator (LSI) value. | |
128 */ | |
129 #if !defined (LSI_VALUE) | |
131
f35e53ef04e0
Update of configuration and projectfiles to support new library folder structure
Ideenmodellierer
parents:
38
diff
changeset
|
130 #define LSI_VALUE ((uint32_t)40000U) |
38 | 131 #endif /* LSI_VALUE */ /*!< Value of the Internal Low Speed oscillator in Hz |
132 The real value may vary depending on the variations | |
133 in voltage and temperature. */ | |
134 /** | |
135 * @brief External Low Speed oscillator (LSE) value. | |
136 */ | |
137 #if !defined (LSE_VALUE) | |
138 #define LSE_VALUE ((uint32_t)32768) /*!< Value of the External Low Speed oscillator in Hz */ | |
139 #endif /* LSE_VALUE */ | |
140 | |
131
f35e53ef04e0
Update of configuration and projectfiles to support new library folder structure
Ideenmodellierer
parents:
38
diff
changeset
|
141 #if !defined (LSE_STARTUP_TIMEOUT) |
f35e53ef04e0
Update of configuration and projectfiles to support new library folder structure
Ideenmodellierer
parents:
38
diff
changeset
|
142 #define LSE_STARTUP_TIMEOUT 5000U /*!< Time out for LSE start up, in ms */ |
f35e53ef04e0
Update of configuration and projectfiles to support new library folder structure
Ideenmodellierer
parents:
38
diff
changeset
|
143 #endif /* LSE_STARTUP_TIMEOUT */ |
f35e53ef04e0
Update of configuration and projectfiles to support new library folder structure
Ideenmodellierer
parents:
38
diff
changeset
|
144 |
38 | 145 /** |
146 * @brief External clock source for I2S peripheral | |
147 * This value is used by the I2S HAL module to compute the I2S clock source | |
148 * frequency, this source is inserted directly through I2S_CKIN pad. | |
149 */ | |
150 #if !defined (EXTERNAL_CLOCK_VALUE) | |
131
f35e53ef04e0
Update of configuration and projectfiles to support new library folder structure
Ideenmodellierer
parents:
38
diff
changeset
|
151 #define EXTERNAL_CLOCK_VALUE ((uint32_t)12288000U) /*!< Value of the External audio frequency in Hz*/ |
38 | 152 #endif /* EXTERNAL_CLOCK_VALUE */ |
153 | |
154 /* Tip: To avoid modifying this file each time you need to use different HSE, | |
155 === you can define the HSE value in your toolchain compiler preprocessor. */ | |
156 | |
157 /* ########################### System Configuration ######################### */ | |
158 /** | |
159 * @brief This is the HAL system configuration section | |
160 */ | |
161 | |
131
f35e53ef04e0
Update of configuration and projectfiles to support new library folder structure
Ideenmodellierer
parents:
38
diff
changeset
|
162 #define VDD_VALUE ((uint32_t)3300U) /*!< Value of VDD in mv */ |
38 | 163 #define TICK_INT_PRIORITY ((uint32_t)0) /*!< tick interrupt priority */ |
164 #define USE_RTOS 0 | |
165 #define PREFETCH_ENABLE 1 | |
166 #define INSTRUCTION_CACHE_ENABLE 1 | |
167 #define DATA_CACHE_ENABLE 1 | |
168 | |
169 /* ########################## Assert Selection ############################## */ | |
170 /** | |
171 * @brief Uncomment the line below to expanse the "assert_param" macro in the | |
172 * HAL drivers code | |
173 */ | |
174 /* #define USE_FULL_ASSERT 1 */ | |
175 | |
176 /* ################## Ethernet peripheral configuration ##################### */ | |
177 | |
178 /* Section 1 : Ethernet peripheral configuration */ | |
179 | |
180 /* MAC ADDRESS: MAC_ADDR0:MAC_ADDR1:MAC_ADDR2:MAC_ADDR3:MAC_ADDR4:MAC_ADDR5 */ | |
131
f35e53ef04e0
Update of configuration and projectfiles to support new library folder structure
Ideenmodellierer
parents:
38
diff
changeset
|
181 #define MAC_ADDR0 2U |
f35e53ef04e0
Update of configuration and projectfiles to support new library folder structure
Ideenmodellierer
parents:
38
diff
changeset
|
182 #define MAC_ADDR1 0U |
f35e53ef04e0
Update of configuration and projectfiles to support new library folder structure
Ideenmodellierer
parents:
38
diff
changeset
|
183 #define MAC_ADDR2 0U |
f35e53ef04e0
Update of configuration and projectfiles to support new library folder structure
Ideenmodellierer
parents:
38
diff
changeset
|
184 #define MAC_ADDR3 0U |
f35e53ef04e0
Update of configuration and projectfiles to support new library folder structure
Ideenmodellierer
parents:
38
diff
changeset
|
185 #define MAC_ADDR4 0U |
f35e53ef04e0
Update of configuration and projectfiles to support new library folder structure
Ideenmodellierer
parents:
38
diff
changeset
|
186 #define MAC_ADDR5 0U |
38 | 187 |
188 /* Definition of the Ethernet driver buffers size and count */ | |
189 #define ETH_RX_BUF_SIZE ETH_MAX_PACKET_SIZE /* buffer size for receive */ | |
190 #define ETH_TX_BUF_SIZE ETH_MAX_PACKET_SIZE /* buffer size for transmit */ | |
191 #define ETH_RXBUFNB ((uint32_t)4) /* 4 Rx buffers of size ETH_RX_BUF_SIZE */ | |
192 #define ETH_TXBUFNB ((uint32_t)4) /* 4 Tx buffers of size ETH_TX_BUF_SIZE */ | |
193 | |
194 /* Section 2: PHY configuration section */ | |
195 | |
196 /* DP83848 PHY Address*/ | |
131
f35e53ef04e0
Update of configuration and projectfiles to support new library folder structure
Ideenmodellierer
parents:
38
diff
changeset
|
197 #define DP83848_PHY_ADDRESS 0x01U |
38 | 198 /* PHY Reset delay these values are based on a 1 ms Systick interrupt*/ |
131
f35e53ef04e0
Update of configuration and projectfiles to support new library folder structure
Ideenmodellierer
parents:
38
diff
changeset
|
199 #define PHY_RESET_DELAY ((uint32_t)0x000000FFU) |
38 | 200 /* PHY Configuration delay */ |
131
f35e53ef04e0
Update of configuration and projectfiles to support new library folder structure
Ideenmodellierer
parents:
38
diff
changeset
|
201 #define PHY_CONFIG_DELAY ((uint32_t)0x00000FFFU) |
38 | 202 |
131
f35e53ef04e0
Update of configuration and projectfiles to support new library folder structure
Ideenmodellierer
parents:
38
diff
changeset
|
203 #define PHY_READ_TO ((uint32_t)0x0000FFFFU) |
f35e53ef04e0
Update of configuration and projectfiles to support new library folder structure
Ideenmodellierer
parents:
38
diff
changeset
|
204 #define PHY_WRITE_TO ((uint32_t)0x0000FFFFU) |
38 | 205 |
206 /* Section 3: Common PHY Registers */ | |
207 | |
131
f35e53ef04e0
Update of configuration and projectfiles to support new library folder structure
Ideenmodellierer
parents:
38
diff
changeset
|
208 #define PHY_BCR ((uint16_t)0x0000) /*!< Transceiver Basic Control Register */ |
f35e53ef04e0
Update of configuration and projectfiles to support new library folder structure
Ideenmodellierer
parents:
38
diff
changeset
|
209 #define PHY_BSR ((uint16_t)0x0001) /*!< Transceiver Basic Status Register */ |
38 | 210 |
211 #define PHY_RESET ((uint16_t)0x8000) /*!< PHY Reset */ | |
212 #define PHY_LOOPBACK ((uint16_t)0x4000) /*!< Select loop-back mode */ | |
213 #define PHY_FULLDUPLEX_100M ((uint16_t)0x2100) /*!< Set the full-duplex mode at 100 Mb/s */ | |
214 #define PHY_HALFDUPLEX_100M ((uint16_t)0x2000) /*!< Set the half-duplex mode at 100 Mb/s */ | |
215 #define PHY_FULLDUPLEX_10M ((uint16_t)0x0100) /*!< Set the full-duplex mode at 10 Mb/s */ | |
216 #define PHY_HALFDUPLEX_10M ((uint16_t)0x0000) /*!< Set the half-duplex mode at 10 Mb/s */ | |
217 #define PHY_AUTONEGOTIATION ((uint16_t)0x1000) /*!< Enable auto-negotiation function */ | |
218 #define PHY_RESTART_AUTONEGOTIATION ((uint16_t)0x0200) /*!< Restart auto-negotiation function */ | |
219 #define PHY_POWERDOWN ((uint16_t)0x0800) /*!< Select the power down mode */ | |
220 #define PHY_ISOLATE ((uint16_t)0x0400) /*!< Isolate PHY from MII */ | |
221 | |
222 #define PHY_AUTONEGO_COMPLETE ((uint16_t)0x0020) /*!< Auto-Negotiation process completed */ | |
223 #define PHY_LINKED_STATUS ((uint16_t)0x0004) /*!< Valid link established */ | |
224 #define PHY_JABBER_DETECTION ((uint16_t)0x0002) /*!< Jabber condition detected */ | |
225 | |
226 /* Section 4: Extended PHY Registers */ | |
227 | |
131
f35e53ef04e0
Update of configuration and projectfiles to support new library folder structure
Ideenmodellierer
parents:
38
diff
changeset
|
228 #define PHY_SR ((uint16_t)0x0010) /*!< PHY status register Offset */ |
f35e53ef04e0
Update of configuration and projectfiles to support new library folder structure
Ideenmodellierer
parents:
38
diff
changeset
|
229 #define PHY_MICR ((uint16_t)0x0011) /*!< MII Interrupt Control Register */ |
f35e53ef04e0
Update of configuration and projectfiles to support new library folder structure
Ideenmodellierer
parents:
38
diff
changeset
|
230 #define PHY_MISR ((uint16_t)0x0012) /*!< MII Interrupt Status and Misc. Control Register */ |
38 | 231 |
232 #define PHY_LINK_STATUS ((uint16_t)0x0001) /*!< PHY Link mask */ | |
233 #define PHY_SPEED_STATUS ((uint16_t)0x0002) /*!< PHY Speed mask */ | |
234 #define PHY_DUPLEX_STATUS ((uint16_t)0x0004) /*!< PHY Duplex mask */ | |
235 | |
236 #define PHY_MICR_INT_EN ((uint16_t)0x0002) /*!< PHY Enable interrupts */ | |
237 #define PHY_MICR_INT_OE ((uint16_t)0x0001) /*!< PHY Enable output interrupt events */ | |
238 | |
239 #define PHY_MISR_LINK_INT_EN ((uint16_t)0x0020) /*!< Enable Interrupt on change of link status */ | |
240 #define PHY_LINK_INTERRUPT ((uint16_t)0x2000) /*!< PHY link status interrupt mask */ | |
241 | |
242 /* Includes ------------------------------------------------------------------*/ | |
243 /** | |
244 * @brief Include module's header file | |
245 */ | |
246 | |
247 #ifdef HAL_RCC_MODULE_ENABLED | |
248 #include "stm32f4xx_hal_rcc.h" | |
249 #endif /* HAL_RCC_MODULE_ENABLED */ | |
250 | |
251 #ifdef HAL_GPIO_MODULE_ENABLED | |
252 #include "stm32f4xx_hal_gpio.h" | |
253 #endif /* HAL_GPIO_MODULE_ENABLED */ | |
254 | |
255 #ifdef HAL_DMA_MODULE_ENABLED | |
256 #include "stm32f4xx_hal_dma.h" | |
257 #endif /* HAL_DMA_MODULE_ENABLED */ | |
258 | |
259 #ifdef HAL_CORTEX_MODULE_ENABLED | |
260 #include "stm32f4xx_hal_cortex.h" | |
261 #endif /* HAL_CORTEX_MODULE_ENABLED */ | |
262 | |
263 #ifdef HAL_ADC_MODULE_ENABLED | |
264 #include "stm32f4xx_hal_adc.h" | |
265 #endif /* HAL_ADC_MODULE_ENABLED */ | |
266 | |
267 #ifdef HAL_CAN_MODULE_ENABLED | |
268 #include "stm32f4xx_hal_can.h" | |
269 #endif /* HAL_CAN_MODULE_ENABLED */ | |
270 | |
271 #ifdef HAL_CRC_MODULE_ENABLED | |
272 #include "stm32f4xx_hal_crc.h" | |
273 #endif /* HAL_CRC_MODULE_ENABLED */ | |
274 | |
275 #ifdef HAL_CRYP_MODULE_ENABLED | |
276 #include "stm32f4xx_hal_cryp.h" | |
277 #endif /* HAL_CRYP_MODULE_ENABLED */ | |
278 | |
279 #ifdef HAL_DMA2D_MODULE_ENABLED | |
280 #include "stm32f4xx_hal_dma2d.h" | |
281 #endif /* HAL_DMA2D_MODULE_ENABLED */ | |
282 | |
283 #ifdef HAL_DAC_MODULE_ENABLED | |
284 #include "stm32f4xx_hal_dac.h" | |
285 #endif /* HAL_DAC_MODULE_ENABLED */ | |
286 | |
287 #ifdef HAL_DCMI_MODULE_ENABLED | |
288 #include "stm32f4xx_hal_dcmi.h" | |
289 #endif /* HAL_DCMI_MODULE_ENABLED */ | |
290 | |
291 #ifdef HAL_ETH_MODULE_ENABLED | |
292 #include "stm32f4xx_hal_eth.h" | |
293 #endif /* HAL_ETH_MODULE_ENABLED */ | |
294 | |
295 #ifdef HAL_FLASH_MODULE_ENABLED | |
296 #include "stm32f4xx_hal_flash.h" | |
297 #endif /* HAL_FLASH_MODULE_ENABLED */ | |
298 | |
299 #ifdef HAL_SRAM_MODULE_ENABLED | |
300 #include "stm32f4xx_hal_sram.h" | |
301 #endif /* HAL_SRAM_MODULE_ENABLED */ | |
302 | |
303 #ifdef HAL_NOR_MODULE_ENABLED | |
304 #include "stm32f4xx_hal_nor.h" | |
305 #endif /* HAL_NOR_MODULE_ENABLED */ | |
306 | |
307 #ifdef HAL_NAND_MODULE_ENABLED | |
308 #include "stm32f4xx_hal_nand.h" | |
309 #endif /* HAL_NAND_MODULE_ENABLED */ | |
310 | |
311 #ifdef HAL_PCCARD_MODULE_ENABLED | |
312 #include "stm32f4xx_hal_pccard.h" | |
313 #endif /* HAL_PCCARD_MODULE_ENABLED */ | |
314 | |
315 #ifdef HAL_SDRAM_MODULE_ENABLED | |
316 #include "stm32f4xx_hal_sdram.h" | |
317 #endif /* HAL_SDRAM_MODULE_ENABLED */ | |
318 | |
319 #ifdef HAL_HASH_MODULE_ENABLED | |
320 #include "stm32f4xx_hal_hash.h" | |
321 #endif /* HAL_HASH_MODULE_ENABLED */ | |
322 | |
323 #ifdef HAL_I2C_MODULE_ENABLED | |
324 #include "stm32f4xx_hal_i2c.h" | |
325 #endif /* HAL_I2C_MODULE_ENABLED */ | |
326 | |
327 #ifdef HAL_I2S_MODULE_ENABLED | |
328 #include "stm32f4xx_hal_i2s.h" | |
329 #endif /* HAL_I2S_MODULE_ENABLED */ | |
330 | |
331 #ifdef HAL_IWDG_MODULE_ENABLED | |
332 #include "stm32f4xx_hal_iwdg.h" | |
333 #endif /* HAL_IWDG_MODULE_ENABLED */ | |
334 | |
335 #ifdef HAL_LTDC_MODULE_ENABLED | |
336 #include "stm32f4xx_hal_ltdc.h" | |
337 #endif /* HAL_LTDC_MODULE_ENABLED */ | |
338 | |
339 #ifdef HAL_PWR_MODULE_ENABLED | |
340 #include "stm32f4xx_hal_pwr.h" | |
341 #endif /* HAL_PWR_MODULE_ENABLED */ | |
342 | |
343 #ifdef HAL_RNG_MODULE_ENABLED | |
344 #include "stm32f4xx_hal_rng.h" | |
345 #endif /* HAL_RNG_MODULE_ENABLED */ | |
346 | |
347 #ifdef HAL_RTC_MODULE_ENABLED | |
348 #include "stm32f4xx_hal_rtc.h" | |
349 #endif /* HAL_RTC_MODULE_ENABLED */ | |
350 | |
351 #ifdef HAL_SAI_MODULE_ENABLED | |
352 #include "stm32f4xx_hal_sai.h" | |
353 #endif /* HAL_SAI_MODULE_ENABLED */ | |
354 | |
355 #ifdef HAL_SD_MODULE_ENABLED | |
356 #include "stm32f4xx_hal_sd.h" | |
357 #endif /* HAL_SD_MODULE_ENABLED */ | |
358 | |
359 #ifdef HAL_SPI_MODULE_ENABLED | |
360 #include "stm32f4xx_hal_spi.h" | |
361 #endif /* HAL_SPI_MODULE_ENABLED */ | |
362 | |
363 #ifdef HAL_TIM_MODULE_ENABLED | |
364 #include "stm32f4xx_hal_tim.h" | |
365 #endif /* HAL_TIM_MODULE_ENABLED */ | |
366 | |
367 #ifdef HAL_UART_MODULE_ENABLED | |
368 #include "stm32f4xx_hal_uart.h" | |
369 #endif /* HAL_UART_MODULE_ENABLED */ | |
370 | |
371 #ifdef HAL_USART_MODULE_ENABLED | |
372 #include "stm32f4xx_hal_usart.h" | |
373 #endif /* HAL_USART_MODULE_ENABLED */ | |
374 | |
375 #ifdef HAL_IRDA_MODULE_ENABLED | |
376 #include "stm32f4xx_hal_irda.h" | |
377 #endif /* HAL_IRDA_MODULE_ENABLED */ | |
378 | |
379 #ifdef HAL_SMARTCARD_MODULE_ENABLED | |
380 #include "stm32f4xx_hal_smartcard.h" | |
381 #endif /* HAL_SMARTCARD_MODULE_ENABLED */ | |
382 | |
383 #ifdef HAL_WWDG_MODULE_ENABLED | |
384 #include "stm32f4xx_hal_wwdg.h" | |
385 #endif /* HAL_WWDG_MODULE_ENABLED */ | |
386 | |
387 #ifdef HAL_PCD_MODULE_ENABLED | |
388 #include "stm32f4xx_hal_pcd.h" | |
389 #endif /* HAL_PCD_MODULE_ENABLED */ | |
390 | |
391 #ifdef HAL_HCD_MODULE_ENABLED | |
392 #include "stm32f4xx_hal_hcd.h" | |
393 #endif /* HAL_HCD_MODULE_ENABLED */ | |
394 | |
395 /* Exported macro ------------------------------------------------------------*/ | |
396 #ifdef USE_FULL_ASSERT | |
397 /** | |
398 * @brief The assert_param macro is used for function's parameters check. | |
399 * @param expr: If expr is false, it calls assert_failed function | |
400 * which reports the name of the source file and the source | |
401 * line number of the call that failed. | |
402 * If expr is true, it returns no value. | |
403 * @retval None | |
404 */ | |
405 #define assert_param(expr) ((expr) ? (void)0 : assert_failed((uint8_t *)__FILE__, __LINE__)) | |
406 /* Exported functions ------------------------------------------------------- */ | |
407 void assert_failed(uint8_t* file, uint32_t line); | |
408 #else | |
409 #define assert_param(expr) ((void)0) | |
410 #endif /* USE_FULL_ASSERT */ | |
411 | |
412 #endif /* STM32F4xx_HAL_CONF_H */ |