Initial commit
This commit is contained in:
		
							
								
								
									
										388
									
								
								Core/Src/main.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										388
									
								
								Core/Src/main.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,388 @@ | ||||
| /* USER CODE BEGIN Header */ | ||||
| /** | ||||
|   ****************************************************************************** | ||||
|   * @file           : main.c | ||||
|   * @brief          : Main program body | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * Copyright (c) 2022 STMicroelectronics. | ||||
|   * All rights reserved. | ||||
|   * | ||||
|   * This software is licensed under terms that can be found in the LICENSE file | ||||
|   * in the root directory of this software component. | ||||
|   * If no LICENSE file comes with this software, it is provided AS-IS. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| /* USER CODE END Header */ | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "main.h" | ||||
|  | ||||
| /* Private includes ----------------------------------------------------------*/ | ||||
| /* USER CODE BEGIN Includes */ | ||||
| #include <string.h> | ||||
| #include <stdio.h> | ||||
| /* USER CODE END Includes */ | ||||
|  | ||||
| /* Private typedef -----------------------------------------------------------*/ | ||||
| /* USER CODE BEGIN PTD */ | ||||
|  | ||||
| /* USER CODE END PTD */ | ||||
|  | ||||
| /* Private define ------------------------------------------------------------*/ | ||||
| /* USER CODE BEGIN PD */ | ||||
| /* USER CODE END PD */ | ||||
|  | ||||
| /* Private macro -------------------------------------------------------------*/ | ||||
| /* USER CODE BEGIN PM */ | ||||
|  | ||||
| /* USER CODE END PM */ | ||||
|  | ||||
| /* Private variables ---------------------------------------------------------*/ | ||||
| TIM_HandleTypeDef htim2; | ||||
| TIM_HandleTypeDef htim4; | ||||
|  | ||||
| UART_HandleTypeDef huart1; | ||||
|  | ||||
| /* USER CODE BEGIN PV */ | ||||
| OptStates opt_state = STOP; | ||||
| /* USER CODE END PV */ | ||||
|  | ||||
| /* Private function prototypes -----------------------------------------------*/ | ||||
| void SystemClock_Config(void); | ||||
| static void MX_GPIO_Init(void); | ||||
| static void MX_TIM4_Init(void); | ||||
| static void MX_USART1_UART_Init(void); | ||||
| static void MX_TIM2_Init(void); | ||||
| /* USER CODE BEGIN PFP */ | ||||
|  | ||||
| /* USER CODE END PFP */ | ||||
|  | ||||
| /* Private user code ---------------------------------------------------------*/ | ||||
| /* USER CODE BEGIN 0 */ | ||||
|  | ||||
| /* USER CODE END 0 */ | ||||
|  | ||||
| /** | ||||
|   * @brief  The application entry point. | ||||
|   * @retval int | ||||
|   */ | ||||
| int main(void) | ||||
| { | ||||
|   /* USER CODE BEGIN 1 */ | ||||
|  | ||||
|   /* USER CODE END 1 */ | ||||
|  | ||||
|   /* MCU Configuration--------------------------------------------------------*/ | ||||
|  | ||||
|   /* Reset of all peripherals, Initializes the Flash interface and the Systick. */ | ||||
|   HAL_Init(); | ||||
|  | ||||
|   /* USER CODE BEGIN Init */ | ||||
|  | ||||
|   /* USER CODE END Init */ | ||||
|  | ||||
|   /* Configure the system clock */ | ||||
|   SystemClock_Config(); | ||||
|  | ||||
|   /* USER CODE BEGIN SysInit */ | ||||
|  | ||||
|   /* USER CODE END SysInit */ | ||||
|  | ||||
|   /* Initialize all configured peripherals */ | ||||
|   MX_GPIO_Init(); | ||||
|   MX_TIM4_Init(); | ||||
|   MX_USART1_UART_Init(); | ||||
|   MX_TIM2_Init(); | ||||
|   /* USER CODE BEGIN 2 */ | ||||
|     HAL_TIM_Base_Start_IT(&htim2); | ||||
|     HAL_TIM_IC_Start_IT(&htim2, TIM_CHANNEL_1); | ||||
|     HAL_TIM_PWM_Start(&htim4, TIM_CHANNEL_1); | ||||
|   /* USER CODE END 2 */ | ||||
|  | ||||
|   /* Infinite loop */ | ||||
|   /* USER CODE BEGIN WHILE */ | ||||
|   OptStates curr_state = STOP; | ||||
|   const char* start_message = "DETECT\n"; | ||||
|   int counter = 0; | ||||
|  | ||||
|   while (1) { | ||||
|       OptStates local_state = opt_state; | ||||
|       if (local_state != curr_state) { | ||||
|           if (local_state == START) { | ||||
|               HAL_UART_Transmit(&huart1, (uint8_t*)start_message, | ||||
|                                 strlen(start_message), HAL_TIMEOUT); | ||||
|           } else { | ||||
|               char buffer[16]; | ||||
|               counter++; | ||||
|               sprintf(buffer, "RAISE (%d)\n", counter); | ||||
|               HAL_UART_Transmit(&huart1, (uint8_t*)buffer, | ||||
|                                 strlen(buffer), HAL_TIMEOUT); | ||||
|           } | ||||
|           curr_state = local_state; | ||||
|       } | ||||
|   } | ||||
|  | ||||
|     /* USER CODE END WHILE */ | ||||
|  | ||||
|     /* USER CODE BEGIN 3 */ | ||||
|   /* USER CODE END 3 */ | ||||
| } | ||||
|  | ||||
| /** | ||||
|   * @brief System Clock Configuration | ||||
|   * @retval None | ||||
|   */ | ||||
| void SystemClock_Config(void) | ||||
| { | ||||
|   RCC_OscInitTypeDef RCC_OscInitStruct = {0}; | ||||
|   RCC_ClkInitTypeDef RCC_ClkInitStruct = {0}; | ||||
|  | ||||
|   /** Initializes the RCC Oscillators according to the specified parameters | ||||
|   * in the RCC_OscInitTypeDef structure. | ||||
|   */ | ||||
|   RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSE; | ||||
|   RCC_OscInitStruct.HSEState = RCC_HSE_ON; | ||||
|   RCC_OscInitStruct.HSEPredivValue = RCC_HSE_PREDIV_DIV1; | ||||
|   RCC_OscInitStruct.HSIState = RCC_HSI_ON; | ||||
|   RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON; | ||||
|   RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSE; | ||||
|   RCC_OscInitStruct.PLL.PLLMUL = RCC_PLL_MUL9; | ||||
|   if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK) | ||||
|   { | ||||
|     Error_Handler(); | ||||
|   } | ||||
|   /** Initializes the CPU, AHB and APB buses clocks | ||||
|   */ | ||||
|   RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK | ||||
|                               |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; | ||||
|  | ||||
|   if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_2) != HAL_OK) | ||||
|   { | ||||
|     Error_Handler(); | ||||
|   } | ||||
| } | ||||
|  | ||||
| /** | ||||
|   * @brief TIM2 Initialization Function | ||||
|   * @param None | ||||
|   * @retval None | ||||
|   */ | ||||
| static void MX_TIM2_Init(void) | ||||
| { | ||||
|  | ||||
|   /* USER CODE BEGIN TIM2_Init 0 */ | ||||
|  | ||||
|   /* USER CODE END TIM2_Init 0 */ | ||||
|  | ||||
|   TIM_ClockConfigTypeDef sClockSourceConfig = {0}; | ||||
|   TIM_MasterConfigTypeDef sMasterConfig = {0}; | ||||
|   TIM_IC_InitTypeDef sConfigIC = {0}; | ||||
|  | ||||
|   /* USER CODE BEGIN TIM2_Init 1 */ | ||||
|  | ||||
|   /* USER CODE END TIM2_Init 1 */ | ||||
|   htim2.Instance = TIM2; | ||||
|   htim2.Init.Prescaler = 72; | ||||
|   htim2.Init.CounterMode = TIM_COUNTERMODE_UP; | ||||
|   htim2.Init.Period = 5000; | ||||
|   htim2.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1; | ||||
|   htim2.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_ENABLE; | ||||
|   if (HAL_TIM_Base_Init(&htim2) != HAL_OK) | ||||
|   { | ||||
|     Error_Handler(); | ||||
|   } | ||||
|   sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL; | ||||
|   if (HAL_TIM_ConfigClockSource(&htim2, &sClockSourceConfig) != HAL_OK) | ||||
|   { | ||||
|     Error_Handler(); | ||||
|   } | ||||
|   if (HAL_TIM_IC_Init(&htim2) != HAL_OK) | ||||
|   { | ||||
|     Error_Handler(); | ||||
|   } | ||||
|   sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET; | ||||
|   sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE; | ||||
|   if (HAL_TIMEx_MasterConfigSynchronization(&htim2, &sMasterConfig) != HAL_OK) | ||||
|   { | ||||
|     Error_Handler(); | ||||
|   } | ||||
|   sConfigIC.ICPolarity = TIM_INPUTCHANNELPOLARITY_RISING; | ||||
|   sConfigIC.ICSelection = TIM_ICSELECTION_DIRECTTI; | ||||
|   sConfigIC.ICPrescaler = TIM_ICPSC_DIV1; | ||||
|   sConfigIC.ICFilter = 1; | ||||
|   if (HAL_TIM_IC_ConfigChannel(&htim2, &sConfigIC, TIM_CHANNEL_1) != HAL_OK) | ||||
|   { | ||||
|     Error_Handler(); | ||||
|   } | ||||
|   /* USER CODE BEGIN TIM2_Init 2 */ | ||||
|  | ||||
|   /* USER CODE END TIM2_Init 2 */ | ||||
|  | ||||
| } | ||||
|  | ||||
| /** | ||||
|   * @brief TIM4 Initialization Function | ||||
|   * @param None | ||||
|   * @retval None | ||||
|   */ | ||||
| static void MX_TIM4_Init(void) | ||||
| { | ||||
|  | ||||
|   /* USER CODE BEGIN TIM4_Init 0 */ | ||||
|  | ||||
|   /* USER CODE END TIM4_Init 0 */ | ||||
|  | ||||
|   TIM_ClockConfigTypeDef sClockSourceConfig = {0}; | ||||
|   TIM_MasterConfigTypeDef sMasterConfig = {0}; | ||||
|   TIM_OC_InitTypeDef sConfigOC = {0}; | ||||
|  | ||||
|   /* USER CODE BEGIN TIM4_Init 1 */ | ||||
|  | ||||
|   /* USER CODE END TIM4_Init 1 */ | ||||
|   htim4.Instance = TIM4; | ||||
|   htim4.Init.Prescaler = 72; | ||||
|   htim4.Init.CounterMode = TIM_COUNTERMODE_UP; | ||||
|   htim4.Init.Period = 1000; | ||||
|   htim4.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1; | ||||
|   htim4.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE; | ||||
|   if (HAL_TIM_Base_Init(&htim4) != HAL_OK) | ||||
|   { | ||||
|     Error_Handler(); | ||||
|   } | ||||
|   sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL; | ||||
|   if (HAL_TIM_ConfigClockSource(&htim4, &sClockSourceConfig) != HAL_OK) | ||||
|   { | ||||
|     Error_Handler(); | ||||
|   } | ||||
|   if (HAL_TIM_PWM_Init(&htim4) != HAL_OK) | ||||
|   { | ||||
|     Error_Handler(); | ||||
|   } | ||||
|   sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET; | ||||
|   sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE; | ||||
|   if (HAL_TIMEx_MasterConfigSynchronization(&htim4, &sMasterConfig) != HAL_OK) | ||||
|   { | ||||
|     Error_Handler(); | ||||
|   } | ||||
|   sConfigOC.OCMode = TIM_OCMODE_PWM1; | ||||
|   sConfigOC.Pulse = 500; | ||||
|   sConfigOC.OCPolarity = TIM_OCPOLARITY_HIGH; | ||||
|   sConfigOC.OCFastMode = TIM_OCFAST_DISABLE; | ||||
|   if (HAL_TIM_PWM_ConfigChannel(&htim4, &sConfigOC, TIM_CHANNEL_1) != HAL_OK) | ||||
|   { | ||||
|     Error_Handler(); | ||||
|   } | ||||
|   /* USER CODE BEGIN TIM4_Init 2 */ | ||||
|  | ||||
|   /* USER CODE END TIM4_Init 2 */ | ||||
|   HAL_TIM_MspPostInit(&htim4); | ||||
|  | ||||
| } | ||||
|  | ||||
| /** | ||||
|   * @brief USART1 Initialization Function | ||||
|   * @param None | ||||
|   * @retval None | ||||
|   */ | ||||
| static void MX_USART1_UART_Init(void) | ||||
| { | ||||
|  | ||||
|   /* USER CODE BEGIN USART1_Init 0 */ | ||||
|  | ||||
|   /* USER CODE END USART1_Init 0 */ | ||||
|  | ||||
|   /* USER CODE BEGIN USART1_Init 1 */ | ||||
|  | ||||
|   /* USER CODE END USART1_Init 1 */ | ||||
|   huart1.Instance = USART1; | ||||
|   huart1.Init.BaudRate = 115200; | ||||
|   huart1.Init.WordLength = UART_WORDLENGTH_8B; | ||||
|   huart1.Init.StopBits = UART_STOPBITS_1; | ||||
|   huart1.Init.Parity = UART_PARITY_NONE; | ||||
|   huart1.Init.Mode = UART_MODE_TX_RX; | ||||
|   huart1.Init.HwFlowCtl = UART_HWCONTROL_NONE; | ||||
|   huart1.Init.OverSampling = UART_OVERSAMPLING_16; | ||||
|   if (HAL_UART_Init(&huart1) != HAL_OK) | ||||
|   { | ||||
|     Error_Handler(); | ||||
|   } | ||||
|   /* USER CODE BEGIN USART1_Init 2 */ | ||||
|  | ||||
|   /* USER CODE END USART1_Init 2 */ | ||||
|  | ||||
| } | ||||
|  | ||||
| /** | ||||
|   * @brief GPIO Initialization Function | ||||
|   * @param None | ||||
|   * @retval None | ||||
|   */ | ||||
| static void MX_GPIO_Init(void) | ||||
| { | ||||
|   GPIO_InitTypeDef GPIO_InitStruct = {0}; | ||||
|  | ||||
|   /* GPIO Ports Clock Enable */ | ||||
|   __HAL_RCC_GPIOD_CLK_ENABLE(); | ||||
|   __HAL_RCC_GPIOA_CLK_ENABLE(); | ||||
|   __HAL_RCC_GPIOB_CLK_ENABLE(); | ||||
|  | ||||
|   /*Configure GPIO pin Output Level */ | ||||
|   HAL_GPIO_WritePin(LED_GPIO_Port, LED_Pin, GPIO_PIN_RESET); | ||||
|  | ||||
|   /*Configure GPIO pin : LED_Pin */ | ||||
|   GPIO_InitStruct.Pin = LED_Pin; | ||||
|   GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP; | ||||
|   GPIO_InitStruct.Pull = GPIO_NOPULL; | ||||
|   GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW; | ||||
|   HAL_GPIO_Init(LED_GPIO_Port, &GPIO_InitStruct); | ||||
|  | ||||
|   /*Configure GPIO pin : PB5 */ | ||||
|   GPIO_InitStruct.Pin = GPIO_PIN_5; | ||||
|   GPIO_InitStruct.Mode = GPIO_MODE_INPUT; | ||||
|   GPIO_InitStruct.Pull = GPIO_NOPULL; | ||||
|   HAL_GPIO_Init(GPIOB, &GPIO_InitStruct); | ||||
|  | ||||
| } | ||||
|  | ||||
| /* USER CODE BEGIN 4 */ | ||||
|  | ||||
| /* USER CODE END 4 */ | ||||
|  | ||||
| /** | ||||
|   * @brief  This function is executed in case of error occurrence. | ||||
|   * @retval None | ||||
|   */ | ||||
| void Error_Handler(void) | ||||
| { | ||||
|   /* USER CODE BEGIN Error_Handler_Debug */ | ||||
|   /* User can add his own implementation to report the HAL error return state */ | ||||
|   __disable_irq(); | ||||
|   while (1) | ||||
|   { | ||||
|   } | ||||
|   /* USER CODE END Error_Handler_Debug */ | ||||
| } | ||||
|  | ||||
| #ifdef  USE_FULL_ASSERT | ||||
| /** | ||||
|   * @brief  Reports the name of the source file and the source line number | ||||
|   *         where the assert_param error has occurred. | ||||
|   * @param  file: pointer to the source file name | ||||
|   * @param  line: assert_param error line source number | ||||
|   * @retval None | ||||
|   */ | ||||
| void assert_failed(uint8_t *file, uint32_t line) | ||||
| { | ||||
|   /* USER CODE BEGIN 6 */ | ||||
|   /* User can add his own implementation to report the file name and line number, | ||||
|      ex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */ | ||||
|   /* USER CODE END 6 */ | ||||
| } | ||||
| #endif /* USE_FULL_ASSERT */ | ||||
|  | ||||
							
								
								
									
										268
									
								
								Core/Src/stm32f1xx_hal_msp.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										268
									
								
								Core/Src/stm32f1xx_hal_msp.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,268 @@ | ||||
| /* USER CODE BEGIN Header */ | ||||
| /** | ||||
|   ****************************************************************************** | ||||
|   * @file         stm32f1xx_hal_msp.c | ||||
|   * @brief        This file provides code for the MSP Initialization | ||||
|   *               and de-Initialization codes. | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * Copyright (c) 2022 STMicroelectronics. | ||||
|   * All rights reserved. | ||||
|   * | ||||
|   * This software is licensed under terms that can be found in the LICENSE file | ||||
|   * in the root directory of this software component. | ||||
|   * If no LICENSE file comes with this software, it is provided AS-IS. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| /* USER CODE END Header */ | ||||
|  | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "main.h" | ||||
| /* USER CODE BEGIN Includes */ | ||||
|  | ||||
| /* USER CODE END Includes */ | ||||
|  | ||||
| /* Private typedef -----------------------------------------------------------*/ | ||||
| /* USER CODE BEGIN TD */ | ||||
|  | ||||
| /* USER CODE END TD */ | ||||
|  | ||||
| /* Private define ------------------------------------------------------------*/ | ||||
| /* USER CODE BEGIN Define */ | ||||
|  | ||||
| /* USER CODE END Define */ | ||||
|  | ||||
| /* Private macro -------------------------------------------------------------*/ | ||||
| /* USER CODE BEGIN Macro */ | ||||
|  | ||||
| /* USER CODE END Macro */ | ||||
|  | ||||
| /* Private variables ---------------------------------------------------------*/ | ||||
| /* USER CODE BEGIN PV */ | ||||
|  | ||||
| /* USER CODE END PV */ | ||||
|  | ||||
| /* Private function prototypes -----------------------------------------------*/ | ||||
| /* USER CODE BEGIN PFP */ | ||||
|  | ||||
| /* USER CODE END PFP */ | ||||
|  | ||||
| /* External functions --------------------------------------------------------*/ | ||||
| /* USER CODE BEGIN ExternalFunctions */ | ||||
|  | ||||
| /* USER CODE END ExternalFunctions */ | ||||
|  | ||||
| /* USER CODE BEGIN 0 */ | ||||
|  | ||||
| /* USER CODE END 0 */ | ||||
|  | ||||
| void HAL_TIM_MspPostInit(TIM_HandleTypeDef *htim); | ||||
|                     /** | ||||
|   * Initializes the Global MSP. | ||||
|   */ | ||||
| void HAL_MspInit(void) | ||||
| { | ||||
|   /* USER CODE BEGIN MspInit 0 */ | ||||
|  | ||||
|   /* USER CODE END MspInit 0 */ | ||||
|  | ||||
|   __HAL_RCC_AFIO_CLK_ENABLE(); | ||||
|   __HAL_RCC_PWR_CLK_ENABLE(); | ||||
|  | ||||
|   /* System interrupt init*/ | ||||
|  | ||||
|   /** NOJTAG: JTAG-DP Disabled and SW-DP Enabled | ||||
|   */ | ||||
|   __HAL_AFIO_REMAP_SWJ_NOJTAG(); | ||||
|  | ||||
|   /* USER CODE BEGIN MspInit 1 */ | ||||
|  | ||||
|   /* USER CODE END MspInit 1 */ | ||||
| } | ||||
|  | ||||
| /** | ||||
| * @brief TIM_Base MSP Initialization | ||||
| * This function configures the hardware resources used in this example | ||||
| * @param htim_base: TIM_Base handle pointer | ||||
| * @retval None | ||||
| */ | ||||
| void HAL_TIM_Base_MspInit(TIM_HandleTypeDef* htim_base) | ||||
| { | ||||
|   GPIO_InitTypeDef GPIO_InitStruct = {0}; | ||||
|   if(htim_base->Instance==TIM2) | ||||
|   { | ||||
|   /* USER CODE BEGIN TIM2_MspInit 0 */ | ||||
|  | ||||
|   /* USER CODE END TIM2_MspInit 0 */ | ||||
|     /* Peripheral clock enable */ | ||||
|     __HAL_RCC_TIM2_CLK_ENABLE(); | ||||
|  | ||||
|     __HAL_RCC_GPIOA_CLK_ENABLE(); | ||||
|     /**TIM2 GPIO Configuration | ||||
|     PA0-WKUP     ------> TIM2_CH1 | ||||
|     */ | ||||
|     GPIO_InitStruct.Pin = GPIO_PIN_0; | ||||
|     GPIO_InitStruct.Mode = GPIO_MODE_INPUT; | ||||
|     GPIO_InitStruct.Pull = GPIO_NOPULL; | ||||
|     HAL_GPIO_Init(GPIOA, &GPIO_InitStruct); | ||||
|  | ||||
|     /* TIM2 interrupt Init */ | ||||
|     HAL_NVIC_SetPriority(TIM2_IRQn, 14, 0); | ||||
|     HAL_NVIC_EnableIRQ(TIM2_IRQn); | ||||
|   /* USER CODE BEGIN TIM2_MspInit 1 */ | ||||
|  | ||||
|   /* USER CODE END TIM2_MspInit 1 */ | ||||
|   } | ||||
|   else if(htim_base->Instance==TIM4) | ||||
|   { | ||||
|   /* USER CODE BEGIN TIM4_MspInit 0 */ | ||||
|  | ||||
|   /* USER CODE END TIM4_MspInit 0 */ | ||||
|     /* Peripheral clock enable */ | ||||
|     __HAL_RCC_TIM4_CLK_ENABLE(); | ||||
|   /* USER CODE BEGIN TIM4_MspInit 1 */ | ||||
|  | ||||
|   /* USER CODE END TIM4_MspInit 1 */ | ||||
|   } | ||||
|  | ||||
| } | ||||
|  | ||||
| void HAL_TIM_MspPostInit(TIM_HandleTypeDef* htim) | ||||
| { | ||||
|   GPIO_InitTypeDef GPIO_InitStruct = {0}; | ||||
|   if(htim->Instance==TIM4) | ||||
|   { | ||||
|   /* USER CODE BEGIN TIM4_MspPostInit 0 */ | ||||
|  | ||||
|   /* USER CODE END TIM4_MspPostInit 0 */ | ||||
|  | ||||
|     __HAL_RCC_GPIOB_CLK_ENABLE(); | ||||
|     /**TIM4 GPIO Configuration | ||||
|     PB6     ------> TIM4_CH1 | ||||
|     */ | ||||
|     GPIO_InitStruct.Pin = GPIO_PIN_6; | ||||
|     GPIO_InitStruct.Mode = GPIO_MODE_AF_PP; | ||||
|     GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW; | ||||
|     HAL_GPIO_Init(GPIOB, &GPIO_InitStruct); | ||||
|  | ||||
|   /* USER CODE BEGIN TIM4_MspPostInit 1 */ | ||||
|  | ||||
|   /* USER CODE END TIM4_MspPostInit 1 */ | ||||
|   } | ||||
|  | ||||
| } | ||||
| /** | ||||
| * @brief TIM_Base MSP De-Initialization | ||||
| * This function freeze the hardware resources used in this example | ||||
| * @param htim_base: TIM_Base handle pointer | ||||
| * @retval None | ||||
| */ | ||||
| void HAL_TIM_Base_MspDeInit(TIM_HandleTypeDef* htim_base) | ||||
| { | ||||
|   if(htim_base->Instance==TIM2) | ||||
|   { | ||||
|   /* USER CODE BEGIN TIM2_MspDeInit 0 */ | ||||
|  | ||||
|   /* USER CODE END TIM2_MspDeInit 0 */ | ||||
|     /* Peripheral clock disable */ | ||||
|     __HAL_RCC_TIM2_CLK_DISABLE(); | ||||
|  | ||||
|     /**TIM2 GPIO Configuration | ||||
|     PA0-WKUP     ------> TIM2_CH1 | ||||
|     */ | ||||
|     HAL_GPIO_DeInit(GPIOA, GPIO_PIN_0); | ||||
|  | ||||
|     /* TIM2 interrupt DeInit */ | ||||
|     HAL_NVIC_DisableIRQ(TIM2_IRQn); | ||||
|   /* USER CODE BEGIN TIM2_MspDeInit 1 */ | ||||
|  | ||||
|   /* USER CODE END TIM2_MspDeInit 1 */ | ||||
|   } | ||||
|   else if(htim_base->Instance==TIM4) | ||||
|   { | ||||
|   /* USER CODE BEGIN TIM4_MspDeInit 0 */ | ||||
|  | ||||
|   /* USER CODE END TIM4_MspDeInit 0 */ | ||||
|     /* Peripheral clock disable */ | ||||
|     __HAL_RCC_TIM4_CLK_DISABLE(); | ||||
|   /* USER CODE BEGIN TIM4_MspDeInit 1 */ | ||||
|  | ||||
|   /* USER CODE END TIM4_MspDeInit 1 */ | ||||
|   } | ||||
|  | ||||
| } | ||||
|  | ||||
| /** | ||||
| * @brief UART MSP Initialization | ||||
| * This function configures the hardware resources used in this example | ||||
| * @param huart: UART handle pointer | ||||
| * @retval None | ||||
| */ | ||||
| void HAL_UART_MspInit(UART_HandleTypeDef* huart) | ||||
| { | ||||
|   GPIO_InitTypeDef GPIO_InitStruct = {0}; | ||||
|   if(huart->Instance==USART1) | ||||
|   { | ||||
|   /* USER CODE BEGIN USART1_MspInit 0 */ | ||||
|  | ||||
|   /* USER CODE END USART1_MspInit 0 */ | ||||
|     /* Peripheral clock enable */ | ||||
|     __HAL_RCC_USART1_CLK_ENABLE(); | ||||
|  | ||||
|     __HAL_RCC_GPIOA_CLK_ENABLE(); | ||||
|     /**USART1 GPIO Configuration | ||||
|     PA9     ------> USART1_TX | ||||
|     PA10     ------> USART1_RX | ||||
|     */ | ||||
|     GPIO_InitStruct.Pin = GPIO_PIN_9; | ||||
|     GPIO_InitStruct.Mode = GPIO_MODE_AF_PP; | ||||
|     GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH; | ||||
|     HAL_GPIO_Init(GPIOA, &GPIO_InitStruct); | ||||
|  | ||||
|     GPIO_InitStruct.Pin = GPIO_PIN_10; | ||||
|     GPIO_InitStruct.Mode = GPIO_MODE_INPUT; | ||||
|     GPIO_InitStruct.Pull = GPIO_NOPULL; | ||||
|     HAL_GPIO_Init(GPIOA, &GPIO_InitStruct); | ||||
|  | ||||
|   /* USER CODE BEGIN USART1_MspInit 1 */ | ||||
|  | ||||
|   /* USER CODE END USART1_MspInit 1 */ | ||||
|   } | ||||
|  | ||||
| } | ||||
|  | ||||
| /** | ||||
| * @brief UART MSP De-Initialization | ||||
| * This function freeze the hardware resources used in this example | ||||
| * @param huart: UART handle pointer | ||||
| * @retval None | ||||
| */ | ||||
| void HAL_UART_MspDeInit(UART_HandleTypeDef* huart) | ||||
| { | ||||
|   if(huart->Instance==USART1) | ||||
|   { | ||||
|   /* USER CODE BEGIN USART1_MspDeInit 0 */ | ||||
|  | ||||
|   /* USER CODE END USART1_MspDeInit 0 */ | ||||
|     /* Peripheral clock disable */ | ||||
|     __HAL_RCC_USART1_CLK_DISABLE(); | ||||
|  | ||||
|     /**USART1 GPIO Configuration | ||||
|     PA9     ------> USART1_TX | ||||
|     PA10     ------> USART1_RX | ||||
|     */ | ||||
|     HAL_GPIO_DeInit(GPIOA, GPIO_PIN_9|GPIO_PIN_10); | ||||
|  | ||||
|   /* USER CODE BEGIN USART1_MspDeInit 1 */ | ||||
|  | ||||
|   /* USER CODE END USART1_MspDeInit 1 */ | ||||
|   } | ||||
|  | ||||
| } | ||||
|  | ||||
| /* USER CODE BEGIN 1 */ | ||||
|  | ||||
| /* USER CODE END 1 */ | ||||
|  | ||||
							
								
								
									
										236
									
								
								Core/Src/stm32f1xx_it.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										236
									
								
								Core/Src/stm32f1xx_it.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,236 @@ | ||||
| /* USER CODE BEGIN Header */ | ||||
| /** | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32f1xx_it.c | ||||
|   * @brief   Interrupt Service Routines. | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * Copyright (c) 2022 STMicroelectronics. | ||||
|   * All rights reserved. | ||||
|   * | ||||
|   * This software is licensed under terms that can be found in the LICENSE file | ||||
|   * in the root directory of this software component. | ||||
|   * If no LICENSE file comes with this software, it is provided AS-IS. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| /* USER CODE END Header */ | ||||
|  | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "main.h" | ||||
| #include "stm32f1xx_it.h" | ||||
| /* Private includes ----------------------------------------------------------*/ | ||||
| /* USER CODE BEGIN Includes */ | ||||
| /* USER CODE END Includes */ | ||||
|  | ||||
| /* Private typedef -----------------------------------------------------------*/ | ||||
| /* USER CODE BEGIN TD */ | ||||
|  | ||||
| /* USER CODE END TD */ | ||||
|  | ||||
| /* Private define ------------------------------------------------------------*/ | ||||
| /* USER CODE BEGIN PD */ | ||||
|  | ||||
| /* USER CODE END PD */ | ||||
|  | ||||
| /* Private macro -------------------------------------------------------------*/ | ||||
| /* USER CODE BEGIN PM */ | ||||
|  | ||||
| /* USER CODE END PM */ | ||||
|  | ||||
| /* Private variables ---------------------------------------------------------*/ | ||||
| /* USER CODE BEGIN PV */ | ||||
|  | ||||
| /* USER CODE END PV */ | ||||
|  | ||||
| /* Private function prototypes -----------------------------------------------*/ | ||||
| /* USER CODE BEGIN PFP */ | ||||
|  | ||||
| /* USER CODE END PFP */ | ||||
|  | ||||
| /* Private user code ---------------------------------------------------------*/ | ||||
| /* USER CODE BEGIN 0 */ | ||||
|  | ||||
| /* USER CODE END 0 */ | ||||
|  | ||||
| /* External variables --------------------------------------------------------*/ | ||||
| extern TIM_HandleTypeDef htim2; | ||||
| /* USER CODE BEGIN EV */ | ||||
|  | ||||
| /* USER CODE END EV */ | ||||
|  | ||||
| /******************************************************************************/ | ||||
| /*           Cortex-M3 Processor Interruption and Exception Handlers          */ | ||||
| /******************************************************************************/ | ||||
| /** | ||||
|   * @brief This function handles Non maskable interrupt. | ||||
|   */ | ||||
| void NMI_Handler(void) | ||||
| { | ||||
|   /* USER CODE BEGIN NonMaskableInt_IRQn 0 */ | ||||
|  | ||||
|   /* USER CODE END NonMaskableInt_IRQn 0 */ | ||||
|   /* USER CODE BEGIN NonMaskableInt_IRQn 1 */ | ||||
|   while (1) | ||||
|   { | ||||
|   } | ||||
|   /* USER CODE END NonMaskableInt_IRQn 1 */ | ||||
| } | ||||
|  | ||||
| /** | ||||
|   * @brief This function handles Hard fault interrupt. | ||||
|   */ | ||||
| void HardFault_Handler(void) | ||||
| { | ||||
|   /* USER CODE BEGIN HardFault_IRQn 0 */ | ||||
|  | ||||
|   /* USER CODE END HardFault_IRQn 0 */ | ||||
|   while (1) | ||||
|   { | ||||
|     /* USER CODE BEGIN W1_HardFault_IRQn 0 */ | ||||
|     /* USER CODE END W1_HardFault_IRQn 0 */ | ||||
|   } | ||||
| } | ||||
|  | ||||
| /** | ||||
|   * @brief This function handles Memory management fault. | ||||
|   */ | ||||
| void MemManage_Handler(void) | ||||
| { | ||||
|   /* USER CODE BEGIN MemoryManagement_IRQn 0 */ | ||||
|  | ||||
|   /* USER CODE END MemoryManagement_IRQn 0 */ | ||||
|   while (1) | ||||
|   { | ||||
|     /* USER CODE BEGIN W1_MemoryManagement_IRQn 0 */ | ||||
|     /* USER CODE END W1_MemoryManagement_IRQn 0 */ | ||||
|   } | ||||
| } | ||||
|  | ||||
| /** | ||||
|   * @brief This function handles Prefetch fault, memory access fault. | ||||
|   */ | ||||
| void BusFault_Handler(void) | ||||
| { | ||||
|   /* USER CODE BEGIN BusFault_IRQn 0 */ | ||||
|  | ||||
|   /* USER CODE END BusFault_IRQn 0 */ | ||||
|   while (1) | ||||
|   { | ||||
|     /* USER CODE BEGIN W1_BusFault_IRQn 0 */ | ||||
|     /* USER CODE END W1_BusFault_IRQn 0 */ | ||||
|   } | ||||
| } | ||||
|  | ||||
| /** | ||||
|   * @brief This function handles Undefined instruction or illegal state. | ||||
|   */ | ||||
| void UsageFault_Handler(void) | ||||
| { | ||||
|   /* USER CODE BEGIN UsageFault_IRQn 0 */ | ||||
|  | ||||
|   /* USER CODE END UsageFault_IRQn 0 */ | ||||
|   while (1) | ||||
|   { | ||||
|     /* USER CODE BEGIN W1_UsageFault_IRQn 0 */ | ||||
|     /* USER CODE END W1_UsageFault_IRQn 0 */ | ||||
|   } | ||||
| } | ||||
|  | ||||
| /** | ||||
|   * @brief This function handles System service call via SWI instruction. | ||||
|   */ | ||||
| void SVC_Handler(void) | ||||
| { | ||||
|   /* USER CODE BEGIN SVCall_IRQn 0 */ | ||||
|  | ||||
|   /* USER CODE END SVCall_IRQn 0 */ | ||||
|   /* USER CODE BEGIN SVCall_IRQn 1 */ | ||||
|  | ||||
|   /* USER CODE END SVCall_IRQn 1 */ | ||||
| } | ||||
|  | ||||
| /** | ||||
|   * @brief This function handles Debug monitor. | ||||
|   */ | ||||
| void DebugMon_Handler(void) | ||||
| { | ||||
|   /* USER CODE BEGIN DebugMonitor_IRQn 0 */ | ||||
|  | ||||
|   /* USER CODE END DebugMonitor_IRQn 0 */ | ||||
|   /* USER CODE BEGIN DebugMonitor_IRQn 1 */ | ||||
|  | ||||
|   /* USER CODE END DebugMonitor_IRQn 1 */ | ||||
| } | ||||
|  | ||||
| /** | ||||
|   * @brief This function handles Pendable request for system service. | ||||
|   */ | ||||
| void PendSV_Handler(void) | ||||
| { | ||||
|   /* USER CODE BEGIN PendSV_IRQn 0 */ | ||||
|  | ||||
|   /* USER CODE END PendSV_IRQn 0 */ | ||||
|   /* USER CODE BEGIN PendSV_IRQn 1 */ | ||||
|  | ||||
|   /* USER CODE END PendSV_IRQn 1 */ | ||||
| } | ||||
|  | ||||
| /** | ||||
|   * @brief This function handles System tick timer. | ||||
|   */ | ||||
| void SysTick_Handler(void) | ||||
| { | ||||
|   /* USER CODE BEGIN SysTick_IRQn 0 */ | ||||
|  | ||||
|   /* USER CODE END SysTick_IRQn 0 */ | ||||
|   HAL_IncTick(); | ||||
|   /* USER CODE BEGIN SysTick_IRQn 1 */ | ||||
|  | ||||
|   /* USER CODE END SysTick_IRQn 1 */ | ||||
| } | ||||
|  | ||||
| /******************************************************************************/ | ||||
| /* STM32F1xx Peripheral Interrupt Handlers                                    */ | ||||
| /* Add here the Interrupt Handlers for the used peripherals.                  */ | ||||
| /* For the available peripheral interrupt handler names,                      */ | ||||
| /* please refer to the startup file (startup_stm32f1xx.s).                    */ | ||||
| /******************************************************************************/ | ||||
|  | ||||
| /** | ||||
|   * @brief This function handles TIM2 global interrupt. | ||||
|   */ | ||||
| void TIM2_IRQHandler(void) | ||||
| { | ||||
|   /* USER CODE BEGIN TIM2_IRQn 0 */ | ||||
|     uint32_t sr = TIM2->SR; | ||||
|     static int _state_counter = 0; | ||||
|     if (sr & TIM_SR_UIF) { | ||||
|         TIM2->SR = TIM_SR_UIF; | ||||
|         // переполнение, так что записываем как стоп | ||||
|         opt_state = STOP; | ||||
|         _state_counter = 0; | ||||
|         LED_GPIO_Port->BSRR = LED_Pin; | ||||
|     } | ||||
|     if (sr & TIM_SR_CC1IF) { | ||||
|         TIM2->SR = TIM_SR_CC1IF; | ||||
|         TIM2->CNT = 0; // обнуляем счетчик таймера | ||||
|         if (_state_counter > 20) { | ||||
|             LED_GPIO_Port->BSRR = (uint32_t)LED_Pin << 16; | ||||
|             opt_state = START; | ||||
|         } else { | ||||
|             _state_counter++; | ||||
|         } | ||||
|     } | ||||
|   /* USER CODE END TIM2_IRQn 0 */ | ||||
|   HAL_TIM_IRQHandler(&htim2); | ||||
|   /* USER CODE BEGIN TIM2_IRQn 1 */ | ||||
|  | ||||
|   /* USER CODE END TIM2_IRQn 1 */ | ||||
| } | ||||
|  | ||||
| /* USER CODE BEGIN 1 */ | ||||
|  | ||||
| /* USER CODE END 1 */ | ||||
|  | ||||
							
								
								
									
										207
									
								
								Core/Src/syscalls.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										207
									
								
								Core/Src/syscalls.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,207 @@ | ||||
