| 2 | 1 /** | 
|  | 2   ****************************************************************************** | 
|  | 3   * @file    stm32f1xx_hal_conf.h | 
|  | 4   * @brief   HAL configuration file. | 
|  | 5   ****************************************************************************** | 
|  | 6   * @attention | 
|  | 7   * | 
|  | 8   * <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics</center></h2> | 
|  | 9   * | 
|  | 10   * Redistribution and use in source and binary forms, with or without modification, | 
|  | 11   * are permitted provided that the following conditions are met: | 
|  | 12   *   1. Redistributions of source code must retain the above copyright notice, | 
|  | 13   *      this list of conditions and the following disclaimer. | 
|  | 14   *   2. Redistributions in binary form must reproduce the above copyright notice, | 
|  | 15   *      this list of conditions and the following disclaimer in the documentation | 
|  | 16   *      and/or other materials provided with the distribution. | 
|  | 17   *   3. Neither the name of STMicroelectronics nor the names of its contributors | 
|  | 18   *      may be used to endorse or promote products derived from this software | 
|  | 19   *      without specific prior written permission. | 
|  | 20   * | 
|  | 21   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | 
|  | 22   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | 
|  | 23   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | 
|  | 24   * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | 
|  | 25   * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | 
|  | 26   * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | 
|  | 27   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER | 
|  | 28   * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | 
|  | 29   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | 
|  | 30   * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 
|  | 31   * | 
|  | 32   ****************************************************************************** | 
|  | 33   */ | 
|  | 34 | 
|  | 35 /* Define to prevent recursive inclusion -------------------------------------*/ | 
|  | 36 #ifndef __STM32F1xx_HAL_CONF_H | 
|  | 37 #define __STM32F1xx_HAL_CONF_H | 
|  | 38 | 
|  | 39 #ifdef __cplusplus | 
|  | 40  extern "C" { | 
|  | 41 #endif | 
|  | 42 | 
|  | 43 #include "main.h" | 
|  | 44 /* Exported types ------------------------------------------------------------*/ | 
|  | 45 /* Exported constants --------------------------------------------------------*/ | 
|  | 46 | 
|  | 47 /* ########################## Module Selection ############################## */ | 
|  | 48 /** | 
|  | 49   * @brief This is the list of modules to be used in the HAL driver | 
|  | 50   */ | 
|  | 51 #define HAL_MODULE_ENABLED | 
|  | 52 /*#define HAL_ADC_MODULE_ENABLED   */ | 
|  | 53 /*#define HAL_CAN_MODULE_ENABLED   */ | 
|  | 54 /*#define HAL_CEC_MODULE_ENABLED   */ | 
|  | 55 /*#define HAL_CORTEX_MODULE_ENABLED   */ | 
|  | 56 /*#define HAL_CRC_MODULE_ENABLED   */ | 
|  | 57 /*#define HAL_DAC_MODULE_ENABLED   */ | 
|  | 58 /*#define HAL_DMA_MODULE_ENABLED   */ | 
|  | 59 /*#define HAL_ETH_MODULE_ENABLED   */ | 
|  | 60 /*#define HAL_FLASH_MODULE_ENABLED   */ | 
|  | 61 #define HAL_GPIO_MODULE_ENABLED | 
|  | 62 /*#define HAL_I2C_MODULE_ENABLED   */ | 
|  | 63 /*#define HAL_I2S_MODULE_ENABLED   */ | 
|  | 64 /*#define HAL_IRDA_MODULE_ENABLED   */ | 
|  | 65 /*#define HAL_IWDG_MODULE_ENABLED   */ | 
|  | 66 /*#define HAL_NOR_MODULE_ENABLED   */ | 
|  | 67 /*#define HAL_NAND_MODULE_ENABLED   */ | 
|  | 68 /*#define HAL_PCCARD_MODULE_ENABLED   */ | 
|  | 69 /*#define HAL_PCD_MODULE_ENABLED   */ | 
|  | 70 /*#define HAL_HCD_MODULE_ENABLED   */ | 
|  | 71 /*#define HAL_PWR_MODULE_ENABLED   */ | 
|  | 72 /*#define HAL_RCC_MODULE_ENABLED   */ | 
|  | 73 /*#define HAL_RTC_MODULE_ENABLED   */ | 
|  | 74 /*#define HAL_SD_MODULE_ENABLED   */ | 
|  | 75 /*#define HAL_SDRAM_MODULE_ENABLED   */ | 
|  | 76 /*#define HAL_SMARTCARD_MODULE_ENABLED   */ | 
|  | 77 /*#define HAL_SPI_MODULE_ENABLED   */ | 
|  | 78 /*#define HAL_SRAM_MODULE_ENABLED   */ | 
|  | 79 #define HAL_TIM_MODULE_ENABLED | 
|  | 80 /*#define HAL_UART_MODULE_ENABLED   */ | 
|  | 81 /*#define HAL_USART_MODULE_ENABLED   */ | 
|  | 82 /*#define HAL_WWDG_MODULE_ENABLED   */ | 
|  | 83 | 
|  | 84 #define HAL_CORTEX_MODULE_ENABLED | 
|  | 85 #define HAL_DMA_MODULE_ENABLED | 
|  | 86 #define HAL_FLASH_MODULE_ENABLED | 
|  | 87 #define HAL_GPIO_MODULE_ENABLED | 
|  | 88 #define HAL_PWR_MODULE_ENABLED | 
|  | 89 #define HAL_RCC_MODULE_ENABLED | 
|  | 90 | 
|  | 91 /* ########################## Oscillator Values adaptation ####################*/ | 
|  | 92 /** | 
|  | 93   * @brief Adjust the value of External High Speed oscillator (HSE) used in your application. | 
|  | 94   *        This value is used by the RCC HAL module to compute the system frequency | 
|  | 95   *        (when HSE is used as system clock source, directly or through the PLL). | 
|  | 96   */ | 
|  | 97 #if !defined  (HSE_VALUE) | 
|  | 98   #define HSE_VALUE    ((uint32_t)8000000) /*!< Value of the External oscillator in Hz */ | 
|  | 99 #endif /* HSE_VALUE */ | 
|  | 100 | 
|  | 101 #if !defined  (HSE_STARTUP_TIMEOUT) | 
|  | 102   #define HSE_STARTUP_TIMEOUT    ((uint32_t)100)   /*!< Time out for HSE start up, in ms */ | 
|  | 103 #endif /* HSE_STARTUP_TIMEOUT */ | 
|  | 104 | 
|  | 105 /** | 
|  | 106   * @brief Internal High Speed oscillator (HSI) value. | 
|  | 107   *        This value is used by the RCC HAL module to compute the system frequency | 
|  | 108   *        (when HSI is used as system clock source, directly or through the PLL). | 
|  | 109   */ | 
|  | 110 #if !defined  (HSI_VALUE) | 
|  | 111   #define HSI_VALUE    ((uint32_t)8000000) /*!< Value of the Internal oscillator in Hz*/ | 
|  | 112 #endif /* HSI_VALUE */ | 
|  | 113 | 
|  | 114 /** | 
|  | 115   * @brief External Low Speed oscillator (LSE) value. | 
|  | 116   *        This value is used by the UART, RTC HAL module to compute the system frequency | 
|  | 117   */ | 
|  | 118 #if !defined  (LSE_VALUE) | 
|  | 119   #define LSE_VALUE    ((uint32_t)32768) /*!< Value of the External oscillator in Hz*/ | 
|  | 120 #endif /* LSE_VALUE */ | 
|  | 121 | 
|  | 122 #if !defined  (LSE_STARTUP_TIMEOUT) | 
|  | 123   #define LSE_STARTUP_TIMEOUT    ((uint32_t)5000)   /*!< Time out for LSE start up, in ms */ | 
|  | 124 #endif /* LSE_STARTUP_TIMEOUT */ | 
|  | 125 | 
|  | 126 /* Tip: To avoid modifying this file each time you need to use different HSE, | 
|  | 127    ===  you can define the HSE value in your toolchain compiler preprocessor. */ | 
|  | 128 | 
|  | 129 /* ########################### System Configuration ######################### */ | 
|  | 130 /** | 
|  | 131   * @brief This is the HAL system configuration section | 
|  | 132   */ | 
|  | 133 #define  VDD_VALUE                    ((uint32_t)3300) /*!< Value of VDD in mv */ | 
|  | 134 #define  TICK_INT_PRIORITY            ((uint32_t)0)    /*!< tick interrupt priority (lowest by default)  */ | 
|  | 135 #define  USE_RTOS                     0 | 
|  | 136 #define  PREFETCH_ENABLE              1 | 
|  | 137 | 
|  | 138 /* ########################## Assert Selection ############################## */ | 
|  | 139 /** | 
|  | 140   * @brief Uncomment the line below to expanse the "assert_param" macro in the | 
|  | 141   *        HAL drivers code | 
|  | 142   */ | 
|  | 143 /* #define USE_FULL_ASSERT    1 */ | 
|  | 144 | 
|  | 145 /* ################## Ethernet peripheral configuration ##################### */ | 
|  | 146 | 
|  | 147 /* Section 1 : Ethernet peripheral configuration */ | 
|  | 148 | 
|  | 149 /* MAC ADDRESS: MAC_ADDR0:MAC_ADDR1:MAC_ADDR2:MAC_ADDR3:MAC_ADDR4:MAC_ADDR5 */ | 
|  | 150 #define MAC_ADDR0   2 | 
|  | 151 #define MAC_ADDR1   0 | 
|  | 152 #define MAC_ADDR2   0 | 
|  | 153 #define MAC_ADDR3   0 | 
|  | 154 #define MAC_ADDR4   0 | 
|  | 155 #define MAC_ADDR5   0 | 
|  | 156 | 
|  | 157 /* Definition of the Ethernet driver buffers size and count */ | 
|  | 158 #define ETH_RX_BUF_SIZE                ETH_MAX_PACKET_SIZE /* buffer size for receive               */ | 
|  | 159 #define ETH_TX_BUF_SIZE                ETH_MAX_PACKET_SIZE /* buffer size for transmit              */ | 
|  | 160 #define ETH_RXBUFNB                    ((uint32_t)8)       /* 4 Rx buffers of size ETH_RX_BUF_SIZE  */ | 
|  | 161 #define ETH_TXBUFNB                    ((uint32_t)4)       /* 4 Tx buffers of size ETH_TX_BUF_SIZE  */ | 
|  | 162 | 
|  | 163 /* Section 2: PHY configuration section */ | 
|  | 164 | 
|  | 165 /* DP83848_PHY_ADDRESS Address*/ | 
|  | 166 #define DP83848_PHY_ADDRESS           0x01U | 
|  | 167 /* PHY Reset delay these values are based on a 1 ms Systick interrupt*/ | 
|  | 168 #define PHY_RESET_DELAY                 ((uint32_t)0x000000FF) | 
|  | 169 /* PHY Configuration delay */ | 
|  | 170 #define PHY_CONFIG_DELAY                ((uint32_t)0x00000FFF) | 
|  | 171 | 
|  | 172 #define PHY_READ_TO                     ((uint32_t)0x0000FFFF) | 
|  | 173 #define PHY_WRITE_TO                    ((uint32_t)0x0000FFFF) | 
|  | 174 | 
|  | 175 /* Section 3: Common PHY Registers */ | 
|  | 176 | 
|  | 177 #define PHY_BCR                         ((uint16_t)0x00)    /*!< Transceiver Basic Control Register   */ | 
|  | 178 #define PHY_BSR                         ((uint16_t)0x01)    /*!< Transceiver Basic Status Register    */ | 
|  | 179 | 
|  | 180 #define PHY_RESET                       ((uint16_t)0x8000)  /*!< PHY Reset */ | 
|  | 181 #define PHY_LOOPBACK                    ((uint16_t)0x4000)  /*!< Select loop-back mode */ | 
|  | 182 #define PHY_FULLDUPLEX_100M             ((uint16_t)0x2100)  /*!< Set the full-duplex mode at 100 Mb/s */ | 
|  | 183 #define PHY_HALFDUPLEX_100M             ((uint16_t)0x2000)  /*!< Set the half-duplex mode at 100 Mb/s */ | 
|  | 184 #define PHY_FULLDUPLEX_10M              ((uint16_t)0x0100)  /*!< Set the full-duplex mode at 10 Mb/s  */ | 
|  | 185 #define PHY_HALFDUPLEX_10M              ((uint16_t)0x0000)  /*!< Set the half-duplex mode at 10 Mb/s  */ | 
|  | 186 #define PHY_AUTONEGOTIATION             ((uint16_t)0x1000)  /*!< Enable auto-negotiation function     */ | 
|  | 187 #define PHY_RESTART_AUTONEGOTIATION     ((uint16_t)0x0200)  /*!< Restart auto-negotiation function    */ | 
|  | 188 #define PHY_POWERDOWN                   ((uint16_t)0x0800)  /*!< Select the power down mode           */ | 
|  | 189 #define PHY_ISOLATE                     ((uint16_t)0x0400)  /*!< Isolate PHY from MII                 */ | 
|  | 190 | 
|  | 191 #define PHY_AUTONEGO_COMPLETE           ((uint16_t)0x0020)  /*!< Auto-Negotiation process completed   */ | 
|  | 192 #define PHY_LINKED_STATUS               ((uint16_t)0x0004)  /*!< Valid link established               */ | 
|  | 193 #define PHY_JABBER_DETECTION            ((uint16_t)0x0002)  /*!< Jabber condition detected            */ | 
|  | 194 | 
|  | 195 /* Section 4: Extended PHY Registers */ | 
|  | 196 #define PHY_SR                          ((uint16_t)0x10U)    /*!< PHY status register Offset                      */ | 
|  | 197 | 
|  | 198 #define PHY_SPEED_STATUS                ((uint16_t)0x0002U)  /*!< PHY Speed mask                                  */ | 
|  | 199 #define PHY_DUPLEX_STATUS               ((uint16_t)0x0004U)  /*!< PHY Duplex mask                                 */ | 
|  | 200 | 
|  | 201 /* Includes ------------------------------------------------------------------*/ | 
|  | 202 /** | 
|  | 203   * @brief Include module's header file | 
|  | 204   */ | 
|  | 205 | 
|  | 206 #ifdef HAL_RCC_MODULE_ENABLED | 
|  | 207  #include "stm32f1xx_hal_rcc.h" | 
|  | 208 #endif /* HAL_RCC_MODULE_ENABLED */ | 
|  | 209 | 
|  | 210 #ifdef HAL_GPIO_MODULE_ENABLED | 
|  | 211  #include "stm32f1xx_hal_gpio.h" | 
|  | 212 #endif /* HAL_GPIO_MODULE_ENABLED */ | 
|  | 213 | 
|  | 214 #ifdef HAL_DMA_MODULE_ENABLED | 
|  | 215   #include "stm32f1xx_hal_dma.h" | 
|  | 216 #endif /* HAL_DMA_MODULE_ENABLED */ | 
|  | 217 | 
|  | 218 #ifdef HAL_ETH_MODULE_ENABLED | 
|  | 219   #include "stm32f1xx_hal_eth.h" | 
|  | 220 #endif /* HAL_ETH_MODULE_ENABLED */ | 
|  | 221 | 
|  | 222 #ifdef HAL_CAN_MODULE_ENABLED | 
|  | 223  #include "stm32f1xx_hal_can.h" | 
|  | 224 #endif /* HAL_CAN_MODULE_ENABLED */ | 
|  | 225 | 
|  | 226 #ifdef HAL_CEC_MODULE_ENABLED | 
|  | 227  #include "stm32f1xx_hal_cec.h" | 
|  | 228 #endif /* HAL_CEC_MODULE_ENABLED */ | 
|  | 229 | 
|  | 230 #ifdef HAL_CORTEX_MODULE_ENABLED | 
|  | 231  #include "stm32f1xx_hal_cortex.h" | 
|  | 232 #endif /* HAL_CORTEX_MODULE_ENABLED */ | 
|  | 233 | 
|  | 234 #ifdef HAL_ADC_MODULE_ENABLED | 
|  | 235  #include "stm32f1xx_hal_adc.h" | 
|  | 236 #endif /* HAL_ADC_MODULE_ENABLED */ | 
|  | 237 | 
|  | 238 #ifdef HAL_CRC_MODULE_ENABLED | 
|  | 239  #include "stm32f1xx_hal_crc.h" | 
|  | 240 #endif /* HAL_CRC_MODULE_ENABLED */ | 
|  | 241 | 
|  | 242 #ifdef HAL_DAC_MODULE_ENABLED | 
|  | 243  #include "stm32f1xx_hal_dac.h" | 
|  | 244 #endif /* HAL_DAC_MODULE_ENABLED */ | 
|  | 245 | 
|  | 246 #ifdef HAL_FLASH_MODULE_ENABLED | 
|  | 247  #include "stm32f1xx_hal_flash.h" | 
|  | 248 #endif /* HAL_FLASH_MODULE_ENABLED */ | 
|  | 249 | 
|  | 250 #ifdef HAL_SRAM_MODULE_ENABLED | 
|  | 251  #include "stm32f1xx_hal_sram.h" | 
|  | 252 #endif /* HAL_SRAM_MODULE_ENABLED */ | 
|  | 253 | 
|  | 254 #ifdef HAL_NOR_MODULE_ENABLED | 
|  | 255  #include "stm32f1xx_hal_nor.h" | 
|  | 256 #endif /* HAL_NOR_MODULE_ENABLED */ | 
|  | 257 | 
|  | 258 #ifdef HAL_I2C_MODULE_ENABLED | 
|  | 259  #include "stm32f1xx_hal_i2c.h" | 
|  | 260 #endif /* HAL_I2C_MODULE_ENABLED */ | 
|  | 261 | 
|  | 262 #ifdef HAL_I2S_MODULE_ENABLED | 
|  | 263  #include "stm32f1xx_hal_i2s.h" | 
|  | 264 #endif /* HAL_I2S_MODULE_ENABLED */ | 
|  | 265 | 
|  | 266 #ifdef HAL_IWDG_MODULE_ENABLED | 
|  | 267  #include "stm32f1xx_hal_iwdg.h" | 
|  | 268 #endif /* HAL_IWDG_MODULE_ENABLED */ | 
|  | 269 | 
|  | 270 #ifdef HAL_PWR_MODULE_ENABLED | 
|  | 271  #include "stm32f1xx_hal_pwr.h" | 
|  | 272 #endif /* HAL_PWR_MODULE_ENABLED */ | 
|  | 273 | 
|  | 274 #ifdef HAL_RTC_MODULE_ENABLED | 
|  | 275  #include "stm32f1xx_hal_rtc.h" | 
|  | 276 #endif /* HAL_RTC_MODULE_ENABLED */ | 
|  | 277 | 
|  | 278 #ifdef HAL_PCCARD_MODULE_ENABLED | 
|  | 279  #include "stm32f1xx_hal_pccard.h" | 
|  | 280 #endif /* HAL_PCCARD_MODULE_ENABLED */ | 
|  | 281 | 
|  | 282 #ifdef HAL_SD_MODULE_ENABLED | 
|  | 283  #include "stm32f1xx_hal_sd.h" | 
|  | 284 #endif /* HAL_SD_MODULE_ENABLED */ | 
|  | 285 | 
|  | 286 #ifdef HAL_NAND_MODULE_ENABLED | 
|  | 287  #include "stm32f1xx_hal_nand.h" | 
|  | 288 #endif /* HAL_NAND_MODULE_ENABLED */ | 
|  | 289 | 
|  | 290 #ifdef HAL_SPI_MODULE_ENABLED | 
|  | 291  #include "stm32f1xx_hal_spi.h" | 
|  | 292 #endif /* HAL_SPI_MODULE_ENABLED */ | 
|  | 293 | 
|  | 294 #ifdef HAL_TIM_MODULE_ENABLED | 
|  | 295  #include "stm32f1xx_hal_tim.h" | 
|  | 296 #endif /* HAL_TIM_MODULE_ENABLED */ | 
|  | 297 | 
|  | 298 #ifdef HAL_UART_MODULE_ENABLED | 
|  | 299  #include "stm32f1xx_hal_uart.h" | 
|  | 300 #endif /* HAL_UART_MODULE_ENABLED */ | 
|  | 301 | 
|  | 302 #ifdef HAL_USART_MODULE_ENABLED | 
|  | 303  #include "stm32f1xx_hal_usart.h" | 
|  | 304 #endif /* HAL_USART_MODULE_ENABLED */ | 
|  | 305 | 
|  | 306 #ifdef HAL_IRDA_MODULE_ENABLED | 
|  | 307  #include "stm32f1xx_hal_irda.h" | 
|  | 308 #endif /* HAL_IRDA_MODULE_ENABLED */ | 
|  | 309 | 
|  | 310 #ifdef HAL_SMARTCARD_MODULE_ENABLED | 
|  | 311  #include "stm32f1xx_hal_smartcard.h" | 
|  | 312 #endif /* HAL_SMARTCARD_MODULE_ENABLED */ | 
|  | 313 | 
|  | 314 #ifdef HAL_WWDG_MODULE_ENABLED | 
|  | 315  #include "stm32f1xx_hal_wwdg.h" | 
|  | 316 #endif /* HAL_WWDG_MODULE_ENABLED */ | 
|  | 317 | 
|  | 318 #ifdef HAL_PCD_MODULE_ENABLED | 
|  | 319  #include "stm32f1xx_hal_pcd.h" | 
|  | 320 #endif /* HAL_PCD_MODULE_ENABLED */ | 
|  | 321 | 
|  | 322 #ifdef HAL_HCD_MODULE_ENABLED | 
|  | 323  #include "stm32f1xx_hal_hcd.h" | 
|  | 324 #endif /* HAL_HCD_MODULE_ENABLED */ | 
|  | 325 | 
|  | 326 | 
|  | 327 /* Exported macro ------------------------------------------------------------*/ | 
|  | 328 #ifdef  USE_FULL_ASSERT | 
|  | 329 /** | 
|  | 330   * @brief  The assert_param macro is used for function's parameters check. | 
|  | 331   * @param  expr: If expr is false, it calls assert_failed function | 
|  | 332   *         which reports the name of the source file and the source | 
|  | 333   *         line number of the call that failed. | 
|  | 334   *         If expr is true, it returns no value. | 
|  | 335   * @retval None | 
|  | 336   */ | 
|  | 337   #define assert_param(expr) ((expr) ? (void)0 : assert_failed((uint8_t *)__FILE__, __LINE__)) | 
|  | 338 /* Exported functions ------------------------------------------------------- */ | 
|  | 339   void assert_failed(uint8_t* file, uint32_t line); | 
|  | 340 #else | 
|  | 341   #define assert_param(expr) ((void)0) | 
|  | 342 #endif /* USE_FULL_ASSERT */ | 
|  | 343 | 
|  | 344 #ifdef __cplusplus | 
|  | 345 } | 
|  | 346 #endif | 
|  | 347 | 
|  | 348 #endif /* __STM32F1xx_HAL_CONF_H */ | 
|  | 349 | 
|  | 350 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ |