port clang stm32: f1, f2, f3
This commit is contained in:
		
							
								
								
									
										10
									
								
								hw/bsp/stm32f3/boards/stm32f303disco/board.cmake
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								hw/bsp/stm32f3/boards/stm32f303disco/board.cmake
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,10 @@ | ||||
| set(MCU_VARIANT stm32f303xc) | ||||
| set(JLINK_DEVICE stm32f303vc) | ||||
|  | ||||
| set(LD_FILE_GNU ${CMAKE_CURRENT_LIST_DIR}/STM32F303VCTx_FLASH.ld) | ||||
|  | ||||
| function(update_board TARGET) | ||||
|   target_compile_definitions(${TARGET} PUBLIC | ||||
|     STM32F303xC | ||||
|     ) | ||||
| endfunction() | ||||
							
								
								
									
										61
									
								
								hw/bsp/stm32f3/boards/stm32f303disco/board.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										61
									
								
								hw/bsp/stm32f3/boards/stm32f303disco/board.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,61 @@ | ||||
| #ifndef BOARD_H | ||||
| #define BOARD_H | ||||
|  | ||||
| #define LED_PORT              GPIOE | ||||
| #define LED_PIN               GPIO_PIN_9 | ||||
| #define LED_STATE_ON          1 | ||||
|  | ||||
| #define BUTTON_PORT           GPIOA | ||||
| #define BUTTON_PIN            GPIO_PIN_0 | ||||
| #define BUTTON_STATE_ACTIVE   1 | ||||
|  | ||||
|  | ||||
| /** | ||||
|   * @brief  System Clock Configuration | ||||
|   *         The system Clock is configured as follow : | ||||
|   *            System Clock source            = PLL (HSE) | ||||
|   *            SYSCLK(Hz)                     = 72000000 | ||||
|   *            HCLK(Hz)                       = 72000000 | ||||
|   *            AHB Prescaler                  = 1 | ||||
|   *            APB1 Prescaler                 = 2 | ||||
|   *            APB2 Prescaler                 = 1 | ||||
|   *            HSE Frequency(Hz)              = 8000000 | ||||
|   *            HSE PREDIV                     = 1 | ||||
|   *            PLLMUL                         = RCC_PLL_MUL9 (9) | ||||
|   *            Flash Latency(WS)              = 2 | ||||
|   * @param  None | ||||
|   * @retval None | ||||
|   */ | ||||
| static inline void SystemClock_Config(void) { | ||||
|   RCC_ClkInitTypeDef RCC_ClkInitStruct; | ||||
|   RCC_OscInitTypeDef RCC_OscInitStruct; | ||||
|   RCC_PeriphCLKInitTypeDef RCC_PeriphClkInit; | ||||
|  | ||||
|   /* Enable HSE Oscillator and activate PLL with HSE as source */ | ||||
|   RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSE; | ||||
|   RCC_OscInitStruct.HSEState = RCC_HSE_ON; | ||||
|   RCC_OscInitStruct.HSEPredivValue = RCC_HSE_PREDIV_DIV1; | ||||
|   RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON; | ||||
|   RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSE; | ||||
|   RCC_OscInitStruct.PLL.PLLMUL = RCC_PLL_MUL9; | ||||
|   HAL_RCC_OscConfig(&RCC_OscInitStruct); | ||||
|  | ||||
|   /* Configures the USB clock */ | ||||
|   HAL_RCCEx_GetPeriphCLKConfig(&RCC_PeriphClkInit); | ||||
|   RCC_PeriphClkInit.USBClockSelection = RCC_USBCLKSOURCE_PLL_DIV1_5; | ||||
|   HAL_RCCEx_PeriphCLKConfig(&RCC_PeriphClkInit); | ||||
|  | ||||
|   /* Select PLL as system clock source and configure the HCLK, PCLK1 and PCLK2 | ||||
|   clocks dividers */ | ||||
|   RCC_ClkInitStruct.ClockType = (RCC_CLOCKTYPE_SYSCLK | RCC_CLOCKTYPE_HCLK | RCC_CLOCKTYPE_PCLK1 | RCC_CLOCKTYPE_PCLK2); | ||||
|   RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK; | ||||
|   RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1; | ||||
|   RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV2; | ||||
|   RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1; | ||||
|   HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_2); | ||||
|  | ||||
|   /* Enable Power Clock */ | ||||
|   __HAL_RCC_PWR_CLK_ENABLE(); | ||||
| } | ||||
|  | ||||
| #endif | ||||
| @@ -1,216 +0,0 @@ | ||||
| /* | ||||
|  * The MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2019 Ha Thach (tinyusb.org) | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * This file is part of the TinyUSB stack. | ||||
|  */ | ||||
|  | ||||
| #include "bsp/board_api.h" | ||||
| #include "stm32f3xx_hal.h" | ||||
|  | ||||
| //--------------------------------------------------------------------+ | ||||
| // Forward USB interrupt events to TinyUSB IRQ Handler | ||||
| //--------------------------------------------------------------------+ | ||||
|  | ||||
| // USB defaults to using interrupts 19, 20 and 42, however, this BSP sets the | ||||
| // SYSCFG_CFGR1.USB_IT_RMP bit remapping interrupts to 74, 75 and 76. | ||||
|  | ||||
| // FIXME: Do all three need to be handled, or just the LP one? | ||||
| // USB high-priority interrupt (Channel 74): Triggered only by a correct | ||||
| // transfer event for isochronous and double-buffer bulk transfer to reach | ||||
| // the highest possible transfer rate. | ||||
| void USB_HP_IRQHandler(void) | ||||
| { | ||||
|   tud_int_handler(0); | ||||
| } | ||||
|  | ||||
| // USB low-priority interrupt (Channel 75): Triggered by all USB events | ||||
| // (Correct transfer, USB reset, etc.). The firmware has to check the | ||||
| // interrupt source before serving the interrupt. | ||||
| void USB_LP_IRQHandler(void) | ||||
| { | ||||
|   tud_int_handler(0); | ||||
| } | ||||
|  | ||||
| // USB wakeup interrupt (Channel 76): Triggered by the wakeup event from the USB | ||||
| // Suspend mode. | ||||
| void USBWakeUp_RMP_IRQHandler(void) | ||||
| { | ||||
|   tud_int_handler(0); | ||||
| } | ||||
|  | ||||
| //--------------------------------------------------------------------+ | ||||
| // MACRO TYPEDEF CONSTANT ENUM | ||||
| //--------------------------------------------------------------------+ | ||||
|  | ||||
| #define LED_PORT              GPIOE | ||||
| #define LED_PIN               GPIO_PIN_9 | ||||
| #define LED_STATE_ON          1 | ||||
|  | ||||
| #define BUTTON_PORT           GPIOA | ||||
| #define BUTTON_PIN            GPIO_PIN_0 | ||||
| #define BUTTON_STATE_ACTIVE   1 | ||||
|  | ||||
|  | ||||
| /** | ||||
|   * @brief  System Clock Configuration | ||||
|   *         The system Clock is configured as follow : | ||||
|   *            System Clock source            = PLL (HSE) | ||||
|   *            SYSCLK(Hz)                     = 72000000 | ||||
|   *            HCLK(Hz)                       = 72000000 | ||||
|   *            AHB Prescaler                  = 1 | ||||
|   *            APB1 Prescaler                 = 2 | ||||
|   *            APB2 Prescaler                 = 1 | ||||
|   *            HSE Frequency(Hz)              = 8000000 | ||||
|   *            HSE PREDIV                     = 1 | ||||
|   *            PLLMUL                         = RCC_PLL_MUL9 (9) | ||||
|   *            Flash Latency(WS)              = 2 | ||||
|   * @param  None | ||||
|   * @retval None | ||||
|   */ | ||||
| static void SystemClock_Config(void) | ||||
| { | ||||
|   RCC_ClkInitTypeDef RCC_ClkInitStruct; | ||||
|   RCC_OscInitTypeDef RCC_OscInitStruct; | ||||
|   RCC_PeriphCLKInitTypeDef  RCC_PeriphClkInit; | ||||
|  | ||||
|   /* Enable HSE Oscillator and activate PLL with HSE as source */ | ||||
|   RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSE; | ||||
|   RCC_OscInitStruct.HSEState = RCC_HSE_ON; | ||||
|   RCC_OscInitStruct.HSEPredivValue = RCC_HSE_PREDIV_DIV1; | ||||
|   RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON; | ||||
|   RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSE; | ||||
|   RCC_OscInitStruct.PLL.PLLMUL = RCC_PLL_MUL9; | ||||
|   HAL_RCC_OscConfig(&RCC_OscInitStruct); | ||||
|  | ||||
|   /* Configures the USB clock */ | ||||
|   HAL_RCCEx_GetPeriphCLKConfig(&RCC_PeriphClkInit); | ||||
|   RCC_PeriphClkInit.USBClockSelection = RCC_USBCLKSOURCE_PLL_DIV1_5; | ||||
|   HAL_RCCEx_PeriphCLKConfig(&RCC_PeriphClkInit); | ||||
|  | ||||
|   /* Select PLL as system clock source and configure the HCLK, PCLK1 and PCLK2 | ||||
|   clocks dividers */ | ||||
|   RCC_ClkInitStruct.ClockType = (RCC_CLOCKTYPE_SYSCLK | RCC_CLOCKTYPE_HCLK | RCC_CLOCKTYPE_PCLK1 | RCC_CLOCKTYPE_PCLK2); | ||||
|   RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK; | ||||
|   RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1; | ||||
|   RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV2; | ||||
|   RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1; | ||||
|   HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_2); | ||||
|  | ||||
|   /* Enable Power Clock */ | ||||
|   __HAL_RCC_PWR_CLK_ENABLE(); | ||||
| } | ||||
|  | ||||
| void board_init(void) | ||||
| { | ||||
|   SystemClock_Config(); | ||||
|  | ||||
|   #if CFG_TUSB_OS  == OPT_OS_NONE | ||||
|   // 1ms tick timer | ||||
|   SysTick_Config(SystemCoreClock / 1000); | ||||
|   #endif | ||||
|  | ||||
|   // Remap the USB interrupts | ||||
|   __HAL_RCC_SYSCFG_CLK_ENABLE(); | ||||
|   __HAL_REMAPINTERRUPT_USB_ENABLE(); | ||||
|  | ||||
|   // LED | ||||
|   __HAL_RCC_GPIOE_CLK_ENABLE(); | ||||
|   GPIO_InitTypeDef  GPIO_InitStruct; | ||||
|   GPIO_InitStruct.Pin = LED_PIN; | ||||
|   GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP; | ||||
|   GPIO_InitStruct.Pull = GPIO_PULLUP; | ||||
|   GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH; | ||||
|   HAL_GPIO_Init(LED_PORT, &GPIO_InitStruct); | ||||
|  | ||||
|   // Button | ||||
|   __HAL_RCC_GPIOA_CLK_ENABLE(); | ||||
|   GPIO_InitStruct.Pin = BUTTON_PIN; | ||||
|   GPIO_InitStruct.Mode = GPIO_MODE_INPUT; | ||||
|   GPIO_InitStruct.Pull = GPIO_PULLDOWN; | ||||
|   GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH; | ||||
|   HAL_GPIO_Init(BUTTON_PORT, &GPIO_InitStruct); | ||||
|  | ||||
|   /* Configure USB DM and DP pins */ | ||||
|   __HAL_RCC_GPIOA_CLK_ENABLE(); | ||||
|   GPIO_InitStruct.Pin = (GPIO_PIN_11 | GPIO_PIN_12); | ||||
|   GPIO_InitStruct.Mode = GPIO_MODE_AF_PP; | ||||
|   GPIO_InitStruct.Pull = GPIO_NOPULL; | ||||
|   GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH; | ||||
|   GPIO_InitStruct.Alternate = GPIO_AF14_USB; | ||||
|   HAL_GPIO_Init(GPIOA, &GPIO_InitStruct); | ||||
|  | ||||
|   // Enable USB clock | ||||
|   __HAL_RCC_USB_CLK_ENABLE(); | ||||
| } | ||||
|  | ||||
| //--------------------------------------------------------------------+ | ||||
| // Board porting API | ||||
| //--------------------------------------------------------------------+ | ||||
|  | ||||
| void board_led_write(bool state) | ||||
| { | ||||
|   HAL_GPIO_WritePin(LED_PORT, LED_PIN, state ? LED_STATE_ON : (1-LED_STATE_ON)); | ||||
| } | ||||
|  | ||||
| uint32_t board_button_read(void) | ||||
| { | ||||
|   return BUTTON_STATE_ACTIVE == HAL_GPIO_ReadPin(BUTTON_PORT, BUTTON_PIN); | ||||
| } | ||||
|  | ||||
| int board_uart_read(uint8_t* buf, int len) | ||||
| { | ||||
|   (void) buf; (void) len; | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
| int board_uart_write(void const * buf, int len) | ||||
| { | ||||
|   (void) buf; (void) len; | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
| #if CFG_TUSB_OS  == OPT_OS_NONE | ||||
| volatile uint32_t system_ticks = 0; | ||||
| void SysTick_Handler (void) | ||||
| { | ||||
|   HAL_IncTick(); | ||||
|   system_ticks++; | ||||
| } | ||||
|  | ||||
| uint32_t board_millis(void) | ||||
| { | ||||
|   return system_ticks; | ||||
| } | ||||
| #endif | ||||
|  | ||||
| void HardFault_Handler (void) | ||||
| { | ||||
|   asm("bkpt"); | ||||
| } | ||||
|  | ||||
| // Required by __libc_init_array in startup code if we are compiling using | ||||
| // -nostdlib/-nostartfiles. | ||||
| void _init(void) | ||||
| { | ||||
|  | ||||
| } | ||||
| @@ -1,357 +0,0 @@ | ||||
| /** | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32f3xx_hal_conf.h | ||||
|   * @author  MCD Application Team | ||||
|   * @brief   HAL configuration file. | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© Copyright (c) 2016 STMicroelectronics. | ||||
|   * All rights reserved.</center></h2> | ||||
|   * | ||||
|   * This software component is licensed by ST under BSD 3-Clause license, | ||||
|   * the "License"; You may not use this file except in compliance with the | ||||
|   * License. You may obtain a copy of the License at: | ||||
|   *                        opensource.org/licenses/BSD-3-Clause | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
|  | ||||
| /* Define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef __STM32F3xx_HAL_CONF_H | ||||
| #define __STM32F3xx_HAL_CONF_H | ||||
|  | ||||
| #ifdef __cplusplus | ||||
|  extern "C" { | ||||
| #endif | ||||
|  | ||||
| /* Exported types ------------------------------------------------------------*/ | ||||
| /* Exported constants --------------------------------------------------------*/ | ||||
|  | ||||
| /* ########################## Module Selection ############################## */ | ||||
| /** | ||||
|   * @brief This is the list of modules to be used in the HAL driver | ||||
|   */ | ||||
| #define HAL_MODULE_ENABLED | ||||
| /* #define HAL_ADC_MODULE_ENABLED */ | ||||
| /* #define HAL_CAN_MODULE_ENABLED */ | ||||
| /* #define HAL_CAN_LEGACY_MODULE_ENABLED */ | ||||
| /* #define HAL_CEC_MODULE_ENABLED */ | ||||
| /* #define HAL_COMP_MODULE_ENABLED */ | ||||
| #define HAL_CORTEX_MODULE_ENABLED | ||||
| /* #define HAL_CRC_MODULE_ENABLED */ | ||||
| /* #define HAL_DAC_MODULE_ENABLED */ | ||||
| #define HAL_DMA_MODULE_ENABLED | ||||
| #define HAL_FLASH_MODULE_ENABLED | ||||
| /* #define HAL_SRAM_MODULE_ENABLED */ | ||||
| /* #define HAL_NOR_MODULE_ENABLED */ | ||||
| /* #define HAL_NAND_MODULE_ENABLED */ | ||||
| /* #define HAL_PCCARD_MODULE_ENABLED */ | ||||
| #define HAL_GPIO_MODULE_ENABLED | ||||
| /* #define HAL_EXTI_MODULE_ENABLED */ | ||||
| /* #define HAL_HRTIM_MODULE_ENABLED */ | ||||
| /* #define HAL_I2C_MODULE_ENABLED */ | ||||
| /* #define HAL_I2S_MODULE_ENABLED */ | ||||
| /* #define HAL_IRDA_MODULE_ENABLED */ | ||||
| /* #define HAL_IWDG_MODULE_ENABLED */ | ||||
| /* #define HAL_OPAMP_MODULE_ENABLED */ | ||||
| /* #define HAL_PCD_MODULE_ENABLED */ | ||||
| /* #define HAL_PWR_MODULE_ENABLED */ | ||||
| #define HAL_RCC_MODULE_ENABLED | ||||
| /* #define HAL_RTC_MODULE_ENABLED */ | ||||
| /* #define HAL_SDADC_MODULE_ENABLED */ | ||||
| /* #define HAL_SMARTCARD_MODULE_ENABLED */ | ||||
| /* #define HAL_SMBUS_MODULE_ENABLED */ | ||||
| /* #define HAL_SPI_MODULE_ENABLED */ | ||||
| /* #define HAL_TIM_MODULE_ENABLED */ | ||||
| /* #define HAL_TSC_MODULE_ENABLED */ | ||||
| #define HAL_UART_MODULE_ENABLED | ||||
| /* #define HAL_USART_MODULE_ENABLED */ | ||||
| /* #define HAL_WWDG_MODULE_ENABLED */ | ||||
|  | ||||
| /* ########################## HSE/HSI Values adaptation ##################### */ | ||||
| /** | ||||
|   * @brief Adjust the value of External High Speed oscillator (HSE) used in your application. | ||||
|   *        This value is used by the RCC HAL module to compute the system frequency | ||||
|   *        (when HSE is used as system clock source, directly or through the PLL). | ||||
|   */ | ||||
| #if !defined  (HSE_VALUE) | ||||
|   #define HSE_VALUE    (8000000U) /*!< Value of the External oscillator in Hz */ | ||||
| #endif /* HSE_VALUE */ | ||||
|  | ||||
| /** | ||||
|   * @brief In the following line adjust the External High Speed oscillator (HSE) Startup | ||||
|   *        Timeout value | ||||
|   */ | ||||
| #if !defined  (HSE_STARTUP_TIMEOUT) | ||||
|   #define HSE_STARTUP_TIMEOUT    (100U)   /*!< Time out for HSE start up, in ms */ | ||||
| #endif /* HSE_STARTUP_TIMEOUT */ | ||||
|  | ||||
| /** | ||||
|   * @brief Internal High Speed oscillator (HSI) value. | ||||
|   *        This value is used by the RCC HAL module to compute the system frequency | ||||
|   *        (when HSI is used as system clock source, directly or through the PLL). | ||||
|   */ | ||||
| #if !defined  (HSI_VALUE) | ||||
|   #define HSI_VALUE    (8000000U) /*!< Value of the Internal oscillator in Hz*/ | ||||
| #endif /* HSI_VALUE */ | ||||
|  | ||||
| /** | ||||
|   * @brief In the following line adjust the Internal High Speed oscillator (HSI) Startup | ||||
|   *        Timeout value | ||||
|   */ | ||||
| #if !defined  (HSI_STARTUP_TIMEOUT) | ||||
|  #define HSI_STARTUP_TIMEOUT   (5000U) /*!< Time out for HSI start up */ | ||||
| #endif /* HSI_STARTUP_TIMEOUT */ | ||||
|  | ||||
| /** | ||||
|   * @brief Internal Low Speed oscillator (LSI) value. | ||||
|   */ | ||||
| #if !defined  (LSI_VALUE) | ||||
|  #define LSI_VALUE  (40000U) | ||||
| #endif /* LSI_VALUE */                      /*!< Value of the Internal Low Speed oscillator in Hz | ||||
|                                              The real value may vary depending on the variations | ||||
|                                              in voltage and temperature.  */ | ||||
| /** | ||||
|   * @brief External Low Speed oscillator (LSE) value. | ||||
|   */ | ||||
| #if !defined  (LSE_VALUE) | ||||
|  #define LSE_VALUE  (32768U)    /*!< Value of the External Low Speed oscillator in Hz */ | ||||
| #endif /* LSE_VALUE */ | ||||
|  | ||||
| /** | ||||
|   * @brief Time out for LSE start up value in ms. | ||||
|   */ | ||||
| #if !defined  (LSE_STARTUP_TIMEOUT) | ||||
|   #define LSE_STARTUP_TIMEOUT    (5000U)   /*!< Time out for LSE start up, in ms */ | ||||
| #endif /* LSE_STARTUP_TIMEOUT */ | ||||
|  | ||||
| /** | ||||
|   * @brief External clock source for I2S peripheral | ||||
|   *        This value is used by the I2S HAL module to compute the I2S clock source | ||||
|   *        frequency, this source is inserted directly through I2S_CKIN pad. | ||||
|   *        - External clock generated through external PLL component on EVAL 303 (based on MCO or crystal) | ||||
|   *        - External clock not generated on EVAL 373 | ||||
|   */ | ||||
| #if !defined  (EXTERNAL_CLOCK_VALUE) | ||||
|   #define EXTERNAL_CLOCK_VALUE    (8000000U) /*!< Value of the External oscillator in Hz*/ | ||||
| #endif /* EXTERNAL_CLOCK_VALUE */ | ||||
|  | ||||
| /* Tip: To avoid modifying this file each time you need to use different HSE, | ||||
|    ===  you can define the HSE value in your toolchain compiler preprocessor. */ | ||||
|  | ||||
| /* ########################### System Configuration ######################### */ | ||||
| /** | ||||
|   * @brief This is the HAL system configuration section | ||||
|   */ | ||||
| #define  VDD_VALUE                    (3300U) /*!< Value of VDD in mv */ | ||||
| #define  TICK_INT_PRIORITY            ((uint32_t)(1U<<__NVIC_PRIO_BITS) - 1U)   /*!< tick interrupt priority (lowest by default) */ | ||||
| #define  USE_RTOS                     0U | ||||
| #define  PREFETCH_ENABLE              1U | ||||
| #define  INSTRUCTION_CACHE_ENABLE     0U | ||||
| #define  DATA_CACHE_ENABLE            0U | ||||
| #define  USE_SPI_CRC                  1U | ||||
|  | ||||
| #define  USE_HAL_ADC_REGISTER_CALLBACKS         0U /* ADC register callback disabled       */ | ||||
| #define  USE_HAL_CAN_REGISTER_CALLBACKS         0U /* CAN register callback disabled       */ | ||||
| #define  USE_HAL_COMP_REGISTER_CALLBACKS        0U /* COMP register callback disabled      */ | ||||
| #define  USE_HAL_CEC_REGISTER_CALLBACKS         0U /* CEC register callback disabled       */ | ||||
| #define  USE_HAL_DAC_REGISTER_CALLBACKS         0U /* DAC register callback disabled       */ | ||||
| #define  USE_HAL_SRAM_REGISTER_CALLBACKS        0U /* SRAM register callback disabled      */ | ||||
| #define  USE_HAL_SMBUS_REGISTER_CALLBACKS       0U /* SMBUS register callback disabled     */ | ||||
| #define  USE_HAL_SDADC_REGISTER_CALLBACKS       0U /* SDADC register callback disabled     */ | ||||
| #define  USE_HAL_NAND_REGISTER_CALLBACKS        0U /* NAND register callback disabled      */ | ||||
| #define  USE_HAL_NOR_REGISTER_CALLBACKS         0U /* NOR register callback disabled       */ | ||||
| #define  USE_HAL_PCCARD_REGISTER_CALLBACKS      0U /* PCCARD register callback disabled    */ | ||||
| #define  USE_HAL_HRTIM_REGISTER_CALLBACKS       0U /* HRTIM register callback disabled     */ | ||||
| #define  USE_HAL_I2C_REGISTER_CALLBACKS         0U /* I2C register callback disabled       */ | ||||
| #define  USE_HAL_UART_REGISTER_CALLBACKS        0U /* UART register callback disabled      */ | ||||
| #define  USE_HAL_USART_REGISTER_CALLBACKS       0U /* USART register callback disabled     */ | ||||
| #define  USE_HAL_IRDA_REGISTER_CALLBACKS        0U /* IRDA register callback disabled      */ | ||||
| #define  USE_HAL_SMARTCARD_REGISTER_CALLBACKS   0U /* SMARTCARD register callback disabled */ | ||||
| #define  USE_HAL_WWDG_REGISTER_CALLBACKS        0U /* WWDG register callback disabled      */ | ||||
| #define  USE_HAL_OPAMP_REGISTER_CALLBACKS       0U /* OPAMP register callback disabled     */ | ||||
| #define  USE_HAL_RTC_REGISTER_CALLBACKS         0U /* RTC register callback disabled       */ | ||||
| #define  USE_HAL_SPI_REGISTER_CALLBACKS         0U /* SPI register callback disabled       */ | ||||
| #define  USE_HAL_I2S_REGISTER_CALLBACKS         0U /* I2S register callback disabled       */ | ||||
| #define  USE_HAL_TIM_REGISTER_CALLBACKS         0U /* TIM register callback disabled       */ | ||||
| #define  USE_HAL_TSC_REGISTER_CALLBACKS         0U /* TSC register callback disabled       */ | ||||
| #define  USE_HAL_PCD_REGISTER_CALLBACKS         0U /* PCD register callback disabled       */ | ||||
|  | ||||
| /* ########################## Assert Selection ############################## */ | ||||
| /** | ||||
|   * @brief Uncomment the line below to expanse the "assert_param" macro in the | ||||
|   *        HAL drivers code | ||||
|   */ | ||||
| /*#define USE_FULL_ASSERT    1U*/ | ||||
|  | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| /** | ||||
|   * @brief Include module's header file | ||||
|   */ | ||||
|  | ||||
| #ifdef HAL_RCC_MODULE_ENABLED | ||||
|  #include "stm32f3xx_hal_rcc.h" | ||||
| #endif /* HAL_RCC_MODULE_ENABLED */ | ||||
|  | ||||
| #ifdef HAL_GPIO_MODULE_ENABLED | ||||
|  #include "stm32f3xx_hal_gpio.h" | ||||
| #endif /* HAL_GPIO_MODULE_ENABLED */ | ||||
|  | ||||
| #ifdef HAL_EXTI_MODULE_ENABLED | ||||
|   #include "stm32f3xx_hal_exti.h" | ||||
| #endif /* HAL_EXTI_MODULE_ENABLED */ | ||||
|  | ||||
| #ifdef HAL_DMA_MODULE_ENABLED | ||||
|   #include "stm32f3xx_hal_dma.h" | ||||
| #endif /* HAL_DMA_MODULE_ENABLED */ | ||||
|  | ||||
| #ifdef HAL_CORTEX_MODULE_ENABLED | ||||
|  #include "stm32f3xx_hal_cortex.h" | ||||
| #endif /* HAL_CORTEX_MODULE_ENABLED */ | ||||
|  | ||||
| #ifdef HAL_ADC_MODULE_ENABLED | ||||
|  #include "stm32f3xx_hal_adc.h" | ||||
| #endif /* HAL_ADC_MODULE_ENABLED */ | ||||
|  | ||||
| #ifdef HAL_CAN_MODULE_ENABLED | ||||
|  #include "stm32f3xx_hal_can.h" | ||||
| #endif /* HAL_CAN_MODULE_ENABLED */ | ||||
|  | ||||
| #ifdef HAL_CAN_LEGACY_MODULE_ENABLED | ||||
|  #include "stm32f3xx_hal_can_legacy.h" | ||||
| #endif /* HAL_CAN_LEGACY_MODULE_ENABLED */ | ||||
|  | ||||
| #ifdef HAL_CEC_MODULE_ENABLED | ||||
|  #include "stm32f3xx_hal_cec.h" | ||||
| #endif /* HAL_CEC_MODULE_ENABLED */ | ||||
|  | ||||
| #ifdef HAL_COMP_MODULE_ENABLED | ||||
|  #include "stm32f3xx_hal_comp.h" | ||||
| #endif /* HAL_COMP_MODULE_ENABLED */ | ||||
|  | ||||
| #ifdef HAL_CRC_MODULE_ENABLED | ||||
|  #include "stm32f3xx_hal_crc.h" | ||||
| #endif /* HAL_CRC_MODULE_ENABLED */ | ||||
|  | ||||
| #ifdef HAL_DAC_MODULE_ENABLED | ||||
|  #include "stm32f3xx_hal_dac.h" | ||||
| #endif /* HAL_DAC_MODULE_ENABLED */ | ||||
|  | ||||
| #ifdef HAL_FLASH_MODULE_ENABLED | ||||
|  #include "stm32f3xx_hal_flash.h" | ||||
| #endif /* HAL_FLASH_MODULE_ENABLED */ | ||||
|  | ||||
| #ifdef HAL_SRAM_MODULE_ENABLED | ||||
|   #include "stm32f3xx_hal_sram.h" | ||||
| #endif /* HAL_SRAM_MODULE_ENABLED */ | ||||
|  | ||||
| #ifdef HAL_NOR_MODULE_ENABLED | ||||
|   #include "stm32f3xx_hal_nor.h" | ||||
| #endif /* HAL_NOR_MODULE_ENABLED */ | ||||
|  | ||||
| #ifdef HAL_NAND_MODULE_ENABLED | ||||
|   #include "stm32f3xx_hal_nand.h" | ||||
| #endif /* HAL_NAND_MODULE_ENABLED */ | ||||
|  | ||||
| #ifdef HAL_PCCARD_MODULE_ENABLED | ||||
|   #include "stm32f3xx_hal_pccard.h" | ||||
| #endif /* HAL_PCCARD_MODULE_ENABLED */ | ||||
|  | ||||
| #ifdef HAL_HRTIM_MODULE_ENABLED | ||||
|  #include "stm32f3xx_hal_hrtim.h" | ||||
| #endif /* HAL_HRTIM_MODULE_ENABLED */ | ||||
|  | ||||
| #ifdef HAL_I2C_MODULE_ENABLED | ||||
|  #include "stm32f3xx_hal_i2c.h" | ||||
| #endif /* HAL_I2C_MODULE_ENABLED */ | ||||
|  | ||||
| #ifdef HAL_I2S_MODULE_ENABLED | ||||
|  #include "stm32f3xx_hal_i2s.h" | ||||
| #endif /* HAL_I2S_MODULE_ENABLED */ | ||||
|  | ||||
| #ifdef HAL_IRDA_MODULE_ENABLED | ||||
|  #include "stm32f3xx_hal_irda.h" | ||||
| #endif /* HAL_IRDA_MODULE_ENABLED */ | ||||
|  | ||||
| #ifdef HAL_IWDG_MODULE_ENABLED | ||||
|  #include "stm32f3xx_hal_iwdg.h" | ||||
| #endif /* HAL_IWDG_MODULE_ENABLED */ | ||||
|  | ||||
| #ifdef HAL_OPAMP_MODULE_ENABLED | ||||
|  #include "stm32f3xx_hal_opamp.h" | ||||
| #endif /* HAL_OPAMP_MODULE_ENABLED */ | ||||
|  | ||||
| #ifdef HAL_PCD_MODULE_ENABLED | ||||
|  #include "stm32f3xx_hal_pcd.h" | ||||
| #endif /* HAL_PCD_MODULE_ENABLED */ | ||||
|  | ||||
| #ifdef HAL_PWR_MODULE_ENABLED | ||||
|  #include "stm32f3xx_hal_pwr.h" | ||||
| #endif /* HAL_PWR_MODULE_ENABLED */ | ||||
|  | ||||
| #ifdef HAL_RTC_MODULE_ENABLED | ||||
|  #include "stm32f3xx_hal_rtc.h" | ||||
| #endif /* HAL_RTC_MODULE_ENABLED */ | ||||
|  | ||||
| #ifdef HAL_SDADC_MODULE_ENABLED | ||||
|  #include "stm32f3xx_hal_sdadc.h" | ||||
| #endif /* HAL_SDADC_MODULE_ENABLED */ | ||||
|  | ||||
| #ifdef HAL_SMARTCARD_MODULE_ENABLED | ||||
|  #include "stm32f3xx_hal_smartcard.h" | ||||
| #endif /* HAL_SMARTCARD_MODULE_ENABLED */ | ||||
|  | ||||
| #ifdef HAL_SMBUS_MODULE_ENABLED | ||||
|  #include "stm32f3xx_hal_smbus.h" | ||||
| #endif /* HAL_SMBUS_MODULE_ENABLED */ | ||||
|  | ||||
| #ifdef HAL_SPI_MODULE_ENABLED | ||||
|  #include "stm32f3xx_hal_spi.h" | ||||
| #endif /* HAL_SPI_MODULE_ENABLED */ | ||||
|  | ||||
| #ifdef HAL_TIM_MODULE_ENABLED | ||||
|  #include "stm32f3xx_hal_tim.h" | ||||
| #endif /* HAL_TIM_MODULE_ENABLED */ | ||||
|  | ||||
| #ifdef HAL_TSC_MODULE_ENABLED | ||||
|  #include "stm32f3xx_hal_tsc.h" | ||||
| #endif /* HAL_TSC_MODULE_ENABLED */ | ||||
|  | ||||
| #ifdef HAL_UART_MODULE_ENABLED | ||||
|  #include "stm32f3xx_hal_uart.h" | ||||
| #endif /* HAL_UART_MODULE_ENABLED */ | ||||
|  | ||||
| #ifdef HAL_USART_MODULE_ENABLED | ||||
|  #include "stm32f3xx_hal_usart.h" | ||||
| #endif /* HAL_USART_MODULE_ENABLED */ | ||||
|  | ||||
| #ifdef HAL_WWDG_MODULE_ENABLED | ||||
|  #include "stm32f3xx_hal_wwdg.h" | ||||
| #endif /* HAL_WWDG_MODULE_ENABLED */ | ||||
|  | ||||
| /* Exported macro ------------------------------------------------------------*/ | ||||
| #ifdef  USE_FULL_ASSERT | ||||
| /** | ||||
|   * @brief  The assert_param macro is used for function's parameters check. | ||||
|   * @param  expr If expr is false, it calls assert_failed function | ||||
|   *         which reports the name of the source file and the source | ||||
|   *         line number of the call that failed. | ||||
|   *         If expr is true, it returns no value. | ||||
|   * @retval None | ||||
|   */ | ||||
|   #define assert_param(expr) ((expr) ? (void)0U : assert_failed((uint8_t *)__FILE__, __LINE__)) | ||||
| /* Exported functions ------------------------------------------------------- */ | ||||
|   void assert_failed(uint8_t* file, uint32_t line); | ||||
| #else | ||||
|   #define assert_param(expr) ((void)0U) | ||||
| #endif /* USE_FULL_ASSERT */ | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
|  | ||||
| #endif /* __STM32F3xx_HAL_CONF_H */ | ||||
|  | ||||
|  | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
		Reference in New Issue
	
	Block a user
	 hathach
					hathach