| /** | ||||
| ***************************************************************************** | ||||
| ** | ||||
| **  File        : syscalls.c | ||||
| ** | ||||
| **  Author		: Auto-generated by System workbench for STM32 | ||||
| ** | ||||
| **  Abstract    : System Workbench Minimal System calls file | ||||
| ** | ||||
| ** 		          For more information about which c-functions | ||||
| **                need which of these lowlevel functions | ||||
| **                please consult the Newlib libc-manual | ||||
| ** | ||||
| **  Target      : STMicroelectronics STM32 | ||||
| ** | ||||
| **  Distribution: The file is distributed “as is,” without any warranty | ||||
| **                of any kind. | ||||
| ** | ||||
| ***************************************************************************** | ||||
| ** @attention | ||||
| ** | ||||
| ** <h2><center>© COPYRIGHT(c) 2019 STMicroelectronics</center></h2> | ||||
| ** | ||||
| ** Redistribution and use in source and binary forms, with or without modification, | ||||
| ** are permitted provided that the following conditions are met: | ||||
| **   1. Redistributions of source code must retain the above copyright notice, | ||||
| **      this list of conditions and the following disclaimer. | ||||
| **   2. Redistributions in binary form must reproduce the above copyright notice, | ||||
| **      this list of conditions and the following disclaimer in the documentation | ||||
| **      and/or other materials provided with the distribution. | ||||
| **   3. Neither the name of STMicroelectronics nor the names of its contributors | ||||
| **      may be used to endorse or promote products derived from this software | ||||
| **      without specific prior written permission. | ||||
| ** | ||||
| ** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | ||||
| ** AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||||
| ** IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||||
| ** DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | ||||
| ** FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||||
| ** DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | ||||
| ** SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER | ||||
| ** CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | ||||
| ** OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
| ** OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| ** | ||||
| ***************************************************************************** | ||||
| */ | ||||
|  | ||||
| /* Includes */ | ||||
| #include <sys/stat.h> | ||||
| #include <stdlib.h> | ||||
| #include <errno.h> | ||||
| #include <stdio.h> | ||||
| #include <signal.h> | ||||
| #include <time.h> | ||||
| #include <sys/time.h> | ||||
| #include <sys/times.h> | ||||
|  | ||||
|  | ||||
| /* Variables */ | ||||
| //#undef errno | ||||
| extern int errno; | ||||
| extern int __io_putchar(int ch) __attribute__((weak)); | ||||
| extern int __io_getchar(void) __attribute__((weak)); | ||||
|  | ||||
| register char * stack_ptr asm("sp"); | ||||
|  | ||||
| char *__env[1] = { 0 }; | ||||
| char **environ = __env; | ||||
|  | ||||
|  | ||||
| /* Functions */ | ||||
| void initialise_monitor_handles() | ||||
| { | ||||
| } | ||||
|  | ||||
| int _getpid(void) | ||||
| { | ||||
| 	return 1; | ||||
| } | ||||
|  | ||||
| int _kill(int pid, int sig) | ||||
| { | ||||
| 	errno = EINVAL; | ||||
| 	return -1; | ||||
| } | ||||
|  | ||||
| void _exit (int status) | ||||
| { | ||||
| 	_kill(status, -1); | ||||
| 	while (1) {}		/* Make sure we hang here */ | ||||
| } | ||||
|  | ||||
| __attribute__((weak)) int _read(int file, char *ptr, int len) | ||||
| { | ||||
| 	int DataIdx; | ||||
|  | ||||
| 	for (DataIdx = 0; DataIdx < len; DataIdx++) | ||||
| 	{ | ||||
| 		*ptr++ = __io_getchar(); | ||||
| 	} | ||||
|  | ||||
| return len; | ||||
| } | ||||
|  | ||||
| __attribute__((weak)) int _write(int file, char *ptr, int len) | ||||
| { | ||||
| 	int DataIdx; | ||||
|  | ||||
| 	for (DataIdx = 0; DataIdx < len; DataIdx++) | ||||
| 	{ | ||||
| 		__io_putchar(*ptr++); | ||||
| 	} | ||||
| 	return len; | ||||
| } | ||||
|  | ||||
| caddr_t _sbrk(int incr) | ||||
| { | ||||
| 	extern char end asm("end"); | ||||
| 	static char *heap_end; | ||||
| 	char *prev_heap_end; | ||||
|  | ||||
| 	if (heap_end == 0) | ||||
| 		heap_end = &end; | ||||
|  | ||||
| 	prev_heap_end = heap_end; | ||||
| 	if (heap_end + incr > stack_ptr) | ||||
| 	{ | ||||
| //		write(1, "Heap and stack collision\n", 25); | ||||
| //		abort(); | ||||
| 		errno = ENOMEM; | ||||
| 		return (caddr_t) -1; | ||||
| 	} | ||||
|  | ||||
| 	heap_end += incr; | ||||
|  | ||||
| 	return (caddr_t) prev_heap_end; | ||||
| } | ||||
|  | ||||
| int _close(int file) | ||||
| { | ||||
| 	return -1; | ||||
| } | ||||
|  | ||||
|  | ||||
| int _fstat(int file, struct stat *st) | ||||
| { | ||||
| 	st->st_mode = S_IFCHR; | ||||
| 	return 0; | ||||
| } | ||||
|  | ||||
| int _isatty(int file) | ||||
| { | ||||
| 	return 1; | ||||
| } | ||||
|  | ||||
| int _lseek(int file, int ptr, int dir) | ||||
| { | ||||
| 	return 0; | ||||
| } | ||||
|  | ||||
| int _open(char *path, int flags, ...) | ||||
| { | ||||
| 	/* Pretend like we always fail */ | ||||
| 	return -1; | ||||
| } | ||||
|  | ||||
| int _wait(int *status) | ||||
| { | ||||
| 	errno = ECHILD; | ||||
| 	return -1; | ||||
| } | ||||
|  | ||||
| int _unlink(char *name) | ||||
| { | ||||
| 	errno = ENOENT; | ||||
| 	return -1; | ||||
| } | ||||
|  | ||||
| int _times(struct tms *buf) | ||||
| { | ||||
| 	return -1; | ||||
| } | ||||
|  | ||||
| int _stat(char *file, struct stat *st) | ||||
| { | ||||
| 	st->st_mode = S_IFCHR; | ||||
| 	return 0; | ||||
| } | ||||
|  | ||||
| int _link(char *old, char *new) | ||||
| { | ||||
| 	errno = EMLINK; | ||||
| 	return -1; | ||||
| } | ||||
|  | ||||
| int _fork(void) | ||||
| { | ||||
| 	errno = EAGAIN; | ||||
| 	return -1; | ||||
| } | ||||
|  | ||||
| int _execve(char *name, char **argv, char **env) | ||||
| { | ||||
| 	errno = ENOMEM; | ||||
| 	return -1; | ||||
| } | ||||
							
								
								
									
										408
									
								
								Core/Src/system_stm32f1xx.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										408
									
								
								Core/Src/system_stm32f1xx.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,408 @@ | ||||
