• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /**
2   ******************************************************************************
3   * @file    stm32f4xx_hal_conf_template.h
4   * @author  MCD Application Team
5   * @brief   HAL configuration template file.
6   *          This file should be copied to the application folder and renamed
7   *          to stm32f4xx_hal_conf.h.
8   ******************************************************************************
9   * @attention
10   *
11   * Copyright (c) 2017 STMicroelectronics.
12   * All rights reserved.
13   *
14   * This software is licensed under terms that can be found in the LICENSE file
15   * in the root directory of this software component.
16   * If no LICENSE file comes with this software, it is provided AS-IS.
17   *
18   ******************************************************************************
19   */
20 #ifndef __STM32F4xx_HAL_CONF_H
21 #define __STM32F4xx_HAL_CONF_H
22 
23 #define HAL_MODULE_ENABLED
24 #define HAL_UART_MODULE_ENABLED
25 #define HAL_GPIO_MODULE_ENABLED
26 #define HAL_DMA_MODULE_ENABLED
27 #define HAL_RCC_MODULE_ENABLED
28 #define HAL_FLASH_MODULE_ENABLED
29 #define HAL_PWR_MODULE_ENABLED
30 #define HAL_CORTEX_MODULE_ENABLED
31 
32 #if !defined(HSE_VALUE)
33 #define HSE_VALUE 25000000U /*!< Value of the External oscillator in Hz */
34 #endif                      /* HSE_VALUE */
35 
36 #if !defined(HSE_STARTUP_TIMEOUT)
37 #define HSE_STARTUP_TIMEOUT 100U /*!< Time out for HSE start up, in ms */
38 #endif                           /* HSE_STARTUP_TIMEOUT */
39 
40 /**
41  * @brief Internal High Speed oscillator (HSI) value.
42  *        This value is used by the RCC HAL module to compute the system frequency
43  *        (when HSI is used as system clock source, directly or through the PLL).
44  */
45 #if !defined(HSI_VALUE)
46 #define HSI_VALUE ((uint32_t)16000000U) /* !< Value of the Internal oscillator in Hz */
47 #endif                                  /* HSI_VALUE */
48 
49 /**
50  * @brief Internal Low Speed oscillator (LSI) value.
51  */
52 #if !defined(LSI_VALUE)
53 #define LSI_VALUE 32000U /* !< LSI Typical Value in Hz */
54 #endif /* LSI_VALUE */   /* !< Value of the Internal Low Speed oscillator in Hz \
55                             The real value may vary depending on the variations \
56                             in voltage and temperature. */
57 /**
58  * @brief External Low Speed oscillator (LSE) value.
59  */
60 #if !defined(LSE_VALUE)
61 #define LSE_VALUE 32768U /*!< Value of the External Low Speed oscillator in Hz */
62 #endif                   /* LSE_VALUE */
63 
64 #if !defined(LSE_STARTUP_TIMEOUT)
65 #define LSE_STARTUP_TIMEOUT 5000U /*!< Time out for LSE start up, in ms */
66 #endif                            /* LSE_STARTUP_TIMEOUT */
67 
68 /**
69  * @brief External clock source for I2S peripheral
70  *        This value is used by the I2S HAL module to compute the I2S clock source
71  *        frequency, this source is inserted directly through I2S_CKIN pad.
72  */
73 #if !defined(EXTERNAL_CLOCK_VALUE)
74 #define EXTERNAL_CLOCK_VALUE 12288000U /* !< Value of the External audio frequency in Hz */
75 #endif                                 /* EXTERNAL_CLOCK_VALUE */
76 
77 /* Tip: To avoid modifying this file each time you need to use different HSE,
78    ===  you can define the HSE value in your toolchain compiler preprocessor. */
79 
80 /* ########################### System Configuration ######################### */
81 /**
82  * @brief This is the HAL system configuration section
83  */
84 #define VDD_VALUE 3300U       /*!< Value of VDD in mv */
85 #define TICK_INT_PRIORITY 15U /*!< tick interrupt priority */
86 #define USE_RTOS 0U
87 #define PREFETCH_ENABLE 1U
88 #define INSTRUCTION_CACHE_ENABLE 1U
89 #define DATA_CACHE_ENABLE 1U
90 
91 #define USE_HAL_ADC_REGISTER_CALLBACKS 0U       /* ADC register callback disabled       */
92 #define USE_HAL_CAN_REGISTER_CALLBACKS 0U       /* CAN register callback disabled       */
93 #define USE_HAL_CEC_REGISTER_CALLBACKS 0U       /* CEC register callback disabled       */
94 #define USE_HAL_CRYP_REGISTER_CALLBACKS 0U      /* CRYP register callback disabled      */
95 #define USE_HAL_DAC_REGISTER_CALLBACKS 0U       /* DAC register callback disabled       */
96 #define USE_HAL_DCMI_REGISTER_CALLBACKS 0U      /* DCMI register callback disabled      */
97 #define USE_HAL_DFSDM_REGISTER_CALLBACKS 0U     /* DFSDM register callback disabled     */
98 #define USE_HAL_DMA2D_REGISTER_CALLBACKS 0U     /* DMA2D register callback disabled     */
99 #define USE_HAL_DSI_REGISTER_CALLBACKS 0U       /* DSI register callback disabled       */
100 #define USE_HAL_ETH_REGISTER_CALLBACKS 0U       /* ETH register callback disabled       */
101 #define USE_HAL_HASH_REGISTER_CALLBACKS 0U      /* HASH register callback disabled      */
102 #define USE_HAL_HCD_REGISTER_CALLBACKS 0U       /* HCD register callback disabled       */
103 #define USE_HAL_I2C_REGISTER_CALLBACKS 0U       /* I2C register callback disabled       */
104 #define USE_HAL_FMPI2C_REGISTER_CALLBACKS 0U    /* FMPI2C register callback disabled    */
105 #define USE_HAL_FMPSMBUS_REGISTER_CALLBACKS 0U  /* FMPSMBUS register callback disabled  */
106 #define USE_HAL_I2S_REGISTER_CALLBACKS 0U       /* I2S register callback disabled       */
107 #define USE_HAL_IRDA_REGISTER_CALLBACKS 0U      /* IRDA register callback disabled      */
108 #define USE_HAL_LPTIM_REGISTER_CALLBACKS 0U     /* LPTIM register callback disabled     */
109 #define USE_HAL_LTDC_REGISTER_CALLBACKS 0U      /* LTDC register callback disabled      */
110 #define USE_HAL_MMC_REGISTER_CALLBACKS 0U       /* MMC register callback disabled       */
111 #define USE_HAL_NAND_REGISTER_CALLBACKS 0U      /* NAND register callback disabled      */
112 #define USE_HAL_NOR_REGISTER_CALLBACKS 0U       /* NOR register callback disabled       */
113 #define USE_HAL_PCCARD_REGISTER_CALLBACKS 0U    /* PCCARD register callback disabled    */
114 #define USE_HAL_PCD_REGISTER_CALLBACKS 0U       /* PCD register callback disabled       */
115 #define USE_HAL_QSPI_REGISTER_CALLBACKS 0U      /* QSPI register callback disabled      */
116 #define USE_HAL_RNG_REGISTER_CALLBACKS 0U       /* RNG register callback disabled       */
117 #define USE_HAL_RTC_REGISTER_CALLBACKS 0U       /* RTC register callback disabled       */
118 #define USE_HAL_SAI_REGISTER_CALLBACKS 0U       /* SAI register callback disabled       */
119 #define USE_HAL_SD_REGISTER_CALLBACKS 0U        /* SD register callback disabled        */
120 #define USE_HAL_SMARTCARD_REGISTER_CALLBACKS 0U /* SMARTCARD register callback disabled */
121 #define USE_HAL_SDRAM_REGISTER_CALLBACKS 0U     /* SDRAM register callback disabled     */
122 #define USE_HAL_SRAM_REGISTER_CALLBACKS 0U      /* SRAM register callback disabled      */
123 #define USE_HAL_SPDIFRX_REGISTER_CALLBACKS 0U   /* SPDIFRX register callback disabled   */
124 #define USE_HAL_SMBUS_REGISTER_CALLBACKS 0U     /* SMBUS register callback disabled     */
125 #define USE_HAL_SPI_REGISTER_CALLBACKS 0U       /* SPI register callback disabled       */
126 #define USE_HAL_TIM_REGISTER_CALLBACKS 0U       /* TIM register callback disabled       */
127 #define USE_HAL_UART_REGISTER_CALLBACKS 0U      /* UART register callback disabled      */
128 #define USE_HAL_USART_REGISTER_CALLBACKS 0U     /* USART register callback disabled     */
129 #define USE_HAL_WWDG_REGISTER_CALLBACKS 0U      /* WWDG register callback disabled      */
130 
131 /* ########################## Assert Selection ############################## */
132 /**
133  * @brief Uncomment the line below to expanse the "assert_param" macro in the
134  *        HAL drivers code
135  */
136 /* #define USE_FULL_ASSERT    1U */
137 
138 /* ################## Ethernet peripheral configuration ##################### */
139 
140 /* Section 1 : Ethernet peripheral configuration */
141 
142 /* MAC ADDRESS: MAC_ADDR0:MAC_ADDR1:MAC_ADDR2:MAC_ADDR3:MAC_ADDR4:MAC_ADDR5 */
143 #define MAC_ADDR0 2U
144 #define MAC_ADDR1 0U
145 #define MAC_ADDR2 0U
146 #define MAC_ADDR3 0U
147 #define MAC_ADDR4 0U
148 #define MAC_ADDR5 0U
149 
150 /* Definition of the Ethernet driver buffers size and count */
151 #define ETH_RX_BUF_SIZE ETH_MAX_PACKET_SIZE /* buffer size for receive               */
152 #define ETH_TX_BUF_SIZE ETH_MAX_PACKET_SIZE /* buffer size for transmit              */
153 #define ETH_RXBUFNB 4U                      /* 4 Rx buffers of size ETH_RX_BUF_SIZE  */
154 #define ETH_TXBUFNB 4U                      /* 4 Tx buffers of size ETH_TX_BUF_SIZE  */
155 
156 /* Section 2: PHY configuration section */
157 
158 /* DP83848_PHY_ADDRESS Address */
159 #define DP83848_PHY_ADDRESS 0x01U
160 /* PHY Reset delay these values are based on a 1 ms Systick interrupt */
161 #define PHY_RESET_DELAY 0x000000FFU
162 /* PHY Configuration delay */
163 #define PHY_CONFIG_DELAY 0x00000FFFU
164 
165 #define PHY_READ_TO 0x0000FFFFU
166 #define PHY_WRITE_TO 0x0000FFFFU
167 
168 /* Section 3: Common PHY Registers */
169 
170 #define PHY_BCR ((uint16_t)0x0000U) /*!< Transceiver Basic Control Register   */
171 #define PHY_BSR ((uint16_t)0x0001U) /*!< Transceiver Basic Status Register    */
172 
173 #define PHY_RESET ((uint16_t)0x8000U)                   /*!< PHY Reset */
174 #define PHY_LOOPBACK ((uint16_t)0x4000U)                /*!< Select loop-back mode */
175 #define PHY_FULLDUPLEX_100M ((uint16_t)0x2100U)         /*!< Set the full-duplex mode at 100 Mb/s */
176 #define PHY_HALFDUPLEX_100M ((uint16_t)0x2000U)         /*!< Set the half-duplex mode at 100 Mb/s */
177 #define PHY_FULLDUPLEX_10M ((uint16_t)0x0100U)          /*!< Set the full-duplex mode at 10 Mb/s  */
178 #define PHY_HALFDUPLEX_10M ((uint16_t)0x0000U)          /*!< Set the half-duplex mode at 10 Mb/s  */
179 #define PHY_AUTONEGOTIATION ((uint16_t)0x1000U)         /*!< Enable auto-negotiation function     */
180 #define PHY_RESTART_AUTONEGOTIATION ((uint16_t)0x0200U) /*!< Restart auto-negotiation function    */
181 #define PHY_POWERDOWN ((uint16_t)0x0800U)               /*!< Select the power down mode           */
182 #define PHY_ISOLATE ((uint16_t)0x0400U)                 /*!< Isolate PHY from MII                 */
183 
184 #define PHY_AUTONEGO_COMPLETE ((uint16_t)0x0020U) /*!< Auto-Negotiation process completed   */
185 #define PHY_LINKED_STATUS ((uint16_t)0x0004U)     /*!< Valid link established               */
186 #define PHY_JABBER_DETECTION ((uint16_t)0x0002U)  /*!< Jabber condition detected            */
187 
188 /* Section 4: Extended PHY Registers */
189 #define PHY_SR ((uint16_t)0x10U) /*!< PHY status register Offset                      */
190 
191 #define PHY_SPEED_STATUS ((uint16_t)0x0002U)  /*!< PHY Speed mask                                  */
192 #define PHY_DUPLEX_STATUS ((uint16_t)0x0004U) /*!< PHY Duplex mask                                 */
193 
194 /* ################## SPI peripheral configuration ########################## */
195 
196 /* CRC FEATURE: Use to activate CRC feature inside HAL SPI Driver
197  * Activated: CRC code is present inside driver
198  * Deactivated: CRC code cleaned from driver
199  */
200 
201 #define USE_SPI_CRC 0U
202 
203 /* Includes ------------------------------------------------------------------*/
204 /**
205  * @brief Include module's header file
206  */
207 
208 #ifdef HAL_RCC_MODULE_ENABLED
209 #include "stm32f4xx_hal_rcc.h"
210 #endif /* HAL_RCC_MODULE_ENABLED */
211 
212 #ifdef HAL_GPIO_MODULE_ENABLED
213 #include "stm32f4xx_hal_gpio.h"
214 #endif /* HAL_GPIO_MODULE_ENABLED */
215 
216 #ifdef HAL_EXTI_MODULE_ENABLED
217 #include "stm32f4xx_hal_exti.h"
218 #endif /* HAL_EXTI_MODULE_ENABLED */
219 
220 #ifdef HAL_DMA_MODULE_ENABLED
221 #include "stm32f4xx_hal_dma.h"
222 #endif /* HAL_DMA_MODULE_ENABLED */
223 
224 #ifdef HAL_CORTEX_MODULE_ENABLED
225 #include "stm32f4xx_hal_cortex.h"
226 #endif /* HAL_CORTEX_MODULE_ENABLED */
227 
228 #ifdef HAL_ADC_MODULE_ENABLED
229 #include "stm32f4xx_hal_adc.h"
230 #endif /* HAL_ADC_MODULE_ENABLED */
231 
232 #ifdef HAL_CAN_MODULE_ENABLED
233 #include "stm32f4xx_hal_can.h"
234 #endif /* HAL_CAN_MODULE_ENABLED */
235 
236 #ifdef HAL_CAN_LEGACY_MODULE_ENABLED
237 #include "stm32f4xx_hal_can_legacy.h"
238 #endif /* HAL_CAN_LEGACY_MODULE_ENABLED */
239 
240 #ifdef HAL_CRC_MODULE_ENABLED
241 #include "stm32f4xx_hal_crc.h"
242 #endif /* HAL_CRC_MODULE_ENABLED */
243 
244 #ifdef HAL_CRYP_MODULE_ENABLED
245 #include "stm32f4xx_hal_cryp.h"
246 #endif /* HAL_CRYP_MODULE_ENABLED */
247 
248 #ifdef HAL_DMA2D_MODULE_ENABLED
249 #include "stm32f4xx_hal_dma2d.h"
250 #endif /* HAL_DMA2D_MODULE_ENABLED */
251 
252 #ifdef HAL_DAC_MODULE_ENABLED
253 #include "stm32f4xx_hal_dac.h"
254 #endif /* HAL_DAC_MODULE_ENABLED */
255 
256 #ifdef HAL_DCMI_MODULE_ENABLED
257 #include "stm32f4xx_hal_dcmi.h"
258 #endif /* HAL_DCMI_MODULE_ENABLED */
259 
260 #ifdef HAL_ETH_MODULE_ENABLED
261 #include "stm32f4xx_hal_eth.h"
262 #endif /* HAL_ETH_MODULE_ENABLED */
263 
264 #ifdef HAL_FLASH_MODULE_ENABLED
265 #include "stm32f4xx_hal_flash.h"
266 #endif /* HAL_FLASH_MODULE_ENABLED */
267 
268 #ifdef HAL_SRAM_MODULE_ENABLED
269 #include "stm32f4xx_hal_sram.h"
270 #endif /* HAL_SRAM_MODULE_ENABLED */
271 
272 #ifdef HAL_NOR_MODULE_ENABLED
273 #include "stm32f4xx_hal_nor.h"
274 #endif /* HAL_NOR_MODULE_ENABLED */
275 
276 #ifdef HAL_NAND_MODULE_ENABLED
277 #include "stm32f4xx_hal_nand.h"
278 #endif /* HAL_NAND_MODULE_ENABLED */
279 
280 #ifdef HAL_PCCARD_MODULE_ENABLED
281 #include "stm32f4xx_hal_pccard.h"
282 #endif /* HAL_PCCARD_MODULE_ENABLED */
283 
284 #ifdef HAL_SDRAM_MODULE_ENABLED
285 #include "stm32f4xx_hal_sdram.h"
286 #endif /* HAL_SDRAM_MODULE_ENABLED */
287 
288 #ifdef HAL_HASH_MODULE_ENABLED
289 #include "stm32f4xx_hal_hash.h"
290 #endif /* HAL_HASH_MODULE_ENABLED */
291 
292 #ifdef HAL_I2C_MODULE_ENABLED
293 #include "stm32f4xx_hal_i2c.h"
294 #endif /* HAL_I2C_MODULE_ENABLED */
295 
296 #ifdef HAL_SMBUS_MODULE_ENABLED
297 #include "stm32f4xx_hal_smbus.h"
298 #endif /* HAL_SMBUS_MODULE_ENABLED */
299 
300 #ifdef HAL_I2S_MODULE_ENABLED
301 #include "stm32f4xx_hal_i2s.h"
302 #endif /* HAL_I2S_MODULE_ENABLED */
303 
304 #ifdef HAL_IWDG_MODULE_ENABLED
305 #include "stm32f4xx_hal_iwdg.h"
306 #endif /* HAL_IWDG_MODULE_ENABLED */
307 
308 #ifdef HAL_LTDC_MODULE_ENABLED
309 #include "stm32f4xx_hal_ltdc.h"
310 #endif /* HAL_LTDC_MODULE_ENABLED */
311 
312 #ifdef HAL_PWR_MODULE_ENABLED
313 #include "stm32f4xx_hal_pwr.h"
314 #endif /* HAL_PWR_MODULE_ENABLED */
315 
316 #ifdef HAL_RNG_MODULE_ENABLED
317 #include "stm32f4xx_hal_rng.h"
318 #endif /* HAL_RNG_MODULE_ENABLED */
319 
320 #ifdef HAL_RTC_MODULE_ENABLED
321 #include "stm32f4xx_hal_rtc.h"
322 #endif /* HAL_RTC_MODULE_ENABLED */
323 
324 #ifdef HAL_SAI_MODULE_ENABLED
325 #include "stm32f4xx_hal_sai.h"
326 #endif /* HAL_SAI_MODULE_ENABLED */
327 
328 #ifdef HAL_SD_MODULE_ENABLED
329 #include "stm32f4xx_hal_sd.h"
330 #endif /* HAL_SD_MODULE_ENABLED */
331 
332 #ifdef HAL_SPI_MODULE_ENABLED
333 #include "stm32f4xx_hal_spi.h"
334 #endif /* HAL_SPI_MODULE_ENABLED */
335 
336 #ifdef HAL_TIM_MODULE_ENABLED
337 #include "stm32f4xx_hal_tim.h"
338 #endif /* HAL_TIM_MODULE_ENABLED */
339 
340 #ifdef HAL_UART_MODULE_ENABLED
341 #include "stm32f4xx_hal_uart.h"
342 #endif /* HAL_UART_MODULE_ENABLED */
343 
344 #ifdef HAL_USART_MODULE_ENABLED
345 #include "stm32f4xx_hal_usart.h"
346 #endif /* HAL_USART_MODULE_ENABLED */
347 
348 #ifdef HAL_IRDA_MODULE_ENABLED
349 #include "stm32f4xx_hal_irda.h"
350 #endif /* HAL_IRDA_MODULE_ENABLED */
351 
352 #ifdef HAL_SMARTCARD_MODULE_ENABLED
353 #include "stm32f4xx_hal_smartcard.h"
354 #endif /* HAL_SMARTCARD_MODULE_ENABLED */
355 
356 #ifdef HAL_WWDG_MODULE_ENABLED
357 #include "stm32f4xx_hal_wwdg.h"
358 #endif /* HAL_WWDG_MODULE_ENABLED */
359 
360 #ifdef HAL_PCD_MODULE_ENABLED
361 #include "stm32f4xx_hal_pcd.h"
362 #endif /* HAL_PCD_MODULE_ENABLED */
363 
364 #ifdef HAL_HCD_MODULE_ENABLED
365 #include "stm32f4xx_hal_hcd.h"
366 #endif /* HAL_HCD_MODULE_ENABLED */
367 
368 #ifdef HAL_DSI_MODULE_ENABLED
369 #include "stm32f4xx_hal_dsi.h"
370 #endif /* HAL_DSI_MODULE_ENABLED */
371 
372 #ifdef HAL_QSPI_MODULE_ENABLED
373 #include "stm32f4xx_hal_qspi.h"
374 #endif /* HAL_QSPI_MODULE_ENABLED */
375 
376 #ifdef HAL_CEC_MODULE_ENABLED
377 #include "stm32f4xx_hal_cec.h"
378 #endif /* HAL_CEC_MODULE_ENABLED */
379 
380 #ifdef HAL_FMPI2C_MODULE_ENABLED
381 #include "stm32f4xx_hal_fmpi2c.h"
382 #endif /* HAL_FMPI2C_MODULE_ENABLED */
383 
384 #ifdef HAL_FMPSMBUS_MODULE_ENABLED
385 #include "stm32f4xx_hal_fmpsmbus.h"
386 #endif /* HAL_FMPSMBUS_MODULE_ENABLED */
387 
388 #ifdef HAL_SPDIFRX_MODULE_ENABLED
389 #include "stm32f4xx_hal_spdifrx.h"
390 #endif /* HAL_SPDIFRX_MODULE_ENABLED */
391 
392 #ifdef HAL_DFSDM_MODULE_ENABLED
393 #include "stm32f4xx_hal_dfsdm.h"
394 #endif /* HAL_DFSDM_MODULE_ENABLED */
395 
396 
397 /* Exported macro ------------------------------------------------------------*/
398 #ifdef USE_FULL_ASSERT
399 /**
400  * @brief  The assert_param macro is used for function's parameters check.
401  * @param  expr If expr is false, it calls assert_failed function
402  *         which reports the name of the source file and the source
403  *         line number of the call that failed.
404  *         If expr is true, it returns no value.
405  * @retval None
406  */
407 #define assert_param(expr) ((expr) ? (void)0U : assert_failed((uint8_t *)__FILE__, __LINE__))
408 /* Exported functions ------------------------------------------------------- */
409 void assert_failed(uint8_t *file, uint32_t line);
410 #else
411 #define assert_param(expr) ((void)0U)
412 #endif /* USE_FULL_ASSERT */
413 
414 #endif
415