blob: a4a3f3086cfb04113834efe0d354ceb3b8497e36 [file] [log] [blame]
Austin Schuh41baf202022-01-01 14:33:40 -08001/**
2 ******************************************************************************
3 * @file USB_Device/HID_Standalone/Inc/stm32f1xx_hal_conf.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 stm32f1xx_hal_conf.h.
8 ******************************************************************************
9 * @attention
10 *
11 * <h2><center>&copy; Copyright (c) 2016 STMicroelectronics.
12 * All rights reserved.</center></h2>
13 *
14 * This software component is licensed by ST under BSD 3-Clause license,
15 * the "License"; You may not use this file except in compliance with the
16 * License. You may obtain a copy of the License at:
17 * opensource.org/licenses/BSD-3-Clause
18 *
19 ******************************************************************************
20 */
21
22/* Define to prevent recursive inclusion -------------------------------------*/
23#ifndef __STM32F1xx_HAL_CONF_H
24#define __STM32F1xx_HAL_CONF_H
25
26#ifdef __cplusplus
27 extern "C" {
28#endif
29
30/* Exported types ------------------------------------------------------------*/
31/* Exported constants --------------------------------------------------------*/
32
33/* ########################## Module Selection ############################## */
34/**
35 * @brief This is the list of modules to be used in the HAL driver
36 */
37#define HAL_MODULE_ENABLED
38/* #define HAL_ADC_MODULE_ENABLED */
39/* #define HAL_CAN_MODULE_ENABLED */
40/* #define HAL_CAN_LEGACY_MODULE_ENABLED */
41#define HAL_CORTEX_MODULE_ENABLED */
42/* #define HAL_CRC_MODULE_ENABLED */
43/* #define HAL_DAC_MODULE_ENABLED */
44#define HAL_DMA_MODULE_ENABLED
45#define HAL_EXTI_MODULE_ENABLED
46#define HAL_FLASH_MODULE_ENABLED
47#define HAL_GPIO_MODULE_ENABLED
48/* #define HAL_I2C_MODULE_ENABLED */
49/* #define HAL_I2S_MODULE_ENABLED */
50/* #define HAL_IRDA_MODULE_ENABLED */
51/* #define HAL_IWDG_MODULE_ENABLED */
52/* #define HAL_NOR_MODULE_ENABLED */
53/* #define HAL_PCCARD_MODULE_ENABLED */
54#define HAL_PCD_MODULE_ENABLED
55#define HAL_PWR_MODULE_ENABLED
56#define HAL_RCC_MODULE_ENABLED
57/* #define HAL_RTC_MODULE_ENABLED */
58/* #define HAL_SD_MODULE_ENABLED */
59/* #define HAL_SDRAM_MODULE_ENABLED */
60/* #define HAL_SMARTCARD_MODULE_ENABLED */
61/* #define HAL_SPI_MODULE_ENABLED */
62/* #define HAL_SRAM_MODULE_ENABLED */
63/* #define HAL_TIM_MODULE_ENABLED */
64#define HAL_UART_MODULE_ENABLED
65/* #define HAL_USART_MODULE_ENABLED */
66/* #define HAL_WWDG_MODULE_ENABLED */
67
68/* ########################## Oscillator Values adaptation ####################*/
69/**
70 * @brief Adjust the value of External High Speed oscillator (HSE) used in your application.
71 * This value is used by the RCC HAL module to compute the system frequency
72 * (when HSE is used as system clock source, directly or through the PLL).
73 */
74#if !defined (HSE_VALUE)
75#if defined(USE_STM3210C_EVAL)
76 #define HSE_VALUE 25000000U /*!< Value of the External oscillator in Hz */
77#else
78 #define HSE_VALUE 8000000U /*!< Value of the External oscillator in Hz */
79#endif
80#endif /* HSE_VALUE */
81
82#if !defined (HSE_STARTUP_TIMEOUT)
83 #define HSE_STARTUP_TIMEOUT 100U /*!< Time out for HSE start up, in ms */
84#endif /* HSE_STARTUP_TIMEOUT */
85
86/**
87 * @brief Internal High Speed oscillator (HSI) value.
88 * This value is used by the RCC HAL module to compute the system frequency
89 * (when HSI is used as system clock source, directly or through the PLL).
90 */
91#if !defined (HSI_VALUE)
92 #define HSI_VALUE 8000000U /*!< Value of the Internal oscillator in Hz */
93#endif /* HSI_VALUE */
94
95/**
96 * @brief Internal Low Speed oscillator (LSI) value.
97 */
98#if !defined (LSI_VALUE)
99 #define LSI_VALUE 40000U /*!< LSI Typical Value in Hz */
100#endif /* LSI_VALUE */ /*!< Value of the Internal Low Speed oscillator in Hz
101 The real value may vary depending on the variations
102 in voltage and temperature. */
103
104/**
105 * @brief External Low Speed oscillator (LSE) value.
106 * This value is used by the UART, RTC HAL module to compute the system frequency
107 */
108#if !defined (LSE_VALUE)
109 #define LSE_VALUE 32768U /*!< Value of the External oscillator in Hz*/
110#endif /* LSE_VALUE */
111
112#if !defined (LSE_STARTUP_TIMEOUT)
113 #define LSE_STARTUP_TIMEOUT 5000U /*!< Time out for LSE start up, in ms */
114#endif /* LSE_STARTUP_TIMEOUT */
115
116/* Tip: To avoid modifying this file each time you need to use different HSE,
117 === you can define the HSE value in your toolchain compiler preprocessor. */
118
119/* ########################### System Configuration ######################### */
120/**
121 * @brief This is the HAL system configuration section
122 */
123#define VDD_VALUE 3300U /*!< Value of VDD in mv */
124#define TICK_INT_PRIORITY 0x00U /*!< tick interrupt priority */
125#define USE_RTOS 0U
126#define PREFETCH_ENABLE 1U
127
128#define USE_HAL_ADC_REGISTER_CALLBACKS 0U /* ADC register callback disabled */
129#define USE_HAL_CAN_REGISTER_CALLBACKS 0U /* CAN register callback disabled */
130#define USE_HAL_CEC_REGISTER_CALLBACKS 0U /* CEC register callback disabled */
131#define USE_HAL_DAC_REGISTER_CALLBACKS 0U /* DAC register callback disabled */
132#define USE_HAL_ETH_REGISTER_CALLBACKS 0U /* ETH register callback disabled */
133#define USE_HAL_HCD_REGISTER_CALLBACKS 0U /* HCD register callback disabled */
134#define USE_HAL_I2C_REGISTER_CALLBACKS 0U /* I2C register callback disabled */
135#define USE_HAL_I2S_REGISTER_CALLBACKS 0U /* I2S register callback disabled */
136#define USE_HAL_MMC_REGISTER_CALLBACKS 0U /* MMC register callback disabled */
137#define USE_HAL_NAND_REGISTER_CALLBACKS 0U /* NAND register callback disabled */
138#define USE_HAL_NOR_REGISTER_CALLBACKS 0U /* NOR register callback disabled */
139#define USE_HAL_PCCARD_REGISTER_CALLBACKS 0U /* PCCARD register callback disabled */
140#define USE_HAL_PCD_REGISTER_CALLBACKS 0U /* PCD register callback disabled */
141#define USE_HAL_RTC_REGISTER_CALLBACKS 0U /* RTC register callback disabled */
142#define USE_HAL_SD_REGISTER_CALLBACKS 0U /* SD register callback disabled */
143#define USE_HAL_SMARTCARD_REGISTER_CALLBACKS 0U /* SMARTCARD register callback disabled */
144#define USE_HAL_IRDA_REGISTER_CALLBACKS 0U /* IRDA register callback disabled */
145#define USE_HAL_SRAM_REGISTER_CALLBACKS 0U /* SRAM register callback disabled */
146#define USE_HAL_SPI_REGISTER_CALLBACKS 0U /* SPI register callback disabled */
147#define USE_HAL_TIM_REGISTER_CALLBACKS 0U /* TIM register callback disabled */
148#define USE_HAL_UART_REGISTER_CALLBACKS 0U /* UART register callback disabled */
149#define USE_HAL_USART_REGISTER_CALLBACKS 0U /* USART register callback disabled */
150#define USE_HAL_WWDG_REGISTER_CALLBACKS 0U /* WWDG register callback disabled */
151
152/* ########################## Assert Selection ############################## */
153/**
154 * @brief Uncomment the line below to expanse the "assert_param" macro in the
155 * HAL drivers code
156 */
157/* #define USE_FULL_ASSERT 1U */
158
159/* ################## Ethernet peripheral configuration ##################### */
160
161/* Section 1 : Ethernet peripheral configuration */
162
163/* MAC ADDRESS: MAC_ADDR0:MAC_ADDR1:MAC_ADDR2:MAC_ADDR3:MAC_ADDR4:MAC_ADDR5 */
164#define MAC_ADDR0 2U
165#define MAC_ADDR1 0U
166#define MAC_ADDR2 0U
167#define MAC_ADDR3 0U
168#define MAC_ADDR4 0U
169#define MAC_ADDR5 0U
170
171/* Definition of the Ethernet driver buffers size and count */
172#define ETH_RX_BUF_SIZE ETH_MAX_PACKET_SIZE /* buffer size for receive */
173#define ETH_TX_BUF_SIZE ETH_MAX_PACKET_SIZE /* buffer size for transmit */
174#define ETH_RXBUFNB 8U /* 8 Rx buffers of size ETH_RX_BUF_SIZE */
175#define ETH_TXBUFNB 4U /* 4 Tx buffers of size ETH_TX_BUF_SIZE */
176
177/* Section 2: PHY configuration section */
178
179/* DP83848 PHY Address*/
180#define DP83848_PHY_ADDRESS 0x01U
181/* PHY Reset delay these values are based on a 1 ms Systick interrupt*/
182#define PHY_RESET_DELAY 0x000000FFU
183/* PHY Configuration delay */
184#define PHY_CONFIG_DELAY 0x00000FFFU
185
186#define PHY_READ_TO 0x0000FFFFU
187#define PHY_WRITE_TO 0x0000FFFFU
188
189/* Section 3: Common PHY Registers */
190
191#define PHY_BCR ((uint16_t)0x0000) /*!< Transceiver Basic Control Register */
192#define PHY_BSR ((uint16_t)0x0001) /*!< Transceiver Basic Status Register */
193
194#define PHY_RESET ((uint16_t)0x8000) /*!< PHY Reset */
195#define PHY_LOOPBACK ((uint16_t)0x4000) /*!< Select loop-back mode */
196#define PHY_FULLDUPLEX_100M ((uint16_t)0x2100) /*!< Set the full-duplex mode at 100 Mb/s */
197#define PHY_HALFDUPLEX_100M ((uint16_t)0x2000) /*!< Set the half-duplex mode at 100 Mb/s */
198#define PHY_FULLDUPLEX_10M ((uint16_t)0x0100) /*!< Set the full-duplex mode at 10 Mb/s */
199#define PHY_HALFDUPLEX_10M ((uint16_t)0x0000) /*!< Set the half-duplex mode at 10 Mb/s */
200#define PHY_AUTONEGOTIATION ((uint16_t)0x1000) /*!< Enable auto-negotiation function */
201#define PHY_RESTART_AUTONEGOTIATION ((uint16_t)0x0200) /*!< Restart auto-negotiation function */
202#define PHY_POWERDOWN ((uint16_t)0x0800) /*!< Select the power down mode */
203#define PHY_ISOLATE ((uint16_t)0x0400) /*!< Isolate PHY from MII */
204
205#define PHY_AUTONEGO_COMPLETE ((uint16_t)0x0020) /*!< Auto-Negotiation process completed */
206#define PHY_LINKED_STATUS ((uint16_t)0x0004) /*!< Valid link established */
207#define PHY_JABBER_DETECTION ((uint16_t)0x0002) /*!< Jabber condition detected */
208
209/* Section 4: Extended PHY Registers */
210
211#define PHY_SR ((uint16_t)0x0010) /*!< PHY status register Offset */
212#define PHY_MICR ((uint16_t)0x0011) /*!< MII Interrupt Control Register */
213#define PHY_MISR ((uint16_t)0x0012) /*!< MII Interrupt Status and Misc. Control Register */
214
215#define PHY_LINK_STATUS ((uint16_t)0x0001) /*!< PHY Link mask */
216#define PHY_SPEED_STATUS ((uint16_t)0x0002) /*!< PHY Speed mask */
217#define PHY_DUPLEX_STATUS ((uint16_t)0x0004) /*!< PHY Duplex mask */
218
219#define PHY_MICR_INT_EN ((uint16_t)0x0002) /*!< PHY Enable interrupts */
220#define PHY_MICR_INT_OE ((uint16_t)0x0001) /*!< PHY Enable output interrupt events */
221
222#define PHY_MISR_LINK_INT_EN ((uint16_t)0x0020) /*!< Enable Interrupt on change of link status */
223#define PHY_LINK_INTERRUPT ((uint16_t)0x2000) /*!< PHY link status interrupt mask */
224
225/* ################## SPI peripheral configuration ########################## */
226
227/* CRC FEATURE: Use to activate CRC feature inside HAL SPI Driver
228* Activated: CRC code is present inside driver
229* Deactivated: CRC code cleaned from driver
230*/
231
232#define USE_SPI_CRC 1U
233
234/* Includes ------------------------------------------------------------------*/
235/**
236 * @brief Include module's header file
237 */
238
239#ifdef HAL_RCC_MODULE_ENABLED
240 #include "stm32f1xx_hal_rcc.h"
241#endif /* HAL_RCC_MODULE_ENABLED */
242
243#ifdef HAL_GPIO_MODULE_ENABLED
244 #include "stm32f1xx_hal_gpio.h"
245#endif /* HAL_GPIO_MODULE_ENABLED */
246
247#ifdef HAL_EXTI_MODULE_ENABLED
248 #include "stm32f1xx_hal_exti.h"
249#endif /* HAL_EXTI_MODULE_ENABLED */
250
251#ifdef HAL_DMA_MODULE_ENABLED
252 #include "stm32f1xx_hal_dma.h"
253#endif /* HAL_DMA_MODULE_ENABLED */
254
255#ifdef HAL_CAN_MODULE_ENABLED
256 #include "stm32f1xx_hal_can.h"
257#endif /* HAL_CAN_MODULE_ENABLED */
258
259#ifdef HAL_CAN_LEGACY_MODULE_ENABLED
260 #include "Legacy/stm32f1xx_hal_can_legacy.h"
261#endif /* HAL_CAN_LEGACY_MODULE_ENABLED */
262
263#ifdef HAL_CORTEX_MODULE_ENABLED
264 #include "stm32f1xx_hal_cortex.h"
265#endif /* HAL_CORTEX_MODULE_ENABLED */
266
267#ifdef HAL_ADC_MODULE_ENABLED
268 #include "stm32f1xx_hal_adc.h"
269#endif /* HAL_ADC_MODULE_ENABLED */
270
271#ifdef HAL_CRC_MODULE_ENABLED
272 #include "stm32f1xx_hal_crc.h"
273#endif /* HAL_CRC_MODULE_ENABLED */
274
275#ifdef HAL_DAC_MODULE_ENABLED
276 #include "stm32f1xx_hal_dac.h"
277#endif /* HAL_DAC_MODULE_ENABLED */
278
279#ifdef HAL_FLASH_MODULE_ENABLED
280 #include "stm32f1xx_hal_flash.h"
281#endif /* HAL_FLASH_MODULE_ENABLED */
282
283#ifdef HAL_SRAM_MODULE_ENABLED
284 #include "stm32f1xx_hal_sram.h"
285#endif /* HAL_SRAM_MODULE_ENABLED */
286
287#ifdef HAL_NOR_MODULE_ENABLED
288 #include "stm32f1xx_hal_nor.h"
289#endif /* HAL_NOR_MODULE_ENABLED */
290
291#ifdef HAL_I2C_MODULE_ENABLED
292 #include "stm32f1xx_hal_i2c.h"
293#endif /* HAL_I2C_MODULE_ENABLED */
294
295#ifdef HAL_I2S_MODULE_ENABLED
296 #include "stm32f1xx_hal_i2s.h"
297#endif /* HAL_I2S_MODULE_ENABLED */
298
299#ifdef HAL_IWDG_MODULE_ENABLED
300 #include "stm32f1xx_hal_iwdg.h"
301#endif /* HAL_IWDG_MODULE_ENABLED */
302
303#ifdef HAL_PWR_MODULE_ENABLED
304 #include "stm32f1xx_hal_pwr.h"
305#endif /* HAL_PWR_MODULE_ENABLED */
306
307#ifdef HAL_RTC_MODULE_ENABLED
308 #include "stm32f1xx_hal_rtc.h"
309#endif /* HAL_RTC_MODULE_ENABLED */
310
311#ifdef HAL_PCCARD_MODULE_ENABLED
312 #include "stm32f1xx_hal_pccard.h"
313#endif /* HAL_PCCARD_MODULE_ENABLED */
314
315#ifdef HAL_SD_MODULE_ENABLED
316 #include "stm32f1xx_hal_sd.h"
317#endif /* HAL_SD_MODULE_ENABLED */
318
319#ifdef HAL_SDRAM_MODULE_ENABLED
320 #include "stm32f1xx_hal_sdram.h"
321#endif /* HAL_SDRAM_MODULE_ENABLED */
322
323#ifdef HAL_SPI_MODULE_ENABLED
324 #include "stm32f1xx_hal_spi.h"
325#endif /* HAL_SPI_MODULE_ENABLED */
326
327#ifdef HAL_TIM_MODULE_ENABLED
328 #include "stm32f1xx_hal_tim.h"
329#endif /* HAL_TIM_MODULE_ENABLED */
330
331#ifdef HAL_UART_MODULE_ENABLED
332 #include "stm32f1xx_hal_uart.h"
333#endif /* HAL_UART_MODULE_ENABLED */
334
335#ifdef HAL_USART_MODULE_ENABLED
336 #include "stm32f1xx_hal_usart.h"
337#endif /* HAL_USART_MODULE_ENABLED */
338
339#ifdef HAL_IRDA_MODULE_ENABLED
340 #include "stm32f1xx_hal_irda.h"
341#endif /* HAL_IRDA_MODULE_ENABLED */
342
343#ifdef HAL_SMARTCARD_MODULE_ENABLED
344 #include "stm32f1xx_hal_smartcard.h"
345#endif /* HAL_SMARTCARD_MODULE_ENABLED */
346
347#ifdef HAL_WWDG_MODULE_ENABLED
348 #include "stm32f1xx_hal_wwdg.h"
349#endif /* HAL_WWDG_MODULE_ENABLED */
350
351#ifdef HAL_PCD_MODULE_ENABLED
352 #include "stm32f1xx_hal_pcd.h"
353#endif /* HAL_PCD_MODULE_ENABLED */
354
355/* Exported macro ------------------------------------------------------------*/
356#ifdef USE_FULL_ASSERT
357/**
358 * @brief The assert_param macro is used for function's parameters check.
359 * @param expr: If expr is false, it calls assert_failed function
360 * which reports the name of the source file and the source
361 * line number of the call that failed.
362 * If expr is true, it returns no value.
363 * @retval None
364 */
365 #define assert_param(expr) ((expr) ? (void)0U : assert_failed((uint8_t *)__FILE__, __LINE__))
366/* Exported functions ------------------------------------------------------- */
367 void assert_failed(uint8_t* file, uint32_t line);
368#else
369 #define assert_param(expr) ((void)0U)
370#endif /* USE_FULL_ASSERT */
371
372#ifdef __cplusplus
373}
374#endif
375
376#endif /* __STM32F1xx_HAL_CONF_H */
377
378
379/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/