| /** | ||||
|   ****************************************************************************** | ||||
|   * @file    system_stm32f1xx.c | ||||
|   * @author  MCD Application Team | ||||
|   * @brief   CMSIS Cortex-M3 Device Peripheral Access Layer System Source File. | ||||
|   *  | ||||
|   * 1.  This file provides two functions and one global variable to be called from  | ||||
|   *     user application: | ||||
|   *      - SystemInit(): Setups the system clock (System clock source, PLL Multiplier | ||||
|   *                      factors, AHB/APBx prescalers and Flash settings).  | ||||
|   *                      This function is called at startup just after reset and  | ||||
|   *                      before branch to main program. This call is made inside | ||||
|   *                      the "startup_stm32f1xx_xx.s" file. | ||||
|   * | ||||
|   *      - SystemCoreClock variable: Contains the core clock (HCLK), it can be used | ||||
|   *                                  by the user application to setup the SysTick  | ||||
|   *                                  timer or configure other parameters. | ||||
|   *                                      | ||||
|   *      - SystemCoreClockUpdate(): Updates the variable SystemCoreClock and must | ||||
|   *                                 be called whenever the core clock is changed | ||||
|   *                                 during program execution. | ||||
|   * | ||||
|   * 2. After each device reset the HSI (8 MHz) is used as system clock source. | ||||
|   *    Then SystemInit() function is called, in "startup_stm32f1xx_xx.s" file, to | ||||
|   *    configure the system clock before to branch to main program. | ||||
|   * | ||||
|   * 4. The default value of HSE crystal is set to 8 MHz (or 25 MHz, depending on | ||||
|   *    the product used), refer to "HSE_VALUE".  | ||||
|   *    When HSE is used as system clock source, directly or through PLL, and you | ||||
|   *    are using different crystal you have to adapt the HSE value to your own | ||||
|   *    configuration. | ||||
|   *         | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© Copyright (c) 2017 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 | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
|  | ||||
| /** @addtogroup CMSIS | ||||
|   * @{ | ||||
|   */ | ||||
|  | ||||
| /** @addtogroup stm32f1xx_system | ||||
|   * @{ | ||||
|   */   | ||||
|    | ||||
| /** @addtogroup STM32F1xx_System_Private_Includes | ||||
|   * @{ | ||||
|   */ | ||||
|  | ||||
| #include "stm32f1xx.h" | ||||
|  | ||||
| /** | ||||
|   * @} | ||||
|   */ | ||||
|  | ||||
| /** @addtogroup STM32F1xx_System_Private_TypesDefinitions | ||||
|   * @{ | ||||
|   */ | ||||
|  | ||||
| /** | ||||
|   * @} | ||||
|   */ | ||||
|  | ||||
| /** @addtogroup STM32F1xx_System_Private_Defines | ||||
|   * @{ | ||||
|   */ | ||||
|  | ||||
| #if !defined  (HSE_VALUE)  | ||||
|   #define HSE_VALUE               8000000U /*!< Default value of the External oscillator in Hz. | ||||
|                                                 This value can be provided and adapted by the user application. */ | ||||
| #endif /* HSE_VALUE */ | ||||
|  | ||||
| #if !defined  (HSI_VALUE) | ||||
|   #define HSI_VALUE               8000000U /*!< Default value of the Internal oscillator in Hz. | ||||
|                                                 This value can be provided and adapted by the user application. */ | ||||
| #endif /* HSI_VALUE */ | ||||
|  | ||||
| /*!< Uncomment the following line if you need to use external SRAM  */  | ||||
| #if defined(STM32F100xE) || defined(STM32F101xE) || defined(STM32F101xG) || defined(STM32F103xE) || defined(STM32F103xG) | ||||
| /* #define DATA_IN_ExtSRAM */ | ||||
| #endif /* STM32F100xE || STM32F101xE || STM32F101xG || STM32F103xE || STM32F103xG */ | ||||
|  | ||||
| /* Note: Following vector table addresses must be defined in line with linker | ||||
|          configuration. */ | ||||
| /*!< Uncomment the following line if you need to relocate the vector table | ||||
|      anywhere in Flash or Sram, else the vector table is kept at the automatic | ||||
|      remap of boot address selected */ | ||||
| /* #define USER_VECT_TAB_ADDRESS */ | ||||
|  | ||||
| #if defined(USER_VECT_TAB_ADDRESS) | ||||
| /*!< Uncomment the following line if you need to relocate your vector Table | ||||
|      in Sram else user remap will be done in Flash. */ | ||||
| /* #define VECT_TAB_SRAM */ | ||||
| #if defined(VECT_TAB_SRAM) | ||||
| #define VECT_TAB_BASE_ADDRESS   SRAM_BASE       /*!< Vector Table base address field. | ||||
|                                                      This value must be a multiple of 0x200. */ | ||||
| #define VECT_TAB_OFFSET         0x00000000U     /*!< Vector Table base offset field. | ||||
|                                                      This value must be a multiple of 0x200. */ | ||||
| #else | ||||
| #define VECT_TAB_BASE_ADDRESS   FLASH_BASE      /*!< Vector Table base address field. | ||||
|                                                      This value must be a multiple of 0x200. */ | ||||
| #define VECT_TAB_OFFSET         0x00000000U     /*!< Vector Table base offset field. | ||||
|                                                      This value must be a multiple of 0x200. */ | ||||
| #endif /* VECT_TAB_SRAM */ | ||||
| #endif /* USER_VECT_TAB_ADDRESS */ | ||||
|  | ||||
| /******************************************************************************/ | ||||
|  | ||||
| /** | ||||
|   * @} | ||||
|   */ | ||||
|  | ||||
| /** @addtogroup STM32F1xx_System_Private_Macros | ||||
|   * @{ | ||||
|   */ | ||||
|  | ||||
| /** | ||||
|   * @} | ||||
|   */ | ||||
|  | ||||
| /** @addtogroup STM32F1xx_System_Private_Variables | ||||
|   * @{ | ||||
|   */ | ||||
|  | ||||
|   /* This variable is updated in three ways: | ||||
|       1) by calling CMSIS function SystemCoreClockUpdate() | ||||
|       2) by calling HAL API function HAL_RCC_GetHCLKFreq() | ||||
|       3) each time HAL_RCC_ClockConfig() is called to configure the system clock frequency  | ||||
|          Note: If you use this function to configure the system clock; then there | ||||
|                is no need to call the 2 first functions listed above, since SystemCoreClock | ||||
|                variable is updated automatically. | ||||
|   */ | ||||
| uint32_t SystemCoreClock = 16000000; | ||||
| const uint8_t AHBPrescTable[16U] = {0, 0, 0, 0, 0, 0, 0, 0, 1, 2, 3, 4, 6, 7, 8, 9}; | ||||
| const uint8_t APBPrescTable[8U] =  {0, 0, 0, 0, 1, 2, 3, 4}; | ||||
|  | ||||
| /** | ||||
|   * @} | ||||
|   */ | ||||
|  | ||||
| /** @addtogroup STM32F1xx_System_Private_FunctionPrototypes | ||||
|   * @{ | ||||
|   */ | ||||
|  | ||||
| #if defined(STM32F100xE) || defined(STM32F101xE) || defined(STM32F101xG) || defined(STM32F103xE) || defined(STM32F103xG) | ||||
| #ifdef DATA_IN_ExtSRAM | ||||
|   static void SystemInit_ExtMemCtl(void);  | ||||
| #endif /* DATA_IN_ExtSRAM */ | ||||
| #endif /* STM32F100xE || STM32F101xE || STM32F101xG || STM32F103xE || STM32F103xG */ | ||||
|  | ||||
| /** | ||||
|   * @} | ||||
|   */ | ||||
|  | ||||
| /** @addtogroup STM32F1xx_System_Private_Functions | ||||
|   * @{ | ||||
|   */ | ||||
|  | ||||
| /** | ||||
|   * @brief  Setup the microcontroller system | ||||
|   *         Initialize the Embedded Flash Interface, the PLL and update the  | ||||
|   *         SystemCoreClock variable. | ||||
|   * @note   This function should be used only after reset. | ||||
|   * @param  None | ||||
|   * @retval None | ||||
|   */ | ||||
| void SystemInit (void) | ||||
| { | ||||
| #if defined(STM32F100xE) || defined(STM32F101xE) || defined(STM32F101xG) || defined(STM32F103xE) || defined(STM32F103xG) | ||||
|   #ifdef DATA_IN_ExtSRAM | ||||
|     SystemInit_ExtMemCtl();  | ||||
|   #endif /* DATA_IN_ExtSRAM */ | ||||
| #endif  | ||||
|  | ||||
|   /* Configure the Vector Table location -------------------------------------*/ | ||||
| #if defined(USER_VECT_TAB_ADDRESS) | ||||
|   SCB->VTOR = VECT_TAB_BASE_ADDRESS | VECT_TAB_OFFSET; /* Vector Table Relocation in Internal SRAM. */ | ||||
| #endif /* USER_VECT_TAB_ADDRESS */ | ||||
| } | ||||
|  | ||||
| /** | ||||
|   * @brief  Update SystemCoreClock variable according to Clock Register Values. | ||||
|   *         The SystemCoreClock variable contains the core clock (HCLK), it can | ||||
|   *         be used by the user application to setup the SysTick timer or configure | ||||
|   *         other parameters. | ||||
|   *            | ||||
|   * @note   Each time the core clock (HCLK) changes, this function must be called | ||||
|   *         to update SystemCoreClock variable value. Otherwise, any configuration | ||||
|   *         based on this variable will be incorrect.          | ||||
|   *      | ||||
|   * @note   - The system frequency computed by this function is not the real  | ||||
|   *           frequency in the chip. It is calculated based on the predefined  | ||||
|   *           constant and the selected clock source: | ||||
|   *              | ||||
|   *           - If SYSCLK source is HSI, SystemCoreClock will contain the HSI_VALUE(*) | ||||
|   *                                               | ||||
|   *           - If SYSCLK source is HSE, SystemCoreClock will contain the HSE_VALUE(**) | ||||
|   *                           | ||||
|   *           - If SYSCLK source is PLL, SystemCoreClock will contain the HSE_VALUE(**)  | ||||
|   *             or HSI_VALUE(*) multiplied by the PLL factors. | ||||
|   *          | ||||
|   *         (*) HSI_VALUE is a constant defined in stm32f1xx.h file (default value | ||||
|   *             8 MHz) but the real value may vary depending on the variations | ||||
|   *             in voltage and temperature.    | ||||
|   *     | ||||
|   *         (**) HSE_VALUE is a constant defined in stm32f1xx.h file (default value | ||||
|   *              8 MHz or 25 MHz, depending on the product used), user has to ensure | ||||
|   *              that HSE_VALUE is same as the real frequency of the crystal used. | ||||
|   *              Otherwise, this function may have wrong result. | ||||
|   *                 | ||||
|   *         - The result of this function could be not correct when using fractional | ||||
|   *           value for HSE crystal. | ||||
|   * @param  None | ||||
|   * @retval None | ||||
|   */ | ||||
| void SystemCoreClockUpdate (void) | ||||
| { | ||||
|   uint32_t tmp = 0U, pllmull = 0U, pllsource = 0U; | ||||
|  | ||||
| #if defined(STM32F105xC) || defined(STM32F107xC) | ||||
|   uint32_t prediv1source = 0U, prediv1factor = 0U, prediv2factor = 0U, pll2mull = 0U; | ||||
| #endif /* STM32F105xC */ | ||||
|  | ||||
| #if defined(STM32F100xB) || defined(STM32F100xE) | ||||
|   uint32_t prediv1factor = 0U; | ||||
| #endif /* STM32F100xB or STM32F100xE */ | ||||
|      | ||||
|   /* Get SYSCLK source -------------------------------------------------------*/ | ||||
|   tmp = RCC->CFGR & RCC_CFGR_SWS; | ||||
|    | ||||
|   switch (tmp) | ||||
|   { | ||||
|     case 0x00U:  /* HSI used as system clock */ | ||||
|       SystemCoreClock = HSI_VALUE; | ||||
|       break; | ||||
|     case 0x04U:  /* HSE used as system clock */ | ||||
|       SystemCoreClock = HSE_VALUE; | ||||
|       break; | ||||
|     case 0x08U:  /* PLL used as system clock */ | ||||
|  | ||||
|       /* Get PLL clock source and multiplication factor ----------------------*/ | ||||
|       pllmull = RCC->CFGR & RCC_CFGR_PLLMULL; | ||||
|       pllsource = RCC->CFGR & RCC_CFGR_PLLSRC; | ||||
|        | ||||
| #if !defined(STM32F105xC) && !defined(STM32F107xC)       | ||||
|       pllmull = ( pllmull >> 18U) + 2U; | ||||
|        | ||||
|       if (pllsource == 0x00U) | ||||
|       { | ||||
|         /* HSI oscillator clock divided by 2 selected as PLL clock entry */ | ||||
|         SystemCoreClock = (HSI_VALUE >> 1U) * pllmull; | ||||
|       } | ||||
|       else | ||||
|       { | ||||
|  #if defined(STM32F100xB) || defined(STM32F100xE) | ||||
|        prediv1factor = (RCC->CFGR2 & RCC_CFGR2_PREDIV1) + 1U; | ||||
|        /* HSE oscillator clock selected as PREDIV1 clock entry */ | ||||
|        SystemCoreClock = (HSE_VALUE / prediv1factor) * pllmull;  | ||||
|  #else | ||||
|         /* HSE selected as PLL clock entry */ | ||||
|         if ((RCC->CFGR & RCC_CFGR_PLLXTPRE) != (uint32_t)RESET) | ||||
|         {/* HSE oscillator clock divided by 2 */ | ||||
|           SystemCoreClock = (HSE_VALUE >> 1U) * pllmull; | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|           SystemCoreClock = HSE_VALUE * pllmull; | ||||
|         } | ||||
|  #endif | ||||
|       } | ||||
| #else | ||||
|       pllmull = pllmull >> 18U; | ||||
|        | ||||
|       if (pllmull != 0x0DU) | ||||
|       { | ||||
|          pllmull += 2U; | ||||
|       } | ||||
|       else | ||||
|       { /* PLL multiplication factor = PLL input clock * 6.5 */ | ||||
|         pllmull = 13U / 2U;  | ||||
|       } | ||||
|              | ||||
|       if (pllsource == 0x00U) | ||||
|       { | ||||
|         /* HSI oscillator clock divided by 2 selected as PLL clock entry */ | ||||
|         SystemCoreClock = (HSI_VALUE >> 1U) * pllmull; | ||||
|       } | ||||
|       else | ||||
|       {/* PREDIV1 selected as PLL clock entry */ | ||||
|          | ||||
|         /* Get PREDIV1 clock source and division factor */ | ||||
|         prediv1source = RCC->CFGR2 & RCC_CFGR2_PREDIV1SRC; | ||||
|         prediv1factor = (RCC->CFGR2 & RCC_CFGR2_PREDIV1) + 1U; | ||||
|          | ||||
|         if (prediv1source == 0U) | ||||
|         {  | ||||
|           /* HSE oscillator clock selected as PREDIV1 clock entry */ | ||||
|           SystemCoreClock = (HSE_VALUE / prediv1factor) * pllmull;           | ||||
|         } | ||||
|         else | ||||
|         {/* PLL2 clock selected as PREDIV1 clock entry */ | ||||
|            | ||||
|           /* Get PREDIV2 division factor and PLL2 multiplication factor */ | ||||
|           prediv2factor = ((RCC->CFGR2 & RCC_CFGR2_PREDIV2) >> 4U) + 1U; | ||||
|           pll2mull = ((RCC->CFGR2 & RCC_CFGR2_PLL2MUL) >> 8U) + 2U;  | ||||
|           SystemCoreClock = (((HSE_VALUE / prediv2factor) * pll2mull) / prediv1factor) * pllmull;                          | ||||
|         } | ||||
|       } | ||||
| #endif /* STM32F105xC */  | ||||
|       break; | ||||
|  | ||||
|     default: | ||||
|       SystemCoreClock = HSI_VALUE; | ||||
|       break; | ||||
|   } | ||||
|    | ||||
|   /* Compute HCLK clock frequency ----------------*/ | ||||
|   /* Get HCLK prescaler */ | ||||
|   tmp = AHBPrescTable[((RCC->CFGR & RCC_CFGR_HPRE) >> 4U)]; | ||||
|   /* HCLK clock frequency */ | ||||
|   SystemCoreClock >>= tmp;   | ||||
| } | ||||
|  | ||||
| #if defined(STM32F100xE) || defined(STM32F101xE) || defined(STM32F101xG) || defined(STM32F103xE) || defined(STM32F103xG) | ||||
| /** | ||||
|   * @brief  Setup the external memory controller. Called in startup_stm32f1xx.s  | ||||
|   *          before jump to __main | ||||
|   * @param  None | ||||
|   * @retval None | ||||
|   */  | ||||
| #ifdef DATA_IN_ExtSRAM | ||||
| /** | ||||
|   * @brief  Setup the external memory controller.  | ||||
|   *         Called in startup_stm32f1xx_xx.s/.c before jump to main. | ||||
|   *         This function configures the external SRAM mounted on STM3210E-EVAL | ||||
|   *         board (STM32 High density devices). This SRAM will be used as program | ||||
|   *         data memory (including heap and stack). | ||||
|   * @param  None | ||||
|   * @retval None | ||||
|   */  | ||||
| void SystemInit_ExtMemCtl(void)  | ||||
| { | ||||
|   __IO uint32_t tmpreg; | ||||
|   /*!< FSMC Bank1 NOR/SRAM3 is used for the STM3210E-EVAL, if another Bank is  | ||||
|     required, then adjust the Register Addresses */ | ||||
|  | ||||
|   /* Enable FSMC clock */ | ||||
|   RCC->AHBENR = 0x00000114U; | ||||
|  | ||||
|   /* Delay after an RCC peripheral clock enabling */ | ||||
|   tmpreg = READ_BIT(RCC->AHBENR, RCC_AHBENR_FSMCEN); | ||||
|    | ||||
|   /* Enable GPIOD, GPIOE, GPIOF and GPIOG clocks */ | ||||
|   RCC->APB2ENR = 0x000001E0U; | ||||
|    | ||||
|   /* Delay after an RCC peripheral clock enabling */ | ||||
|   tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_IOPDEN); | ||||
|  | ||||
|   (void)(tmpreg); | ||||
|    | ||||
| /* ---------------  SRAM Data lines, NOE and NWE configuration ---------------*/ | ||||
| /*----------------  SRAM Address lines configuration -------------------------*/ | ||||
| /*----------------  NOE and NWE configuration --------------------------------*/   | ||||
| /*----------------  NE3 configuration ----------------------------------------*/ | ||||
| /*----------------  NBL0, NBL1 configuration ---------------------------------*/ | ||||
|    | ||||
|   GPIOD->CRL = 0x44BB44BBU;   | ||||
|   GPIOD->CRH = 0xBBBBBBBBU; | ||||
|  | ||||
|   GPIOE->CRL = 0xB44444BBU;   | ||||
|   GPIOE->CRH = 0xBBBBBBBBU; | ||||
|  | ||||
|   GPIOF->CRL = 0x44BBBBBBU;   | ||||
|   GPIOF->CRH = 0xBBBB4444U; | ||||
|  | ||||
|   GPIOG->CRL = 0x44BBBBBBU;   | ||||
|   GPIOG->CRH = 0x444B4B44U; | ||||
|     | ||||
| /*----------------  FSMC Configuration ---------------------------------------*/   | ||||
| /*----------------  Enable FSMC Bank1_SRAM Bank ------------------------------*/ | ||||
|    | ||||
|   FSMC_Bank1->BTCR[4U] = 0x00001091U; | ||||
|   FSMC_Bank1->BTCR[5U] = 0x00110212U; | ||||
| } | ||||
| #endif /* DATA_IN_ExtSRAM */ | ||||
| #endif /* STM32F100xE || STM32F101xE || STM32F101xG || STM32F103xE || STM32F103xG */ | ||||
|  | ||||
| /** | ||||
|   * @} | ||||
|   */ | ||||
|  | ||||
| /** | ||||
|   * @} | ||||
|   */ | ||||
|    | ||||
| /** | ||||
|   * @} | ||||
|   */     | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
		Reference in New Issue
	
	Block a user