iwdg correct
This commit is contained in:
		
							parent
							
								
									a0d433f87e
								
							
						
					
					
						commit
						72f7b16e51
					
				
							
								
								
									
										27
									
								
								.mxproject
									
									
									
									
									
								
							
							
						
						
									
										27
									
								
								.mxproject
									
									
									
									
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -1,3 +1,4 @@ | ||||
| /* USER CODE BEGIN Header */ | ||||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    can.h | ||||
| @ -6,16 +7,16 @@ | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© Copyright (c) 2025 STMicroelectronics. | ||||
|   * All rights reserved.</center></h2> | ||||
|   * Copyright (c) 2025 STMicroelectronics. | ||||
|   * All rights reserved. | ||||
|   * | ||||
|   * 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 | ||||
|   * 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 */ | ||||
| /* Define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef __CAN_H__ | ||||
| #define __CAN_H__ | ||||
| @ -52,4 +53,3 @@ int CAN_send(uint16_t data[], int Addr, int Qua); | ||||
| 
 | ||||
| #endif /* __CAN_H__ */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | ||||
| @ -1,3 +1,4 @@ | ||||
| /* USER CODE BEGIN Header */ | ||||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    gpio.h | ||||
| @ -6,16 +7,16 @@ | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© Copyright (c) 2025 STMicroelectronics. | ||||
|   * All rights reserved.</center></h2> | ||||
|   * Copyright (c) 2025 STMicroelectronics. | ||||
|   * All rights reserved. | ||||
|   * | ||||
|   * 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 | ||||
|   * 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 */ | ||||
| /* Define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef __GPIO_H__ | ||||
| #define __GPIO_H__ | ||||
| @ -162,4 +163,3 @@ void MX_GPIO_Init(void); | ||||
| #endif | ||||
| #endif /*__ GPIO_H__ */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | ||||
							
								
								
									
										52
									
								
								Core/Inc/iwdg.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										52
									
								
								Core/Inc/iwdg.h
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,52 @@ | ||||
| /* USER CODE BEGIN Header */ | ||||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    iwdg.h | ||||
|   * @brief   This file contains all the function prototypes for | ||||
|   *          the iwdg.c file | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * Copyright (c) 2025 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 */ | ||||
| /* Define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef __IWDG_H__ | ||||
| #define __IWDG_H__ | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "main.h" | ||||
| 
 | ||||
| /* USER CODE BEGIN Includes */ | ||||
| 
 | ||||
| /* USER CODE END Includes */ | ||||
| 
 | ||||
| extern IWDG_HandleTypeDef hiwdg; | ||||
| 
 | ||||
| /* USER CODE BEGIN Private defines */ | ||||
| 
 | ||||
| /* USER CODE END Private defines */ | ||||
| 
 | ||||
| void MX_IWDG_Init(void); | ||||
| 
 | ||||
| /* USER CODE BEGIN Prototypes */ | ||||
| 
 | ||||
| /* USER CODE END Prototypes */ | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif /* __IWDG_H__ */ | ||||
| 
 | ||||
| @ -32,7 +32,7 @@ extern "C" { | ||||
| 
 | ||||
| /* Private includes ----------------------------------------------------------*/ | ||||
| /* USER CODE BEGIN Includes */ | ||||
| 
 | ||||
| void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim); | ||||
| /* USER CODE END Includes */ | ||||
| 
 | ||||
| /* Exported types ------------------------------------------------------------*/ | ||||
| @ -42,6 +42,18 @@ extern "C" { | ||||
| 
 | ||||
| /* Exported constants --------------------------------------------------------*/ | ||||
| /* USER CODE BEGIN EC */ | ||||
| typedef struct  | ||||
| { | ||||
| 	uint8_t force_pause:1; | ||||
| 	uint32_t pause; | ||||
| 	 | ||||
| 	 | ||||
| 	 | ||||
| //	uint8_t 
 | ||||
| //	uint16_t 
 | ||||
| 	 | ||||
| }FLAG; | ||||
| 
 | ||||
| 
 | ||||
| /* USER CODE END EC */ | ||||
| 
 | ||||
| @ -60,6 +72,59 @@ void Millisecond(void); | ||||
| /* USER CODE END EFP */ | ||||
| 
 | ||||
| /* Private defines -----------------------------------------------------------*/ | ||||
| #define IN_06_Pin GPIO_PIN_13 | ||||
| #define IN_06_GPIO_Port GPIOC | ||||
| #define SELEKT_PCH_Pin GPIO_PIN_14 | ||||
| #define SELEKT_PCH_GPIO_Port GPIOC | ||||
| #define IN_05_Pin GPIO_PIN_15 | ||||
| #define IN_05_GPIO_Port GPIOC | ||||
| //#define LED1_Pin GPIO_PIN_2
 | ||||
| //#define LED1_GPIO_Port GPIOC
 | ||||
| //#define LED2_Pin GPIO_PIN_3
 | ||||
| #define LED2_GPIO_Port GPIOC | ||||
| #define IN_04_Pin GPIO_PIN_0 | ||||
| #define IN_04_GPIO_Port GPIOA | ||||
| #define IN_03_Pin GPIO_PIN_1 | ||||
| #define IN_03_GPIO_Port GPIOA | ||||
| #define IN_02_Pin GPIO_PIN_2 | ||||
| #define IN_02_GPIO_Port GPIOA | ||||
| #define IN_01_Pin GPIO_PIN_3 | ||||
| #define IN_01_GPIO_Port GPIOA | ||||
| #define IN_14_Pin GPIO_PIN_4 | ||||
| #define IN_14_GPIO_Port GPIOA | ||||
| #define IN_13_Pin GPIO_PIN_5 | ||||
| #define IN_13_GPIO_Port GPIOA | ||||
| //#define J0_Pin GPIO_PIN_7
 | ||||
| #define J0_GPIO_Port GPIOA | ||||
| //#define J1_Pin GPIO_PIN_4
 | ||||
| //#define J1_GPIO_Port GPIOC
 | ||||
| //#define J2_Pin GPIO_PIN_5
 | ||||
| #define J2_GPIO_Port GPIOC | ||||
| //#define J3_Pin GPIO_PIN_0
 | ||||
| //#define J3_GPIO_Port GPIOB
 | ||||
| //#define IN_12_Pin GPIO_PIN_1
 | ||||
| #define IN_12_GPIO_Port GPIOB | ||||
| #define BOOT1_Pin GPIO_PIN_2 | ||||
| #define BOOT1_GPIO_Port GPIOB | ||||
| //#define IN_11_Pin GPIO_PIN_10
 | ||||
| #define IN_11_GPIO_Port GPIOB | ||||
| #define IN_10_Pin GPIO_PIN_12 | ||||
| #define IN_10_GPIO_Port GPIOB | ||||
| #define IN_09_Pin GPIO_PIN_13 | ||||
| #define IN_09_GPIO_Port GPIOB | ||||
| #define IN_08_Pin GPIO_PIN_14 | ||||
| #define IN_08_GPIO_Port GPIOB | ||||
| #define IN_07_Pin GPIO_PIN_15 | ||||
| #define IN_07_GPIO_Port GPIOB | ||||
| #define PVT4_Pin GPIO_PIN_6 | ||||
| #define PVT4_GPIO_Port GPIOC | ||||
| #define PVT3_Pin GPIO_PIN_7 | ||||
| #define PVT3_GPIO_Port GPIOC | ||||
| #define PVT2_Pin GPIO_PIN_8 | ||||
| #define PVT2_GPIO_Port GPIOC | ||||
| #define PVT1_Pin GPIO_PIN_9 | ||||
| #define PVT1_GPIO_Port GPIOC | ||||
| 
 | ||||
| /* USER CODE BEGIN Private defines */ | ||||
| 
 | ||||
| /* USER CODE END Private defines */ | ||||
| @ -69,5 +134,3 @@ void Millisecond(void); | ||||
| #endif | ||||
| 
 | ||||
| #endif /* __MAIN_H */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | ||||
| @ -8,16 +8,16 @@ typedef unsigned char CHAR; | ||||
| 
 | ||||
| #define Modbus_LEN 0x000080 | ||||
| #define Modbus ((WORDE *)modbus) | ||||
| #define Params ((WORDE *)params) | ||||
| 
 | ||||
| extern uint16_t Mode; | ||||
| 
 | ||||
| extern uint16_t modbus[],archiv[],county[],espero[];   | ||||
| extern uint16_t modbus[],params[],archiv[],county[],espero[];   | ||||
| 
 | ||||
| extern LONGE* outputs; | ||||
| 
 | ||||
| extern uint16_t Maska[][8]; | ||||
| 
 | ||||
| 
 | ||||
| void Save_params(void); | ||||
| void Load_params(void); | ||||
| void Default_params(void); | ||||
|  | ||||
| @ -6,7 +6,9 @@ | ||||
| #define m_FAST 0 | ||||
| #define m_SLOW 1 | ||||
| 
 | ||||
| #define keys	0x0 | ||||
| 
 | ||||
| 
 | ||||
| #define keys	0x0					//	адрес повтораемой посылки «keys»
 | ||||
| 
 | ||||
| #define Inputs	Modbus[0x0] | ||||
| #define Alarms	Modbus[0x1] | ||||
| @ -15,43 +17,61 @@ | ||||
| #define Alarm_mask	Modbus[0x8] | ||||
| #define Error_mask	Modbus[0x9] | ||||
| 
 | ||||
| #define Error_mask	Modbus[0x9] | ||||
| 
 | ||||
| #define Jumpers		Modbus[0x10] | ||||
| #define Buttons		Modbus[0x11] | ||||
| #define jumpers		modbus[0x10] | ||||
| #define buttons		modbus[0x11] | ||||
| 
 | ||||
| #define Squazh_U	(modbus+0x20) | ||||
| #define Squazh_U	(modbus+0x18) | ||||
| 
 | ||||
| #define Sleep_time	modbus[0x48] | ||||
| 
 | ||||
| #define Squazh_L	(modbus+0x30) | ||||
| 
 | ||||
| #define	Cancount	(modbus+0x60)	//	пауза между I посылками CAN
 | ||||
| #define	CanWait		(modbus+0x62)	//	максимальнаа пауза
 | ||||
| #define	Cancount	(modbus+0x60)	//	пауза между посылками CAN
 | ||||
| #define	CanWait		(modbus+0x62)	//	пауза после прохождениа цикла
 | ||||
| #define	CanRestart	(modbus+0x64)	//	перезапуск посылки
 | ||||
| #define	CanRepeat	 modbus[0x66]	//	сколько раз повторать надо
 | ||||
| #define	CanRptVez	 modbus[0x66]	//	кол-во повторений посылки «keys»
 | ||||
| #define	CanRptLen	 modbus[0x67]	//	длина повтораемой посылки «keys»
 | ||||
| 
 | ||||
| #define	Brightness	 modbus[0x68]	//	аркость сигнальной лампочки
 | ||||
| #define	Lightness	 modbus[0x6A]	//	управление сигнальной лампочки
 | ||||
| 
 | ||||
| #define cancyclo	0x78			//	его адрес
 | ||||
| #define CanCycle	(modbus+0x78)	//	счетчик циклов CAN
 | ||||
| #define CanRound	(modbus+0x7A)	//	счетчик еще более полных циклов  CAN
 | ||||
| 
 | ||||
| #define Protokol	modbus[125] | ||||
| #define LastMode	Modbus[126].all | ||||
| #define LastMode	modbus[126] | ||||
| #define Commands	modbus[127] | ||||
| 
 | ||||
| #define Commands	Modbus[127].all | ||||
| #define command		params[128] | ||||
| #define bit_command	Params[128] | ||||
| 
 | ||||
| #define cTestLamp	bit_command.bit.bit0 | ||||
| #define cDefParam	bit_command.bit.bit1 | ||||
| #define cSaveParam	bit_command.bit.bit2 | ||||
| #define cLoadParam	bit_command.bit.bit3 | ||||
| #define cTermoCal	bit_command.bit.bit4 | ||||
| #define cKoefCalc	bit_command.bit.bit5 | ||||
| #define cSecretBt	bit_command.bit.bit6 | ||||
| #define cCanReset	bit_command.bit.bit7 | ||||
| #define cRawMeat	bit_command.bit.bit8 | ||||
| #define cCanReset	bit_command.bit.bit7 | ||||
| #define cReset		bit_command.bit.bitF | ||||
| 
 | ||||
| /*
 | ||||
| #define cTestLamp	Modbus[127].bit.bit0 | ||||
| #define cDefParam	Modbus[127].bit.bit1 | ||||
| #define cSaveParam	Modbus[127].bit.bit2 | ||||
| #define cLoadParam	Modbus[127].bit.bit3 | ||||
| 
 | ||||
| #define cExtLamp	Modbus[127].bit.bit6 | ||||
| #define cExtLite	Modbus[127].bit.bit7 | ||||
| 
 | ||||
| #define cTermoCal	Modbus[127].bit.bit4 | ||||
| #define cKoefCalc	Modbus[127].bit.bit5 | ||||
| #define cSecretBt	Modbus[127].bit.bit6 | ||||
| #define cCanReset	Modbus[127].bit.bit7 | ||||
| #define cRawMeat	Modbus[127].bit.bit8 | ||||
| #define cCanReset	Modbus[127].bit.bit7 | ||||
| #define cReset		Modbus[127].bit.bitF | ||||
| 
 | ||||
| */ | ||||
| #endif	//PACKAGE
 | ||||
| 
 | ||||
|  | ||||
| @ -1,3 +1,4 @@ | ||||
| /* USER CODE BEGIN Header */ | ||||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32f1xx_hal_conf.h | ||||
| @ -5,16 +6,16 @@ | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© Copyright (c) 2017 STMicroelectronics. | ||||
|   * All rights reserved.</center></h2> | ||||
|   * Copyright (c) 2017 STMicroelectronics. | ||||
|   * All rights reserved. | ||||
|   * | ||||
|   * 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 | ||||
|   * 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 */ | ||||
| 
 | ||||
| /* Define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef __STM32F1xx_HAL_CONF_H | ||||
| @ -48,7 +49,7 @@ | ||||
| /*#define HAL_I2C_MODULE_ENABLED   */ | ||||
| /*#define HAL_I2S_MODULE_ENABLED   */ | ||||
| /*#define HAL_IRDA_MODULE_ENABLED   */ | ||||
| /*#define HAL_IWDG_MODULE_ENABLED   */ | ||||
| #define HAL_IWDG_MODULE_ENABLED | ||||
| /*#define HAL_NOR_MODULE_ENABLED   */ | ||||
| /*#define HAL_NAND_MODULE_ENABLED   */ | ||||
| /*#define HAL_PCCARD_MODULE_ENABLED   */ | ||||
| @ -128,7 +129,7 @@ | ||||
|   * @brief This is the HAL system configuration section | ||||
|   */ | ||||
| #define  VDD_VALUE                    3300U /*!< Value of VDD in mv */ | ||||
| #define  TICK_INT_PRIORITY            0U    /*!< tick interrupt priority (lowest by default)  */ | ||||
| #define  TICK_INT_PRIORITY            15U    /*!< tick interrupt priority (lowest by default)  */ | ||||
| #define  USE_RTOS                     0U | ||||
| #define  PREFETCH_ENABLE              1U | ||||
| 
 | ||||
| @ -388,4 +389,3 @@ void assert_failed(uint8_t* file, uint32_t line); | ||||
| 
 | ||||
| #endif /* __STM32F1xx_HAL_CONF_H */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | ||||
							
								
								
									
										391
									
								
								Core/Inc/stm32f1xx_hal_conf.h.bak
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										391
									
								
								Core/Inc/stm32f1xx_hal_conf.h.bak
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,391 @@ | ||||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32f1xx_hal_conf.h | ||||
|   * @brief   HAL configuration file. | ||||
|   ****************************************************************************** | ||||
|   * @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 | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef __STM32F1xx_HAL_CONF_H | ||||
| #define __STM32F1xx_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_CRYP_MODULE_ENABLED   */ | ||||
| #define HAL_CAN_MODULE_ENABLED | ||||
| /*#define HAL_CAN_LEGACY_MODULE_ENABLED   */ | ||||
| /*#define HAL_CEC_MODULE_ENABLED   */ | ||||
| /*#define HAL_CORTEX_MODULE_ENABLED   */ | ||||
| /*#define HAL_CRC_MODULE_ENABLED   */ | ||||
| /*#define HAL_DAC_MODULE_ENABLED   */ | ||||
| /*#define HAL_DMA_MODULE_ENABLED   */ | ||||
| /*#define HAL_ETH_MODULE_ENABLED   */ | ||||
| /*#define HAL_FLASH_MODULE_ENABLED   */ | ||||
| #define HAL_GPIO_MODULE_ENABLED | ||||
| /*#define HAL_I2C_MODULE_ENABLED   */ | ||||
| /*#define HAL_I2S_MODULE_ENABLED   */ | ||||
| /*#define HAL_IRDA_MODULE_ENABLED   */ | ||||
| #define HAL_IWDG_MODULE_ENABLED | ||||
| /*#define HAL_NOR_MODULE_ENABLED   */ | ||||
| /*#define HAL_NAND_MODULE_ENABLED   */ | ||||
| /*#define HAL_PCCARD_MODULE_ENABLED   */ | ||||
| /*#define HAL_PCD_MODULE_ENABLED   */ | ||||
| /*#define HAL_HCD_MODULE_ENABLED   */ | ||||
| /*#define HAL_PWR_MODULE_ENABLED   */ | ||||
| /*#define HAL_RCC_MODULE_ENABLED   */ | ||||
| /*#define HAL_RTC_MODULE_ENABLED   */ | ||||
| /*#define HAL_SD_MODULE_ENABLED   */ | ||||
| /*#define HAL_MMC_MODULE_ENABLED   */ | ||||
| /*#define HAL_SDRAM_MODULE_ENABLED   */ | ||||
| /*#define HAL_SMARTCARD_MODULE_ENABLED   */ | ||||
| /*#define HAL_SPI_MODULE_ENABLED   */ | ||||
| /*#define HAL_SRAM_MODULE_ENABLED   */ | ||||
| #define HAL_TIM_MODULE_ENABLED | ||||
| /*#define HAL_UART_MODULE_ENABLED   */ | ||||
| /*#define HAL_USART_MODULE_ENABLED   */ | ||||
| /*#define HAL_WWDG_MODULE_ENABLED   */ | ||||
| 
 | ||||
| #define HAL_CORTEX_MODULE_ENABLED | ||||
| #define HAL_DMA_MODULE_ENABLED | ||||
| #define HAL_FLASH_MODULE_ENABLED | ||||
| #define HAL_EXTI_MODULE_ENABLED | ||||
| #define HAL_GPIO_MODULE_ENABLED | ||||
| #define HAL_PWR_MODULE_ENABLED | ||||
| #define HAL_RCC_MODULE_ENABLED | ||||
| 
 | ||||
| /* ########################## Oscillator 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 */ | ||||
| 
 | ||||
| #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 Internal Low Speed oscillator (LSI) value. | ||||
|   */ | ||||
| #if !defined  (LSI_VALUE) | ||||
|  #define LSI_VALUE               40000U    /*!< LSI Typical Value in Hz */ | ||||
| #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. | ||||
|   *        This value is used by the UART, RTC HAL module to compute the system frequency | ||||
|   */ | ||||
| #if !defined  (LSE_VALUE) | ||||
|   #define LSE_VALUE    32768U /*!< Value of the External oscillator in Hz*/ | ||||
| #endif /* LSE_VALUE */ | ||||
| 
 | ||||
| #if !defined  (LSE_STARTUP_TIMEOUT) | ||||
|   #define LSE_STARTUP_TIMEOUT    5000U   /*!< Time out for LSE start up, in ms */ | ||||
| #endif /* LSE_STARTUP_TIMEOUT */ | ||||
| 
 | ||||
| /* 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            0U    /*!< tick interrupt priority (lowest by default)  */ | ||||
| #define  USE_RTOS                     0U | ||||
| #define  PREFETCH_ENABLE              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_CEC_REGISTER_CALLBACKS         0U /* CEC register callback disabled       */ | ||||
| #define  USE_HAL_DAC_REGISTER_CALLBACKS         0U /* DAC register callback disabled       */ | ||||
| #define  USE_HAL_ETH_REGISTER_CALLBACKS         0U /* ETH register callback disabled       */ | ||||
| #define  USE_HAL_HCD_REGISTER_CALLBACKS         0U /* HCD register callback disabled       */ | ||||
| #define  USE_HAL_I2C_REGISTER_CALLBACKS         0U /* I2C register callback disabled       */ | ||||
| #define  USE_HAL_I2S_REGISTER_CALLBACKS         0U /* I2S register callback disabled       */ | ||||
| #define  USE_HAL_MMC_REGISTER_CALLBACKS         0U /* MMC 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_PCD_REGISTER_CALLBACKS         0U /* PCD register callback disabled       */ | ||||
| #define  USE_HAL_RTC_REGISTER_CALLBACKS         0U /* RTC register callback disabled       */ | ||||
| #define  USE_HAL_SD_REGISTER_CALLBACKS          0U /* SD register callback disabled        */ | ||||
| #define  USE_HAL_SMARTCARD_REGISTER_CALLBACKS   0U /* SMARTCARD register callback disabled */ | ||||
| #define  USE_HAL_IRDA_REGISTER_CALLBACKS        0U /* IRDA register callback disabled      */ | ||||
| #define  USE_HAL_SRAM_REGISTER_CALLBACKS        0U /* SRAM register callback disabled      */ | ||||
| #define  USE_HAL_SPI_REGISTER_CALLBACKS         0U /* SPI register callback disabled       */ | ||||
| #define  USE_HAL_TIM_REGISTER_CALLBACKS         0U /* TIM 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_WWDG_REGISTER_CALLBACKS        0U /* WWDG 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 */ | ||||
| 
 | ||||
| /* ################## Ethernet peripheral configuration ##################### */ | ||||
| 
 | ||||
| /* Section 1 : Ethernet peripheral configuration */ | ||||
| 
 | ||||
| /* MAC ADDRESS: MAC_ADDR0:MAC_ADDR1:MAC_ADDR2:MAC_ADDR3:MAC_ADDR4:MAC_ADDR5 */ | ||||
| #define MAC_ADDR0   2U | ||||
| #define MAC_ADDR1   0U | ||||
| #define MAC_ADDR2   0U | ||||
| #define MAC_ADDR3   0U | ||||
| #define MAC_ADDR4   0U | ||||
| #define MAC_ADDR5   0U | ||||
| 
 | ||||
| /* Definition of the Ethernet driver buffers size and count */ | ||||
| #define ETH_RX_BUF_SIZE                ETH_MAX_PACKET_SIZE /* buffer size for receive               */ | ||||
| #define ETH_TX_BUF_SIZE                ETH_MAX_PACKET_SIZE /* buffer size for transmit              */ | ||||
| #define ETH_RXBUFNB                    8U       /* 4 Rx buffers of size ETH_RX_BUF_SIZE  */ | ||||
| #define ETH_TXBUFNB                    4U       /* 4 Tx buffers of size ETH_TX_BUF_SIZE  */ | ||||
| 
 | ||||
| /* Section 2: PHY configuration section */ | ||||
| 
 | ||||
| /* DP83848_PHY_ADDRESS Address*/ | ||||
| #define DP83848_PHY_ADDRESS           0x01U | ||||
| /* PHY Reset delay these values are based on a 1 ms Systick interrupt*/ | ||||
| #define PHY_RESET_DELAY                 0x000000FFU | ||||
| /* PHY Configuration delay */ | ||||
| #define PHY_CONFIG_DELAY                0x00000FFFU | ||||
| 
 | ||||
| #define PHY_READ_TO                     0x0000FFFFU | ||||
| #define PHY_WRITE_TO                    0x0000FFFFU | ||||
| 
 | ||||
| /* Section 3: Common PHY Registers */ | ||||
| 
 | ||||
| #define PHY_BCR                         ((uint16_t)0x00)    /*!< Transceiver Basic Control Register   */ | ||||
| #define PHY_BSR                         ((uint16_t)0x01)    /*!< Transceiver Basic Status Register    */ | ||||
| 
 | ||||
| #define PHY_RESET                       ((uint16_t)0x8000)  /*!< PHY Reset */ | ||||
| #define PHY_LOOPBACK                    ((uint16_t)0x4000)  /*!< Select loop-back mode */ | ||||
| #define PHY_FULLDUPLEX_100M             ((uint16_t)0x2100)  /*!< Set the full-duplex mode at 100 Mb/s */ | ||||
| #define PHY_HALFDUPLEX_100M             ((uint16_t)0x2000)  /*!< Set the half-duplex mode at 100 Mb/s */ | ||||
| #define PHY_FULLDUPLEX_10M              ((uint16_t)0x0100)  /*!< Set the full-duplex mode at 10 Mb/s  */ | ||||
| #define PHY_HALFDUPLEX_10M              ((uint16_t)0x0000)  /*!< Set the half-duplex mode at 10 Mb/s  */ | ||||
| #define PHY_AUTONEGOTIATION             ((uint16_t)0x1000)  /*!< Enable auto-negotiation function     */ | ||||
| #define PHY_RESTART_AUTONEGOTIATION     ((uint16_t)0x0200)  /*!< Restart auto-negotiation function    */ | ||||
| #define PHY_POWERDOWN                   ((uint16_t)0x0800)  /*!< Select the power down mode           */ | ||||
| #define PHY_ISOLATE                     ((uint16_t)0x0400)  /*!< Isolate PHY from MII                 */ | ||||
| 
 | ||||
| #define PHY_AUTONEGO_COMPLETE           ((uint16_t)0x0020)  /*!< Auto-Negotiation process completed   */ | ||||
| #define PHY_LINKED_STATUS               ((uint16_t)0x0004)  /*!< Valid link established               */ | ||||
| #define PHY_JABBER_DETECTION            ((uint16_t)0x0002)  /*!< Jabber condition detected            */ | ||||
| 
 | ||||
| /* Section 4: Extended PHY Registers */ | ||||
| #define PHY_SR                          ((uint16_t)0x10U)    /*!< PHY status register Offset                      */ | ||||
| 
 | ||||
| #define PHY_SPEED_STATUS                ((uint16_t)0x0002U)  /*!< PHY Speed mask                                  */ | ||||
| #define PHY_DUPLEX_STATUS               ((uint16_t)0x0004U)  /*!< PHY Duplex mask                                 */ | ||||
| 
 | ||||
| /* ################## SPI peripheral configuration ########################## */ | ||||
| 
 | ||||
| /* CRC FEATURE: Use to activate CRC feature inside HAL SPI Driver
 | ||||
| * Activated: CRC code is present inside driver | ||||
| * Deactivated: CRC code cleaned from driver | ||||
| */ | ||||
| 
 | ||||
| #define USE_SPI_CRC                     0U | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| /**
 | ||||
|   * @brief Include module's header file | ||||
|   */ | ||||
| 
 | ||||
| #ifdef HAL_RCC_MODULE_ENABLED | ||||
| #include "stm32f1xx_hal_rcc.h" | ||||
| #endif /* HAL_RCC_MODULE_ENABLED */ | ||||
| 
 | ||||
| #ifdef HAL_GPIO_MODULE_ENABLED | ||||
| #include "stm32f1xx_hal_gpio.h" | ||||
| #endif /* HAL_GPIO_MODULE_ENABLED */ | ||||
| 
 | ||||
| #ifdef HAL_EXTI_MODULE_ENABLED | ||||
| #include "stm32f1xx_hal_exti.h" | ||||
| #endif /* HAL_EXTI_MODULE_ENABLED */ | ||||
| 
 | ||||
| #ifdef HAL_DMA_MODULE_ENABLED | ||||
| #include "stm32f1xx_hal_dma.h" | ||||
| #endif /* HAL_DMA_MODULE_ENABLED */ | ||||
| 
 | ||||
| #ifdef HAL_ETH_MODULE_ENABLED | ||||
| #include "stm32f1xx_hal_eth.h" | ||||
| #endif /* HAL_ETH_MODULE_ENABLED */ | ||||
| 
 | ||||
| #ifdef HAL_CAN_MODULE_ENABLED | ||||
| #include "stm32f1xx_hal_can.h" | ||||
| #endif /* HAL_CAN_MODULE_ENABLED */ | ||||
| 
 | ||||
| #ifdef HAL_CAN_LEGACY_MODULE_ENABLED | ||||
|   #include "Legacy/stm32f1xx_hal_can_legacy.h" | ||||
| #endif /* HAL_CAN_LEGACY_MODULE_ENABLED */ | ||||
| 
 | ||||
| #ifdef HAL_CEC_MODULE_ENABLED | ||||
| #include "stm32f1xx_hal_cec.h" | ||||
| #endif /* HAL_CEC_MODULE_ENABLED */ | ||||
| 
 | ||||
| #ifdef HAL_CORTEX_MODULE_ENABLED | ||||
| #include "stm32f1xx_hal_cortex.h" | ||||
| #endif /* HAL_CORTEX_MODULE_ENABLED */ | ||||
| 
 | ||||
| #ifdef HAL_ADC_MODULE_ENABLED | ||||
| #include "stm32f1xx_hal_adc.h" | ||||
| #endif /* HAL_ADC_MODULE_ENABLED */ | ||||
| 
 | ||||
| #ifdef HAL_CRC_MODULE_ENABLED | ||||
| #include "stm32f1xx_hal_crc.h" | ||||
| #endif /* HAL_CRC_MODULE_ENABLED */ | ||||
| 
 | ||||
| #ifdef HAL_DAC_MODULE_ENABLED | ||||
| #include "stm32f1xx_hal_dac.h" | ||||
| #endif /* HAL_DAC_MODULE_ENABLED */ | ||||
| 
 | ||||
| #ifdef HAL_FLASH_MODULE_ENABLED | ||||
| #include "stm32f1xx_hal_flash.h" | ||||
| #endif /* HAL_FLASH_MODULE_ENABLED */ | ||||
| 
 | ||||
| #ifdef HAL_SRAM_MODULE_ENABLED | ||||
| #include "stm32f1xx_hal_sram.h" | ||||
| #endif /* HAL_SRAM_MODULE_ENABLED */ | ||||
| 
 | ||||
| #ifdef HAL_NOR_MODULE_ENABLED | ||||
| #include "stm32f1xx_hal_nor.h" | ||||
| #endif /* HAL_NOR_MODULE_ENABLED */ | ||||
| 
 | ||||
| #ifdef HAL_I2C_MODULE_ENABLED | ||||
| #include "stm32f1xx_hal_i2c.h" | ||||
| #endif /* HAL_I2C_MODULE_ENABLED */ | ||||
| 
 | ||||
| #ifdef HAL_I2S_MODULE_ENABLED | ||||
| #include "stm32f1xx_hal_i2s.h" | ||||
| #endif /* HAL_I2S_MODULE_ENABLED */ | ||||
| 
 | ||||
| #ifdef HAL_IWDG_MODULE_ENABLED | ||||
| #include "stm32f1xx_hal_iwdg.h" | ||||
| #endif /* HAL_IWDG_MODULE_ENABLED */ | ||||
| 
 | ||||
| #ifdef HAL_PWR_MODULE_ENABLED | ||||
| #include "stm32f1xx_hal_pwr.h" | ||||
| #endif /* HAL_PWR_MODULE_ENABLED */ | ||||
| 
 | ||||
| #ifdef HAL_RTC_MODULE_ENABLED | ||||
| #include "stm32f1xx_hal_rtc.h" | ||||
| #endif /* HAL_RTC_MODULE_ENABLED */ | ||||
| 
 | ||||
| #ifdef HAL_PCCARD_MODULE_ENABLED | ||||
| #include "stm32f1xx_hal_pccard.h" | ||||
| #endif /* HAL_PCCARD_MODULE_ENABLED */ | ||||
| 
 | ||||
| #ifdef HAL_SD_MODULE_ENABLED | ||||
| #include "stm32f1xx_hal_sd.h" | ||||
| #endif /* HAL_SD_MODULE_ENABLED */ | ||||
| 
 | ||||
| #ifdef HAL_NAND_MODULE_ENABLED | ||||
| #include "stm32f1xx_hal_nand.h" | ||||
| #endif /* HAL_NAND_MODULE_ENABLED */ | ||||
| 
 | ||||
| #ifdef HAL_SPI_MODULE_ENABLED | ||||
| #include "stm32f1xx_hal_spi.h" | ||||
| #endif /* HAL_SPI_MODULE_ENABLED */ | ||||
| 
 | ||||
| #ifdef HAL_TIM_MODULE_ENABLED | ||||
| #include "stm32f1xx_hal_tim.h" | ||||
| #endif /* HAL_TIM_MODULE_ENABLED */ | ||||
| 
 | ||||
| #ifdef HAL_UART_MODULE_ENABLED | ||||
| #include "stm32f1xx_hal_uart.h" | ||||
| #endif /* HAL_UART_MODULE_ENABLED */ | ||||
| 
 | ||||
| #ifdef HAL_USART_MODULE_ENABLED | ||||
| #include "stm32f1xx_hal_usart.h" | ||||
| #endif /* HAL_USART_MODULE_ENABLED */ | ||||
| 
 | ||||
| #ifdef HAL_IRDA_MODULE_ENABLED | ||||
| #include "stm32f1xx_hal_irda.h" | ||||
| #endif /* HAL_IRDA_MODULE_ENABLED */ | ||||
| 
 | ||||
| #ifdef HAL_SMARTCARD_MODULE_ENABLED | ||||
| #include "stm32f1xx_hal_smartcard.h" | ||||
| #endif /* HAL_SMARTCARD_MODULE_ENABLED */ | ||||
| 
 | ||||
| #ifdef HAL_WWDG_MODULE_ENABLED | ||||
| #include "stm32f1xx_hal_wwdg.h" | ||||
| #endif /* HAL_WWDG_MODULE_ENABLED */ | ||||
| 
 | ||||
| #ifdef HAL_PCD_MODULE_ENABLED | ||||
| #include "stm32f1xx_hal_pcd.h" | ||||
| #endif /* HAL_PCD_MODULE_ENABLED */ | ||||
| 
 | ||||
| #ifdef HAL_HCD_MODULE_ENABLED | ||||
| #include "stm32f1xx_hal_hcd.h" | ||||
| #endif /* HAL_HCD_MODULE_ENABLED */ | ||||
| 
 | ||||
| #ifdef HAL_MMC_MODULE_ENABLED | ||||
| #include "stm32f1xx_hal_mmc.h" | ||||
| #endif /* HAL_MMC_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 /* __STM32F1xx_HAL_CONF_H */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
| @ -59,6 +59,7 @@ void SysTick_Handler(void); | ||||
| void USB_HP_CAN1_TX_IRQHandler(void); | ||||
| void USB_LP_CAN1_RX0_IRQHandler(void); | ||||
| void TIM4_IRQHandler(void); | ||||
| void TIM8_UP_IRQHandler(void); | ||||
| /* USER CODE BEGIN EFP */ | ||||
| 
 | ||||
| /* USER CODE END EFP */ | ||||
| @ -68,5 +69,3 @@ void TIM4_IRQHandler(void); | ||||
| #endif | ||||
| 
 | ||||
| #endif /* __STM32F1xx_IT_H */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | ||||
| @ -1,3 +1,4 @@ | ||||
| /* USER CODE BEGIN Header */ | ||||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    tim.h | ||||
| @ -6,16 +7,16 @@ | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© Copyright (c) 2025 STMicroelectronics. | ||||
|   * All rights reserved.</center></h2> | ||||
|   * Copyright (c) 2025 STMicroelectronics. | ||||
|   * All rights reserved. | ||||
|   * | ||||
|   * 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 | ||||
|   * 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 */ | ||||
| /* Define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef __TIM_H__ | ||||
| #define __TIM_H__ | ||||
| @ -49,4 +50,3 @@ void MX_TIM4_Init(void); | ||||
| 
 | ||||
| #endif /* __TIM_H__ */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | ||||
| @ -1,3 +1,4 @@ | ||||
| /* USER CODE BEGIN Header */ | ||||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    can.c | ||||
| @ -6,17 +7,16 @@ | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© Copyright (c) 2025 STMicroelectronics. | ||||
|   * All rights reserved.</center></h2> | ||||
|   * Copyright (c) 2025 STMicroelectronics. | ||||
|   * All rights reserved. | ||||
|   * | ||||
|   * 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 | ||||
|   * 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 "can.h" | ||||
| 
 | ||||
| @ -175,8 +175,8 @@ void HAL_CAN_MspDeInit(CAN_HandleTypeDef* canHandle) | ||||
| 
 | ||||
| void Setup_CAN_addr(uint8_t mode) | ||||
| { | ||||
|   	BC_box_ID = 0x1F<<20; | ||||
| 	RX_box_ID = mode<<20; | ||||
|   	BC_box_ID = 0x9F<<20; | ||||
| 	RX_box_ID = (0x80+mode)<<20; | ||||
| 	TX_box_ID = RX_box_ID | (1L<<28); | ||||
| } | ||||
| 
 | ||||
| @ -271,5 +271,3 @@ int CAN_send(uint16_t data[], int Addr, int Qua) | ||||
| }	} | ||||
| 
 | ||||
| /* USER CODE END 1 */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | ||||
| @ -1,3 +1,4 @@ | ||||
| /* USER CODE BEGIN Header */ | ||||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    gpio.c | ||||
| @ -6,16 +7,16 @@ | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© Copyright (c) 2025 STMicroelectronics. | ||||
|   * All rights reserved.</center></h2> | ||||
|   * Copyright (c) 2025 STMicroelectronics. | ||||
|   * All rights reserved. | ||||
|   * | ||||
|   * 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 | ||||
|   * 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 "gpio.h" | ||||
| @ -45,38 +46,51 @@ void MX_GPIO_Init(void) | ||||
|   __HAL_RCC_GPIOA_CLK_ENABLE(); | ||||
|   __HAL_RCC_GPIOB_CLK_ENABLE(); | ||||
| 
 | ||||
| // INPUT C
 | ||||
|   GPIO_InitStruct.Pin = IN_06_Pin|Jselect_Pin|IN_05_Pin|J2_Pin|J3_Pin; | ||||
|   /*Configure GPIO pin Output Level */ | ||||
|   HAL_GPIO_WritePin(GPIOC, LED1_Pin|LED2_Pin|PVT4_Pin|PVT3_Pin | ||||
|                           |PVT2_Pin|PVT1_Pin, GPIO_PIN_RESET); | ||||
| 
 | ||||
|   /*Configure GPIO pins : PCPin PCPin PCPin PC0
 | ||||
|                            PC1 PCPin PCPin */ | ||||
|   GPIO_InitStruct.Pin = IN_06_Pin|SELEKT_PCH_Pin|IN_05_Pin|GPIO_PIN_0 | ||||
|                           |GPIO_PIN_1|J1_Pin|J2_Pin; | ||||
|   GPIO_InitStruct.Mode = GPIO_MODE_INPUT; | ||||
|   GPIO_InitStruct.Pull = GPIO_NOPULL; | ||||
|   HAL_GPIO_Init(GPIOC, &GPIO_InitStruct); | ||||
| 
 | ||||
| // OUTPUT C
 | ||||
|   GPIO_InitStruct.Pin = LED2_Pin|LED3_Pin|PVT4_Pin|PVT3_Pin|PVT2_Pin|PVT1_Pin; | ||||
|   /*Configure GPIO pins : PD0 PD1 */ | ||||
|   GPIO_InitStruct.Pin = GPIO_PIN_0|GPIO_PIN_1; | ||||
|   GPIO_InitStruct.Mode = GPIO_MODE_INPUT; | ||||
|   GPIO_InitStruct.Pull = GPIO_NOPULL; | ||||
|   HAL_GPIO_Init(GPIOD, &GPIO_InitStruct); | ||||
| 
 | ||||
|   /*Configure GPIO pins : PCPin PCPin PCPin PCPin
 | ||||
|                            PCPin PCPin */ | ||||
|   GPIO_InitStruct.Pin = LED1_Pin|LED2_Pin|PVT4_Pin|PVT3_Pin | ||||
|                           |PVT2_Pin|PVT1_Pin; | ||||
|   GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP; | ||||
|   GPIO_InitStruct.Pull = GPIO_NOPULL; | ||||
|   GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW; | ||||
|   HAL_GPIO_Init(GPIOC, &GPIO_InitStruct); | ||||
| 
 | ||||
| // INPUT A
 | ||||
|   GPIO_InitStruct.Pin = IN_04_Pin|IN_03_Pin|IN_02_Pin|IN_01_Pin|IN_14_Pin|IN_13_Pin|J0_Pin|J1_Pin; | ||||
|   /*Configure GPIO pins : PAPin PAPin PAPin PAPin
 | ||||
|                            PAPin PAPin PA6 PAPin */ | ||||
|   GPIO_InitStruct.Pin = IN_04_Pin|IN_03_Pin|IN_02_Pin|IN_01_Pin | ||||
|                           |IN_14_Pin|IN_13_Pin|GPIO_PIN_6|J0_Pin; | ||||
|   GPIO_InitStruct.Mode = GPIO_MODE_INPUT; | ||||
|   GPIO_InitStruct.Pull = GPIO_NOPULL; | ||||
|   HAL_GPIO_Init(GPIOA, &GPIO_InitStruct); | ||||
| 
 | ||||
| // INPUT B
 | ||||
|   GPIO_InitStruct.Pin = IN_12_Pin|IN_11_Pin|IN_10_Pin|IN_09_Pin|IN_08_Pin|IN_07_Pin; | ||||
|   /*Configure GPIO pins : PBPin PBPin PBPin PBPin
 | ||||
|                            PB11 PBPin PBPin PBPin | ||||
|                            PBPin */ | ||||
|   GPIO_InitStruct.Pin = J3_Pin|IN_12_Pin|BOOT1_Pin|IN_11_Pin | ||||
|                           |GPIO_PIN_11|IN_10_Pin|IN_09_Pin|IN_08_Pin | ||||
|                           |IN_07_Pin; | ||||
|   GPIO_InitStruct.Mode = GPIO_MODE_INPUT; | ||||
|   GPIO_InitStruct.Pull = GPIO_NOPULL; | ||||
|   HAL_GPIO_Init(GPIOB, &GPIO_InitStruct); | ||||
| 
 | ||||
| // OUTPUT B
 | ||||
|   GPIO_InitStruct.Pin = LED0_Pin|LED1_Pin; | ||||
|   GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP; | ||||
|   GPIO_InitStruct.Pull = GPIO_NOPULL; | ||||
|   GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW; | ||||
|   HAL_GPIO_Init(GPIOB, &GPIO_InitStruct); | ||||
| 
 | ||||
|   /*Configure GPIO pin : PA8 */ | ||||
|   GPIO_InitStruct.Pin = GPIO_PIN_8; | ||||
|   GPIO_InitStruct.Mode = GPIO_MODE_AF_PP; | ||||
| @ -91,5 +105,3 @@ void MX_GPIO_Init(void) | ||||
| /* USER CODE BEGIN 2 */ | ||||
| 
 | ||||
| /* USER CODE END 2 */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | ||||
							
								
								
									
										55
									
								
								Core/Src/iwdg.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								Core/Src/iwdg.c
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,55 @@ | ||||
| /* USER CODE BEGIN Header */ | ||||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    iwdg.c | ||||
|   * @brief   This file provides code for the configuration | ||||
|   *          of the IWDG instances. | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * Copyright (c) 2025 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 "iwdg.h" | ||||
| 
 | ||||
| /* USER CODE BEGIN 0 */ | ||||
| 
 | ||||
| /* USER CODE END 0 */ | ||||
| 
 | ||||
| IWDG_HandleTypeDef hiwdg; | ||||
| 
 | ||||
| /* IWDG init function */ | ||||
| void MX_IWDG_Init(void) | ||||
| { | ||||
| 
 | ||||
|   /* USER CODE BEGIN IWDG_Init 0 */ | ||||
| 
 | ||||
|   /* USER CODE END IWDG_Init 0 */ | ||||
| 
 | ||||
|   /* USER CODE BEGIN IWDG_Init 1 */ | ||||
| 
 | ||||
|   /* USER CODE END IWDG_Init 1 */ | ||||
|   hiwdg.Instance = IWDG; | ||||
|   hiwdg.Init.Prescaler = IWDG_PRESCALER_4; | ||||
|   hiwdg.Init.Reload = 4095; | ||||
|   if (HAL_IWDG_Init(&hiwdg) != HAL_OK) | ||||
|   { | ||||
|     Error_Handler(); | ||||
|   } | ||||
|   /* USER CODE BEGIN IWDG_Init 2 */ | ||||
| 
 | ||||
|   /* USER CODE END IWDG_Init 2 */ | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| /* USER CODE BEGIN 1 */ | ||||
| 
 | ||||
| /* USER CODE END 1 */ | ||||
| @ -7,7 +7,7 @@ | ||||
| 
 | ||||
| void ReadEnteres(void) | ||||
| { | ||||
|   WORDE input; | ||||
|   WORDE input, alarm, error; | ||||
| 
 | ||||
| 	input.bit.bit0 = !IN_06;	//	Контроль ИП1 (питание управляющего контроллера)
 | ||||
| 	input.bit.bit1 = !IN_05;	//	Контроль ИП2 (питание периферийных устройств)
 | ||||
| @ -32,12 +32,16 @@ void ReadEnteres(void) | ||||
| 	input.bit.bitD = !IN_14;	//	Контроль питания СКК
 | ||||
| */	 | ||||
| 	Inputs.all = input.all; | ||||
| 	Alarms.all = ~Inputs.all & Alarm_mask.all; | ||||
| 	Alarms.bit.bit7 = 0;				//	Заряд накопителя
 | ||||
| 	Alarms.bit.bit8 = Inputs.bit.bit8;	//	Разряд накопителя
 | ||||
| 	Alarms.bit.bit9 = Inputs.bit.bit9;	//	Авария в сети 24 В
 | ||||
| 	Errors.all = ~Inputs.all & Error_mask.all; | ||||
| 	Errors.bit.bit9 = Inputs.bit.bit9;	//	Авария в сети 24 В
 | ||||
| 	 | ||||
| 	alarm.all = ~Inputs.all & Alarm_mask.all; | ||||
| 	alarm.bit.bit7 = 0;				//	Заряд накопителя
 | ||||
| 	alarm.bit.bit8 = Inputs.bit.bit8;	//	Разряд накопителя
 | ||||
| 	alarm.bit.bit9 = Inputs.bit.bit9;	//	Авария в сети 24 В
 | ||||
| 	Alarms = alarm; | ||||
| 	 | ||||
| 	error.all = ~Inputs.all & Error_mask.all; | ||||
| 	error.bit.bit9 = Inputs.bit.bit9;	//	Авария в сети 24 В
 | ||||
| 	Errors = error; | ||||
| } | ||||
| 
 | ||||
| uint16_t ReadJumpers(void) | ||||
| @ -62,10 +66,21 @@ uint16_t TestJumper(void) | ||||
| void ReadSeanus(void) | ||||
| { | ||||
|   static uint32_t cownt=0; | ||||
|   static uint32_t sum_u[4]={0,0,0,0}; | ||||
| //  static float flt_u[4]={0,0,0,0};
 | ||||
|   static uint32_t sum_u[4]; | ||||
|   static float flt_u[4]; | ||||
|   static uint8_t Ist=1; | ||||
|   uint8_t i; | ||||
| 	 | ||||
| 	if(Ist) | ||||
| 	{ | ||||
| 		Ist=0; | ||||
| 		for(i=0;i<4;i++) | ||||
| 		{ | ||||
| 			Squazh_U[i]=100; | ||||
| 			flt_u[i]=10000.0; | ||||
| 			sum_u[i]=0; | ||||
| 	}	} | ||||
| 		 | ||||
| 	sum_u[0] += !IN_11; | ||||
| 	sum_u[1] += !IN_12; | ||||
| 	sum_u[2] += !IN_13; | ||||
| @ -77,8 +92,8 @@ void ReadSeanus(void) | ||||
| 		 | ||||
| 		for(i=0;i<4;i++) | ||||
| 		{ | ||||
| //			flt_u[i] +=((float)sum_u[i]-flt_u[i])/10+1;
 | ||||
| 			Squazh_U[i]=sum_u[i]/100; | ||||
| 			flt_u[i] +=((float)sum_u[i]-flt_u[i])/3+1; | ||||
| 			Squazh_U[i]=flt_u[i]/100; | ||||
| 			sum_u[i] = 0; | ||||
| }	}	} | ||||
| 
 | ||||
|  | ||||
							
								
								
									
										263
									
								
								Core/Src/main.c
									
									
									
									
									
								
							
							
						
						
									
										263
									
								
								Core/Src/main.c
									
									
									
									
									
								
							| @ -20,6 +20,7 @@ | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "main.h" | ||||
| #include "can.h" | ||||
| #include "iwdg.h" | ||||
| #include "tim.h" | ||||
| #include "gpio.h" | ||||
| 
 | ||||
| @ -34,7 +35,7 @@ | ||||
| 
 | ||||
| /* Private typedef -----------------------------------------------------------*/ | ||||
| /* USER CODE BEGIN PTD */ | ||||
| 
 | ||||
| FLAG flag; | ||||
| /* USER CODE END PTD */ | ||||
| 
 | ||||
| /* Private define ------------------------------------------------------------*/ | ||||
| @ -51,7 +52,7 @@ | ||||
| /* USER CODE BEGIN PV */ | ||||
| 
 | ||||
| static long Falling_asleep; | ||||
| int CanGO=0; | ||||
| uint8_t CanGO=0, timGo=0; | ||||
| 
 | ||||
| /* USER CODE END PV */ | ||||
| 
 | ||||
| @ -64,17 +65,20 @@ void SystemClock_Config(void); | ||||
| /* Private user code ---------------------------------------------------------*/ | ||||
| /* USER CODE BEGIN 0 */ | ||||
| 
 | ||||
| int Isit(int num, int i) | ||||
| int Isit(int num, int i, int z) | ||||
| { | ||||
|   int res, pls; | ||||
| 
 | ||||
| 	if((num<0)||(num>=0x80)) return 0; | ||||
| 	res = Maska[0][num/0x10];	if(i) | ||||
| 	res|= Maska[1][num/0x10]; | ||||
| 	res = Maska[i][num/0x10]; | ||||
| 	res &= (1<<(num&0x0F)); | ||||
| 	pls = (espero[num]>CanRestart[i]/3); | ||||
| 	pls = pls || county[num]; | ||||
| 	res = res && pls; | ||||
| 	 | ||||
| 	if(z) | ||||
| 	{ | ||||
| 		pls = (espero[num]>CanRestart[i]/2); | ||||
| 		pls = pls || county[num]; | ||||
| 		res = res && pls; | ||||
| 	} | ||||
| 
 | ||||
| 	return res; | ||||
| } | ||||
| @ -87,12 +91,14 @@ int Isit(int num, int i) | ||||
|   */ | ||||
| int main(void) | ||||
| { | ||||
| 
 | ||||
|   /* USER CODE BEGIN 1 */ | ||||
| 
 | ||||
|   int i,j,n,mask,qua; | ||||
|   static int i,j,n,z,mask,qua; | ||||
|   static int cancount[2]={1,2},cancell[2]={0,0},candid[2]={0,0}; | ||||
|   static unsigned int masca[8]; | ||||
| 		 | ||||
|   static uint16_t precom=0; | ||||
| 
 | ||||
|   /* USER CODE END 1 */ | ||||
| 
 | ||||
|   /* MCU Configuration--------------------------------------------------------*/ | ||||
| @ -101,7 +107,7 @@ int main(void) | ||||
|   HAL_Init(); | ||||
| 
 | ||||
|   /* USER CODE BEGIN Init */ | ||||
| 
 | ||||
|  MX_IWDG_Init(); | ||||
|   /* USER CODE END Init */ | ||||
| 
 | ||||
|   /* Configure the system clock */ | ||||
| @ -115,12 +121,39 @@ int main(void) | ||||
|   MX_GPIO_Init(); | ||||
|   MX_CAN_Init(); | ||||
|   MX_TIM4_Init(); | ||||
|  // MX_IWDG_Init();
 | ||||
|   /* USER CODE BEGIN 2 */ | ||||
|      | ||||
|   	Mode = ReadJumpers(); | ||||
| 	Setup_CAN_addr(Mode); | ||||
| 	LastMode = Mode; | ||||
| 
 | ||||
|   LED_0_ON; | ||||
| 	LED_1_OFF; | ||||
| 	LED_2_ON; | ||||
| 	LED_3_OFF; | ||||
| 
 | ||||
| 	for(i=0;i<10;i++) | ||||
| 	{ | ||||
| 		LED_0_TGL; | ||||
| 		LED_1_TGL; | ||||
| 		LED_2_TGL; | ||||
| 		LED_3_TGL;	HAL_Delay(50); | ||||
| 	} | ||||
| 
 | ||||
|   	Mode = ReadJumpers()+1; | ||||
| 	Setup_CAN_addr(Mode-1); | ||||
| 	Load_params();	 | ||||
| 	LastMode = Mode; | ||||
| 	Protokol = PROTOKOL; | ||||
| 	 | ||||
| 	command=0; | ||||
| 	 | ||||
| 	for(i=0;i<0x80;i++) | ||||
| 	county[i]=1; | ||||
| 	for(i=0;i<8;i++) | ||||
| 	masca[i]=0; | ||||
| 	for(i=0;i<2;i++) | ||||
| 	CanRound[i]= | ||||
| 	CanCycle[i]=0; | ||||
| 
 | ||||
| 	timGo=1; | ||||
| 
 | ||||
|   /* USER CODE END 2 */ | ||||
| 
 | ||||
| @ -128,6 +161,13 @@ int main(void) | ||||
|   /* USER CODE BEGIN WHILE */ | ||||
| 	while (1) | ||||
| 	{ | ||||
| 		if (flag.force_pause) | ||||
| 		{ | ||||
| 		__disable_irq();	 | ||||
| 			for(int i=0;i<flag.pause;i++); | ||||
| 		__enable_irq();	 | ||||
| 		} | ||||
| 			 | ||||
| 		if( CanGO) | ||||
| 		{	CanGO=0; | ||||
| 			 | ||||
| @ -136,6 +176,7 @@ int main(void) | ||||
| 				 | ||||
| 			for(i=0;i<2;i++) | ||||
| 			if(cancount[i]) cancount[i]--; | ||||
| 			else cancell[i] = 0; | ||||
| 		} | ||||
| 			 | ||||
| 		for(i=0;i<2;i++) | ||||
| @ -151,9 +192,9 @@ int main(void) | ||||
| 					{	candid[i]=0; | ||||
| 						CanCycle[i]++; | ||||
| 						cancount[i] = CanWait[i]; | ||||
| 						continue; | ||||
| 				}	} | ||||
| 
 | ||||
| 						goto Next; | ||||
| 				}	}	 | ||||
| 				 | ||||
| 				mask = Maska[i][cancell[i]/0x10] >> (cancell[i]&0x0F); | ||||
| 				if(!mask) cancell[i] = (cancell[i] + 0x10) & 0xFFF0 ; | ||||
| 				else | ||||
| @ -165,18 +206,26 @@ int main(void) | ||||
| 					break; | ||||
| 			}	} | ||||
| 				 | ||||
| 				 | ||||
| 			z=1; | ||||
| 			if(espero[cancell[i]]>CanRestart[i]) | ||||
| 			county[cancell[i]]=1; | ||||
| 
 | ||||
| 			{ | ||||
| 				county[cancell[i]]=1; | ||||
| 				z=0; | ||||
| 			} | ||||
| 			 | ||||
| 			if(modbus[cancell[i]] != archiv[cancell[i]]) | ||||
| 
 | ||||
| 			county[cancell[i]] = (cancell[i]==keys) ? CanRepeat:1; | ||||
| 			{	 | ||||
| 				if(cancell[i]==keys) | ||||
| 				for(j=0;j<CanRptLen;j++) | ||||
| 				county[cancell[i]+j] = CanRptVez; | ||||
| 				else	 | ||||
| 				county[cancell[i]] = 1; | ||||
| 			} | ||||
| 
 | ||||
| 			if (county[cancell[i]]) | ||||
| 			{ | ||||
| 				for(j=  3; j>0 && !Isit(cancell[i]+j,i); j--); | ||||
| 				for(n=j-3; n<0 && !Isit(cancell[i]+n,i); n++); | ||||
| 				for(j=  3; j>0 && !Isit(cancell[i]+j,i,z); j--); | ||||
| 				for(n=j-3; n<0 && !Isit(cancell[i]+n,i,1); n++); | ||||
| 
 | ||||
| 				qua = 1 + j - n; | ||||
| 				cancell[i]+= n; | ||||
| @ -184,8 +233,9 @@ int main(void) | ||||
| 				for(j=0;j<qua;j++) | ||||
| 				{ | ||||
| 					n=cancell[i]+j; | ||||
| 
 | ||||
| 					archiv[n]= modbus[n]; espero[n]= 0; | ||||
| 					archiv[n]= modbus[n];  | ||||
| 					espero[n]= 0; | ||||
| 					 | ||||
| 					if( county[n]) | ||||
| 					{	county[n]--; | ||||
| 						if(!county[n] && n != cancyclo+i)	candid[i]=1; | ||||
| @ -206,29 +256,35 @@ int main(void) | ||||
| 					CanRound[i]++; | ||||
| 				} | ||||
| 
 | ||||
| 				if( Cancount[i]>1) | ||||
| 				if(!cancount[!i]) | ||||
| 					cancount[!i]=1;	// ????? ?? ?????
 | ||||
| 					cancount[!i]=1; | ||||
| 			} | ||||
| 			else	cancell[i]++;  | ||||
| 		}	 | ||||
| 			else	 | ||||
| 				cancell[i]++;  | ||||
| 		} | ||||
| 	   | ||||
| 		Next: | ||||
| 		 | ||||
| 		ReadEnteres();	 | ||||
| 		 | ||||
| //		ReadSeanus();
 | ||||
| 			 | ||||
| 		if(Alarms.all)	Pvt4_OFF;	//	ñèãíàë "Ñèñòåìà ÂÝÏ â íîðìå"
 | ||||
| 		else			Pvt4_ON; | ||||
| 		if(Errors.all|Alarms.all) | ||||
| 						Pvt4_OFF; | ||||
| 		else			Pvt4_ON;	//	ñèãíàë "Ñèñòåìà ÂÝÏ â íîðìå"
 | ||||
| 			 | ||||
| 		if(Errors.all)	Pvt3_ON;	//	ñèãíàë "Àâàðèÿ ñèñòåìû ÂÝÏ"
 | ||||
| 		else			Pvt3_OFF; | ||||
| 			 | ||||
| 		if(Inputs.bit.bit9)	Pvt2_OFF;		//	?????? ? ???? 24 ?
 | ||||
| 		else				Pvt2_ON;		//	?????? "?????????? ????? 24?"
 | ||||
| 		 | ||||
| 		if (Falling_asleep)	Pvt2_ON;		//	Ïîêà íå ñïèì, ýòî çàìêíóòî
 | ||||
| 		if(Falling_asleep)	Pvt2_ON;		//	Ïîêà íå ñïèì, ýòî çàìêíóòî
 | ||||
| 		else				Pvt2_OFF;		//	ñèãíàë "Óïðàâëåíèå ñåòüþ 24Â"
 | ||||
| 		 | ||||
| 
 | ||||
| 
 | ||||
| 		if(Commands!=precom) | ||||
| 		{ | ||||
| 			command= (~precom|command) & Commands; | ||||
| 		} | ||||
| 		precom = Commands; | ||||
| 		 | ||||
| 		if(cDefParam) | ||||
| 		{ | ||||
| 			cDefParam=0; | ||||
| @ -245,6 +301,21 @@ int main(void) | ||||
| 		{ | ||||
| 			cLoadParam=0; | ||||
| 			Load_params(); | ||||
| 		} | ||||
| 
 | ||||
| 		if(cCanReset) | ||||
| 		{ | ||||
| 			cCanReset=0; | ||||
| 
 | ||||
| 			for(i=0;i<0x80;i++) | ||||
| 			county[i]=1; | ||||
| 			for(i=0;i<2;i++) | ||||
| 			CanCycle[i]= | ||||
| 			CanRound[i]= | ||||
| 			cancount[i]= | ||||
| 			cancell[i]=0; | ||||
| 			for(i=0;i<8;i++) | ||||
| 			masca[i]=0; | ||||
| }	}	} | ||||
| 	 | ||||
|     /* USER CODE END WHILE */ | ||||
| @ -263,11 +334,14 @@ void Millisecond() | ||||
| 
 | ||||
| #define CANPOWSE 10		//	10 msec
 | ||||
| #define BLINK_TIME 250	//	.25 sec
 | ||||
| 
 | ||||
|   	if(!cReset) | ||||
| 	 IWDG->KR = 0xAAAA;//HAL_IWDG_Refresh(&hiwdg);
 | ||||
|    | ||||
| //	ReadSeanus();
 | ||||
|    | ||||
| 	if(!timGo) return; | ||||
| 
 | ||||
| 	Jumpers.byt.byte_1 = ReadJumpers(); | ||||
| 	Jumpers.bit.bit0 = TestJumper(); | ||||
| 	Jumpers.bit.bit0 =  | ||||
| 	Buttons.bit.bit0 = TestJumper(); | ||||
|    | ||||
| 	if(++CanPowse >= CANPOWSE) | ||||
| @ -281,24 +355,8 @@ void Millisecond() | ||||
| 	} | ||||
| 	else	Falling_asleep = 1000L * Sleep_time; | ||||
| 	 | ||||
| 	if(work_diod)	LED_2_ON; | ||||
| 	else			LED_2_OFF; | ||||
| 
 | ||||
| 	if(norm_diod)	LED_3_ON; | ||||
| 	else			LED_3_OFF; | ||||
| 	 | ||||
| 	TST = TestJumper() | cTestLamp; | ||||
| 	 | ||||
| 	if(++count_bright == 10) //maximum_bright
 | ||||
| 	{	 count_bright  = 0 ; | ||||
| 
 | ||||
| 		if(power_lamp)	Pvt1_ON; | ||||
| 		else			Pvt1_OFF; | ||||
| 	} | ||||
| 	 | ||||
| 	if(count_bright >= Brightness) | ||||
| 	if(!TST)	Pvt1_OFF;         //îòêëþ÷åíèå ëàìïî÷êè
 | ||||
| 	   | ||||
| 	if(TST & !preTest) | ||||
| 	{ | ||||
| 		count_blink = BLINK_TIME; | ||||
| @ -315,27 +373,53 @@ void Millisecond() | ||||
| 	} | ||||
| 
 | ||||
| 	power_lamp= 1; | ||||
| 	norm_diod= 1; | ||||
| 	work_diod = 1; | ||||
| 	norm_diod = 1; | ||||
| 	work_diod =!blink_over; | ||||
| 	 | ||||
| 	if(TST) | ||||
| 	{ | ||||
| 		power_lamp= blink_over; | ||||
| 		norm_diod= blink_over; | ||||
| 		work_diod= !blink_over; | ||||
| 		power_lamp	= blink_over; | ||||
| 		norm_diod	= blink_over; | ||||
| 		work_diod	= blink_over; | ||||
| 	} | ||||
| 	else | ||||
| 	if(Lightness) | ||||
| 	{ | ||||
| 		if(Alarms.all) | ||||
| 		{ | ||||
| 			norm_diod= blink_alarm; | ||||
| 			power_lamp=blink_alarm; | ||||
| 		} | ||||
| 		if(Errors.all) | ||||
| 		{ | ||||
| 			power_lamp= blink_over; | ||||
| 			norm_diod= blink_over; | ||||
| 	}	}	 | ||||
| 		power_lamp	= norm_diod	= 0; | ||||
| 		if(Lightness==2) power_lamp	= norm_diod	= 1; | ||||
| 		if(Lightness==3) power_lamp	= norm_diod	= blink_over; | ||||
| 		if(Lightness==4) power_lamp	= norm_diod	= blink_alarm; | ||||
| 		if(Lightness==5) power_lamp	= norm_diod	= !blink_alarm; | ||||
| 	} | ||||
| 	else | ||||
| 	if(Errors.all) | ||||
| 	{ | ||||
| 		power_lamp	= blink_over; | ||||
| 		norm_diod	= blink_over; | ||||
| 	}	 | ||||
| 	else | ||||
| 	if(Alarms.all) | ||||
| 	{ | ||||
| 		power_lamp	= blink_alarm; | ||||
| 		norm_diod	= blink_alarm; | ||||
| 	} | ||||
| 	 | ||||
| 	if(++count_bright == 10) //maximum_bright
 | ||||
| 	{	 count_bright  = 0 ; | ||||
| 
 | ||||
| 		if(power_lamp)	Pvt1_ON; | ||||
| 		else			Pvt1_OFF; | ||||
| 	} | ||||
| 	 | ||||
| 	if(count_bright == Brightness) | ||||
| 	if(!TST)	Pvt1_OFF;         //îòêëþ÷åíèå ëàìïî÷êè
 | ||||
| 	 | ||||
| 	if(work_diod)	LED_2_ON; | ||||
| 	else			LED_2_OFF; | ||||
| 
 | ||||
| 	if(norm_diod)	LED_3_ON; | ||||
| 	else			LED_3_OFF; | ||||
| 	 | ||||
|   /* USER CODE END 3 */ | ||||
| } | ||||
| 
 | ||||
| @ -351,16 +435,18 @@ void SystemClock_Config(void) | ||||
|   /** Initializes the RCC Oscillators according to the specified parameters
 | ||||
|   * in the RCC_OscInitTypeDef structure. | ||||
|   */ | ||||
|   RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSI; | ||||
|   RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSI|RCC_OSCILLATORTYPE_LSI; | ||||
|   RCC_OscInitStruct.HSIState = RCC_HSI_ON; | ||||
|   RCC_OscInitStruct.HSICalibrationValue = RCC_HSICALIBRATION_DEFAULT; | ||||
|   RCC_OscInitStruct.LSIState = RCC_LSI_ON; | ||||
|   RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON; | ||||
|   RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSI_DIV2; | ||||
|   RCC_OscInitStruct.PLL.PLLMUL = RCC_PLL_MUL10; | ||||
|   RCC_OscInitStruct.PLL.PLLMUL = RCC_PLL_MUL16; | ||||
|   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 | ||||
| @ -370,17 +456,38 @@ void SystemClock_Config(void) | ||||
|   RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV2; | ||||
|   RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV2; | ||||
| 
 | ||||
|   if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_1) != HAL_OK) | ||||
|   if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_2) != HAL_OK) | ||||
|   { | ||||
|     Error_Handler(); | ||||
|   } | ||||
|   HAL_RCC_MCOConfig(RCC_MCO, RCC_MCO1SOURCE_SYSCLK, RCC_MCODIV_1); | ||||
|   HAL_RCC_MCOConfig(RCC_MCO, RCC_MCO1SOURCE_HSI, RCC_MCODIV_1); | ||||
| } | ||||
| 
 | ||||
| /* USER CODE BEGIN 4 */ | ||||
| 
 | ||||
| /* USER CODE END 4 */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Period elapsed callback in non blocking mode | ||||
|   * @note   This function is called  when TIM8 interrupt took place, inside | ||||
|   * HAL_TIM_IRQHandler(). It makes a direct call to HAL_IncTick() to increment | ||||
|   * a global variable "uwTick" used as application time base. | ||||
|   * @param  htim : TIM handle | ||||
|   * @retval None | ||||
|   */ | ||||
| void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim) | ||||
| { | ||||
|   /* USER CODE BEGIN Callback 0 */ | ||||
| 
 | ||||
|   /* USER CODE END Callback 0 */ | ||||
|   if (htim->Instance == TIM8) { | ||||
|     HAL_IncTick(); | ||||
|   } | ||||
|   /* USER CODE BEGIN Callback 1 */ | ||||
| 
 | ||||
|   /* USER CODE END Callback 1 */ | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  This function is executed in case of error occurrence. | ||||
|   * @retval None | ||||
| @ -412,5 +519,3 @@ void assert_failed(uint8_t *file, uint32_t line) | ||||
|   /* USER CODE END 6 */ | ||||
| } | ||||
| #endif /* USE_FULL_ASSERT */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | ||||
							
								
								
									
										492
									
								
								Core/Src/main.c.bak
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										492
									
								
								Core/Src/main.c.bak
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,492 @@ | ||||
| /* USER CODE BEGIN Header */ | ||||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file           : main.c | ||||
|   * @brief          : Main program body | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© Copyright (c) 2022 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 | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| /* USER CODE END Header */ | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "main.h" | ||||
| #include "can.h" | ||||
| #include "iwdg.h" | ||||
| #include "tim.h" | ||||
| #include "gpio.h" | ||||
| 
 | ||||
| /* Private includes ----------------------------------------------------------*/ | ||||
| /* USER CODE BEGIN Includes */ | ||||
| 
 | ||||
| #include "package.h" | ||||
| #include "message.h" | ||||
| #include "lampa.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 ---------------------------------------------------------*/ | ||||
| 
 | ||||
| /* USER CODE BEGIN PV */ | ||||
| 
 | ||||
| static long Falling_asleep; | ||||
| uint8_t CanGO=0, timGo=0; | ||||
| 
 | ||||
| /* USER CODE END PV */ | ||||
| 
 | ||||
| /* Private function prototypes -----------------------------------------------*/ | ||||
| void SystemClock_Config(void); | ||||
| /* USER CODE BEGIN PFP */ | ||||
| 
 | ||||
| /* USER CODE END PFP */ | ||||
| 
 | ||||
| /* Private user code ---------------------------------------------------------*/ | ||||
| /* USER CODE BEGIN 0 */ | ||||
| 
 | ||||
| int Isit(int num, int i, int z) | ||||
| { | ||||
|   int res, pls; | ||||
| 
 | ||||
| 	if((num<0)||(num>=0x80)) return 0; | ||||
| 	res = Maska[i][num/0x10]; | ||||
| 	res &= (1<<(num&0x0F)); | ||||
| 	 | ||||
| 	if(z) | ||||
| 	{ | ||||
| 		pls = (espero[num]>CanRestart[i]/2); | ||||
| 		pls = pls || county[num]; | ||||
| 		res = res && pls; | ||||
| 	} | ||||
| 
 | ||||
| 	return res; | ||||
| } | ||||
| 
 | ||||
| /* USER CODE END 0 */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  The application entry point. | ||||
|   * @retval int | ||||
|   */ | ||||
| int main(void) | ||||
| { | ||||
|   /* USER CODE BEGIN 1 */ | ||||
| 
 | ||||
|   static int i,j,n,z,mask,qua; | ||||
|   static int cancount[2]={1,2},cancell[2]={0,0},candid[2]={0,0}; | ||||
|   static unsigned int masca[8]; | ||||
|   static uint16_t precom=0; | ||||
| 
 | ||||
|   /* 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_CAN_Init(); | ||||
|   MX_TIM4_Init(); | ||||
|   /* USER CODE BEGIN 2 */ | ||||
| 
 | ||||
|   	LED_0_OFF; | ||||
| 	LED_1_OFF; | ||||
| 	LED_2_OFF; | ||||
| 	LED_3_OFF; | ||||
| 
 | ||||
| 	for(i=0;i<10;i++) | ||||
| 	{ | ||||
| 		LED_0_TGL; 	HAL_Delay(15);	 | ||||
| 		LED_1_TGL;	HAL_Delay(15); | ||||
| 		LED_2_TGL;	HAL_Delay(15); | ||||
| 		LED_3_TGL;	HAL_Delay(15); | ||||
| 	} | ||||
| 
 | ||||
|   	Mode = ReadJumpers()+1; | ||||
| 	Setup_CAN_addr(Mode-1); | ||||
| 	Load_params();	 | ||||
| 	LastMode = Mode; | ||||
| 	Protokol = PROTOKOL; | ||||
| 	 | ||||
| 	command=0; | ||||
| 	 | ||||
| 	for(i=0;i<0x80;i++) | ||||
| 	county[i]=1; | ||||
| 	for(i=0;i<8;i++) | ||||
| 	masca[i]=0; | ||||
| 	for(i=0;i<2;i++) | ||||
| 	CanRound[i]= | ||||
| 	CanCycle[i]=0; | ||||
| 
 | ||||
| 	timGo=1; | ||||
| 
 | ||||
|   /* USER CODE END 2 */ | ||||
| 
 | ||||
|   /* Infinite loop */ | ||||
|   /* USER CODE BEGIN WHILE */ | ||||
| 	while (1) | ||||
| 	{ | ||||
| 		if( CanGO) | ||||
| 		{	CanGO=0; | ||||
| 			 | ||||
| 			for(i=0;i<0x80;i++) | ||||
| 			if(espero[i]<30000) espero[i]++; | ||||
| 				 | ||||
| 			for(i=0;i<2;i++) | ||||
| 			if(cancount[i]) cancount[i]--; | ||||
| 			else cancell[i] = 0; | ||||
| 		} | ||||
| 			 | ||||
| 		for(i=0;i<2;i++) | ||||
| 		if( Cancount[i]) | ||||
| 		if(!cancount[i])  | ||||
| 		{ | ||||
| 			while(1) | ||||
| 			{ | ||||
| 				if( cancell[i]>= 0x80) | ||||
| 				{	cancell[i]=0; | ||||
| 
 | ||||
| 					if( candid[i]) | ||||
| 					{	candid[i]=0; | ||||
| 						CanCycle[i]++; | ||||
| 						cancount[i] = CanWait[i]; | ||||
| 						goto Next; | ||||
| 				}	}	 | ||||
| 				 | ||||
| 				mask = Maska[i][cancell[i]/0x10] >> (cancell[i]&0x0F); | ||||
| 				if(!mask) cancell[i] = (cancell[i] + 0x10) & 0xFFF0 ; | ||||
| 				else | ||||
| 				{ | ||||
| 					while(!(mask & 1)) | ||||
| 					{ | ||||
| 						cancell[i]++; mask >>= 1; | ||||
| 					} | ||||
| 					break; | ||||
| 			}	} | ||||
| 				 | ||||
| 			z=1; | ||||
| 			if(espero[cancell[i]]>CanRestart[i]) | ||||
| 			{ | ||||
| 				county[cancell[i]]=1; | ||||
| 				z=0; | ||||
| 			} | ||||
| 			 | ||||
| 			if(modbus[cancell[i]] != archiv[cancell[i]]) | ||||
| 			{	 | ||||
| 				if(cancell[i]==keys) | ||||
| 				for(j=0;j<CanRptLen;j++) | ||||
| 				county[cancell[i]+j] = CanRptVez; | ||||
| 				else	 | ||||
| 				county[cancell[i]] = 1; | ||||
| 			} | ||||
| 
 | ||||
| 			if (county[cancell[i]]) | ||||
| 			{ | ||||
| 				for(j=  3; j>0 && !Isit(cancell[i]+j,i,z); j--); | ||||
| 				for(n=j-3; n<0 && !Isit(cancell[i]+n,i,1); n++); | ||||
| 
 | ||||
| 				qua = 1 + j - n; | ||||
| 				cancell[i]+= n; | ||||
| 
 | ||||
| 				for(j=0;j<qua;j++) | ||||
| 				{ | ||||
| 					n=cancell[i]+j; | ||||
| 					archiv[n]= modbus[n];  | ||||
| 					espero[n]= 0; | ||||
| 					 | ||||
| 					if( county[n]) | ||||
| 					{	county[n]--; | ||||
| 						if(!county[n] && n != cancyclo+i)	candid[i]=1; | ||||
| 					}	 | ||||
| 					if(!county[n]) masca[n/0x10] |= (1<<(n&0x0F)); | ||||
| 				}	 | ||||
| 
 | ||||
| 				CAN_send(archiv,cancell[i],qua); | ||||
| 
 | ||||
| 				cancount[i] = Cancount[i]; | ||||
| 				cancell[i]+=qua;  | ||||
| 
 | ||||
| 				for(j=0;j<8;j++) | ||||
| 				if((masca[j] & Maska[i][j]) != Maska[i][j]) break; | ||||
| 				if(j==8) | ||||
| 				{ | ||||
| 					for(j=0;j<8;j++) masca[j]&=~Maska[i][j]; | ||||
| 					CanRound[i]++; | ||||
| 				} | ||||
| 
 | ||||
| 				if( Cancount[i]>1) | ||||
| 				if(!cancount[!i]) | ||||
| 					cancount[!i]=1; | ||||
| 			} | ||||
| 			else	 | ||||
| 				cancell[i]++;  | ||||
| 		} | ||||
| 	   | ||||
| 		Next: | ||||
| 		 | ||||
| 		ReadEnteres();	 | ||||
| 		 | ||||
| 		if(Errors.all|Alarms.all) | ||||
| 						Pvt4_OFF; | ||||
| 		else			Pvt4_ON;	//	ñèãíàë "Ñèñòåìà ÂÝÏ â íîðìå"
 | ||||
| 			 | ||||
| 		if(Errors.all)	Pvt3_ON;	//	ñèãíàë "Àâàðèÿ ñèñòåìû ÂÝÏ"
 | ||||
| 		else			Pvt3_OFF; | ||||
| 			 | ||||
| 		if(Falling_asleep)	Pvt2_ON;		//	Ïîêà íå ñïèì, ýòî çàìêíóòî
 | ||||
| 		else				Pvt2_OFF;		//	ñèãíàë "Óïðàâëåíèå ñåòüþ 24Â"
 | ||||
| 
 | ||||
| 
 | ||||
| 		if(Commands!=precom) | ||||
| 		{ | ||||
| 			command= (~precom|command) & Commands; | ||||
| 			modbus[23]=command; | ||||
| 		} | ||||
| 		precom = Commands; | ||||
| 		 | ||||
| 		if(cDefParam) | ||||
| 		{ | ||||
| 			cDefParam=0; | ||||
| 			Default_params(); | ||||
| 		} | ||||
| 
 | ||||
| 		if(cSaveParam) | ||||
| 		{ | ||||
| 			cSaveParam=0; | ||||
| 			Save_params(); | ||||
| 		} | ||||
| 
 | ||||
| 		if(cLoadParam) | ||||
| 		{ | ||||
| 			cLoadParam=0; | ||||
| 			Load_params(); | ||||
| 		} | ||||
| 
 | ||||
| 		if(cCanReset) | ||||
| 		{ | ||||
| 			cCanReset=0; | ||||
| 
 | ||||
| 			for(i=0;i<0x80;i++) | ||||
| 			county[i]=1; | ||||
| 			for(i=0;i<2;i++) | ||||
| 			CanCycle[i]= | ||||
| 			CanRound[i]= | ||||
| 			cancount[i]= | ||||
| 			cancell[i]=0; | ||||
| 			for(i=0;i<8;i++) | ||||
| 			masca[i]=0; | ||||
| }	}	} | ||||
| 	 | ||||
|     /* USER CODE END WHILE */ | ||||
| 
 | ||||
|     /* USER CODE BEGIN 3 */ | ||||
| 		 | ||||
| void Millisecond() | ||||
| { | ||||
|   static int CanPowse; | ||||
| 	 | ||||
|   static unsigned int | ||||
|   count_blink=0, count_bright=0, count_mode,  | ||||
|   blink_over, blink_alarm, power_lamp, work_diod, norm_diod; | ||||
|   static int preTest; | ||||
|   int TST; | ||||
| 
 | ||||
| #define CANPOWSE 10		//	10 msec
 | ||||
| #define BLINK_TIME 250	//	.25 sec
 | ||||
| 
 | ||||
| 	if(!cReset) | ||||
| 	HAL_IWDG_Refresh(&hiwdg); | ||||
| 
 | ||||
| 	if(!timGo) return; | ||||
| 
 | ||||
| 	Jumpers.byt.byte_1 = ReadJumpers(); | ||||
| 	Jumpers.bit.bit0 =  | ||||
| 	Buttons.bit.bit0 = TestJumper(); | ||||
|    | ||||
| 	if(++CanPowse >= CANPOWSE) | ||||
| 	{ | ||||
| 		CanPowse = 0;	CanGO = 1; | ||||
| 	} | ||||
| 	 | ||||
| 	if(Alarms.bit.bit8)	//	Ðàçðÿä áàòàðåè
 | ||||
| 	{ | ||||
| 		if (Falling_asleep) Falling_asleep--; | ||||
| 	} | ||||
| 	else	Falling_asleep = 1000L * Sleep_time; | ||||
| 	 | ||||
| 	TST = TestJumper() | cTestLamp; | ||||
| 	 | ||||
| 	if(TST & !preTest) | ||||
| 	{ | ||||
| 		count_blink = BLINK_TIME; | ||||
| 		count_mode = 0; | ||||
| 	} | ||||
| 	preTest = TST; | ||||
| 
 | ||||
| 	if(++count_blink >= BLINK_TIME) | ||||
| 	{ | ||||
| 		count_blink=0; | ||||
| 		count_mode++; | ||||
| 		blink_over  = (count_mode & 1)?1:0; | ||||
| 		blink_alarm = (count_mode & 7)?1:0; | ||||
| 	} | ||||
| 
 | ||||
| 	power_lamp= 1; | ||||
| 	norm_diod= 1; | ||||
| 	work_diod = 1; | ||||
| 	 | ||||
| 	if(TST) | ||||
| 	{ | ||||
| 		power_lamp	= blink_over; | ||||
| 		norm_diod	= blink_over; | ||||
| 		work_diod	=!blink_over; | ||||
| 	} | ||||
| 	else | ||||
| 	if(Lightness) | ||||
| 	{ | ||||
| 		power_lamp	= norm_diod	= 0; | ||||
| 		if(Lightness==2) power_lamp	= norm_diod	= 1; | ||||
| 		if(Lightness==3) power_lamp	= norm_diod	= blink_over; | ||||
| 		if(Lightness==4) power_lamp	= norm_diod	= blink_alarm; | ||||
| 		if(Lightness==5) power_lamp	= norm_diod	= !blink_alarm; | ||||
| 	} | ||||
| 	else | ||||
| 	if(Errors.all) | ||||
| 	{ | ||||
| 		power_lamp	= blink_over; | ||||
| 		norm_diod	= blink_over; | ||||
| 	}	 | ||||
| 	else | ||||
| 	if(Alarms.all) | ||||
| 	{ | ||||
| 		power_lamp	= blink_alarm; | ||||
| 		norm_diod	= blink_alarm; | ||||
| 	} | ||||
| 	 | ||||
| 	if(++count_bright == 10) //maximum_bright
 | ||||
| 	{	 count_bright  = 0 ; | ||||
| 
 | ||||
| 		if(power_lamp)	Pvt1_ON; | ||||
| 		else			Pvt1_OFF; | ||||
| 	} | ||||
| 	 | ||||
| 	if(count_bright == Brightness) | ||||
| 	if(!TST)	Pvt1_OFF;         //îòêëþ÷åíèå ëàìïî÷êè
 | ||||
| 	 | ||||
| 	if(work_diod)	LED_2_ON; | ||||
| 	else			LED_2_OFF; | ||||
| 
 | ||||
| 	if(norm_diod)	LED_3_ON; | ||||
| 	else			LED_3_OFF; | ||||
| 	 | ||||
|   /* 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_HSI; | ||||
|   RCC_OscInitStruct.HSIState = RCC_HSI_ON; | ||||
|   RCC_OscInitStruct.HSICalibrationValue = RCC_HSICALIBRATION_DEFAULT; | ||||
|   RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON; | ||||
|   RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSI_DIV2; | ||||
|   RCC_OscInitStruct.PLL.PLLMUL = RCC_PLL_MUL10; | ||||
|   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_DIV2; | ||||
| 
 | ||||
|   if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_1) != HAL_OK) | ||||
|   { | ||||
|     Error_Handler(); | ||||
|   } | ||||
|   HAL_RCC_MCOConfig(RCC_MCO, RCC_MCO1SOURCE_SYSCLK, RCC_MCODIV_1); | ||||
| } | ||||
| 
 | ||||
| /* 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 */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
| @ -20,6 +20,7 @@ void Init_packMask(void); | ||||
| 
 | ||||
| uint16_t Maska[2][8];  | ||||
| 
 | ||||
| 
 | ||||
| void Default_params() | ||||
| { | ||||
|   unsigned int i; | ||||
| @ -41,7 +42,7 @@ void Default_params() | ||||
| 
 | ||||
| 	LastMode = Mode; | ||||
| 
 | ||||
| 	Sleep_time = 60;		//	минута чтобы отклюиться
 | ||||
| 	Sleep_time = 60;		//	минута чтобы отключиться
 | ||||
| 	 | ||||
| 	Cancount[m_FAST] = 5;	//	* 10msec, пауза между посылками CAN
 | ||||
| 	Cancount[m_SLOW] = 100;	//	* 10msec, пауза между посылками CAN
 | ||||
| @ -52,9 +53,10 @@ void Default_params() | ||||
| 	CanRestart[m_FAST] = 500;	//	* 10msec, перезапуск посылки
 | ||||
| 	CanRestart[m_SLOW] = 1000;	//	* 10msec, перезапуск посылки
 | ||||
| 
 | ||||
| 	CanRepeat = 3;	//	сколько раз повторять надо
 | ||||
| 	 | ||||
| 	Brightness = 9;	 | ||||
| 	CanRptVez = 3;	//	кол-во повторений посылки «keys»
 | ||||
| 	CanRptLen = 3;	//	длина повтораемой посылки «keys»
 | ||||
| 		 | ||||
| 	Brightness = 10;	 | ||||
| 	 | ||||
| 	Protokol = PROTOKOL; | ||||
| } | ||||
| @ -113,17 +115,12 @@ void Init_packMask() | ||||
| 	} | ||||
| 	 | ||||
| 	Maska[m_FAST][0]|= 0x0007;	//	Дискретные входы, неисправности и аварии
 | ||||
| 
 | ||||
| 	Maska[m_SLOW][0]|= 0x0300;	//  Маски на неисправности и аварии
 | ||||
| 	Maska[m_SLOW][1]|= 0x0003;	//  Состояние джамперов
 | ||||
| 	Maska[m_SLOW][2]|= 0x000F;	//	Скважность датчика напряжения
 | ||||
| 	Maska[m_SLOW][1]|= 0x0F00;	//	Скважность датчика напряжения
 | ||||
| 	Maska[m_SLOW][3]|= 0x000F;	//  Аварийная уставка скважности
 | ||||
| 	Maska[m_SLOW][4]|= 0x0100;	//	Время автоматического отключения
 | ||||
| 
 | ||||
| 	Maska[m_SLOW][6]|= 0x0007;	//	Яркость ламп и периоды посылок
 | ||||
| 	Maska[m_SLOW][7]|= 0xE000;	//	Адрес, команды, и чтоб не вылазило
 | ||||
| 	 | ||||
| 	Maska[m_SLOW][6]|= 0x017F;	//	Яркость лампы и периоды посылок
 | ||||
| 	Maska[m_SLOW][6]|= 0x05FF;	//	Яркость лампы и периоды посылок
 | ||||
| 	Maska[m_FAST][7]|= 0x0100;	//	Счетчик посылок
 | ||||
| 	Maska[m_SLOW][7]|= 0x0E00;	//	Счетчик посылок
 | ||||
| 	Maska[m_SLOW][7]|= 0xE000;	//	Протокол, адрес, команды
 | ||||
|  | ||||
| @ -1,3 +1,4 @@ | ||||
| 
 | ||||
| /* USER CODE BEGIN Header */ | ||||
| /**
 | ||||
|   ****************************************************************************** | ||||
| @ -63,6 +64,7 @@ | ||||
|   */ | ||||
| void HAL_MspInit(void) | ||||
| { | ||||
| 
 | ||||
|   /* USER CODE BEGIN MspInit 0 */ | ||||
| 
 | ||||
|   /* USER CODE END MspInit 0 */ | ||||
| @ -72,9 +74,9 @@ void HAL_MspInit(void) | ||||
| 
 | ||||
|   /* System interrupt init*/ | ||||
| 
 | ||||
|   /** ENABLE: Full SWJ (JTAG-DP + SW-DP): Reset State
 | ||||
|   /** NONJTRST: Full SWJ (JTAG-DP + SW-DP) but without NJTRST
 | ||||
|   */ | ||||
|   __HAL_AFIO_REMAP_SWJ_ENABLE(); | ||||
|   __HAL_AFIO_REMAP_SWJ_NONJTRST(); | ||||
| 
 | ||||
|   /* USER CODE BEGIN MspInit 1 */ | ||||
| 
 | ||||
| @ -84,5 +86,3 @@ void HAL_MspInit(void) | ||||
| /* USER CODE BEGIN 1 */ | ||||
| 
 | ||||
| /* USER CODE END 1 */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | ||||
							
								
								
									
										127
									
								
								Core/Src/stm32f1xx_hal_timebase_tim.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										127
									
								
								Core/Src/stm32f1xx_hal_timebase_tim.c
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,127 @@ | ||||
| /* USER CODE BEGIN Header */ | ||||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32f1xx_hal_timebase_tim.c | ||||
|   * @brief   HAL time base based on the hardware TIM. | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * Copyright (c) 2025 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 "stm32f1xx_hal.h" | ||||
| #include "stm32f1xx_hal_tim.h" | ||||
| 
 | ||||
| /* Private typedef -----------------------------------------------------------*/ | ||||
| /* Private define ------------------------------------------------------------*/ | ||||
| /* Private macro -------------------------------------------------------------*/ | ||||
| /* Private variables ---------------------------------------------------------*/ | ||||
| TIM_HandleTypeDef        htim8; | ||||
| /* Private function prototypes -----------------------------------------------*/ | ||||
| void TIM8_IRQHandler(void); | ||||
| /* Private functions ---------------------------------------------------------*/ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  This function configures the TIM8 as a time base source. | ||||
|   *         The time source is configured  to have 1ms time base with a dedicated | ||||
|   *         Tick interrupt priority. | ||||
|   * @note   This function is called  automatically at the beginning of program after | ||||
|   *         reset by HAL_Init() or at any time when clock is configured, by HAL_RCC_ClockConfig(). | ||||
|   * @param  TickPriority: Tick interrupt priority. | ||||
|   * @retval HAL status | ||||
|   */ | ||||
| HAL_StatusTypeDef HAL_InitTick(uint32_t TickPriority) | ||||
| { | ||||
|   RCC_ClkInitTypeDef    clkconfig; | ||||
|   uint32_t              uwTimclock = 0U; | ||||
| 
 | ||||
|   uint32_t              uwPrescalerValue = 0U; | ||||
|   uint32_t              pFLatency; | ||||
|   HAL_StatusTypeDef     status = HAL_OK; | ||||
| 
 | ||||
|   /* Enable TIM8 clock */ | ||||
|   __HAL_RCC_TIM8_CLK_ENABLE(); | ||||
|   /* Get clock configuration */ | ||||
|   HAL_RCC_GetClockConfig(&clkconfig, &pFLatency); | ||||
|   /* Compute TIM8 clock */ | ||||
|       uwTimclock = 2*HAL_RCC_GetPCLK2Freq(); | ||||
| 
 | ||||
|   /* Compute the prescaler value to have TIM8 counter clock equal to 1MHz */ | ||||
|   uwPrescalerValue = (uint32_t) ((uwTimclock / 1000000U) - 1U); | ||||
| 
 | ||||
|   /* Initialize TIM8 */ | ||||
|   htim8.Instance = TIM8; | ||||
| 
 | ||||
|   /* Initialize TIMx peripheral as follow:
 | ||||
| 
 | ||||
|   + Period = [(TIM8CLK/1000) - 1]. to have a (1/1000) s time base. | ||||
|   + Prescaler = (uwTimclock/1000000 - 1) to have a 1MHz counter clock. | ||||
|   + ClockDivision = 0 | ||||
|   + Counter direction = Up | ||||
|   */ | ||||
|   htim8.Init.Period = (1000000U / 1000U) - 1U; | ||||
|   htim8.Init.Prescaler = uwPrescalerValue; | ||||
|   htim8.Init.ClockDivision = 0; | ||||
|   htim8.Init.CounterMode = TIM_COUNTERMODE_UP; | ||||
|   htim8.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE; | ||||
| 
 | ||||
|   status = HAL_TIM_Base_Init(&htim8); | ||||
|   if (status == HAL_OK) | ||||
|   { | ||||
|     /* Start the TIM time Base generation in interrupt mode */ | ||||
|     status = HAL_TIM_Base_Start_IT(&htim8); | ||||
|     if (status == HAL_OK) | ||||
|     { | ||||
|     /* Enable the TIM8 global Interrupt */ | ||||
|         HAL_NVIC_EnableIRQ(TIM8_UP_IRQn); | ||||
|       /* Configure the SysTick IRQ priority */ | ||||
|       if (TickPriority < (1UL << __NVIC_PRIO_BITS)) | ||||
|       { | ||||
|         /* Configure the TIM IRQ priority */ | ||||
|         HAL_NVIC_SetPriority(TIM8_UP_IRQn, TickPriority, 0U); | ||||
|         uwTickPrio = TickPriority; | ||||
|       } | ||||
|       else | ||||
|       { | ||||
|         status = HAL_ERROR; | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|  /* Return function status */ | ||||
|   return status; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Suspend Tick increment. | ||||
|   * @note   Disable the tick increment by disabling TIM8 update interrupt. | ||||
|   * @param  None | ||||
|   * @retval None | ||||
|   */ | ||||
| void HAL_SuspendTick(void) | ||||
| { | ||||
|   /* Disable TIM8 update Interrupt */ | ||||
|   __HAL_TIM_DISABLE_IT(&htim8, TIM_IT_UPDATE); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Resume Tick increment. | ||||
|   * @note   Enable the tick increment by Enabling TIM8 update interrupt. | ||||
|   * @param  None | ||||
|   * @retval None | ||||
|   */ | ||||
| void HAL_ResumeTick(void) | ||||
| { | ||||
|   /* Enable TIM8 Update interrupt */ | ||||
|   __HAL_TIM_ENABLE_IT(&htim8, TIM_IT_UPDATE); | ||||
| } | ||||
| 
 | ||||
| @ -58,6 +58,8 @@ | ||||
| /* External variables --------------------------------------------------------*/ | ||||
| extern CAN_HandleTypeDef hcan; | ||||
| extern TIM_HandleTypeDef htim4; | ||||
| extern TIM_HandleTypeDef htim8; | ||||
| 
 | ||||
| /* USER CODE BEGIN EV */ | ||||
| 
 | ||||
| /* USER CODE END EV */ | ||||
| @ -187,9 +189,9 @@ void SysTick_Handler(void) | ||||
|   /* USER CODE BEGIN SysTick_IRQn 0 */ | ||||
| 
 | ||||
|   /* USER CODE END SysTick_IRQn 0 */ | ||||
|   HAL_IncTick(); | ||||
| 
 | ||||
|   /* USER CODE BEGIN SysTick_IRQn 1 */ | ||||
| 	Millisecond();	 | ||||
| 
 | ||||
|   /* USER CODE END SysTick_IRQn 1 */ | ||||
| } | ||||
| 
 | ||||
| @ -242,7 +244,20 @@ void TIM4_IRQHandler(void) | ||||
|   /* USER CODE END TIM4_IRQn 1 */ | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief This function handles TIM8 update interrupt. | ||||
|   */ | ||||
| void TIM8_UP_IRQHandler(void) | ||||
| { | ||||
|   /* USER CODE BEGIN TIM8_UP_IRQn 0 */ | ||||
| 
 | ||||
|   /* USER CODE END TIM8_UP_IRQn 0 */ | ||||
|   HAL_TIM_IRQHandler(&htim8); | ||||
|   /* USER CODE BEGIN TIM8_UP_IRQn 1 */ | ||||
| Millisecond(); | ||||
|   /* USER CODE END TIM8_UP_IRQn 1 */ | ||||
| } | ||||
| 
 | ||||
| /* USER CODE BEGIN 1 */ | ||||
| 
 | ||||
| /* USER CODE END 1 */ | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | ||||
| @ -1,3 +1,4 @@ | ||||
| /* USER CODE BEGIN Header */ | ||||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    tim.c | ||||
| @ -6,17 +7,16 @@ | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© Copyright (c) 2025 STMicroelectronics. | ||||
|   * All rights reserved.</center></h2> | ||||
|   * Copyright (c) 2025 STMicroelectronics. | ||||
|   * All rights reserved. | ||||
|   * | ||||
|   * 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 | ||||
|   * 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 "tim.h" | ||||
| 
 | ||||
| @ -45,9 +45,9 @@ void MX_TIM4_Init(void) | ||||
|   htim4.Instance = TIM4; | ||||
|   htim4.Init.Prescaler = 0; | ||||
|   htim4.Init.CounterMode = TIM_COUNTERMODE_UP; | ||||
|   htim4.Init.Period = 799; | ||||
|   htim4.Init.Period = 4000; | ||||
|   htim4.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1; | ||||
|   htim4.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_ENABLE; | ||||
|   htim4.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE; | ||||
|   if (HAL_TIM_Base_Init(&htim4) != HAL_OK) | ||||
|   { | ||||
|     Error_Handler(); | ||||
| @ -114,16 +114,14 @@ void HAL_TIM_Base_MspDeInit(TIM_HandleTypeDef* tim_baseHandle) | ||||
| 
 | ||||
| /* USER CODE BEGIN 1 */ | ||||
| 
 | ||||
| void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim) | ||||
| { | ||||
| //void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim)
 | ||||
| //{
 | ||||
| 
 | ||||
| 	if(htim->Instance == TIM4) //check if the interrupt comes from TIM1
 | ||||
| //	if(htim->Instance == TIM4) //check if the interrupt comes from TIM1
 | ||||
| 
 | ||||
| 	ReadSeanus(); | ||||
| 	 | ||||
| } | ||||
| //	ReadSeanus();
 | ||||
| //	
 | ||||
| //}
 | ||||
| 
 | ||||
| 
 | ||||
| /* USER CODE END 1 */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | ||||
| @ -9,18 +9,17 @@ | ||||
|   *          This file contains: | ||||
|   *           - Data structures and the address mapping for all peripherals | ||||
|   *           - Peripheral's registers declarations and bits definition | ||||
|   *           - Macros to access peripheral’s registers hardware | ||||
|   *           - Macros to access peripheral's registers hardware | ||||
|   *   | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© Copyright (c) 2017 STMicroelectronics. | ||||
|   * All rights reserved.</center></h2> | ||||
|   * Copyright (c) 2017-2021 STMicroelectronics. | ||||
|   * All rights reserved. | ||||
|   * | ||||
|   * 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 | ||||
|   * 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. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| @ -904,7 +903,15 @@ typedef struct | ||||
| /** @addtogroup Exported_constants
 | ||||
|   * @{ | ||||
|   */ | ||||
|    | ||||
| 
 | ||||
|   /** @addtogroup Hardware_Constant_Definition
 | ||||
|     * @{ | ||||
|     */ | ||||
| #define LSI_STARTUP_TIME                85U /*!< LSI Maximum startup time in us */ | ||||
|   /**
 | ||||
|     * @} | ||||
|     */ | ||||
| 
 | ||||
|   /** @addtogroup Peripheral_Registers_Bits_Definition
 | ||||
|   * @{ | ||||
|   */ | ||||
| @ -1820,7 +1827,7 @@ typedef struct | ||||
| #define RCC_BDCR_RTCSEL_0                    (0x1UL << RCC_BDCR_RTCSEL_Pos)     /*!< 0x00000100 */ | ||||
| #define RCC_BDCR_RTCSEL_1                    (0x2UL << RCC_BDCR_RTCSEL_Pos)     /*!< 0x00000200 */ | ||||
| 
 | ||||
| /*!< RTC congiguration */ | ||||
| /*!< RTC configuration */ | ||||
| #define RCC_BDCR_RTCSEL_NOCLOCK              0x00000000U                       /*!< No clock */ | ||||
| #define RCC_BDCR_RTCSEL_LSE                  0x00000100U                       /*!< LSE oscillator clock used as RTC clock */ | ||||
| #define RCC_BDCR_RTCSEL_LSI                  0x00000200U                       /*!< LSI oscillator clock used as RTC clock */ | ||||
| @ -3840,7 +3847,7 @@ typedef struct | ||||
| #define ADC_CR2_DMA                         ADC_CR2_DMA_Msk                    /*!< ADC DMA transfer enable */ | ||||
| #define ADC_CR2_ALIGN_Pos                   (11U)                               | ||||
| #define ADC_CR2_ALIGN_Msk                   (0x1UL << ADC_CR2_ALIGN_Pos)        /*!< 0x00000800 */ | ||||
| #define ADC_CR2_ALIGN                       ADC_CR2_ALIGN_Msk                  /*!< ADC data alignement */ | ||||
| #define ADC_CR2_ALIGN                       ADC_CR2_ALIGN_Msk                  /*!< ADC data alignment */ | ||||
| 
 | ||||
| #define ADC_CR2_JEXTSEL_Pos                 (12U)                               | ||||
| #define ADC_CR2_JEXTSEL_Msk                 (0x7UL << ADC_CR2_JEXTSEL_Pos)      /*!< 0x00007000 */ | ||||
| @ -10426,7 +10433,7 @@ typedef struct | ||||
| /*                                                                            */ | ||||
| /******************************************************************************/ | ||||
| /*
 | ||||
|  * @brief Specific device feature definitions (not present on all devices in the STM32F1 serie) | ||||
|  * @brief Specific device feature definitions (not present on all devices in the STM32F1 series) | ||||
|  */ | ||||
| #define SPI_I2S_SUPPORT       /*!< I2S support */ | ||||
| #define SPI_CRC_ERROR_WORKAROUND_FEATURE | ||||
| @ -11694,22 +11701,22 @@ typedef struct | ||||
| #define TIM9_IRQn               TIM1_BRK_IRQn | ||||
| #define TIM1_BRK_TIM15_IRQn     TIM1_BRK_IRQn | ||||
| #define TIM11_IRQn              TIM1_TRG_COM_IRQn | ||||
| #define TIM1_TRG_COM_TIM11_IRQn TIM1_TRG_COM_IRQn | ||||
| #define TIM1_TRG_COM_TIM17_IRQn TIM1_TRG_COM_IRQn | ||||
| #define TIM1_UP_TIM10_IRQn      TIM1_UP_IRQn | ||||
| #define TIM1_TRG_COM_TIM11_IRQn TIM1_TRG_COM_IRQn | ||||
| #define TIM1_UP_TIM16_IRQn      TIM1_UP_IRQn | ||||
| #define TIM1_UP_TIM10_IRQn      TIM1_UP_IRQn | ||||
| #define TIM10_IRQn              TIM1_UP_IRQn | ||||
| #define TIM6_DAC_IRQn           TIM6_IRQn | ||||
| #define TIM8_BRK_TIM12_IRQn     TIM8_BRK_IRQn | ||||
| #define TIM12_IRQn              TIM8_BRK_IRQn | ||||
| #define TIM14_IRQn              TIM8_TRG_COM_IRQn | ||||
| #define TIM8_BRK_TIM12_IRQn     TIM8_BRK_IRQn | ||||
| #define TIM8_TRG_COM_TIM14_IRQn TIM8_TRG_COM_IRQn | ||||
| #define TIM14_IRQn              TIM8_TRG_COM_IRQn | ||||
| #define TIM8_UP_TIM13_IRQn      TIM8_UP_IRQn | ||||
| #define TIM13_IRQn              TIM8_UP_IRQn | ||||
| #define CEC_IRQn                USBWakeUp_IRQn | ||||
| #define OTG_FS_WKUP_IRQn        USBWakeUp_IRQn | ||||
| #define USB_HP_IRQn             USB_HP_CAN1_TX_IRQn | ||||
| #define CAN1_TX_IRQn            USB_HP_CAN1_TX_IRQn | ||||
| #define USB_HP_IRQn             USB_HP_CAN1_TX_IRQn | ||||
| #define USB_LP_IRQn             USB_LP_CAN1_RX0_IRQn | ||||
| #define CAN1_RX0_IRQn           USB_LP_CAN1_RX0_IRQn | ||||
| 
 | ||||
| @ -11721,22 +11728,22 @@ typedef struct | ||||
| #define TIM9_IRQHandler               TIM1_BRK_IRQHandler | ||||
| #define TIM1_BRK_TIM15_IRQHandler     TIM1_BRK_IRQHandler | ||||
| #define TIM11_IRQHandler              TIM1_TRG_COM_IRQHandler | ||||
| #define TIM1_TRG_COM_TIM11_IRQHandler TIM1_TRG_COM_IRQHandler | ||||
| #define TIM1_TRG_COM_TIM17_IRQHandler TIM1_TRG_COM_IRQHandler | ||||
| #define TIM1_UP_TIM10_IRQHandler      TIM1_UP_IRQHandler | ||||
| #define TIM1_TRG_COM_TIM11_IRQHandler TIM1_TRG_COM_IRQHandler | ||||
| #define TIM1_UP_TIM16_IRQHandler      TIM1_UP_IRQHandler | ||||
| #define TIM1_UP_TIM10_IRQHandler      TIM1_UP_IRQHandler | ||||
| #define TIM10_IRQHandler              TIM1_UP_IRQHandler | ||||
| #define TIM6_DAC_IRQHandler           TIM6_IRQHandler | ||||
| #define TIM8_BRK_TIM12_IRQHandler     TIM8_BRK_IRQHandler | ||||
| #define TIM12_IRQHandler              TIM8_BRK_IRQHandler | ||||
| #define TIM14_IRQHandler              TIM8_TRG_COM_IRQHandler | ||||
| #define TIM8_BRK_TIM12_IRQHandler     TIM8_BRK_IRQHandler | ||||
| #define TIM8_TRG_COM_TIM14_IRQHandler TIM8_TRG_COM_IRQHandler | ||||
| #define TIM14_IRQHandler              TIM8_TRG_COM_IRQHandler | ||||
| #define TIM8_UP_TIM13_IRQHandler      TIM8_UP_IRQHandler | ||||
| #define TIM13_IRQHandler              TIM8_UP_IRQHandler | ||||
| #define CEC_IRQHandler                USBWakeUp_IRQHandler | ||||
| #define OTG_FS_WKUP_IRQHandler        USBWakeUp_IRQHandler | ||||
| #define USB_HP_IRQHandler             USB_HP_CAN1_TX_IRQHandler | ||||
| #define CAN1_TX_IRQHandler            USB_HP_CAN1_TX_IRQHandler | ||||
| #define USB_HP_IRQHandler             USB_HP_CAN1_TX_IRQHandler | ||||
| #define USB_LP_IRQHandler             USB_LP_CAN1_RX0_IRQHandler | ||||
| #define CAN1_RX0_IRQHandler           USB_LP_CAN1_RX0_IRQHandler | ||||
| 
 | ||||
| @ -11757,5 +11764,4 @@ typedef struct | ||||
| #endif /* __STM32F103xE_H */ | ||||
|    | ||||
|    | ||||
|    | ||||
|   /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
| 
 | ||||
|  | ||||
| @ -8,21 +8,20 @@ | ||||
|   *          is using in the C source code, usually in main.c. This file contains: | ||||
|   *            - Configuration section that allows to select: | ||||
|   *              - The STM32F1xx device used in the target application | ||||
|   *              - To use or not the peripheral’s drivers in application code(i.e.  | ||||
|   *                code will be based on direct access to peripheral’s registers  | ||||
|   *              - To use or not the peripheral's drivers in application code(i.e.  | ||||
|   *                code will be based on direct access to peripheral's registers  | ||||
|   *                rather than drivers API), this option is controlled by  | ||||
|   *                "#define USE_HAL_DRIVER" | ||||
|   *   | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© Copyright (c) 2017 STMicroelectronics. | ||||
|   * All rights reserved.</center></h2> | ||||
|   * Copyright (c) 2017-2021 STMicroelectronics. | ||||
|   * All rights reserved. | ||||
|   * | ||||
|   * 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 | ||||
|   * 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. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| @ -90,11 +89,11 @@ | ||||
| #endif /* USE_HAL_DRIVER */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief CMSIS Device version number V4.3.2 | ||||
|   * @brief CMSIS Device version number | ||||
|   */ | ||||
| #define __STM32F1_CMSIS_VERSION_MAIN   (0x04) /*!< [31:24] main version */ | ||||
| #define __STM32F1_CMSIS_VERSION_SUB1   (0x03) /*!< [23:16] sub1 version */ | ||||
| #define __STM32F1_CMSIS_VERSION_SUB2   (0x02) /*!< [15:8]  sub2 version */ | ||||
| #define __STM32F1_CMSIS_VERSION_SUB2   (0x05) /*!< [15:8]  sub2 version */ | ||||
| #define __STM32F1_CMSIS_VERSION_RC     (0x00) /*!< [7:0]  release candidate */  | ||||
| #define __STM32F1_CMSIS_VERSION        ((__STM32F1_CMSIS_VERSION_MAIN << 24)\ | ||||
|                                        |(__STM32F1_CMSIS_VERSION_SUB1 << 16)\ | ||||
| @ -191,6 +190,61 @@ typedef enum | ||||
| 
 | ||||
| #define POSITION_VAL(VAL)     (__CLZ(__RBIT(VAL)))  | ||||
| 
 | ||||
| /* Use of CMSIS compiler intrinsics for register exclusive access */ | ||||
| /* Atomic 32-bit register access macro to set one or several bits */ | ||||
| #define ATOMIC_SET_BIT(REG, BIT)                             \ | ||||
|   do {                                                       \ | ||||
|     uint32_t val;                                            \ | ||||
|     do {                                                     \ | ||||
|       val = __LDREXW((__IO uint32_t *)&(REG)) | (BIT);       \ | ||||
|     } while ((__STREXW(val,(__IO uint32_t *)&(REG))) != 0U); \ | ||||
|   } while(0) | ||||
| 
 | ||||
| /* Atomic 32-bit register access macro to clear one or several bits */ | ||||
| #define ATOMIC_CLEAR_BIT(REG, BIT)                           \ | ||||
|   do {                                                       \ | ||||
|     uint32_t val;                                            \ | ||||
|     do {                                                     \ | ||||
|       val = __LDREXW((__IO uint32_t *)&(REG)) & ~(BIT);      \ | ||||
|     } while ((__STREXW(val,(__IO uint32_t *)&(REG))) != 0U); \ | ||||
|   } while(0) | ||||
| 
 | ||||
| /* Atomic 32-bit register access macro to clear and set one or several bits */ | ||||
| #define ATOMIC_MODIFY_REG(REG, CLEARMSK, SETMASK)                          \ | ||||
|   do {                                                                     \ | ||||
|     uint32_t val;                                                          \ | ||||
|     do {                                                                   \ | ||||
|       val = (__LDREXW((__IO uint32_t *)&(REG)) & ~(CLEARMSK)) | (SETMASK); \ | ||||
|     } while ((__STREXW(val,(__IO uint32_t *)&(REG))) != 0U);               \ | ||||
|   } while(0) | ||||
| 
 | ||||
| /* Atomic 16-bit register access macro to set one or several bits */ | ||||
| #define ATOMIC_SETH_BIT(REG, BIT)                            \ | ||||
|   do {                                                       \ | ||||
|     uint16_t val;                                            \ | ||||
|     do {                                                     \ | ||||
|       val = __LDREXH((__IO uint16_t *)&(REG)) | (BIT);       \ | ||||
|     } while ((__STREXH(val,(__IO uint16_t *)&(REG))) != 0U); \ | ||||
|   } while(0) | ||||
| 
 | ||||
| /* Atomic 16-bit register access macro to clear one or several bits */ | ||||
| #define ATOMIC_CLEARH_BIT(REG, BIT)                          \ | ||||
|   do {                                                       \ | ||||
|     uint16_t val;                                            \ | ||||
|     do {                                                     \ | ||||
|       val = __LDREXH((__IO uint16_t *)&(REG)) & ~(BIT);      \ | ||||
|     } while ((__STREXH(val,(__IO uint16_t *)&(REG))) != 0U); \ | ||||
|   } while(0) | ||||
| 
 | ||||
| /* Atomic 16-bit register access macro to clear and set one or several bits */ | ||||
| #define ATOMIC_MODIFYH_REG(REG, CLEARMSK, SETMASK)                         \ | ||||
|   do {                                                                     \ | ||||
|     uint16_t val;                                                          \ | ||||
|     do {                                                                   \ | ||||
|       val = (__LDREXH((__IO uint16_t *)&(REG)) & ~(CLEARMSK)) | (SETMASK); \ | ||||
|     } while ((__STREXH(val,(__IO uint16_t *)&(REG))) != 0U);               \ | ||||
|   } while(0) | ||||
| 
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
| @ -217,4 +271,3 @@ typedef enum | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | ||||
| @ -1,18 +1,17 @@ | ||||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    system_stm32f10x.h | ||||
|   * @file    system_stm32f1xx.h | ||||
|   * @author  MCD Application Team | ||||
|   * @brief   CMSIS Cortex-M3 Device Peripheral Access Layer System Header File. | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© Copyright (c) 2017 STMicroelectronics. | ||||
|   * All rights reserved.</center></h2> | ||||
|   * Copyright (c) 2017-2021 STMicroelectronics. | ||||
|   * All rights reserved. | ||||
|   * | ||||
|   * 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 | ||||
|   * 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. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| @ -94,5 +93,4 @@ extern void SystemCoreClockUpdate(void); | ||||
|    | ||||
| /**
 | ||||
|   * @} | ||||
|   */   | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|   */ | ||||
|  | ||||
							
								
								
									
										6
									
								
								Drivers/CMSIS/Device/ST/STM32F1xx/LICENSE.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								Drivers/CMSIS/Device/ST/STM32F1xx/LICENSE.txt
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,6 @@ | ||||
| This software component is provided to you as part of a software package and | ||||
| applicable license terms are in the Package_license file. If you received this | ||||
| software component outside of a package or without applicable license terms, | ||||
| the terms of the Apache-2.0 license shall apply. | ||||
| You may obtain a copy of the Apache-2.0 at: | ||||
| https://opensource.org/licenses/Apache-2.0 | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @ -7,13 +7,12 @@ | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© Copyright (c) 2017 STMicroelectronics. | ||||
|   * All rights reserved.</center></h2> | ||||
|   * Copyright (c) 2017 STMicroelectronics. | ||||
|   * All rights reserved. | ||||
|   * | ||||
|   * 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 | ||||
|   * 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. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| @ -355,4 +354,4 @@ void HAL_DBGMCU_DisableDBGStandbyMode(void); | ||||
| 
 | ||||
| #endif /* __STM32F1xx_HAL_H */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
| 
 | ||||
|  | ||||
| @ -6,13 +6,12 @@ | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© Copyright (c) 2016 STMicroelectronics. | ||||
|   * All rights reserved.</center></h2> | ||||
|   * Copyright (c) 2016 STMicroelectronics. | ||||
|   * All rights reserved. | ||||
|   * | ||||
|   * 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 | ||||
|   * 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. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| @ -103,21 +102,25 @@ typedef struct | ||||
| { | ||||
|   uint32_t FilterIdHigh;          /*!< Specifies the filter identification number (MSBs for a 32-bit
 | ||||
|                                        configuration, first one for a 16-bit configuration). | ||||
|                                        This parameter must be a number between Min_Data = 0x0000 and Max_Data = 0xFFFF. */ | ||||
|                                        This parameter must be a number between | ||||
|                                        Min_Data = 0x0000 and Max_Data = 0xFFFF. */ | ||||
| 
 | ||||
|   uint32_t FilterIdLow;           /*!< Specifies the filter identification number (LSBs for a 32-bit
 | ||||
|                                        configuration, second one for a 16-bit configuration). | ||||
|                                        This parameter must be a number between Min_Data = 0x0000 and Max_Data = 0xFFFF. */ | ||||
|                                        This parameter must be a number between | ||||
|                                        Min_Data = 0x0000 and Max_Data = 0xFFFF. */ | ||||
| 
 | ||||
|   uint32_t FilterMaskIdHigh;      /*!< Specifies the filter mask number or identification number,
 | ||||
|                                        according to the mode (MSBs for a 32-bit configuration, | ||||
|                                        first one for a 16-bit configuration). | ||||
|                                        This parameter must be a number between Min_Data = 0x0000 and Max_Data = 0xFFFF. */ | ||||
|                                        This parameter must be a number between | ||||
|                                        Min_Data = 0x0000 and Max_Data = 0xFFFF. */ | ||||
| 
 | ||||
|   uint32_t FilterMaskIdLow;       /*!< Specifies the filter mask number or identification number,
 | ||||
|                                        according to the mode (LSBs for a 32-bit configuration, | ||||
|                                        second one for a 16-bit configuration). | ||||
|                                        This parameter must be a number between Min_Data = 0x0000 and Max_Data = 0xFFFF. */ | ||||
|                                        This parameter must be a number between | ||||
|                                        Min_Data = 0x0000 and Max_Data = 0xFFFF. */ | ||||
| 
 | ||||
|   uint32_t FilterFIFOAssignment;  /*!< Specifies the FIFO (0 or 1U) which will be assigned to the filter.
 | ||||
|                                        This parameter can be a value of @ref CAN_filter_FIFO */ | ||||
| @ -206,7 +209,11 @@ typedef struct | ||||
| /**
 | ||||
|   * @brief  CAN handle Structure definition | ||||
|   */ | ||||
| #if USE_HAL_CAN_REGISTER_CALLBACKS == 1 | ||||
| typedef struct __CAN_HandleTypeDef | ||||
| #else | ||||
| typedef struct | ||||
| #endif /* USE_HAL_CAN_REGISTER_CALLBACKS */ | ||||
| { | ||||
|   CAN_TypeDef                 *Instance;                 /*!< Register base address */ | ||||
| 
 | ||||
| @ -255,7 +262,7 @@ typedef enum | ||||
|   HAL_CAN_RX_FIFO1_MSG_PENDING_CB_ID       = 0x08U,    /*!< CAN Rx FIFO 1 message pending callback ID     */ | ||||
|   HAL_CAN_RX_FIFO1_FULL_CB_ID              = 0x09U,    /*!< CAN Rx FIFO 1 full callback ID                */ | ||||
|   HAL_CAN_SLEEP_CB_ID                      = 0x0AU,    /*!< CAN Sleep callback ID                         */ | ||||
|   HAL_CAN_WAKEUP_FROM_RX_MSG_CB_ID         = 0x0BU,    /*!< CAN Wake Up fropm Rx msg callback ID          */ | ||||
|   HAL_CAN_WAKEUP_FROM_RX_MSG_CB_ID         = 0x0BU,    /*!< CAN Wake Up from Rx msg callback ID          */ | ||||
|   HAL_CAN_ERROR_CB_ID                      = 0x0CU,    /*!< CAN Error callback ID                         */ | ||||
| 
 | ||||
|   HAL_CAN_MSPINIT_CB_ID                    = 0x0DU,    /*!< CAN MspInit callback ID                       */ | ||||
| @ -295,11 +302,11 @@ typedef  void (*pCAN_CallbackTypeDef)(CAN_HandleTypeDef *hcan); /*!< pointer to | ||||
| #define HAL_CAN_ERROR_RX_FOV0         (0x00000200U)  /*!< Rx FIFO0 overrun error                               */ | ||||
| #define HAL_CAN_ERROR_RX_FOV1         (0x00000400U)  /*!< Rx FIFO1 overrun error                               */ | ||||
| #define HAL_CAN_ERROR_TX_ALST0        (0x00000800U)  /*!< TxMailbox 0 transmit failure due to arbitration lost */ | ||||
| #define HAL_CAN_ERROR_TX_TERR0        (0x00001000U)  /*!< TxMailbox 1 transmit failure due to transmit error    */ | ||||
| #define HAL_CAN_ERROR_TX_ALST1        (0x00002000U)  /*!< TxMailbox 0 transmit failure due to arbitration lost */ | ||||
| #define HAL_CAN_ERROR_TX_TERR1        (0x00004000U)  /*!< TxMailbox 1 transmit failure due to transmit error    */ | ||||
| #define HAL_CAN_ERROR_TX_ALST2        (0x00008000U)  /*!< TxMailbox 0 transmit failure due to arbitration lost */ | ||||
| #define HAL_CAN_ERROR_TX_TERR2        (0x00010000U)  /*!< TxMailbox 1 transmit failure due to transmit error    */ | ||||
| #define HAL_CAN_ERROR_TX_TERR0        (0x00001000U)  /*!< TxMailbox 0 transmit failure due to transmit error   */ | ||||
| #define HAL_CAN_ERROR_TX_ALST1        (0x00002000U)  /*!< TxMailbox 1 transmit failure due to arbitration lost */ | ||||
| #define HAL_CAN_ERROR_TX_TERR1        (0x00004000U)  /*!< TxMailbox 1 transmit failure due to transmit error   */ | ||||
| #define HAL_CAN_ERROR_TX_ALST2        (0x00008000U)  /*!< TxMailbox 2 transmit failure due to arbitration lost */ | ||||
| #define HAL_CAN_ERROR_TX_TERR2        (0x00010000U)  /*!< TxMailbox 2 transmit failure due to transmit error   */ | ||||
| #define HAL_CAN_ERROR_TIMEOUT         (0x00020000U)  /*!< Timeout error                                        */ | ||||
| #define HAL_CAN_ERROR_NOT_INITIALIZED (0x00040000U)  /*!< Peripheral not initialized                           */ | ||||
| #define HAL_CAN_ERROR_NOT_READY       (0x00080000U)  /*!< Peripheral not ready                                 */ | ||||
| @ -330,7 +337,8 @@ typedef  void (*pCAN_CallbackTypeDef)(CAN_HandleTypeDef *hcan); /*!< pointer to | ||||
| #define CAN_MODE_NORMAL             (0x00000000U)                              /*!< Normal mode   */ | ||||
| #define CAN_MODE_LOOPBACK           ((uint32_t)CAN_BTR_LBKM)                   /*!< Loopback mode */ | ||||
| #define CAN_MODE_SILENT             ((uint32_t)CAN_BTR_SILM)                   /*!< Silent mode   */ | ||||
| #define CAN_MODE_SILENT_LOOPBACK    ((uint32_t)(CAN_BTR_LBKM | CAN_BTR_SILM))  /*!< Loopback combined with silent mode */ | ||||
| #define CAN_MODE_SILENT_LOOPBACK    ((uint32_t)(CAN_BTR_LBKM | CAN_BTR_SILM))  /*!< Loopback combined with | ||||
|                                                                                     silent mode   */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| @ -645,7 +653,8 @@ void HAL_CAN_MspDeInit(CAN_HandleTypeDef *hcan); | ||||
| 
 | ||||
| #if USE_HAL_CAN_REGISTER_CALLBACKS == 1 | ||||
| /* Callbacks Register/UnRegister functions  ***********************************/ | ||||
| HAL_StatusTypeDef HAL_CAN_RegisterCallback(CAN_HandleTypeDef *hcan, HAL_CAN_CallbackIDTypeDef CallbackID, void (* pCallback)(CAN_HandleTypeDef *_hcan)); | ||||
| HAL_StatusTypeDef HAL_CAN_RegisterCallback(CAN_HandleTypeDef *hcan, HAL_CAN_CallbackIDTypeDef CallbackID, | ||||
|                                            void (* pCallback)(CAN_HandleTypeDef *_hcan)); | ||||
| HAL_StatusTypeDef HAL_CAN_UnRegisterCallback(CAN_HandleTypeDef *hcan, HAL_CAN_CallbackIDTypeDef CallbackID); | ||||
| 
 | ||||
| #endif /* (USE_HAL_CAN_REGISTER_CALLBACKS) */ | ||||
| @ -659,7 +668,7 @@ HAL_StatusTypeDef HAL_CAN_UnRegisterCallback(CAN_HandleTypeDef *hcan, HAL_CAN_Ca | ||||
|  */ | ||||
| 
 | ||||
| /* Configuration functions ****************************************************/ | ||||
| HAL_StatusTypeDef HAL_CAN_ConfigFilter(CAN_HandleTypeDef *hcan, CAN_FilterTypeDef *sFilterConfig); | ||||
| HAL_StatusTypeDef HAL_CAN_ConfigFilter(CAN_HandleTypeDef *hcan, const CAN_FilterTypeDef *sFilterConfig); | ||||
| 
 | ||||
| /**
 | ||||
|  * @} | ||||
| @ -675,14 +684,16 @@ HAL_StatusTypeDef HAL_CAN_Start(CAN_HandleTypeDef *hcan); | ||||
| HAL_StatusTypeDef HAL_CAN_Stop(CAN_HandleTypeDef *hcan); | ||||
| HAL_StatusTypeDef HAL_CAN_RequestSleep(CAN_HandleTypeDef *hcan); | ||||
| HAL_StatusTypeDef HAL_CAN_WakeUp(CAN_HandleTypeDef *hcan); | ||||
| uint32_t HAL_CAN_IsSleepActive(CAN_HandleTypeDef *hcan); | ||||
| HAL_StatusTypeDef HAL_CAN_AddTxMessage(CAN_HandleTypeDef *hcan, CAN_TxHeaderTypeDef *pHeader, uint8_t aData[], uint32_t *pTxMailbox); | ||||
| uint32_t HAL_CAN_IsSleepActive(const CAN_HandleTypeDef *hcan); | ||||
| HAL_StatusTypeDef HAL_CAN_AddTxMessage(CAN_HandleTypeDef *hcan, const CAN_TxHeaderTypeDef *pHeader, | ||||
|                                        const uint8_t aData[], uint32_t *pTxMailbox); | ||||
| HAL_StatusTypeDef HAL_CAN_AbortTxRequest(CAN_HandleTypeDef *hcan, uint32_t TxMailboxes); | ||||
| uint32_t HAL_CAN_GetTxMailboxesFreeLevel(CAN_HandleTypeDef *hcan); | ||||
| uint32_t HAL_CAN_IsTxMessagePending(CAN_HandleTypeDef *hcan, uint32_t TxMailboxes); | ||||
| uint32_t HAL_CAN_GetTxTimestamp(CAN_HandleTypeDef *hcan, uint32_t TxMailbox); | ||||
| HAL_StatusTypeDef HAL_CAN_GetRxMessage(CAN_HandleTypeDef *hcan, uint32_t RxFifo, CAN_RxHeaderTypeDef *pHeader, uint8_t aData[]); | ||||
| uint32_t HAL_CAN_GetRxFifoFillLevel(CAN_HandleTypeDef *hcan, uint32_t RxFifo); | ||||
| uint32_t HAL_CAN_GetTxMailboxesFreeLevel(const CAN_HandleTypeDef *hcan); | ||||
| uint32_t HAL_CAN_IsTxMessagePending(const CAN_HandleTypeDef *hcan, uint32_t TxMailboxes); | ||||
| uint32_t HAL_CAN_GetTxTimestamp(const CAN_HandleTypeDef *hcan, uint32_t TxMailbox); | ||||
| HAL_StatusTypeDef HAL_CAN_GetRxMessage(CAN_HandleTypeDef *hcan, uint32_t RxFifo, | ||||
|                                        CAN_RxHeaderTypeDef *pHeader, uint8_t aData[]); | ||||
| uint32_t HAL_CAN_GetRxFifoFillLevel(const CAN_HandleTypeDef *hcan, uint32_t RxFifo); | ||||
| 
 | ||||
| /**
 | ||||
|  * @} | ||||
| @ -730,8 +741,8 @@ void HAL_CAN_ErrorCallback(CAN_HandleTypeDef *hcan); | ||||
|  * @{ | ||||
|  */ | ||||
| /* Peripheral State and Error functions ***************************************/ | ||||
| HAL_CAN_StateTypeDef HAL_CAN_GetState(CAN_HandleTypeDef *hcan); | ||||
| uint32_t HAL_CAN_GetError(CAN_HandleTypeDef *hcan); | ||||
| HAL_CAN_StateTypeDef HAL_CAN_GetState(const CAN_HandleTypeDef *hcan); | ||||
| uint32_t HAL_CAN_GetError(const CAN_HandleTypeDef *hcan); | ||||
| HAL_StatusTypeDef HAL_CAN_ResetError(CAN_HandleTypeDef *hcan); | ||||
| 
 | ||||
| /**
 | ||||
| @ -809,7 +820,8 @@ HAL_StatusTypeDef HAL_CAN_ResetError(CAN_HandleTypeDef *hcan); | ||||
| #define IS_CAN_TX_MAILBOX(TRANSMITMAILBOX) (((TRANSMITMAILBOX) == CAN_TX_MAILBOX0 ) || \ | ||||
|                                             ((TRANSMITMAILBOX) == CAN_TX_MAILBOX1 ) || \ | ||||
|                                             ((TRANSMITMAILBOX) == CAN_TX_MAILBOX2 )) | ||||
| #define IS_CAN_TX_MAILBOX_LIST(TRANSMITMAILBOX) ((TRANSMITMAILBOX) <= (CAN_TX_MAILBOX0 | CAN_TX_MAILBOX1 | CAN_TX_MAILBOX2)) | ||||
| #define IS_CAN_TX_MAILBOX_LIST(TRANSMITMAILBOX) ((TRANSMITMAILBOX) <= (CAN_TX_MAILBOX0 | CAN_TX_MAILBOX1 | \ | ||||
|                                                                        CAN_TX_MAILBOX2)) | ||||
| #define IS_CAN_STDID(STDID)   ((STDID) <= 0x7FFU) | ||||
| #define IS_CAN_EXTID(EXTID)   ((EXTID) <= 0x1FFFFFFFU) | ||||
| #define IS_CAN_DLC(DLC)       ((DLC) <= 8U) | ||||
| @ -845,6 +857,3 @@ HAL_StatusTypeDef HAL_CAN_ResetError(CAN_HandleTypeDef *hcan); | ||||
| #endif | ||||
| 
 | ||||
| #endif /* STM32F1xx_HAL_CAN_H */ | ||||
| 
 | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | ||||
| @ -6,13 +6,12 @@ | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© Copyright (c) 2017 STMicroelectronics. | ||||
|   * All rights reserved.</center></h2> | ||||
|   * Copyright (c) 2017 STMicroelectronics. | ||||
|   * All rights reserved. | ||||
|   * | ||||
|   * 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 | ||||
|   * 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. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| @ -286,6 +285,8 @@ void HAL_SYSTICK_Callback(void); | ||||
| #if (__MPU_PRESENT == 1U) | ||||
| void HAL_MPU_Enable(uint32_t MPU_Control); | ||||
| void HAL_MPU_Disable(void); | ||||
| void HAL_MPU_EnableRegion(uint32_t RegionNumber); | ||||
| void HAL_MPU_DisableRegion(uint32_t RegionNumber); | ||||
| void HAL_MPU_ConfigRegion(MPU_Region_InitTypeDef *MPU_Init); | ||||
| #endif /* __MPU_PRESENT */ | ||||
| /**
 | ||||
| @ -407,4 +408,3 @@ void HAL_MPU_ConfigRegion(MPU_Region_InitTypeDef *MPU_Init); | ||||
| #endif /* __STM32F1xx_HAL_CORTEX_H */ | ||||
|   | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | ||||
| @ -7,13 +7,12 @@ | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© Copyright (c) 2017 STMicroelectronics. | ||||
|   * All rights reserved.</center></h2> | ||||
|   * Copyright (c) 2017 STMicroelectronics. | ||||
|   * All rights reserved. | ||||
|   * | ||||
|   * 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 | ||||
|   * 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. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| @ -65,7 +64,9 @@ typedef enum | ||||
|                               (__DMA_HANDLE__).Parent = (__HANDLE__);             \ | ||||
|                           } while(0U) | ||||
| 
 | ||||
| #if !defined(UNUSED) | ||||
| #define UNUSED(X) (void)X      /* To avoid gcc/g++ warnings */ | ||||
| #endif /* UNUSED */ | ||||
| 
 | ||||
| /** @brief Reset the Handle's State field.
 | ||||
|   * @param __HANDLE__ specifies the Peripheral Handle. | ||||
| @ -207,4 +208,4 @@ typedef enum | ||||
| 
 | ||||
| #endif /* ___STM32F1xx_HAL_DEF */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
| 
 | ||||
|  | ||||
| @ -6,13 +6,12 @@ | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© Copyright (c) 2016 STMicroelectronics. | ||||
|   * All rights reserved.</center></h2> | ||||
|   * Copyright (c) 2016 STMicroelectronics. | ||||
|   * All rights reserved. | ||||
|   * | ||||
|   * 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 | ||||
|   * 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. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| @ -110,29 +109,29 @@ typedef enum | ||||
|   */ | ||||
| typedef struct __DMA_HandleTypeDef | ||||
| { | ||||
|   DMA_Channel_TypeDef   *Instance;                       /*!< Register base address                  */ | ||||
|   DMA_Channel_TypeDef        *Instance;                                                    /*!< Register base address                  */ | ||||
|    | ||||
|   DMA_InitTypeDef       Init;                            /*!< DMA communication parameters           */  | ||||
|   DMA_InitTypeDef            Init;                                                         /*!< DMA communication parameters           */ | ||||
|    | ||||
|   HAL_LockTypeDef       Lock;                            /*!< DMA locking object                     */   | ||||
|   HAL_LockTypeDef            Lock;                                                         /*!< DMA locking object                     */ | ||||
|    | ||||
|   HAL_DMA_StateTypeDef  State;                           /*!< DMA transfer state                     */ | ||||
|   __IO HAL_DMA_StateTypeDef  State;                                                        /*!< DMA transfer state                     */ | ||||
|    | ||||
|   void                  *Parent;                                                      /*!< Parent object state                    */   | ||||
|   void                       *Parent;                                                      /*!< Parent object state                    */ | ||||
|    | ||||
|   void                  (* XferCpltCallback)( struct __DMA_HandleTypeDef * hdma);     /*!< DMA transfer complete callback         */ | ||||
|   void                       (* XferCpltCallback)( struct __DMA_HandleTypeDef * hdma);     /*!< DMA transfer complete callback         */ | ||||
|    | ||||
|   void                  (* XferHalfCpltCallback)( struct __DMA_HandleTypeDef * hdma); /*!< DMA Half transfer complete callback    */ | ||||
|   void                       (* XferHalfCpltCallback)( struct __DMA_HandleTypeDef * hdma); /*!< DMA Half transfer complete callback    */ | ||||
|    | ||||
|   void                  (* XferErrorCallback)( struct __DMA_HandleTypeDef * hdma);    /*!< DMA transfer error callback            */ | ||||
|   void                       (* XferErrorCallback)( struct __DMA_HandleTypeDef * hdma);    /*!< DMA transfer error callback            */ | ||||
| 
 | ||||
|   void                  (* XferAbortCallback)( struct __DMA_HandleTypeDef * hdma);    /*!< DMA transfer abort callback            */   | ||||
|   void                       (* XferAbortCallback)( struct __DMA_HandleTypeDef * hdma);    /*!< DMA transfer abort callback            */ | ||||
|    | ||||
|   __IO uint32_t         ErrorCode;                                                    /*!< DMA Error code                         */ | ||||
|   __IO uint32_t              ErrorCode;                                                    /*!< DMA Error code                         */ | ||||
| 
 | ||||
|   DMA_TypeDef            *DmaBaseAddress;                                             /*!< DMA Channel Base Address               */ | ||||
|   DMA_TypeDef                *DmaBaseAddress;                                             /*!< DMA Channel Base Address               */ | ||||
|    | ||||
|   uint32_t               ChannelIndex;                                                /*!< DMA Channel Index                      */   | ||||
|   uint32_t                   ChannelIndex;                                                /*!< DMA Channel Index                      */ | ||||
| 
 | ||||
| } DMA_HandleTypeDef;     | ||||
| /**
 | ||||
| @ -454,4 +453,3 @@ uint32_t HAL_DMA_GetError(DMA_HandleTypeDef *hdma); | ||||
| 
 | ||||
| #endif /* __STM32F1xx_HAL_DMA_H */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | ||||
| @ -6,13 +6,12 @@ | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© Copyright (c) 2016 STMicroelectronics. | ||||
|   * All rights reserved.</center></h2> | ||||
|   * Copyright (c) 2016 STMicroelectronics. | ||||
|   * All rights reserved. | ||||
|   * | ||||
|   * 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 | ||||
|   * 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. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| @ -274,4 +273,3 @@ | ||||
| 
 | ||||
| #endif /* __STM32F1xx_HAL_DMA_H */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | ||||
| @ -6,13 +6,12 @@ | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© Copyright (c) 2019 STMicroelectronics. | ||||
|   * All rights reserved.</center></h2> | ||||
|   * Copyright (c) 2019 STMicroelectronics. | ||||
|   * All rights reserved. | ||||
|   * | ||||
|   * 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 | ||||
|   * 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. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| @ -217,19 +216,19 @@ typedef struct | ||||
| /** @defgroup EXTI_Private_Macros EXTI Private Macros
 | ||||
|   * @{ | ||||
|   */ | ||||
| #define IS_EXTI_LINE(__LINE__)          ((((__LINE__) & ~(EXTI_PROPERTY_MASK | EXTI_PIN_MASK)) == 0x00u) && \ | ||||
|                                         ((((__LINE__) & EXTI_PROPERTY_MASK) == EXTI_CONFIG)   || \ | ||||
|                                          (((__LINE__) & EXTI_PROPERTY_MASK) == EXTI_GPIO))    && \ | ||||
|                                          (((__LINE__) & EXTI_PIN_MASK) < EXTI_LINE_NB)) | ||||
| #define IS_EXTI_LINE(__EXTI_LINE__)          ((((__EXTI_LINE__) & ~(EXTI_PROPERTY_MASK | EXTI_PIN_MASK)) == 0x00u) && \ | ||||
|                                              ((((__EXTI_LINE__) & EXTI_PROPERTY_MASK) == EXTI_CONFIG)   || \ | ||||
|                                               (((__EXTI_LINE__) & EXTI_PROPERTY_MASK) == EXTI_GPIO))    && \ | ||||
|                                               (((__EXTI_LINE__) & EXTI_PIN_MASK) < EXTI_LINE_NB)) | ||||
| 
 | ||||
| #define IS_EXTI_MODE(__LINE__)          ((((__LINE__) & EXTI_MODE_MASK) != 0x00u) && \ | ||||
|                                          (((__LINE__) & ~EXTI_MODE_MASK) == 0x00u)) | ||||
| #define IS_EXTI_MODE(__EXTI_LINE__)          ((((__EXTI_LINE__) & EXTI_MODE_MASK) != 0x00u) && \ | ||||
|                                               (((__EXTI_LINE__) & ~EXTI_MODE_MASK) == 0x00u)) | ||||
| 
 | ||||
| #define IS_EXTI_TRIGGER(__LINE__)       (((__LINE__) & ~EXTI_TRIGGER_MASK) == 0x00u) | ||||
| #define IS_EXTI_TRIGGER(__EXTI_LINE__)       (((__EXTI_LINE__) & ~EXTI_TRIGGER_MASK) == 0x00u) | ||||
| 
 | ||||
| #define IS_EXTI_PENDING_EDGE(__LINE__)  ((__LINE__) == EXTI_TRIGGER_RISING_FALLING) | ||||
| #define IS_EXTI_PENDING_EDGE(__EXTI_LINE__)  ((__EXTI_LINE__) == EXTI_TRIGGER_RISING_FALLING) | ||||
| 
 | ||||
| #define IS_EXTI_CONFIG_LINE(__LINE__)   (((__LINE__) & EXTI_CONFIG) != 0x00u) | ||||
| #define IS_EXTI_CONFIG_LINE(__EXTI_LINE__)   (((__EXTI_LINE__) & EXTI_CONFIG) != 0x00u) | ||||
| 
 | ||||
| #if defined (GPIOG) | ||||
| #define IS_EXTI_GPIO_PORT(__PORT__)     (((__PORT__) == EXTI_GPIOA) || \ | ||||
| @ -317,4 +316,3 @@ void              HAL_EXTI_GenerateSWI(EXTI_HandleTypeDef *hexti); | ||||
| 
 | ||||
| #endif /* STM32F1xx_HAL_EXTI_H */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | ||||
| @ -6,14 +6,12 @@ | ||||
|   ****************************************************************************** | ||||
|   * @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 | ||||
|   * Copyright (c) 2016 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. | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| @ -324,5 +322,4 @@ HAL_StatusTypeDef       FLASH_WaitForLastOperationBank2(uint32_t Timeout); | ||||
| 
 | ||||
| #endif /* __STM32F1xx_HAL_FLASH_H */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
| 
 | ||||
|  | ||||
| @ -6,14 +6,12 @@ | ||||
|   ****************************************************************************** | ||||
|   * @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 | ||||
|   * Copyright (c) 2016 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. | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| @ -783,4 +781,3 @@ uint32_t           HAL_FLASHEx_OBGetUserData(uint32_t DATAAdress); | ||||
| 
 | ||||
| #endif /* __STM32F1xx_HAL_FLASH_EX_H */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | ||||
| @ -6,13 +6,12 @@ | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© Copyright (c) 2016 STMicroelectronics. | ||||
|   * All rights reserved.</center></h2> | ||||
|   * Copyright (c) 2016 STMicroelectronics. | ||||
|   * All rights reserved. | ||||
|   * | ||||
|   * 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 | ||||
|   * 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. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| @ -305,4 +304,3 @@ void HAL_GPIO_EXTI_Callback(uint16_t GPIO_Pin); | ||||
| 
 | ||||
| #endif /* STM32F1xx_HAL_GPIO_H */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | ||||
| @ -6,13 +6,12 @@ | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© Copyright (c) 2016 STMicroelectronics. | ||||
|   * All rights reserved.</center></h2> | ||||
|   * Copyright (c) 2016 STMicroelectronics. | ||||
|   * All rights reserved. | ||||
|   * | ||||
|   * 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 | ||||
|   * 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. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| @ -891,4 +890,3 @@ void HAL_GPIOEx_DisableEventout(void); | ||||
| 
 | ||||
| #endif /* STM32F1xx_HAL_GPIO_EX_H */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | ||||
							
								
								
									
										220
									
								
								Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_iwdg.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										220
									
								
								Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_iwdg.h
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,220 @@ | ||||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32f1xx_hal_iwdg.h | ||||
|   * @author  MCD Application Team | ||||
|   * @brief   Header file of IWDG HAL module. | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * Copyright (c) 2016 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. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef STM32F1xx_HAL_IWDG_H | ||||
| #define STM32F1xx_HAL_IWDG_H | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32f1xx_hal_def.h" | ||||
| 
 | ||||
| /** @addtogroup STM32F1xx_HAL_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup IWDG IWDG
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /* Exported types ------------------------------------------------------------*/ | ||||
| /** @defgroup IWDG_Exported_Types IWDG Exported Types
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  IWDG Init structure definition | ||||
|   */ | ||||
| typedef struct | ||||
| { | ||||
|   uint32_t Prescaler;  /*!< Select the prescaler of the IWDG.
 | ||||
|                             This parameter can be a value of @ref IWDG_Prescaler */ | ||||
| 
 | ||||
|   uint32_t Reload;     /*!< Specifies the IWDG down-counter reload value.
 | ||||
|                             This parameter must be a number between Min_Data = 0 and Max_Data = 0x0FFF */ | ||||
| 
 | ||||
| } IWDG_InitTypeDef; | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  IWDG Handle Structure definition | ||||
|   */ | ||||
| typedef struct | ||||
| { | ||||
|   IWDG_TypeDef                 *Instance;  /*!< Register base address    */ | ||||
| 
 | ||||
|   IWDG_InitTypeDef             Init;       /*!< IWDG required parameters */ | ||||
| } IWDG_HandleTypeDef; | ||||
| 
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /* Exported constants --------------------------------------------------------*/ | ||||
| /** @defgroup IWDG_Exported_Constants IWDG Exported Constants
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup IWDG_Prescaler IWDG Prescaler
 | ||||
|   * @{ | ||||
|   */ | ||||
| #define IWDG_PRESCALER_4                0x00000000u                                     /*!< IWDG prescaler set to 4   */ | ||||
| #define IWDG_PRESCALER_8                IWDG_PR_PR_0                                    /*!< IWDG prescaler set to 8   */ | ||||
| #define IWDG_PRESCALER_16               IWDG_PR_PR_1                                    /*!< IWDG prescaler set to 16  */ | ||||
| #define IWDG_PRESCALER_32               (IWDG_PR_PR_1 | IWDG_PR_PR_0)                   /*!< IWDG prescaler set to 32  */ | ||||
| #define IWDG_PRESCALER_64               IWDG_PR_PR_2                                    /*!< IWDG prescaler set to 64  */ | ||||
| #define IWDG_PRESCALER_128              (IWDG_PR_PR_2 | IWDG_PR_PR_0)                   /*!< IWDG prescaler set to 128 */ | ||||
| #define IWDG_PRESCALER_256              (IWDG_PR_PR_2 | IWDG_PR_PR_1)                   /*!< IWDG prescaler set to 256 */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /* Exported macros -----------------------------------------------------------*/ | ||||
| /** @defgroup IWDG_Exported_Macros IWDG Exported Macros
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enable the IWDG peripheral. | ||||
|   * @param  __HANDLE__  IWDG handle | ||||
|   * @retval None | ||||
|   */ | ||||
| #define __HAL_IWDG_START(__HANDLE__)                WRITE_REG((__HANDLE__)->Instance->KR, IWDG_KEY_ENABLE) | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Reload IWDG counter with value defined in the reload register | ||||
|   *         (write access to IWDG_PR and IWDG_RLR registers disabled). | ||||
|   * @param  __HANDLE__  IWDG handle | ||||
|   * @retval None | ||||
|   */ | ||||
| #define __HAL_IWDG_RELOAD_COUNTER(__HANDLE__)       WRITE_REG((__HANDLE__)->Instance->KR, IWDG_KEY_RELOAD) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /* Exported functions --------------------------------------------------------*/ | ||||
| /** @defgroup IWDG_Exported_Functions  IWDG Exported Functions
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup IWDG_Exported_Functions_Group1 Initialization and Start functions
 | ||||
|   * @{ | ||||
|   */ | ||||
| /* Initialization/Start functions  ********************************************/ | ||||
| HAL_StatusTypeDef     HAL_IWDG_Init(IWDG_HandleTypeDef *hiwdg); | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup IWDG_Exported_Functions_Group2 IO operation functions
 | ||||
|   * @{ | ||||
|   */ | ||||
| /* I/O operation functions ****************************************************/ | ||||
| HAL_StatusTypeDef     HAL_IWDG_Refresh(IWDG_HandleTypeDef *hiwdg); | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /* Private constants ---------------------------------------------------------*/ | ||||
| /** @defgroup IWDG_Private_Constants IWDG Private Constants
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  IWDG Key Register BitMask | ||||
|   */ | ||||
| #define IWDG_KEY_RELOAD                 0x0000AAAAu  /*!< IWDG Reload Counter Enable   */ | ||||
| #define IWDG_KEY_ENABLE                 0x0000CCCCu  /*!< IWDG Peripheral Enable       */ | ||||
| #define IWDG_KEY_WRITE_ACCESS_ENABLE    0x00005555u  /*!< IWDG KR Write Access Enable  */ | ||||
| #define IWDG_KEY_WRITE_ACCESS_DISABLE   0x00000000u  /*!< IWDG KR Write Access Disable */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /* Private macros ------------------------------------------------------------*/ | ||||
| /** @defgroup IWDG_Private_Macros IWDG Private Macros
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enable write access to IWDG_PR and IWDG_RLR registers. | ||||
|   * @param  __HANDLE__  IWDG handle | ||||
|   * @retval None | ||||
|   */ | ||||
| #define IWDG_ENABLE_WRITE_ACCESS(__HANDLE__)  WRITE_REG((__HANDLE__)->Instance->KR, IWDG_KEY_WRITE_ACCESS_ENABLE) | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Disable write access to IWDG_PR and IWDG_RLR registers. | ||||
|   * @param  __HANDLE__  IWDG handle | ||||
|   * @retval None | ||||
|   */ | ||||
| #define IWDG_DISABLE_WRITE_ACCESS(__HANDLE__) WRITE_REG((__HANDLE__)->Instance->KR, IWDG_KEY_WRITE_ACCESS_DISABLE) | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Check IWDG prescaler value. | ||||
|   * @param  __PRESCALER__  IWDG prescaler value | ||||
|   * @retval None | ||||
|   */ | ||||
| #define IS_IWDG_PRESCALER(__PRESCALER__)      (((__PRESCALER__) == IWDG_PRESCALER_4)  || \ | ||||
|                                                ((__PRESCALER__) == IWDG_PRESCALER_8)  || \ | ||||
|                                                ((__PRESCALER__) == IWDG_PRESCALER_16) || \ | ||||
|                                                ((__PRESCALER__) == IWDG_PRESCALER_32) || \ | ||||
|                                                ((__PRESCALER__) == IWDG_PRESCALER_64) || \ | ||||
|                                                ((__PRESCALER__) == IWDG_PRESCALER_128)|| \ | ||||
|                                                ((__PRESCALER__) == IWDG_PRESCALER_256)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Check IWDG reload value. | ||||
|   * @param  __RELOAD__  IWDG reload value | ||||
|   * @retval None | ||||
|   */ | ||||
| #define IS_IWDG_RELOAD(__RELOAD__)            ((__RELOAD__) <= IWDG_RLR_RL) | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif /* STM32F1xx_HAL_IWDG_H */ | ||||
							
								
								
									
										232
									
								
								Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_iwdg.h.bak
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										232
									
								
								Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_iwdg.h.bak
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,232 @@ | ||||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32f1xx_hal_iwdg.h | ||||
|   * @author  MCD Application Team | ||||
|   * @brief   Header file of IWDG HAL module. | ||||
|   ****************************************************************************** | ||||
|   * @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 STM32F1xx_HAL_IWDG_H | ||||
| #define STM32F1xx_HAL_IWDG_H | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32f1xx_hal_def.h" | ||||
| 
 | ||||
| /** @addtogroup STM32F1xx_HAL_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup IWDG IWDG
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /* Exported types ------------------------------------------------------------*/ | ||||
| /** @defgroup IWDG_Exported_Types IWDG Exported Types
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  IWDG Init structure definition | ||||
|   */ | ||||
| typedef struct | ||||
| { | ||||
|   uint32_t Prescaler;  /*!< Select the prescaler of the IWDG.
 | ||||
|                             This parameter can be a value of @ref IWDG_Prescaler */ | ||||
| 
 | ||||
|   uint32_t Reload;     /*!< Specifies the IWDG down-counter reload value.
 | ||||
|                             This parameter must be a number between Min_Data = 0 and Max_Data = 0x0FFF */ | ||||
| 
 | ||||
| } IWDG_InitTypeDef; | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  IWDG Handle Structure definition | ||||
|   */ | ||||
| typedef struct | ||||
| { | ||||
|   IWDG_TypeDef                 *Instance;  /*!< Register base address    */ | ||||
| 
 | ||||
|   IWDG_InitTypeDef             Init;       /*!< IWDG required parameters */ | ||||
| } IWDG_HandleTypeDef; | ||||
| 
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /* Exported constants --------------------------------------------------------*/ | ||||
| /** @defgroup IWDG_Exported_Constants IWDG Exported Constants
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup IWDG_Prescaler IWDG Prescaler
 | ||||
|   * @{ | ||||
|   */ | ||||
| #define IWDG_PRESCALER_4                0x00000000U                                     /*!< IWDG prescaler set to 4   */ | ||||
| #define IWDG_PRESCALER_8                IWDG_PR_PR_0                                    /*!< IWDG prescaler set to 8   */ | ||||
| #define IWDG_PRESCALER_16               IWDG_PR_PR_1                                    /*!< IWDG prescaler set to 16  */ | ||||
| #define IWDG_PRESCALER_32               (IWDG_PR_PR_1 | IWDG_PR_PR_0)                   /*!< IWDG prescaler set to 32  */ | ||||
| #define IWDG_PRESCALER_64               IWDG_PR_PR_2                                    /*!< IWDG prescaler set to 64  */ | ||||
| #define IWDG_PRESCALER_128              (IWDG_PR_PR_2 | IWDG_PR_PR_0)                   /*!< IWDG prescaler set to 128 */ | ||||
| #define IWDG_PRESCALER_256              (IWDG_PR_PR_2 | IWDG_PR_PR_1)                   /*!< IWDG prescaler set to 256 */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /* Exported macros -----------------------------------------------------------*/ | ||||
| /** @defgroup IWDG_Exported_Macros IWDG Exported Macros
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enable the IWDG peripheral. | ||||
|   * @param  __HANDLE__  IWDG handle | ||||
|   * @retval None | ||||
|   */ | ||||
| #define __HAL_IWDG_START(__HANDLE__)                WRITE_REG((__HANDLE__)->Instance->KR, IWDG_KEY_ENABLE) | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Reload IWDG counter with value defined in the reload register | ||||
|   *         (write access to IWDG_PR and IWDG_RLR registers disabled). | ||||
|   * @param  __HANDLE__  IWDG handle | ||||
|   * @retval None | ||||
|   */ | ||||
| #define __HAL_IWDG_RELOAD_COUNTER(__HANDLE__)       WRITE_REG((__HANDLE__)->Instance->KR, IWDG_KEY_RELOAD) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /* Exported functions --------------------------------------------------------*/ | ||||
| /** @defgroup IWDG_Exported_Functions  IWDG Exported Functions
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup IWDG_Exported_Functions_Group1 Initialization and Start functions
 | ||||
|   * @{ | ||||
|   */ | ||||
| /* Initialization/Start functions  ********************************************/ | ||||
| HAL_StatusTypeDef HAL_IWDG_Init(IWDG_HandleTypeDef *hiwdg); | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup IWDG_Exported_Functions_Group2 IO operation functions
 | ||||
|   * @{ | ||||
|   */ | ||||
| /* I/O operation functions ****************************************************/ | ||||
| HAL_StatusTypeDef HAL_IWDG_Refresh(IWDG_HandleTypeDef *hiwdg); | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /* Private constants ---------------------------------------------------------*/ | ||||
| /** @defgroup IWDG_Private_Constants IWDG Private Constants
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  IWDG Key Register BitMask | ||||
|   */ | ||||
| #define IWDG_KEY_RELOAD                 0x000000AAU  /*!< IWDG Reload Counter Enable   */ | ||||
| #define IWDG_KEY_ENABLE                 0x000000CCU  /*!< IWDG Peripheral Enable       */ | ||||
| #define IWDG_KEY_WRITE_ACCESS_ENABLE    0x00000055U  /*!< IWDG KR Write Access Enable  */ | ||||
| #define IWDG_KEY_WRITE_ACCESS_DISABLE   0x00000000U  /*!< IWDG KR Write Access Disable */ | ||||
| 
 | ||||
| //#define IWDG_KEY_RELOAD                 0x0000AAAAU  /*!< IWDG Reload Counter Enable   */
 | ||||
| //#define IWDG_KEY_ENABLE                 0x0000CCCCU  /*!< IWDG Peripheral Enable       */
 | ||||
| //#define IWDG_KEY_WRITE_ACCESS_ENABLE    0x00005555U  /*!< IWDG KR Write Access Enable  */
 | ||||
| //#define IWDG_KEY_WRITE_ACCESS_DISABLE   0x00000000U  /*!< IWDG KR Write Access Disable */
 | ||||
| 
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /* Private macros ------------------------------------------------------------*/ | ||||
| /** @defgroup IWDG_Private_Macros IWDG Private Macros
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enable write access to IWDG_PR and IWDG_RLR registers. | ||||
|   * @param  __HANDLE__  IWDG handle | ||||
|   * @retval None | ||||
|   */ | ||||
| #define IWDG_ENABLE_WRITE_ACCESS(__HANDLE__)  WRITE_REG((__HANDLE__)->Instance->KR, IWDG_KEY_WRITE_ACCESS_ENABLE) | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Disable write access to IWDG_PR and IWDG_RLR registers. | ||||
|   * @param  __HANDLE__  IWDG handle | ||||
|   * @retval None | ||||
|   */ | ||||
| #define IWDG_DISABLE_WRITE_ACCESS(__HANDLE__) WRITE_REG((__HANDLE__)->Instance->KR, IWDG_KEY_WRITE_ACCESS_DISABLE) | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Check IWDG prescaler value. | ||||
|   * @param  __PRESCALER__  IWDG prescaler value | ||||
|   * @retval None | ||||
|   */ | ||||
| #define IS_IWDG_PRESCALER(__PRESCALER__)      (((__PRESCALER__) == IWDG_PRESCALER_4)  || \ | ||||
|                                                ((__PRESCALER__) == IWDG_PRESCALER_8)  || \ | ||||
|                                                ((__PRESCALER__) == IWDG_PRESCALER_16) || \ | ||||
|                                                ((__PRESCALER__) == IWDG_PRESCALER_32) || \ | ||||
|                                                ((__PRESCALER__) == IWDG_PRESCALER_64) || \ | ||||
|                                                ((__PRESCALER__) == IWDG_PRESCALER_128)|| \ | ||||
|                                                ((__PRESCALER__) == IWDG_PRESCALER_256)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Check IWDG reload value. | ||||
|   * @param  __RELOAD__  IWDG reload value | ||||
|   * @retval None | ||||
|   */ | ||||
| #define IS_IWDG_RELOAD(__RELOAD__)            ((__RELOAD__) <= IWDG_RLR_RL) | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif /* STM32F1xx_HAL_IWDG_H */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
| @ -6,13 +6,12 @@ | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© Copyright (c) 2016 STMicroelectronics. | ||||
|   * All rights reserved.</center></h2> | ||||
|   * Copyright (c) 2016 STMicroelectronics. | ||||
|   * All rights reserved. | ||||
|   * | ||||
|   * 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 | ||||
|   * 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. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| @ -384,5 +383,3 @@ void HAL_PWR_PVDCallback(void); | ||||
| 
 | ||||
| 
 | ||||
| #endif /* __STM32F1xx_HAL_PWR_H */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | ||||
| @ -6,14 +6,12 @@ | ||||
|   ****************************************************************************** | ||||
|   * @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 | ||||
|   * Copyright (c) 2016 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. | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| @ -614,7 +612,7 @@ typedef struct | ||||
|   * @brief  Force or release APB1 peripheral reset. | ||||
|   * @{ | ||||
|   */ | ||||
| #define __HAL_RCC_APB1_FORCE_RESET()       (RCC->APB2RSTR = 0xFFFFFFFFU) | ||||
| #define __HAL_RCC_APB1_FORCE_RESET()       (RCC->APB1RSTR = 0xFFFFFFFFU) | ||||
| #define __HAL_RCC_TIM2_FORCE_RESET()       (RCC->APB1RSTR |= (RCC_APB1RSTR_TIM2RST)) | ||||
| #define __HAL_RCC_TIM3_FORCE_RESET()       (RCC->APB1RSTR |= (RCC_APB1RSTR_TIM3RST)) | ||||
| #define __HAL_RCC_WWDG_FORCE_RESET()       (RCC->APB1RSTR |= (RCC_APB1RSTR_WWDGRST)) | ||||
| @ -1374,5 +1372,4 @@ void              HAL_RCC_CSSCallback(void); | ||||
| 
 | ||||
| #endif /* __STM32F1xx_HAL_RCC_H */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
| 
 | ||||
|  | ||||
| @ -6,14 +6,12 @@ | ||||
|   ****************************************************************************** | ||||
|   * @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 | ||||
|   * Copyright (c) 2016 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. | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| @ -1904,5 +1902,4 @@ HAL_StatusTypeDef HAL_RCCEx_DisablePLL2(void); | ||||
| 
 | ||||
| #endif /* __STM32F1xx_HAL_RCC_EX_H */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
| 
 | ||||
|  | ||||
| @ -6,13 +6,12 @@ | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© Copyright (c) 2016 STMicroelectronics. | ||||
|   * All rights reserved.</center></h2> | ||||
|   * Copyright (c) 2016 STMicroelectronics. | ||||
|   * All rights reserved. | ||||
|   * | ||||
|   * 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 | ||||
|   * 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. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| @ -65,8 +64,10 @@ typedef struct | ||||
|                                     This means in PWM mode that (N+1) corresponds to: | ||||
|                                         - the number of PWM periods in edge-aligned mode | ||||
|                                         - the number of half PWM period in center-aligned mode | ||||
|                                      GP timers: this parameter must be a number between Min_Data = 0x00 and Max_Data = 0xFF. | ||||
|                                      Advanced timers: this parameter must be a number between Min_Data = 0x0000 and Max_Data = 0xFFFF. */ | ||||
|                                      GP timers: this parameter must be a number between Min_Data = 0x00 and | ||||
|                                      Max_Data = 0xFF. | ||||
|                                      Advanced timers: this parameter must be a number between Min_Data = 0x0000 and | ||||
|                                      Max_Data = 0xFFFF. */ | ||||
| 
 | ||||
|   uint32_t AutoReloadPreload;  /*!< Specifies the auto-reload preload.
 | ||||
|                                    This parameter can be a value of @ref TIM_AutoReloadPreload */ | ||||
| @ -218,7 +219,8 @@ typedef struct | ||||
|   uint32_t ClearInputPolarity;   /*!< TIM Clear Input polarity
 | ||||
|                                       This parameter can be a value of @ref TIM_ClearInput_Polarity */ | ||||
|   uint32_t ClearInputPrescaler;  /*!< TIM Clear Input prescaler
 | ||||
|                                       This parameter must be 0: When OCRef clear feature is used with ETR source, ETR prescaler must be off */ | ||||
|                                       This parameter must be 0: When OCRef clear feature is used with ETR source, | ||||
|                                       ETR prescaler must be off */ | ||||
|   uint32_t ClearInputFilter;     /*!< TIM Clear Input filter
 | ||||
|                                       This parameter can be a number between Min_Data = 0x0 and Max_Data = 0xF */ | ||||
| } TIM_ClearInputConfigTypeDef; | ||||
| @ -264,22 +266,22 @@ typedef struct | ||||
|   */ | ||||
| typedef struct | ||||
| { | ||||
|   uint32_t OffStateRunMode;      /*!< TIM off state in run mode
 | ||||
|                                       This parameter can be a value of @ref TIM_OSSR_Off_State_Selection_for_Run_mode_state */ | ||||
|   uint32_t OffStateIDLEMode;     /*!< TIM off state in IDLE mode
 | ||||
|                                       This parameter can be a value of @ref TIM_OSSI_Off_State_Selection_for_Idle_mode_state */ | ||||
|   uint32_t LockLevel;            /*!< TIM Lock level
 | ||||
|                                       This parameter can be a value of @ref TIM_Lock_level */ | ||||
|   uint32_t DeadTime;             /*!< TIM dead Time
 | ||||
|                                       This parameter can be a number between Min_Data = 0x00 and Max_Data = 0xFF */ | ||||
|   uint32_t BreakState;           /*!< TIM Break State
 | ||||
|                                       This parameter can be a value of @ref TIM_Break_Input_enable_disable */ | ||||
|   uint32_t BreakPolarity;        /*!< TIM Break input polarity
 | ||||
|                                       This parameter can be a value of @ref TIM_Break_Polarity */ | ||||
|   uint32_t BreakFilter;          /*!< Specifies the break input filter.
 | ||||
|                                       This parameter can be a number between Min_Data = 0x0 and Max_Data = 0xF */ | ||||
|   uint32_t AutomaticOutput;      /*!< TIM Automatic Output Enable state
 | ||||
|                                       This parameter can be a value of @ref TIM_AOE_Bit_Set_Reset */ | ||||
|   uint32_t OffStateRunMode;      /*!< TIM off state in run mode, This parameter can be a value of @ref TIM_OSSR_Off_State_Selection_for_Run_mode_state */ | ||||
| 
 | ||||
|   uint32_t OffStateIDLEMode;     /*!< TIM off state in IDLE mode, This parameter can be a value of @ref TIM_OSSI_Off_State_Selection_for_Idle_mode_state */ | ||||
| 
 | ||||
|   uint32_t LockLevel;            /*!< TIM Lock level, This parameter can be a value of @ref TIM_Lock_level */ | ||||
| 
 | ||||
|   uint32_t DeadTime;             /*!< TIM dead Time, This parameter can be a number between Min_Data = 0x00 and Max_Data = 0xFF */ | ||||
| 
 | ||||
|   uint32_t BreakState;           /*!< TIM Break State, This parameter can be a value of @ref TIM_Break_Input_enable_disable */ | ||||
| 
 | ||||
|   uint32_t BreakPolarity;        /*!< TIM Break input polarity, This parameter can be a value of @ref TIM_Break_Polarity */ | ||||
| 
 | ||||
|   uint32_t BreakFilter;          /*!< Specifies the break input filter.This parameter can be a number between Min_Data = 0x0 and Max_Data = 0xF */ | ||||
| 
 | ||||
|   uint32_t AutomaticOutput;      /*!< TIM Automatic Output Enable state, This parameter can be a value of @ref TIM_AOE_Bit_Set_Reset */ | ||||
| 
 | ||||
| } TIM_BreakDeadTimeConfigTypeDef; | ||||
| 
 | ||||
| /**
 | ||||
| @ -383,29 +385,28 @@ typedef struct | ||||
|   */ | ||||
| typedef enum | ||||
| { | ||||
|   HAL_TIM_BASE_MSPINIT_CB_ID              = 0x00U   /*!< TIM Base MspInit Callback ID                              */ | ||||
|   , HAL_TIM_BASE_MSPDEINIT_CB_ID          = 0x01U   /*!< TIM Base MspDeInit Callback ID                            */ | ||||
|   , HAL_TIM_IC_MSPINIT_CB_ID              = 0x02U   /*!< TIM IC MspInit Callback ID                                */ | ||||
|   , HAL_TIM_IC_MSPDEINIT_CB_ID            = 0x03U   /*!< TIM IC MspDeInit Callback ID                              */ | ||||
|   , HAL_TIM_OC_MSPINIT_CB_ID              = 0x04U   /*!< TIM OC MspInit Callback ID                                */ | ||||
|   , HAL_TIM_OC_MSPDEINIT_CB_ID            = 0x05U   /*!< TIM OC MspDeInit Callback ID                              */ | ||||
|   , HAL_TIM_PWM_MSPINIT_CB_ID             = 0x06U   /*!< TIM PWM MspInit Callback ID                               */ | ||||
|   , HAL_TIM_PWM_MSPDEINIT_CB_ID           = 0x07U   /*!< TIM PWM MspDeInit Callback ID                             */ | ||||
|   , HAL_TIM_ONE_PULSE_MSPINIT_CB_ID       = 0x08U   /*!< TIM One Pulse MspInit Callback ID                         */ | ||||
|   , HAL_TIM_ONE_PULSE_MSPDEINIT_CB_ID     = 0x09U   /*!< TIM One Pulse MspDeInit Callback ID                       */ | ||||
|   , HAL_TIM_ENCODER_MSPINIT_CB_ID         = 0x0AU   /*!< TIM Encoder MspInit Callback ID                           */ | ||||
|   , HAL_TIM_ENCODER_MSPDEINIT_CB_ID       = 0x0BU   /*!< TIM Encoder MspDeInit Callback ID                         */ | ||||
|   , HAL_TIM_HALL_SENSOR_MSPINIT_CB_ID     = 0x0CU   /*!< TIM Hall Sensor MspDeInit Callback ID                     */ | ||||
|   , HAL_TIM_HALL_SENSOR_MSPDEINIT_CB_ID   = 0x0DU   /*!< TIM Hall Sensor MspDeInit Callback ID                     */ | ||||
|   HAL_TIM_BASE_MSPINIT_CB_ID              = 0x00U   /*!< TIM Base MspInit Callback ID                               */ | ||||
|   , HAL_TIM_BASE_MSPDEINIT_CB_ID          = 0x01U   /*!< TIM Base MspDeInit Callback ID                             */ | ||||
|   , HAL_TIM_IC_MSPINIT_CB_ID              = 0x02U   /*!< TIM IC MspInit Callback ID                                 */ | ||||
|   , HAL_TIM_IC_MSPDEINIT_CB_ID            = 0x03U   /*!< TIM IC MspDeInit Callback ID                               */ | ||||
|   , HAL_TIM_OC_MSPINIT_CB_ID              = 0x04U   /*!< TIM OC MspInit Callback ID                                 */ | ||||
|   , HAL_TIM_OC_MSPDEINIT_CB_ID            = 0x05U   /*!< TIM OC MspDeInit Callback ID                               */ | ||||
|   , HAL_TIM_PWM_MSPINIT_CB_ID             = 0x06U   /*!< TIM PWM MspInit Callback ID                                */ | ||||
|   , HAL_TIM_PWM_MSPDEINIT_CB_ID           = 0x07U   /*!< TIM PWM MspDeInit Callback ID                              */ | ||||
|   , HAL_TIM_ONE_PULSE_MSPINIT_CB_ID       = 0x08U   /*!< TIM One Pulse MspInit Callback ID                          */ | ||||
|   , HAL_TIM_ONE_PULSE_MSPDEINIT_CB_ID     = 0x09U   /*!< TIM One Pulse MspDeInit Callback ID                        */ | ||||
|   , HAL_TIM_ENCODER_MSPINIT_CB_ID         = 0x0AU   /*!< TIM Encoder MspInit Callback ID                            */ | ||||
|   , HAL_TIM_ENCODER_MSPDEINIT_CB_ID       = 0x0BU   /*!< TIM Encoder MspDeInit Callback ID                          */ | ||||
|   , HAL_TIM_HALL_SENSOR_MSPINIT_CB_ID     = 0x0CU   /*!< TIM Hall Sensor MspDeInit Callback ID                      */ | ||||
|   , HAL_TIM_HALL_SENSOR_MSPDEINIT_CB_ID   = 0x0DU   /*!< TIM Hall Sensor MspDeInit Callback ID                      */ | ||||
|   , HAL_TIM_PERIOD_ELAPSED_CB_ID          = 0x0EU   /*!< TIM Period Elapsed Callback ID                             */ | ||||
|   , HAL_TIM_PERIOD_ELAPSED_HALF_CB_ID     = 0x0FU   /*!< TIM Period Elapsed half complete Callback ID               */ | ||||
|   , HAL_TIM_TRIGGER_CB_ID                 = 0x10U   /*!< TIM Trigger Callback ID                                    */ | ||||
|   , HAL_TIM_TRIGGER_HALF_CB_ID            = 0x11U   /*!< TIM Trigger half complete Callback ID                      */ | ||||
| 
 | ||||
|   , HAL_TIM_IC_CAPTURE_CB_ID              = 0x12U   /*!< TIM Input Capture Callback ID                              */ | ||||
|   , HAL_TIM_IC_CAPTURE_HALF_CB_ID         = 0x13U   /*!< TIM Input Capture half complete Callback ID                */ | ||||
|   , HAL_TIM_OC_DELAY_ELAPSED_CB_ID        = 0x14U   /*!< TIM Output Compare Delay Elapsed Callback ID               */ | ||||
|   , HAL_TIM_PWM_PULSE_FINISHED_CB_ID      = 0x15U   /*!< TIM PWM Pulse Finished Callback ID           */ | ||||
|   , HAL_TIM_PWM_PULSE_FINISHED_CB_ID      = 0x15U   /*!< TIM PWM Pulse Finished Callback ID                         */ | ||||
|   , HAL_TIM_PWM_PULSE_FINISHED_HALF_CB_ID = 0x16U   /*!< TIM PWM Pulse Finished half complete Callback ID           */ | ||||
|   , HAL_TIM_ERROR_CB_ID                   = 0x17U   /*!< TIM Error Callback ID                                      */ | ||||
|   , HAL_TIM_COMMUTATION_CB_ID             = 0x18U   /*!< TIM Commutation Callback ID                                */ | ||||
| @ -628,10 +629,8 @@ typedef  void (*pTIM_CallbackTypeDef)(TIM_HandleTypeDef *htim);  /*!< pointer to | ||||
| /** @defgroup TIM_Input_Capture_Selection TIM Input Capture Selection
 | ||||
|   * @{ | ||||
|   */ | ||||
| #define TIM_ICSELECTION_DIRECTTI           TIM_CCMR1_CC1S_0                     /*!< TIM Input 1, 2, 3 or 4 is selected to be | ||||
|                                                                                      connected to IC1, IC2, IC3 or IC4, respectively */ | ||||
| #define TIM_ICSELECTION_INDIRECTTI         TIM_CCMR1_CC1S_1                     /*!< TIM Input 1, 2, 3 or 4 is selected to be | ||||
|                                                                                      connected to IC2, IC1, IC4 or IC3, respectively */ | ||||
| #define TIM_ICSELECTION_DIRECTTI           TIM_CCMR1_CC1S_0                     /*!< TIM Input 1, 2, 3 or 4 is selected to be connected to IC1, IC2, IC3 or IC4, respectively */ | ||||
| #define TIM_ICSELECTION_INDIRECTTI         TIM_CCMR1_CC1S_1                     /*!< TIM Input 1, 2, 3 or 4 is selected to be connected to IC2, IC1, IC4 or IC3, respectively */ | ||||
| #define TIM_ICSELECTION_TRC                TIM_CCMR1_CC1S                       /*!< TIM Input 1, 2, 3 or 4 is selected to be connected to TRC */ | ||||
| /**
 | ||||
|   * @} | ||||
| @ -705,6 +704,15 @@ typedef  void (*pTIM_CallbackTypeDef)(TIM_HandleTypeDef *htim);  /*!< pointer to | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup TIM_CC_DMA_Request CCx DMA request selection
 | ||||
|   * @{ | ||||
|   */ | ||||
| #define TIM_CCDMAREQUEST_CC                 0x00000000U                         /*!< CCx DMA request sent when capture or compare match event occurs */ | ||||
| #define TIM_CCDMAREQUEST_UPDATE             TIM_CR2_CCDS                        /*!< CCx DMA requests sent when update event occurs */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup TIM_Flag_definition TIM Flag Definition
 | ||||
|   * @{ | ||||
|   */ | ||||
| @ -739,16 +747,16 @@ typedef  void (*pTIM_CallbackTypeDef)(TIM_HandleTypeDef *htim);  /*!< pointer to | ||||
| /** @defgroup TIM_Clock_Source TIM Clock Source
 | ||||
|   * @{ | ||||
|   */ | ||||
| #define TIM_CLOCKSOURCE_ETRMODE2    TIM_SMCR_ETPS_1      /*!< External clock source mode 2                          */ | ||||
| #define TIM_CLOCKSOURCE_INTERNAL    TIM_SMCR_ETPS_0      /*!< Internal clock source                                 */ | ||||
| #define TIM_CLOCKSOURCE_ETRMODE1    TIM_TS_ETRF          /*!< External clock source mode 1 (ETRF)                   */ | ||||
| #define TIM_CLOCKSOURCE_ETRMODE2    TIM_SMCR_ETPS_1      /*!< External clock source mode 2                          */ | ||||
| #define TIM_CLOCKSOURCE_TI1ED       TIM_TS_TI1F_ED       /*!< External clock source mode 1 (TTI1FP1 + edge detect.) */ | ||||
| #define TIM_CLOCKSOURCE_TI1         TIM_TS_TI1FP1        /*!< External clock source mode 1 (TTI1FP1)                */ | ||||
| #define TIM_CLOCKSOURCE_TI2         TIM_TS_TI2FP2        /*!< External clock source mode 1 (TTI2FP2)                */ | ||||
| #define TIM_CLOCKSOURCE_ITR0        TIM_TS_ITR0          /*!< External clock source mode 1 (ITR0)                   */ | ||||
| #define TIM_CLOCKSOURCE_ITR1        TIM_TS_ITR1          /*!< External clock source mode 1 (ITR1)                   */ | ||||
| #define TIM_CLOCKSOURCE_ITR2        TIM_TS_ITR2          /*!< External clock source mode 1 (ITR2)                   */ | ||||
| #define TIM_CLOCKSOURCE_ITR3        TIM_TS_ITR3          /*!< External clock source mode 1 (ITR3)                   */ | ||||
| #define TIM_CLOCKSOURCE_TI1ED       TIM_TS_TI1F_ED       /*!< External clock source mode 1 (TTI1FP1 + edge detect.) */ | ||||
| #define TIM_CLOCKSOURCE_TI1         TIM_TS_TI1FP1        /*!< External clock source mode 1 (TTI1FP1)                */ | ||||
| #define TIM_CLOCKSOURCE_TI2         TIM_TS_TI2FP2        /*!< External clock source mode 1 (TTI2FP2)                */ | ||||
| #define TIM_CLOCKSOURCE_ETRMODE1    TIM_TS_ETRF          /*!< External clock source mode 1 (ETRF)                   */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| @ -846,8 +854,7 @@ typedef  void (*pTIM_CallbackTypeDef)(TIM_HandleTypeDef *htim);  /*!< pointer to | ||||
|   * @{ | ||||
|   */ | ||||
| #define TIM_AUTOMATICOUTPUT_DISABLE        0x00000000U                          /*!< MOE can be set only by software */ | ||||
| #define TIM_AUTOMATICOUTPUT_ENABLE         TIM_BDTR_AOE                         /*!< MOE can be set by software or automatically at the next update event | ||||
|                                                                                     (if none of the break inputs BRK and BRK2 is active) */ | ||||
| #define TIM_AUTOMATICOUTPUT_ENABLE         TIM_BDTR_AOE                         /*!< MOE can be set by software or automatically at the next update event (if none of the break inputs BRK and BRK2 is active) */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| @ -954,24 +961,24 @@ typedef  void (*pTIM_CallbackTypeDef)(TIM_HandleTypeDef *htim);  /*!< pointer to | ||||
| /** @defgroup TIM_DMA_Burst_Length TIM DMA Burst Length
 | ||||
|   * @{ | ||||
|   */ | ||||
| #define TIM_DMABURSTLENGTH_1TRANSFER       0x00000000U                          /*!< The transfer is done to 1 register starting trom TIMx_CR1 + TIMx_DCR.DBA   */ | ||||
| #define TIM_DMABURSTLENGTH_2TRANSFERS      0x00000100U                          /*!< The transfer is done to 2 registers starting trom TIMx_CR1 + TIMx_DCR.DBA  */ | ||||
| #define TIM_DMABURSTLENGTH_3TRANSFERS      0x00000200U                          /*!< The transfer is done to 3 registers starting trom TIMx_CR1 + TIMx_DCR.DBA  */ | ||||
| #define TIM_DMABURSTLENGTH_4TRANSFERS      0x00000300U                          /*!< The transfer is done to 4 registers starting trom TIMx_CR1 + TIMx_DCR.DBA  */ | ||||
| #define TIM_DMABURSTLENGTH_5TRANSFERS      0x00000400U                          /*!< The transfer is done to 5 registers starting trom TIMx_CR1 + TIMx_DCR.DBA  */ | ||||
| #define TIM_DMABURSTLENGTH_6TRANSFERS      0x00000500U                          /*!< The transfer is done to 6 registers starting trom TIMx_CR1 + TIMx_DCR.DBA  */ | ||||
| #define TIM_DMABURSTLENGTH_7TRANSFERS      0x00000600U                          /*!< The transfer is done to 7 registers starting trom TIMx_CR1 + TIMx_DCR.DBA  */ | ||||
| #define TIM_DMABURSTLENGTH_8TRANSFERS      0x00000700U                          /*!< The transfer is done to 8 registers starting trom TIMx_CR1 + TIMx_DCR.DBA  */ | ||||
| #define TIM_DMABURSTLENGTH_9TRANSFERS      0x00000800U                          /*!< The transfer is done to 9 registers starting trom TIMx_CR1 + TIMx_DCR.DBA  */ | ||||
| #define TIM_DMABURSTLENGTH_10TRANSFERS     0x00000900U                          /*!< The transfer is done to 10 registers starting trom TIMx_CR1 + TIMx_DCR.DBA */ | ||||
| #define TIM_DMABURSTLENGTH_11TRANSFERS     0x00000A00U                          /*!< The transfer is done to 11 registers starting trom TIMx_CR1 + TIMx_DCR.DBA */ | ||||
| #define TIM_DMABURSTLENGTH_12TRANSFERS     0x00000B00U                          /*!< The transfer is done to 12 registers starting trom TIMx_CR1 + TIMx_DCR.DBA */ | ||||
| #define TIM_DMABURSTLENGTH_13TRANSFERS     0x00000C00U                          /*!< The transfer is done to 13 registers starting trom TIMx_CR1 + TIMx_DCR.DBA */ | ||||
| #define TIM_DMABURSTLENGTH_14TRANSFERS     0x00000D00U                          /*!< The transfer is done to 14 registers starting trom TIMx_CR1 + TIMx_DCR.DBA */ | ||||
| #define TIM_DMABURSTLENGTH_15TRANSFERS     0x00000E00U                          /*!< The transfer is done to 15 registers starting trom TIMx_CR1 + TIMx_DCR.DBA */ | ||||
| #define TIM_DMABURSTLENGTH_16TRANSFERS     0x00000F00U                          /*!< The transfer is done to 16 registers starting trom TIMx_CR1 + TIMx_DCR.DBA */ | ||||
| #define TIM_DMABURSTLENGTH_17TRANSFERS     0x00001000U                          /*!< The transfer is done to 17 registers starting trom TIMx_CR1 + TIMx_DCR.DBA */ | ||||
| #define TIM_DMABURSTLENGTH_18TRANSFERS     0x00001100U                          /*!< The transfer is done to 18 registers starting trom TIMx_CR1 + TIMx_DCR.DBA */ | ||||
| #define TIM_DMABURSTLENGTH_1TRANSFER       0x00000000U                          /*!< The transfer is done to 1 register starting from TIMx_CR1 + TIMx_DCR.DBA   */ | ||||
| #define TIM_DMABURSTLENGTH_2TRANSFERS      0x00000100U                          /*!< The transfer is done to 2 registers starting from TIMx_CR1 + TIMx_DCR.DBA  */ | ||||
| #define TIM_DMABURSTLENGTH_3TRANSFERS      0x00000200U                          /*!< The transfer is done to 3 registers starting from TIMx_CR1 + TIMx_DCR.DBA  */ | ||||
| #define TIM_DMABURSTLENGTH_4TRANSFERS      0x00000300U                          /*!< The transfer is done to 4 registers starting from TIMx_CR1 + TIMx_DCR.DBA  */ | ||||
| #define TIM_DMABURSTLENGTH_5TRANSFERS      0x00000400U                          /*!< The transfer is done to 5 registers starting from TIMx_CR1 + TIMx_DCR.DBA  */ | ||||
| #define TIM_DMABURSTLENGTH_6TRANSFERS      0x00000500U                          /*!< The transfer is done to 6 registers starting from TIMx_CR1 + TIMx_DCR.DBA  */ | ||||
| #define TIM_DMABURSTLENGTH_7TRANSFERS      0x00000600U                          /*!< The transfer is done to 7 registers starting from TIMx_CR1 + TIMx_DCR.DBA  */ | ||||
| #define TIM_DMABURSTLENGTH_8TRANSFERS      0x00000700U                          /*!< The transfer is done to 8 registers starting from TIMx_CR1 + TIMx_DCR.DBA  */ | ||||
| #define TIM_DMABURSTLENGTH_9TRANSFERS      0x00000800U                          /*!< The transfer is done to 9 registers starting from TIMx_CR1 + TIMx_DCR.DBA  */ | ||||
| #define TIM_DMABURSTLENGTH_10TRANSFERS     0x00000900U                          /*!< The transfer is done to 10 registers starting from TIMx_CR1 + TIMx_DCR.DBA */ | ||||
| #define TIM_DMABURSTLENGTH_11TRANSFERS     0x00000A00U                          /*!< The transfer is done to 11 registers starting from TIMx_CR1 + TIMx_DCR.DBA */ | ||||
| #define TIM_DMABURSTLENGTH_12TRANSFERS     0x00000B00U                          /*!< The transfer is done to 12 registers starting from TIMx_CR1 + TIMx_DCR.DBA */ | ||||
| #define TIM_DMABURSTLENGTH_13TRANSFERS     0x00000C00U                          /*!< The transfer is done to 13 registers starting from TIMx_CR1 + TIMx_DCR.DBA */ | ||||
| #define TIM_DMABURSTLENGTH_14TRANSFERS     0x00000D00U                          /*!< The transfer is done to 14 registers starting from TIMx_CR1 + TIMx_DCR.DBA */ | ||||
| #define TIM_DMABURSTLENGTH_15TRANSFERS     0x00000E00U                          /*!< The transfer is done to 15 registers starting from TIMx_CR1 + TIMx_DCR.DBA */ | ||||
| #define TIM_DMABURSTLENGTH_16TRANSFERS     0x00000F00U                          /*!< The transfer is done to 16 registers starting from TIMx_CR1 + TIMx_DCR.DBA */ | ||||
| #define TIM_DMABURSTLENGTH_17TRANSFERS     0x00001000U                          /*!< The transfer is done to 17 registers starting from TIMx_CR1 + TIMx_DCR.DBA */ | ||||
| #define TIM_DMABURSTLENGTH_18TRANSFERS     0x00001100U                          /*!< The transfer is done to 18 registers starting from TIMx_CR1 + TIMx_DCR.DBA */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| @ -1091,7 +1098,8 @@ typedef  void (*pTIM_CallbackTypeDef)(TIM_HandleTypeDef *htim);  /*!< pointer to | ||||
|   * @brief  Disable the TIM main Output. | ||||
|   * @param  __HANDLE__ TIM handle | ||||
|   * @retval None | ||||
|   * @note The Main Output Enable of a timer instance is disabled only if all the CCx and CCxN channels have been disabled | ||||
|   * @note The Main Output Enable of a timer instance is disabled only if all the CCx and CCxN channels have been | ||||
|   *       disabled | ||||
|   */ | ||||
| #define __HAL_TIM_MOE_DISABLE(__HANDLE__) \ | ||||
|   do { \ | ||||
| @ -1252,8 +1260,8 @@ typedef  void (*pTIM_CallbackTypeDef)(TIM_HandleTypeDef *htim);  /*!< pointer to | ||||
|   * @brief  Indicates whether or not the TIM Counter is used as downcounter. | ||||
|   * @param  __HANDLE__ TIM handle. | ||||
|   * @retval False (Counter used as upcounter) or True (Counter used as downcounter) | ||||
|   * @note This macro is particularly useful to get the counting mode when the timer operates in Center-aligned mode or Encoder | ||||
| mode. | ||||
|   * @note This macro is particularly useful to get the counting mode when the timer operates in Center-aligned mode | ||||
|   *       or Encoder mode. | ||||
|   */ | ||||
| #define __HAL_TIM_IS_TIM_COUNTING_DOWN(__HANDLE__)    (((__HANDLE__)->Instance->CR1 &(TIM_CR1_DIR)) == (TIM_CR1_DIR)) | ||||
| 
 | ||||
| @ -1327,7 +1335,8 @@ mode. | ||||
| #define __HAL_TIM_GET_CLOCKDIVISION(__HANDLE__)  ((__HANDLE__)->Instance->CR1 & TIM_CR1_CKD) | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Set the TIM Input Capture prescaler on runtime without calling another time HAL_TIM_IC_ConfigChannel() function. | ||||
|   * @brief  Set the TIM Input Capture prescaler on runtime without calling another time HAL_TIM_IC_ConfigChannel() | ||||
|   *         function. | ||||
|   * @param  __HANDLE__ TIM handle. | ||||
|   * @param  __CHANNEL__ TIM Channels to be configured. | ||||
|   *          This parameter can be one of the following values: | ||||
| @ -1525,6 +1534,17 @@ mode. | ||||
|     TIM_SET_CAPTUREPOLARITY((__HANDLE__), (__CHANNEL__), (__POLARITY__)); \ | ||||
|   }while(0) | ||||
| 
 | ||||
| /** @brief  Select the Capture/compare DMA request source.
 | ||||
|   * @param  __HANDLE__ specifies the TIM Handle. | ||||
|   * @param  __CCDMA__ specifies Capture/compare DMA request source | ||||
|   *          This parameter can be one of the following values: | ||||
|   *            @arg TIM_CCDMAREQUEST_CC: CCx DMA request generated on Capture/Compare event | ||||
|   *            @arg TIM_CCDMAREQUEST_UPDATE: CCx DMA request generated on Update event | ||||
|   * @retval None | ||||
|   */ | ||||
| #define __HAL_TIM_SELECT_CCDMAREQUEST(__HANDLE__, __CCDMA__)    \ | ||||
|   MODIFY_REG((__HANDLE__)->Instance->CR2, TIM_CR2_CCDS, (__CCDMA__)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| @ -1633,20 +1653,22 @@ mode. | ||||
| #define IS_TIM_OPM_CHANNELS(__CHANNEL__)   (((__CHANNEL__) == TIM_CHANNEL_1) || \ | ||||
|                                             ((__CHANNEL__) == TIM_CHANNEL_2)) | ||||
| 
 | ||||
| #define IS_TIM_PERIOD(__PERIOD__)      (((__PERIOD__) > 0U) && ((__PERIOD__) <= 0xFFFFU)) | ||||
| 
 | ||||
| #define IS_TIM_COMPLEMENTARY_CHANNELS(__CHANNEL__) (((__CHANNEL__) == TIM_CHANNEL_1) || \ | ||||
|                                                     ((__CHANNEL__) == TIM_CHANNEL_2) || \ | ||||
|                                                     ((__CHANNEL__) == TIM_CHANNEL_3)) | ||||
| 
 | ||||
| #define IS_TIM_CLOCKSOURCE(__CLOCK__) (((__CLOCK__) == TIM_CLOCKSOURCE_INTERNAL) || \ | ||||
|                                        ((__CLOCK__) == TIM_CLOCKSOURCE_ETRMODE1) || \ | ||||
|                                        ((__CLOCK__) == TIM_CLOCKSOURCE_ETRMODE2) || \ | ||||
|                                        ((__CLOCK__) == TIM_CLOCKSOURCE_ITR0)     || \ | ||||
|                                        ((__CLOCK__) == TIM_CLOCKSOURCE_ITR1)     || \ | ||||
|                                        ((__CLOCK__) == TIM_CLOCKSOURCE_ITR2)     || \ | ||||
|                                        ((__CLOCK__) == TIM_CLOCKSOURCE_ITR3)     || \ | ||||
|                                        ((__CLOCK__) == TIM_CLOCKSOURCE_TI1ED)    || \ | ||||
|                                        ((__CLOCK__) == TIM_CLOCKSOURCE_TI1)      || \ | ||||
|                                        ((__CLOCK__) == TIM_CLOCKSOURCE_TI2)      || \ | ||||
|                                        ((__CLOCK__) == TIM_CLOCKSOURCE_ETRMODE1)) | ||||
|                                        ((__CLOCK__) == TIM_CLOCKSOURCE_ITR0)     || \ | ||||
|                                        ((__CLOCK__) == TIM_CLOCKSOURCE_ITR1)     || \ | ||||
|                                        ((__CLOCK__) == TIM_CLOCKSOURCE_ITR2)     || \ | ||||
|                                        ((__CLOCK__) == TIM_CLOCKSOURCE_ITR3)) | ||||
| 
 | ||||
| #define IS_TIM_CLOCKPOLARITY(__POLARITY__) (((__POLARITY__) == TIM_CLOCKPOLARITY_INVERTED)    || \ | ||||
|                                             ((__POLARITY__) == TIM_CLOCKPOLARITY_NONINVERTED) || \ | ||||
| @ -1684,7 +1706,6 @@ mode. | ||||
| 
 | ||||
| #define IS_TIM_BREAK_FILTER(__BRKFILTER__) ((__BRKFILTER__) <= 0xFUL) | ||||
| 
 | ||||
| 
 | ||||
| #define IS_TIM_BREAK_STATE(__STATE__)      (((__STATE__) == TIM_BREAK_ENABLE) || \ | ||||
|                                             ((__STATE__) == TIM_BREAK_DISABLE)) | ||||
| 
 | ||||
| @ -1722,13 +1743,13 @@ mode. | ||||
|                                    ((__MODE__) == TIM_OCMODE_FORCED_ACTIVE)      || \ | ||||
|                                    ((__MODE__) == TIM_OCMODE_FORCED_INACTIVE)) | ||||
| 
 | ||||
| #define IS_TIM_TRIGGER_SELECTION(__SELECTION__) (((__SELECTION__) == TIM_TS_ITR0) || \ | ||||
|                                                  ((__SELECTION__) == TIM_TS_ITR1) || \ | ||||
|                                                  ((__SELECTION__) == TIM_TS_ITR2) || \ | ||||
|                                                  ((__SELECTION__) == TIM_TS_ITR3) || \ | ||||
| #define IS_TIM_TRIGGER_SELECTION(__SELECTION__) (((__SELECTION__) == TIM_TS_ITR0)    || \ | ||||
|                                                  ((__SELECTION__) == TIM_TS_ITR1)    || \ | ||||
|                                                  ((__SELECTION__) == TIM_TS_ITR2)    || \ | ||||
|                                                  ((__SELECTION__) == TIM_TS_ITR3)    || \ | ||||
|                                                  ((__SELECTION__) == TIM_TS_TI1F_ED) || \ | ||||
|                                                  ((__SELECTION__) == TIM_TS_TI1FP1) || \ | ||||
|                                                  ((__SELECTION__) == TIM_TS_TI2FP2) || \ | ||||
|                                                  ((__SELECTION__) == TIM_TS_TI1FP1)  || \ | ||||
|                                                  ((__SELECTION__) == TIM_TS_TI2FP2)  || \ | ||||
|                                                  ((__SELECTION__) == TIM_TS_ETRF)) | ||||
| 
 | ||||
| #define IS_TIM_INTERNAL_TRIGGEREVENT_SELECTION(__SELECTION__) (((__SELECTION__) == TIM_TS_ITR0) || \ | ||||
| @ -1817,11 +1838,11 @@ mode. | ||||
|    ((__HANDLE__)->ChannelState[3] = (__CHANNEL_STATE__))) | ||||
| 
 | ||||
| #define TIM_CHANNEL_STATE_SET_ALL(__HANDLE__,  __CHANNEL_STATE__) do { \ | ||||
|   (__HANDLE__)->ChannelState[0]  = (__CHANNEL_STATE__);  \ | ||||
|   (__HANDLE__)->ChannelState[1]  = (__CHANNEL_STATE__);  \ | ||||
|   (__HANDLE__)->ChannelState[2]  = (__CHANNEL_STATE__);  \ | ||||
|   (__HANDLE__)->ChannelState[3]  = (__CHANNEL_STATE__);  \ | ||||
|  } while(0) | ||||
|                                                                        (__HANDLE__)->ChannelState[0]  = (__CHANNEL_STATE__);  \ | ||||
|                                                                        (__HANDLE__)->ChannelState[1]  = (__CHANNEL_STATE__);  \ | ||||
|                                                                        (__HANDLE__)->ChannelState[2]  = (__CHANNEL_STATE__);  \ | ||||
|                                                                        (__HANDLE__)->ChannelState[3]  = (__CHANNEL_STATE__);  \ | ||||
|                                                                      } while(0) | ||||
| 
 | ||||
| #define TIM_CHANNEL_N_STATE_GET(__HANDLE__, __CHANNEL__)\ | ||||
|   (((__CHANNEL__) == TIM_CHANNEL_1) ? (__HANDLE__)->ChannelNState[0] :\ | ||||
| @ -1836,11 +1857,15 @@ mode. | ||||
|    ((__HANDLE__)->ChannelNState[3] = (__CHANNEL_STATE__))) | ||||
| 
 | ||||
| #define TIM_CHANNEL_N_STATE_SET_ALL(__HANDLE__,  __CHANNEL_STATE__) do { \ | ||||
|   (__HANDLE__)->ChannelNState[0] = (__CHANNEL_STATE__);  \ | ||||
|   (__HANDLE__)->ChannelNState[1] = (__CHANNEL_STATE__);  \ | ||||
|   (__HANDLE__)->ChannelNState[2] = (__CHANNEL_STATE__);  \ | ||||
|   (__HANDLE__)->ChannelNState[3] = (__CHANNEL_STATE__);  \ | ||||
|  } while(0) | ||||
|                                                                          (__HANDLE__)->ChannelNState[0] = \ | ||||
|                                                                          (__CHANNEL_STATE__);  \ | ||||
|                                                                          (__HANDLE__)->ChannelNState[1] = \ | ||||
|                                                                          (__CHANNEL_STATE__);  \ | ||||
|                                                                          (__HANDLE__)->ChannelNState[2] = \ | ||||
|                                                                          (__CHANNEL_STATE__);  \ | ||||
|                                                                          (__HANDLE__)->ChannelNState[3] = \ | ||||
|                                                                          (__CHANNEL_STATE__);  \ | ||||
|                                                                        } while(0) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
| @ -1871,7 +1896,7 @@ HAL_StatusTypeDef HAL_TIM_Base_Stop(TIM_HandleTypeDef *htim); | ||||
| HAL_StatusTypeDef HAL_TIM_Base_Start_IT(TIM_HandleTypeDef *htim); | ||||
| HAL_StatusTypeDef HAL_TIM_Base_Stop_IT(TIM_HandleTypeDef *htim); | ||||
| /* Non-Blocking mode: DMA */ | ||||
| HAL_StatusTypeDef HAL_TIM_Base_Start_DMA(TIM_HandleTypeDef *htim, uint32_t *pData, uint16_t Length); | ||||
| HAL_StatusTypeDef HAL_TIM_Base_Start_DMA(TIM_HandleTypeDef *htim, const uint32_t *pData, uint16_t Length); | ||||
| HAL_StatusTypeDef HAL_TIM_Base_Stop_DMA(TIM_HandleTypeDef *htim); | ||||
| /**
 | ||||
|   * @} | ||||
| @ -1893,7 +1918,8 @@ HAL_StatusTypeDef HAL_TIM_OC_Stop(TIM_HandleTypeDef *htim, uint32_t Channel); | ||||
| HAL_StatusTypeDef HAL_TIM_OC_Start_IT(TIM_HandleTypeDef *htim, uint32_t Channel); | ||||
| HAL_StatusTypeDef HAL_TIM_OC_Stop_IT(TIM_HandleTypeDef *htim, uint32_t Channel); | ||||
| /* Non-Blocking mode: DMA */ | ||||
| HAL_StatusTypeDef HAL_TIM_OC_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Channel, uint32_t *pData, uint16_t Length); | ||||
| HAL_StatusTypeDef HAL_TIM_OC_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Channel, const uint32_t *pData, | ||||
|                                        uint16_t Length); | ||||
| HAL_StatusTypeDef HAL_TIM_OC_Stop_DMA(TIM_HandleTypeDef *htim, uint32_t Channel); | ||||
| /**
 | ||||
|   * @} | ||||
| @ -1915,7 +1941,8 @@ HAL_StatusTypeDef HAL_TIM_PWM_Stop(TIM_HandleTypeDef *htim, uint32_t Channel); | ||||
| HAL_StatusTypeDef HAL_TIM_PWM_Start_IT(TIM_HandleTypeDef *htim, uint32_t Channel); | ||||
| HAL_StatusTypeDef HAL_TIM_PWM_Stop_IT(TIM_HandleTypeDef *htim, uint32_t Channel); | ||||
| /* Non-Blocking mode: DMA */ | ||||
| HAL_StatusTypeDef HAL_TIM_PWM_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Channel, uint32_t *pData, uint16_t Length); | ||||
| HAL_StatusTypeDef HAL_TIM_PWM_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Channel, const uint32_t *pData, | ||||
|                                         uint16_t Length); | ||||
| HAL_StatusTypeDef HAL_TIM_PWM_Stop_DMA(TIM_HandleTypeDef *htim, uint32_t Channel); | ||||
| /**
 | ||||
|   * @} | ||||
| @ -1967,7 +1994,7 @@ HAL_StatusTypeDef HAL_TIM_OnePulse_Stop_IT(TIM_HandleTypeDef *htim, uint32_t Out | ||||
|   * @{ | ||||
|   */ | ||||
| /* Timer Encoder functions ****************************************************/ | ||||
| HAL_StatusTypeDef HAL_TIM_Encoder_Init(TIM_HandleTypeDef *htim,  TIM_Encoder_InitTypeDef *sConfig); | ||||
| HAL_StatusTypeDef HAL_TIM_Encoder_Init(TIM_HandleTypeDef *htim, const TIM_Encoder_InitTypeDef *sConfig); | ||||
| HAL_StatusTypeDef HAL_TIM_Encoder_DeInit(TIM_HandleTypeDef *htim); | ||||
| void HAL_TIM_Encoder_MspInit(TIM_HandleTypeDef *htim); | ||||
| void HAL_TIM_Encoder_MspDeInit(TIM_HandleTypeDef *htim); | ||||
| @ -2000,31 +2027,36 @@ void HAL_TIM_IRQHandler(TIM_HandleTypeDef *htim); | ||||
|   * @{ | ||||
|   */ | ||||
| /* Control functions  *********************************************************/ | ||||
| HAL_StatusTypeDef HAL_TIM_OC_ConfigChannel(TIM_HandleTypeDef *htim, TIM_OC_InitTypeDef *sConfig, uint32_t Channel); | ||||
| HAL_StatusTypeDef HAL_TIM_PWM_ConfigChannel(TIM_HandleTypeDef *htim, TIM_OC_InitTypeDef *sConfig, uint32_t Channel); | ||||
| HAL_StatusTypeDef HAL_TIM_IC_ConfigChannel(TIM_HandleTypeDef *htim, TIM_IC_InitTypeDef *sConfig, uint32_t Channel); | ||||
| HAL_StatusTypeDef HAL_TIM_OC_ConfigChannel(TIM_HandleTypeDef *htim, const TIM_OC_InitTypeDef *sConfig, | ||||
|                                            uint32_t Channel); | ||||
| HAL_StatusTypeDef HAL_TIM_PWM_ConfigChannel(TIM_HandleTypeDef *htim, const TIM_OC_InitTypeDef *sConfig, | ||||
|                                             uint32_t Channel); | ||||
| HAL_StatusTypeDef HAL_TIM_IC_ConfigChannel(TIM_HandleTypeDef *htim, const TIM_IC_InitTypeDef *sConfig, | ||||
|                                            uint32_t Channel); | ||||
| HAL_StatusTypeDef HAL_TIM_OnePulse_ConfigChannel(TIM_HandleTypeDef *htim, TIM_OnePulse_InitTypeDef *sConfig, | ||||
|                                                  uint32_t OutputChannel,  uint32_t InputChannel); | ||||
| HAL_StatusTypeDef HAL_TIM_ConfigOCrefClear(TIM_HandleTypeDef *htim, TIM_ClearInputConfigTypeDef *sClearInputConfig, | ||||
| HAL_StatusTypeDef HAL_TIM_ConfigOCrefClear(TIM_HandleTypeDef *htim, | ||||
|                                            const TIM_ClearInputConfigTypeDef *sClearInputConfig, | ||||
|                                            uint32_t Channel); | ||||
| HAL_StatusTypeDef HAL_TIM_ConfigClockSource(TIM_HandleTypeDef *htim, TIM_ClockConfigTypeDef *sClockSourceConfig); | ||||
| HAL_StatusTypeDef HAL_TIM_ConfigClockSource(TIM_HandleTypeDef *htim, const TIM_ClockConfigTypeDef *sClockSourceConfig); | ||||
| HAL_StatusTypeDef HAL_TIM_ConfigTI1Input(TIM_HandleTypeDef *htim, uint32_t TI1_Selection); | ||||
| HAL_StatusTypeDef HAL_TIM_SlaveConfigSynchro(TIM_HandleTypeDef *htim, TIM_SlaveConfigTypeDef *sSlaveConfig); | ||||
| HAL_StatusTypeDef HAL_TIM_SlaveConfigSynchro_IT(TIM_HandleTypeDef *htim, TIM_SlaveConfigTypeDef *sSlaveConfig); | ||||
| HAL_StatusTypeDef HAL_TIM_SlaveConfigSynchro(TIM_HandleTypeDef *htim, const TIM_SlaveConfigTypeDef *sSlaveConfig); | ||||
| HAL_StatusTypeDef HAL_TIM_SlaveConfigSynchro_IT(TIM_HandleTypeDef *htim, const TIM_SlaveConfigTypeDef *sSlaveConfig); | ||||
| HAL_StatusTypeDef HAL_TIM_DMABurst_WriteStart(TIM_HandleTypeDef *htim, uint32_t BurstBaseAddress, | ||||
|                                               uint32_t BurstRequestSrc, uint32_t  *BurstBuffer, uint32_t  BurstLength); | ||||
|                                               uint32_t BurstRequestSrc, const uint32_t  *BurstBuffer, | ||||
|                                               uint32_t  BurstLength); | ||||
| HAL_StatusTypeDef HAL_TIM_DMABurst_MultiWriteStart(TIM_HandleTypeDef *htim, uint32_t BurstBaseAddress, | ||||
|                                                    uint32_t BurstRequestSrc, uint32_t *BurstBuffer, uint32_t BurstLength, | ||||
|                                                    uint32_t DataLength); | ||||
|                                                    uint32_t BurstRequestSrc, const uint32_t *BurstBuffer, | ||||
|                                                    uint32_t BurstLength,  uint32_t DataLength); | ||||
| HAL_StatusTypeDef HAL_TIM_DMABurst_WriteStop(TIM_HandleTypeDef *htim, uint32_t BurstRequestSrc); | ||||
| HAL_StatusTypeDef HAL_TIM_DMABurst_ReadStart(TIM_HandleTypeDef *htim, uint32_t BurstBaseAddress, | ||||
|                                              uint32_t BurstRequestSrc, uint32_t  *BurstBuffer, uint32_t  BurstLength); | ||||
| HAL_StatusTypeDef HAL_TIM_DMABurst_MultiReadStart(TIM_HandleTypeDef *htim, uint32_t BurstBaseAddress, | ||||
|                                                   uint32_t BurstRequestSrc, uint32_t  *BurstBuffer, uint32_t  BurstLength, | ||||
|                                                   uint32_t  DataLength); | ||||
|                                                   uint32_t BurstRequestSrc, uint32_t  *BurstBuffer, | ||||
|                                                   uint32_t  BurstLength, uint32_t  DataLength); | ||||
| HAL_StatusTypeDef HAL_TIM_DMABurst_ReadStop(TIM_HandleTypeDef *htim, uint32_t BurstRequestSrc); | ||||
| HAL_StatusTypeDef HAL_TIM_GenerateEvent(TIM_HandleTypeDef *htim, uint32_t EventSource); | ||||
| uint32_t HAL_TIM_ReadCapturedValue(TIM_HandleTypeDef *htim, uint32_t Channel); | ||||
| uint32_t HAL_TIM_ReadCapturedValue(const TIM_HandleTypeDef *htim, uint32_t Channel); | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| @ -2061,17 +2093,17 @@ HAL_StatusTypeDef HAL_TIM_UnRegisterCallback(TIM_HandleTypeDef *htim, HAL_TIM_Ca | ||||
|   * @{ | ||||
|   */ | ||||
| /* Peripheral State functions  ************************************************/ | ||||
| HAL_TIM_StateTypeDef HAL_TIM_Base_GetState(TIM_HandleTypeDef *htim); | ||||
| HAL_TIM_StateTypeDef HAL_TIM_OC_GetState(TIM_HandleTypeDef *htim); | ||||
| HAL_TIM_StateTypeDef HAL_TIM_PWM_GetState(TIM_HandleTypeDef *htim); | ||||
| HAL_TIM_StateTypeDef HAL_TIM_IC_GetState(TIM_HandleTypeDef *htim); | ||||
| HAL_TIM_StateTypeDef HAL_TIM_OnePulse_GetState(TIM_HandleTypeDef *htim); | ||||
| HAL_TIM_StateTypeDef HAL_TIM_Encoder_GetState(TIM_HandleTypeDef *htim); | ||||
| HAL_TIM_StateTypeDef HAL_TIM_Base_GetState(const TIM_HandleTypeDef *htim); | ||||
| HAL_TIM_StateTypeDef HAL_TIM_OC_GetState(const TIM_HandleTypeDef *htim); | ||||
| HAL_TIM_StateTypeDef HAL_TIM_PWM_GetState(const TIM_HandleTypeDef *htim); | ||||
| HAL_TIM_StateTypeDef HAL_TIM_IC_GetState(const TIM_HandleTypeDef *htim); | ||||
| HAL_TIM_StateTypeDef HAL_TIM_OnePulse_GetState(const TIM_HandleTypeDef *htim); | ||||
| HAL_TIM_StateTypeDef HAL_TIM_Encoder_GetState(const TIM_HandleTypeDef *htim); | ||||
| 
 | ||||
| /* Peripheral Channel state functions  ************************************************/ | ||||
| HAL_TIM_ActiveChannel HAL_TIM_GetActiveChannel(TIM_HandleTypeDef *htim); | ||||
| HAL_TIM_ChannelStateTypeDef HAL_TIM_GetChannelState(TIM_HandleTypeDef *htim,  uint32_t Channel); | ||||
| HAL_TIM_DMABurstStateTypeDef HAL_TIM_DMABurstState(TIM_HandleTypeDef *htim); | ||||
| HAL_TIM_ActiveChannel HAL_TIM_GetActiveChannel(const TIM_HandleTypeDef *htim); | ||||
| HAL_TIM_ChannelStateTypeDef HAL_TIM_GetChannelState(const TIM_HandleTypeDef *htim,  uint32_t Channel); | ||||
| HAL_TIM_DMABurstStateTypeDef HAL_TIM_DMABurstState(const TIM_HandleTypeDef *htim); | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| @ -2085,9 +2117,9 @@ HAL_TIM_DMABurstStateTypeDef HAL_TIM_DMABurstState(TIM_HandleTypeDef *htim); | ||||
| /** @defgroup TIM_Private_Functions TIM Private Functions
 | ||||
|   * @{ | ||||
|   */ | ||||
| void TIM_Base_SetConfig(TIM_TypeDef *TIMx, TIM_Base_InitTypeDef *Structure); | ||||
| void TIM_Base_SetConfig(TIM_TypeDef *TIMx, const TIM_Base_InitTypeDef *Structure); | ||||
| void TIM_TI1_SetConfig(TIM_TypeDef *TIMx, uint32_t TIM_ICPolarity, uint32_t TIM_ICSelection, uint32_t TIM_ICFilter); | ||||
| void TIM_OC2_SetConfig(TIM_TypeDef *TIMx, TIM_OC_InitTypeDef *OC_Config); | ||||
| void TIM_OC2_SetConfig(TIM_TypeDef *TIMx, const TIM_OC_InitTypeDef *OC_Config); | ||||
| void TIM_ETR_SetConfig(TIM_TypeDef *TIMx, uint32_t TIM_ExtTRGPrescaler, | ||||
|                        uint32_t TIM_ExtTRGPolarity, uint32_t ExtTRGFilter); | ||||
| 
 | ||||
| @ -2119,5 +2151,3 @@ void TIM_ResetCallback(TIM_HandleTypeDef *htim); | ||||
| #endif | ||||
| 
 | ||||
| #endif /* STM32F1xx_HAL_TIM_H */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | ||||
| @ -6,13 +6,12 @@ | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© Copyright (c) 2016 STMicroelectronics. | ||||
|   * All rights reserved.</center></h2> | ||||
|   * Copyright (c) 2016 STMicroelectronics. | ||||
|   * All rights reserved. | ||||
|   * | ||||
|   * 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 | ||||
|   * 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. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| @ -111,7 +110,7 @@ typedef struct | ||||
|   * @{ | ||||
|   */ | ||||
| /*  Timer Hall Sensor functions  **********************************************/ | ||||
| HAL_StatusTypeDef HAL_TIMEx_HallSensor_Init(TIM_HandleTypeDef *htim, TIM_HallSensor_InitTypeDef *sConfig); | ||||
| HAL_StatusTypeDef HAL_TIMEx_HallSensor_Init(TIM_HandleTypeDef *htim, const TIM_HallSensor_InitTypeDef *sConfig); | ||||
| HAL_StatusTypeDef HAL_TIMEx_HallSensor_DeInit(TIM_HandleTypeDef *htim); | ||||
| 
 | ||||
| void HAL_TIMEx_HallSensor_MspInit(TIM_HandleTypeDef *htim); | ||||
| @ -144,7 +143,8 @@ HAL_StatusTypeDef HAL_TIMEx_OCN_Start_IT(TIM_HandleTypeDef *htim, uint32_t Chann | ||||
| HAL_StatusTypeDef HAL_TIMEx_OCN_Stop_IT(TIM_HandleTypeDef *htim, uint32_t Channel); | ||||
| 
 | ||||
| /* Non-Blocking mode: DMA */ | ||||
| HAL_StatusTypeDef HAL_TIMEx_OCN_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Channel, uint32_t *pData, uint16_t Length); | ||||
| HAL_StatusTypeDef HAL_TIMEx_OCN_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Channel, const uint32_t *pData, | ||||
|                                           uint16_t Length); | ||||
| HAL_StatusTypeDef HAL_TIMEx_OCN_Stop_DMA(TIM_HandleTypeDef *htim, uint32_t Channel); | ||||
| /**
 | ||||
|   * @} | ||||
| @ -163,7 +163,8 @@ HAL_StatusTypeDef HAL_TIMEx_PWMN_Stop(TIM_HandleTypeDef *htim, uint32_t Channel) | ||||
| HAL_StatusTypeDef HAL_TIMEx_PWMN_Start_IT(TIM_HandleTypeDef *htim, uint32_t Channel); | ||||
| HAL_StatusTypeDef HAL_TIMEx_PWMN_Stop_IT(TIM_HandleTypeDef *htim, uint32_t Channel); | ||||
| /* Non-Blocking mode: DMA */ | ||||
| HAL_StatusTypeDef HAL_TIMEx_PWMN_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Channel, uint32_t *pData, uint16_t Length); | ||||
| HAL_StatusTypeDef HAL_TIMEx_PWMN_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Channel, const uint32_t *pData, | ||||
|                                            uint16_t Length); | ||||
| HAL_StatusTypeDef HAL_TIMEx_PWMN_Stop_DMA(TIM_HandleTypeDef *htim, uint32_t Channel); | ||||
| /**
 | ||||
|   * @} | ||||
| @ -197,9 +198,9 @@ HAL_StatusTypeDef HAL_TIMEx_ConfigCommutEvent_IT(TIM_HandleTypeDef *htim, uint32 | ||||
| HAL_StatusTypeDef HAL_TIMEx_ConfigCommutEvent_DMA(TIM_HandleTypeDef *htim, uint32_t  InputTrigger, | ||||
|                                                   uint32_t  CommutationSource); | ||||
| HAL_StatusTypeDef HAL_TIMEx_MasterConfigSynchronization(TIM_HandleTypeDef *htim, | ||||
|                                                         TIM_MasterConfigTypeDef *sMasterConfig); | ||||
|                                                         const TIM_MasterConfigTypeDef *sMasterConfig); | ||||
| HAL_StatusTypeDef HAL_TIMEx_ConfigBreakDeadTime(TIM_HandleTypeDef *htim, | ||||
|                                                 TIM_BreakDeadTimeConfigTypeDef *sBreakDeadTimeConfig); | ||||
|                                                 const TIM_BreakDeadTimeConfigTypeDef *sBreakDeadTimeConfig); | ||||
| HAL_StatusTypeDef HAL_TIMEx_RemapConfig(TIM_HandleTypeDef *htim, uint32_t Remap); | ||||
| /**
 | ||||
|   * @} | ||||
| @ -222,8 +223,8 @@ void HAL_TIMEx_BreakCallback(TIM_HandleTypeDef *htim); | ||||
|   * @{ | ||||
|   */ | ||||
| /* Extended Peripheral State functions  ***************************************/ | ||||
| HAL_TIM_StateTypeDef HAL_TIMEx_HallSensor_GetState(TIM_HandleTypeDef *htim); | ||||
| HAL_TIM_ChannelStateTypeDef HAL_TIMEx_GetChannelNState(TIM_HandleTypeDef *htim,  uint32_t ChannelN); | ||||
| HAL_TIM_StateTypeDef HAL_TIMEx_HallSensor_GetState(const TIM_HandleTypeDef *htim); | ||||
| HAL_TIM_ChannelStateTypeDef HAL_TIMEx_GetChannelNState(const TIM_HandleTypeDef *htim,  uint32_t ChannelN); | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| @ -234,7 +235,7 @@ HAL_TIM_ChannelStateTypeDef HAL_TIMEx_GetChannelNState(TIM_HandleTypeDef *htim, | ||||
| /* End of exported functions -------------------------------------------------*/ | ||||
| 
 | ||||
| /* Private functions----------------------------------------------------------*/ | ||||
| /** @addtogroup TIMEx_Private_Functions TIMEx Private Functions
 | ||||
| /** @addtogroup TIMEx_Private_Functions TIM Extended Private Functions
 | ||||
|   * @{ | ||||
|   */ | ||||
| void TIMEx_DMACommutationCplt(DMA_HandleTypeDef *hdma); | ||||
| @ -258,5 +259,3 @@ void TIMEx_DMACommutationHalfCplt(DMA_HandleTypeDef *hdma); | ||||
| 
 | ||||
| 
 | ||||
| #endif /* STM32F1xx_HAL_TIM_EX_H */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | ||||
							
								
								
									
										1012
									
								
								Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_ll_bus.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1012
									
								
								Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_ll_bus.h
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										638
									
								
								Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_ll_cortex.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										638
									
								
								Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_ll_cortex.h
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,638 @@ | ||||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32f1xx_ll_cortex.h | ||||
|   * @author  MCD Application Team | ||||
|   * @brief   Header file of CORTEX LL module. | ||||
|   @verbatim | ||||
|   ============================================================================== | ||||
|                      ##### How to use this driver ##### | ||||
|   ============================================================================== | ||||
|     [..] | ||||
|     The LL CORTEX driver contains a set of generic APIs that can be | ||||
|     used by user: | ||||
|       (+) SYSTICK configuration used by LL_mDelay and LL_Init1msTick | ||||
|           functions | ||||
|       (+) Low power mode configuration (SCB register of Cortex-MCU) | ||||
|       (+) MPU API to configure and enable regions | ||||
|           (MPU services provided only on some devices) | ||||
|       (+) API to access to MCU info (CPUID register) | ||||
|       (+) API to enable fault handler (SHCSR accesses) | ||||
| 
 | ||||
|   @endverbatim | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * Copyright (c) 2017 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. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef __STM32F1xx_LL_CORTEX_H | ||||
| #define __STM32F1xx_LL_CORTEX_H | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32f1xx.h" | ||||
| 
 | ||||
| /** @addtogroup STM32F1xx_LL_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup CORTEX_LL CORTEX
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /* Private types -------------------------------------------------------------*/ | ||||
| /* Private variables ---------------------------------------------------------*/ | ||||
| 
 | ||||
| /* Private constants ---------------------------------------------------------*/ | ||||
| 
 | ||||
| /* Private macros ------------------------------------------------------------*/ | ||||
| 
 | ||||
| /* Exported types ------------------------------------------------------------*/ | ||||
| /* Exported constants --------------------------------------------------------*/ | ||||
| /** @defgroup CORTEX_LL_Exported_Constants CORTEX Exported Constants
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup CORTEX_LL_EC_CLKSOURCE_HCLK SYSTICK Clock Source
 | ||||
|   * @{ | ||||
|   */ | ||||
| #define LL_SYSTICK_CLKSOURCE_HCLK_DIV8     0x00000000U                 /*!< AHB clock divided by 8 selected as SysTick clock source.*/ | ||||
| #define LL_SYSTICK_CLKSOURCE_HCLK          SysTick_CTRL_CLKSOURCE_Msk  /*!< AHB clock selected as SysTick clock source. */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup CORTEX_LL_EC_FAULT Handler Fault type
 | ||||
|   * @{ | ||||
|   */ | ||||
| #define LL_HANDLER_FAULT_USG               SCB_SHCSR_USGFAULTENA_Msk              /*!< Usage fault */ | ||||
| #define LL_HANDLER_FAULT_BUS               SCB_SHCSR_BUSFAULTENA_Msk              /*!< Bus fault */ | ||||
| #define LL_HANDLER_FAULT_MEM               SCB_SHCSR_MEMFAULTENA_Msk              /*!< Memory management fault */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| #if __MPU_PRESENT | ||||
| 
 | ||||
| /** @defgroup CORTEX_LL_EC_CTRL_HFNMI_PRIVDEF MPU Control
 | ||||
|   * @{ | ||||
|   */ | ||||
| #define LL_MPU_CTRL_HFNMI_PRIVDEF_NONE     0x00000000U                                       /*!< Disable NMI and privileged SW access */ | ||||
| #define LL_MPU_CTRL_HARDFAULT_NMI          MPU_CTRL_HFNMIENA_Msk                             /*!< Enables the operation of MPU during hard fault, NMI, and FAULTMASK handlers */ | ||||
| #define LL_MPU_CTRL_PRIVILEGED_DEFAULT     MPU_CTRL_PRIVDEFENA_Msk                           /*!< Enable privileged software access to default memory map */ | ||||
| #define LL_MPU_CTRL_HFNMI_PRIVDEF          (MPU_CTRL_HFNMIENA_Msk | MPU_CTRL_PRIVDEFENA_Msk) /*!< Enable NMI and privileged SW access */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup CORTEX_LL_EC_REGION MPU Region Number
 | ||||
|   * @{ | ||||
|   */ | ||||
| #define LL_MPU_REGION_NUMBER0              0x00U /*!< REGION Number 0 */ | ||||
| #define LL_MPU_REGION_NUMBER1              0x01U /*!< REGION Number 1 */ | ||||
| #define LL_MPU_REGION_NUMBER2              0x02U /*!< REGION Number 2 */ | ||||
| #define LL_MPU_REGION_NUMBER3              0x03U /*!< REGION Number 3 */ | ||||
| #define LL_MPU_REGION_NUMBER4              0x04U /*!< REGION Number 4 */ | ||||
| #define LL_MPU_REGION_NUMBER5              0x05U /*!< REGION Number 5 */ | ||||
| #define LL_MPU_REGION_NUMBER6              0x06U /*!< REGION Number 6 */ | ||||
| #define LL_MPU_REGION_NUMBER7              0x07U /*!< REGION Number 7 */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup CORTEX_LL_EC_REGION_SIZE MPU Region Size
 | ||||
|   * @{ | ||||
|   */ | ||||
| #define LL_MPU_REGION_SIZE_32B             (0x04U << MPU_RASR_SIZE_Pos) /*!< 32B Size of the MPU protection region */ | ||||
| #define LL_MPU_REGION_SIZE_64B             (0x05U << MPU_RASR_SIZE_Pos) /*!< 64B Size of the MPU protection region */ | ||||
| #define LL_MPU_REGION_SIZE_128B            (0x06U << MPU_RASR_SIZE_Pos) /*!< 128B Size of the MPU protection region */ | ||||
| #define LL_MPU_REGION_SIZE_256B            (0x07U << MPU_RASR_SIZE_Pos) /*!< 256B Size of the MPU protection region */ | ||||
| #define LL_MPU_REGION_SIZE_512B            (0x08U << MPU_RASR_SIZE_Pos) /*!< 512B Size of the MPU protection region */ | ||||
| #define LL_MPU_REGION_SIZE_1KB             (0x09U << MPU_RASR_SIZE_Pos) /*!< 1KB Size of the MPU protection region */ | ||||
| #define LL_MPU_REGION_SIZE_2KB             (0x0AU << MPU_RASR_SIZE_Pos) /*!< 2KB Size of the MPU protection region */ | ||||
| #define LL_MPU_REGION_SIZE_4KB             (0x0BU << MPU_RASR_SIZE_Pos) /*!< 4KB Size of the MPU protection region */ | ||||
| #define LL_MPU_REGION_SIZE_8KB             (0x0CU << MPU_RASR_SIZE_Pos) /*!< 8KB Size of the MPU protection region */ | ||||
| #define LL_MPU_REGION_SIZE_16KB            (0x0DU << MPU_RASR_SIZE_Pos) /*!< 16KB Size of the MPU protection region */ | ||||
| #define LL_MPU_REGION_SIZE_32KB            (0x0EU << MPU_RASR_SIZE_Pos) /*!< 32KB Size of the MPU protection region */ | ||||
| #define LL_MPU_REGION_SIZE_64KB            (0x0FU << MPU_RASR_SIZE_Pos) /*!< 64KB Size of the MPU protection region */ | ||||
| #define LL_MPU_REGION_SIZE_128KB           (0x10U << MPU_RASR_SIZE_Pos) /*!< 128KB Size of the MPU protection region */ | ||||
| #define LL_MPU_REGION_SIZE_256KB           (0x11U << MPU_RASR_SIZE_Pos) /*!< 256KB Size of the MPU protection region */ | ||||
| #define LL_MPU_REGION_SIZE_512KB           (0x12U << MPU_RASR_SIZE_Pos) /*!< 512KB Size of the MPU protection region */ | ||||
| #define LL_MPU_REGION_SIZE_1MB             (0x13U << MPU_RASR_SIZE_Pos) /*!< 1MB Size of the MPU protection region */ | ||||
| #define LL_MPU_REGION_SIZE_2MB             (0x14U << MPU_RASR_SIZE_Pos) /*!< 2MB Size of the MPU protection region */ | ||||
| #define LL_MPU_REGION_SIZE_4MB             (0x15U << MPU_RASR_SIZE_Pos) /*!< 4MB Size of the MPU protection region */ | ||||
| #define LL_MPU_REGION_SIZE_8MB             (0x16U << MPU_RASR_SIZE_Pos) /*!< 8MB Size of the MPU protection region */ | ||||
| #define LL_MPU_REGION_SIZE_16MB            (0x17U << MPU_RASR_SIZE_Pos) /*!< 16MB Size of the MPU protection region */ | ||||
| #define LL_MPU_REGION_SIZE_32MB            (0x18U << MPU_RASR_SIZE_Pos) /*!< 32MB Size of the MPU protection region */ | ||||
| #define LL_MPU_REGION_SIZE_64MB            (0x19U << MPU_RASR_SIZE_Pos) /*!< 64MB Size of the MPU protection region */ | ||||
| #define LL_MPU_REGION_SIZE_128MB           (0x1AU << MPU_RASR_SIZE_Pos) /*!< 128MB Size of the MPU protection region */ | ||||
| #define LL_MPU_REGION_SIZE_256MB           (0x1BU << MPU_RASR_SIZE_Pos) /*!< 256MB Size of the MPU protection region */ | ||||
| #define LL_MPU_REGION_SIZE_512MB           (0x1CU << MPU_RASR_SIZE_Pos) /*!< 512MB Size of the MPU protection region */ | ||||
| #define LL_MPU_REGION_SIZE_1GB             (0x1DU << MPU_RASR_SIZE_Pos) /*!< 1GB Size of the MPU protection region */ | ||||
| #define LL_MPU_REGION_SIZE_2GB             (0x1EU << MPU_RASR_SIZE_Pos) /*!< 2GB Size of the MPU protection region */ | ||||
| #define LL_MPU_REGION_SIZE_4GB             (0x1FU << MPU_RASR_SIZE_Pos) /*!< 4GB Size of the MPU protection region */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup CORTEX_LL_EC_REGION_PRIVILEDGES MPU Region Privileges
 | ||||
|   * @{ | ||||
|   */ | ||||
| #define LL_MPU_REGION_NO_ACCESS            (0x00U << MPU_RASR_AP_Pos) /*!< No access*/ | ||||
| #define LL_MPU_REGION_PRIV_RW              (0x01U << MPU_RASR_AP_Pos) /*!< RW privileged (privileged access only)*/ | ||||
| #define LL_MPU_REGION_PRIV_RW_URO          (0x02U << MPU_RASR_AP_Pos) /*!< RW privileged - RO user (Write in a user program generates a fault) */ | ||||
| #define LL_MPU_REGION_FULL_ACCESS          (0x03U << MPU_RASR_AP_Pos) /*!< RW privileged & user (Full access) */ | ||||
| #define LL_MPU_REGION_PRIV_RO              (0x05U << MPU_RASR_AP_Pos) /*!< RO privileged (privileged read only)*/ | ||||
| #define LL_MPU_REGION_PRIV_RO_URO          (0x06U << MPU_RASR_AP_Pos) /*!< RO privileged & user (read only) */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup CORTEX_LL_EC_TEX MPU TEX Level
 | ||||
|   * @{ | ||||
|   */ | ||||
| #define LL_MPU_TEX_LEVEL0                  (0x00U << MPU_RASR_TEX_Pos) /*!< b000 for TEX bits */ | ||||
| #define LL_MPU_TEX_LEVEL1                  (0x01U << MPU_RASR_TEX_Pos) /*!< b001 for TEX bits */ | ||||
| #define LL_MPU_TEX_LEVEL2                  (0x02U << MPU_RASR_TEX_Pos) /*!< b010 for TEX bits */ | ||||
| #define LL_MPU_TEX_LEVEL4                  (0x04U << MPU_RASR_TEX_Pos) /*!< b100 for TEX bits */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup CORTEX_LL_EC_INSTRUCTION_ACCESS MPU Instruction Access
 | ||||
|   * @{ | ||||
|   */ | ||||
| #define LL_MPU_INSTRUCTION_ACCESS_ENABLE   0x00U            /*!< Instruction fetches enabled */ | ||||
| #define LL_MPU_INSTRUCTION_ACCESS_DISABLE  MPU_RASR_XN_Msk  /*!< Instruction fetches disabled*/ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup CORTEX_LL_EC_SHAREABLE_ACCESS MPU Shareable Access
 | ||||
|   * @{ | ||||
|   */ | ||||
| #define LL_MPU_ACCESS_SHAREABLE            MPU_RASR_S_Msk   /*!< Shareable memory attribute */ | ||||
| #define LL_MPU_ACCESS_NOT_SHAREABLE        0x00U            /*!< Not Shareable memory attribute */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup CORTEX_LL_EC_CACHEABLE_ACCESS MPU Cacheable Access
 | ||||
|   * @{ | ||||
|   */ | ||||
| #define LL_MPU_ACCESS_CACHEABLE            MPU_RASR_C_Msk   /*!< Cacheable memory attribute */ | ||||
| #define LL_MPU_ACCESS_NOT_CACHEABLE        0x00U            /*!< Not Cacheable memory attribute */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup CORTEX_LL_EC_BUFFERABLE_ACCESS MPU Bufferable Access
 | ||||
|   * @{ | ||||
|   */ | ||||
| #define LL_MPU_ACCESS_BUFFERABLE           MPU_RASR_B_Msk   /*!< Bufferable memory attribute */ | ||||
| #define LL_MPU_ACCESS_NOT_BUFFERABLE       0x00U            /*!< Not Bufferable memory attribute */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| #endif /* __MPU_PRESENT */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /* Exported macro ------------------------------------------------------------*/ | ||||
| 
 | ||||
| /* Exported functions --------------------------------------------------------*/ | ||||
| /** @defgroup CORTEX_LL_Exported_Functions CORTEX Exported Functions
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup CORTEX_LL_EF_SYSTICK SYSTICK
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  This function checks if the Systick counter flag is active or not. | ||||
|   * @note   It can be used in timeout function on application side. | ||||
|   * @rmtoll STK_CTRL     COUNTFLAG     LL_SYSTICK_IsActiveCounterFlag | ||||
|   * @retval State of bit (1 or 0). | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_SYSTICK_IsActiveCounterFlag(void) | ||||
| { | ||||
|   return ((SysTick->CTRL & SysTick_CTRL_COUNTFLAG_Msk) == (SysTick_CTRL_COUNTFLAG_Msk)); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Configures the SysTick clock source | ||||
|   * @rmtoll STK_CTRL     CLKSOURCE     LL_SYSTICK_SetClkSource | ||||
|   * @param  Source This parameter can be one of the following values: | ||||
|   *         @arg @ref LL_SYSTICK_CLKSOURCE_HCLK_DIV8 | ||||
|   *         @arg @ref LL_SYSTICK_CLKSOURCE_HCLK | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_SYSTICK_SetClkSource(uint32_t Source) | ||||
| { | ||||
|   if (Source == LL_SYSTICK_CLKSOURCE_HCLK) | ||||
|   { | ||||
|     SET_BIT(SysTick->CTRL, LL_SYSTICK_CLKSOURCE_HCLK); | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     CLEAR_BIT(SysTick->CTRL, LL_SYSTICK_CLKSOURCE_HCLK); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Get the SysTick clock source | ||||
|   * @rmtoll STK_CTRL     CLKSOURCE     LL_SYSTICK_GetClkSource | ||||
|   * @retval Returned value can be one of the following values: | ||||
|   *         @arg @ref LL_SYSTICK_CLKSOURCE_HCLK_DIV8 | ||||
|   *         @arg @ref LL_SYSTICK_CLKSOURCE_HCLK | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_SYSTICK_GetClkSource(void) | ||||
| { | ||||
|   return READ_BIT(SysTick->CTRL, LL_SYSTICK_CLKSOURCE_HCLK); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enable SysTick exception request | ||||
|   * @rmtoll STK_CTRL     TICKINT       LL_SYSTICK_EnableIT | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_SYSTICK_EnableIT(void) | ||||
| { | ||||
|   SET_BIT(SysTick->CTRL, SysTick_CTRL_TICKINT_Msk); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Disable SysTick exception request | ||||
|   * @rmtoll STK_CTRL     TICKINT       LL_SYSTICK_DisableIT | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_SYSTICK_DisableIT(void) | ||||
| { | ||||
|   CLEAR_BIT(SysTick->CTRL, SysTick_CTRL_TICKINT_Msk); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Checks if the SYSTICK interrupt is enabled or disabled. | ||||
|   * @rmtoll STK_CTRL     TICKINT       LL_SYSTICK_IsEnabledIT | ||||
|   * @retval State of bit (1 or 0). | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_SYSTICK_IsEnabledIT(void) | ||||
| { | ||||
|   return (READ_BIT(SysTick->CTRL, SysTick_CTRL_TICKINT_Msk) == (SysTick_CTRL_TICKINT_Msk)); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup CORTEX_LL_EF_LOW_POWER_MODE LOW POWER MODE
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Processor uses sleep as its low power mode | ||||
|   * @rmtoll SCB_SCR      SLEEPDEEP     LL_LPM_EnableSleep | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_LPM_EnableSleep(void) | ||||
| { | ||||
|   /* Clear SLEEPDEEP bit of Cortex System Control Register */ | ||||
|   CLEAR_BIT(SCB->SCR, ((uint32_t)SCB_SCR_SLEEPDEEP_Msk)); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Processor uses deep sleep as its low power mode | ||||
|   * @rmtoll SCB_SCR      SLEEPDEEP     LL_LPM_EnableDeepSleep | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_LPM_EnableDeepSleep(void) | ||||
| { | ||||
|   /* Set SLEEPDEEP bit of Cortex System Control Register */ | ||||
|   SET_BIT(SCB->SCR, ((uint32_t)SCB_SCR_SLEEPDEEP_Msk)); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Configures sleep-on-exit when returning from Handler mode to Thread mode. | ||||
|   * @note   Setting this bit to 1 enables an interrupt-driven application to avoid returning to an | ||||
|   *         empty main application. | ||||
|   * @rmtoll SCB_SCR      SLEEPONEXIT   LL_LPM_EnableSleepOnExit | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_LPM_EnableSleepOnExit(void) | ||||
| { | ||||
|   /* Set SLEEPONEXIT bit of Cortex System Control Register */ | ||||
|   SET_BIT(SCB->SCR, ((uint32_t)SCB_SCR_SLEEPONEXIT_Msk)); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Do not sleep when returning to Thread mode. | ||||
|   * @rmtoll SCB_SCR      SLEEPONEXIT   LL_LPM_DisableSleepOnExit | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_LPM_DisableSleepOnExit(void) | ||||
| { | ||||
|   /* Clear SLEEPONEXIT bit of Cortex System Control Register */ | ||||
|   CLEAR_BIT(SCB->SCR, ((uint32_t)SCB_SCR_SLEEPONEXIT_Msk)); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enabled events and all interrupts, including disabled interrupts, can wakeup the | ||||
|   *         processor. | ||||
|   * @rmtoll SCB_SCR      SEVEONPEND    LL_LPM_EnableEventOnPend | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_LPM_EnableEventOnPend(void) | ||||
| { | ||||
|   /* Set SEVEONPEND bit of Cortex System Control Register */ | ||||
|   SET_BIT(SCB->SCR, ((uint32_t)SCB_SCR_SEVONPEND_Msk)); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Only enabled interrupts or events can wakeup the processor, disabled interrupts are | ||||
|   *         excluded | ||||
|   * @rmtoll SCB_SCR      SEVEONPEND    LL_LPM_DisableEventOnPend | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_LPM_DisableEventOnPend(void) | ||||
| { | ||||
|   /* Clear SEVEONPEND bit of Cortex System Control Register */ | ||||
|   CLEAR_BIT(SCB->SCR, ((uint32_t)SCB_SCR_SEVONPEND_Msk)); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup CORTEX_LL_EF_HANDLER HANDLER
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enable a fault in System handler control register (SHCSR) | ||||
|   * @rmtoll SCB_SHCSR    MEMFAULTENA   LL_HANDLER_EnableFault | ||||
|   * @param  Fault This parameter can be a combination of the following values: | ||||
|   *         @arg @ref LL_HANDLER_FAULT_USG | ||||
|   *         @arg @ref LL_HANDLER_FAULT_BUS | ||||
|   *         @arg @ref LL_HANDLER_FAULT_MEM | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_HANDLER_EnableFault(uint32_t Fault) | ||||
| { | ||||
|   /* Enable the system handler fault */ | ||||
|   SET_BIT(SCB->SHCSR, Fault); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Disable a fault in System handler control register (SHCSR) | ||||
|   * @rmtoll SCB_SHCSR    MEMFAULTENA   LL_HANDLER_DisableFault | ||||
|   * @param  Fault This parameter can be a combination of the following values: | ||||
|   *         @arg @ref LL_HANDLER_FAULT_USG | ||||
|   *         @arg @ref LL_HANDLER_FAULT_BUS | ||||
|   *         @arg @ref LL_HANDLER_FAULT_MEM | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_HANDLER_DisableFault(uint32_t Fault) | ||||
| { | ||||
|   /* Disable the system handler fault */ | ||||
|   CLEAR_BIT(SCB->SHCSR, Fault); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup CORTEX_LL_EF_MCU_INFO MCU INFO
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Get Implementer code | ||||
|   * @rmtoll SCB_CPUID    IMPLEMENTER   LL_CPUID_GetImplementer | ||||
|   * @retval Value should be equal to 0x41 for ARM | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_CPUID_GetImplementer(void) | ||||
| { | ||||
|   return (uint32_t)(READ_BIT(SCB->CPUID, SCB_CPUID_IMPLEMENTER_Msk) >> SCB_CPUID_IMPLEMENTER_Pos); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Get Variant number (The r value in the rnpn product revision identifier) | ||||
|   * @rmtoll SCB_CPUID    VARIANT       LL_CPUID_GetVariant | ||||
|   * @retval Value between 0 and 255 (0x1: revision 1, 0x2: revision 2) | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_CPUID_GetVariant(void) | ||||
| { | ||||
|   return (uint32_t)(READ_BIT(SCB->CPUID, SCB_CPUID_VARIANT_Msk) >> SCB_CPUID_VARIANT_Pos); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Get Constant number | ||||
|   * @rmtoll SCB_CPUID    ARCHITECTURE  LL_CPUID_GetConstant | ||||
|   * @retval Value should be equal to 0xF for Cortex-M3 devices | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_CPUID_GetConstant(void) | ||||
| { | ||||
|   return (uint32_t)(READ_BIT(SCB->CPUID, SCB_CPUID_ARCHITECTURE_Msk) >> SCB_CPUID_ARCHITECTURE_Pos); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Get Part number | ||||
|   * @rmtoll SCB_CPUID    PARTNO        LL_CPUID_GetParNo | ||||
|   * @retval Value should be equal to 0xC23 for Cortex-M3 | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_CPUID_GetParNo(void) | ||||
| { | ||||
|   return (uint32_t)(READ_BIT(SCB->CPUID, SCB_CPUID_PARTNO_Msk) >> SCB_CPUID_PARTNO_Pos); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Get Revision number (The p value in the rnpn product revision identifier, indicates patch release) | ||||
|   * @rmtoll SCB_CPUID    REVISION      LL_CPUID_GetRevision | ||||
|   * @retval Value between 0 and 255 (0x0: patch 0, 0x1: patch 1) | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_CPUID_GetRevision(void) | ||||
| { | ||||
|   return (uint32_t)(READ_BIT(SCB->CPUID, SCB_CPUID_REVISION_Msk) >> SCB_CPUID_REVISION_Pos); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| #if __MPU_PRESENT | ||||
| /** @defgroup CORTEX_LL_EF_MPU MPU
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enable MPU with input options | ||||
|   * @rmtoll MPU_CTRL     ENABLE        LL_MPU_Enable | ||||
|   * @param  Options This parameter can be one of the following values: | ||||
|   *         @arg @ref LL_MPU_CTRL_HFNMI_PRIVDEF_NONE | ||||
|   *         @arg @ref LL_MPU_CTRL_HARDFAULT_NMI | ||||
|   *         @arg @ref LL_MPU_CTRL_PRIVILEGED_DEFAULT | ||||
|   *         @arg @ref LL_MPU_CTRL_HFNMI_PRIVDEF | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_MPU_Enable(uint32_t Options) | ||||
| { | ||||
|   /* Enable the MPU*/ | ||||
|   WRITE_REG(MPU->CTRL, (MPU_CTRL_ENABLE_Msk | Options)); | ||||
|   /* Ensure MPU settings take effects */ | ||||
|   __DSB(); | ||||
|   /* Sequence instruction fetches using update settings */ | ||||
|   __ISB(); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Disable MPU | ||||
|   * @rmtoll MPU_CTRL     ENABLE        LL_MPU_Disable | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_MPU_Disable(void) | ||||
| { | ||||
|   /* Make sure outstanding transfers are done */ | ||||
|   __DMB(); | ||||
|   /* Disable MPU*/ | ||||
|   WRITE_REG(MPU->CTRL, 0U); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Check if MPU is enabled or not | ||||
|   * @rmtoll MPU_CTRL     ENABLE        LL_MPU_IsEnabled | ||||
|   * @retval State of bit (1 or 0). | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_MPU_IsEnabled(void) | ||||
| { | ||||
|   return (READ_BIT(MPU->CTRL, MPU_CTRL_ENABLE_Msk) == (MPU_CTRL_ENABLE_Msk)); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enable a MPU region | ||||
|   * @rmtoll MPU_RASR     ENABLE        LL_MPU_EnableRegion | ||||
|   * @param  Region This parameter can be one of the following values: | ||||
|   *         @arg @ref LL_MPU_REGION_NUMBER0 | ||||
|   *         @arg @ref LL_MPU_REGION_NUMBER1 | ||||
|   *         @arg @ref LL_MPU_REGION_NUMBER2 | ||||
|   *         @arg @ref LL_MPU_REGION_NUMBER3 | ||||
|   *         @arg @ref LL_MPU_REGION_NUMBER4 | ||||
|   *         @arg @ref LL_MPU_REGION_NUMBER5 | ||||
|   *         @arg @ref LL_MPU_REGION_NUMBER6 | ||||
|   *         @arg @ref LL_MPU_REGION_NUMBER7 | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_MPU_EnableRegion(uint32_t Region) | ||||
| { | ||||
|   /* Set Region number */ | ||||
|   WRITE_REG(MPU->RNR, Region); | ||||
|   /* Enable the MPU region */ | ||||
|   SET_BIT(MPU->RASR, MPU_RASR_ENABLE_Msk); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Configure and enable a region | ||||
|   * @rmtoll MPU_RNR      REGION        LL_MPU_ConfigRegion\n | ||||
|   *         MPU_RBAR     REGION        LL_MPU_ConfigRegion\n | ||||
|   *         MPU_RBAR     ADDR          LL_MPU_ConfigRegion\n | ||||
|   *         MPU_RASR     XN            LL_MPU_ConfigRegion\n | ||||
|   *         MPU_RASR     AP            LL_MPU_ConfigRegion\n | ||||
|   *         MPU_RASR     S             LL_MPU_ConfigRegion\n | ||||
|   *         MPU_RASR     C             LL_MPU_ConfigRegion\n | ||||
|   *         MPU_RASR     B             LL_MPU_ConfigRegion\n | ||||
|   *         MPU_RASR     SIZE          LL_MPU_ConfigRegion | ||||
|   * @param  Region This parameter can be one of the following values: | ||||
|   *         @arg @ref LL_MPU_REGION_NUMBER0 | ||||
|   *         @arg @ref LL_MPU_REGION_NUMBER1 | ||||
|   *         @arg @ref LL_MPU_REGION_NUMBER2 | ||||
|   *         @arg @ref LL_MPU_REGION_NUMBER3 | ||||
|   *         @arg @ref LL_MPU_REGION_NUMBER4 | ||||
|   *         @arg @ref LL_MPU_REGION_NUMBER5 | ||||
|   *         @arg @ref LL_MPU_REGION_NUMBER6 | ||||
|   *         @arg @ref LL_MPU_REGION_NUMBER7 | ||||
|   * @param  Address Value of region base address | ||||
|   * @param  SubRegionDisable Sub-region disable value between Min_Data = 0x00 and Max_Data = 0xFF | ||||
|   * @param  Attributes This parameter can be a combination of the following values: | ||||
|   *         @arg @ref LL_MPU_REGION_SIZE_32B or @ref LL_MPU_REGION_SIZE_64B or @ref LL_MPU_REGION_SIZE_128B or @ref LL_MPU_REGION_SIZE_256B or @ref LL_MPU_REGION_SIZE_512B | ||||
|   *           or @ref LL_MPU_REGION_SIZE_1KB or @ref LL_MPU_REGION_SIZE_2KB or @ref LL_MPU_REGION_SIZE_4KB or @ref LL_MPU_REGION_SIZE_8KB or @ref LL_MPU_REGION_SIZE_16KB | ||||
|   *           or @ref LL_MPU_REGION_SIZE_32KB or @ref LL_MPU_REGION_SIZE_64KB or @ref LL_MPU_REGION_SIZE_128KB or @ref LL_MPU_REGION_SIZE_256KB or @ref LL_MPU_REGION_SIZE_512KB | ||||
|   *           or @ref LL_MPU_REGION_SIZE_1MB or @ref LL_MPU_REGION_SIZE_2MB or @ref LL_MPU_REGION_SIZE_4MB or @ref LL_MPU_REGION_SIZE_8MB or @ref LL_MPU_REGION_SIZE_16MB | ||||
|   *           or @ref LL_MPU_REGION_SIZE_32MB or @ref LL_MPU_REGION_SIZE_64MB or @ref LL_MPU_REGION_SIZE_128MB or @ref LL_MPU_REGION_SIZE_256MB or @ref LL_MPU_REGION_SIZE_512MB | ||||
|   *           or @ref LL_MPU_REGION_SIZE_1GB or @ref LL_MPU_REGION_SIZE_2GB or @ref LL_MPU_REGION_SIZE_4GB | ||||
|   *         @arg @ref LL_MPU_REGION_NO_ACCESS or @ref LL_MPU_REGION_PRIV_RW or @ref LL_MPU_REGION_PRIV_RW_URO or @ref LL_MPU_REGION_FULL_ACCESS | ||||
|   *           or @ref LL_MPU_REGION_PRIV_RO or @ref LL_MPU_REGION_PRIV_RO_URO | ||||
|   *         @arg @ref LL_MPU_TEX_LEVEL0 or @ref LL_MPU_TEX_LEVEL1 or @ref LL_MPU_TEX_LEVEL2 or @ref LL_MPU_TEX_LEVEL4 | ||||
|   *         @arg @ref LL_MPU_INSTRUCTION_ACCESS_ENABLE or  @ref LL_MPU_INSTRUCTION_ACCESS_DISABLE | ||||
|   *         @arg @ref LL_MPU_ACCESS_SHAREABLE or @ref LL_MPU_ACCESS_NOT_SHAREABLE | ||||
|   *         @arg @ref LL_MPU_ACCESS_CACHEABLE or @ref LL_MPU_ACCESS_NOT_CACHEABLE | ||||
|   *         @arg @ref LL_MPU_ACCESS_BUFFERABLE or @ref LL_MPU_ACCESS_NOT_BUFFERABLE | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_MPU_ConfigRegion(uint32_t Region, uint32_t SubRegionDisable, uint32_t Address, uint32_t Attributes) | ||||
| { | ||||
|   /* Set Region number */ | ||||
|   WRITE_REG(MPU->RNR, Region); | ||||
|   /* Set base address */ | ||||
|   WRITE_REG(MPU->RBAR, (Address & 0xFFFFFFE0U)); | ||||
|   /* Configure MPU */ | ||||
|   WRITE_REG(MPU->RASR, (MPU_RASR_ENABLE_Msk | Attributes | (SubRegionDisable << MPU_RASR_SRD_Pos))); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Disable a region | ||||
|   * @rmtoll MPU_RNR      REGION        LL_MPU_DisableRegion\n | ||||
|   *         MPU_RASR     ENABLE        LL_MPU_DisableRegion | ||||
|   * @param  Region This parameter can be one of the following values: | ||||
|   *         @arg @ref LL_MPU_REGION_NUMBER0 | ||||
|   *         @arg @ref LL_MPU_REGION_NUMBER1 | ||||
|   *         @arg @ref LL_MPU_REGION_NUMBER2 | ||||
|   *         @arg @ref LL_MPU_REGION_NUMBER3 | ||||
|   *         @arg @ref LL_MPU_REGION_NUMBER4 | ||||
|   *         @arg @ref LL_MPU_REGION_NUMBER5 | ||||
|   *         @arg @ref LL_MPU_REGION_NUMBER6 | ||||
|   *         @arg @ref LL_MPU_REGION_NUMBER7 | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_MPU_DisableRegion(uint32_t Region) | ||||
| { | ||||
|   /* Set Region number */ | ||||
|   WRITE_REG(MPU->RNR, Region); | ||||
|   /* Disable the MPU region */ | ||||
|   CLEAR_BIT(MPU->RASR, MPU_RASR_ENABLE_Msk); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| #endif /* __MPU_PRESENT */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif /* __STM32F1xx_LL_CORTEX_H */ | ||||
| 
 | ||||
							
								
								
									
										1958
									
								
								Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_ll_dma.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1958
									
								
								Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_ll_dma.h
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										886
									
								
								Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_ll_exti.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										886
									
								
								Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_ll_exti.h
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,886 @@ | ||||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32f1xx_ll_exti.h | ||||
|   * @author  MCD Application Team | ||||
|   * @brief   Header file of EXTI LL module. | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * Copyright (c) 2016 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. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef STM32F1xx_LL_EXTI_H | ||||
| #define STM32F1xx_LL_EXTI_H | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32f1xx.h" | ||||
| 
 | ||||
| /** @addtogroup STM32F1xx_LL_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #if defined (EXTI) | ||||
| 
 | ||||
| /** @defgroup EXTI_LL EXTI
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /* Private types -------------------------------------------------------------*/ | ||||
| /* Private variables ---------------------------------------------------------*/ | ||||
| /* Private constants ---------------------------------------------------------*/ | ||||
| /* Private Macros ------------------------------------------------------------*/ | ||||
| #if defined(USE_FULL_LL_DRIVER) | ||||
| /** @defgroup EXTI_LL_Private_Macros EXTI Private Macros
 | ||||
|   * @{ | ||||
|   */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| #endif /*USE_FULL_LL_DRIVER*/ | ||||
| /* Exported types ------------------------------------------------------------*/ | ||||
| #if defined(USE_FULL_LL_DRIVER) | ||||
| /** @defgroup EXTI_LL_ES_INIT EXTI Exported Init structure
 | ||||
|   * @{ | ||||
|   */ | ||||
| typedef struct | ||||
| { | ||||
| 
 | ||||
|   uint32_t Line_0_31;           /*!< Specifies the EXTI lines to be enabled or disabled for Lines in range 0 to 31
 | ||||
|                                      This parameter can be any combination of @ref EXTI_LL_EC_LINE */ | ||||
| 
 | ||||
|   FunctionalState LineCommand;  /*!< Specifies the new state of the selected EXTI lines.
 | ||||
|                                      This parameter can be set either to ENABLE or DISABLE */ | ||||
| 
 | ||||
|   uint8_t Mode;                 /*!< Specifies the mode for the EXTI lines.
 | ||||
|                                      This parameter can be a value of @ref EXTI_LL_EC_MODE. */ | ||||
| 
 | ||||
|   uint8_t Trigger;              /*!< Specifies the trigger signal active edge for the EXTI lines.
 | ||||
|                                      This parameter can be a value of @ref EXTI_LL_EC_TRIGGER. */ | ||||
| } LL_EXTI_InitTypeDef; | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| #endif /*USE_FULL_LL_DRIVER*/ | ||||
| 
 | ||||
| /* Exported constants --------------------------------------------------------*/ | ||||
| /** @defgroup EXTI_LL_Exported_Constants EXTI Exported Constants
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup EXTI_LL_EC_LINE LINE
 | ||||
|   * @{ | ||||
|   */ | ||||
| #define LL_EXTI_LINE_0                 EXTI_IMR_IM0           /*!< Extended line 0 */ | ||||
| #define LL_EXTI_LINE_1                 EXTI_IMR_IM1           /*!< Extended line 1 */ | ||||
| #define LL_EXTI_LINE_2                 EXTI_IMR_IM2           /*!< Extended line 2 */ | ||||
| #define LL_EXTI_LINE_3                 EXTI_IMR_IM3           /*!< Extended line 3 */ | ||||
| #define LL_EXTI_LINE_4                 EXTI_IMR_IM4           /*!< Extended line 4 */ | ||||
| #define LL_EXTI_LINE_5                 EXTI_IMR_IM5           /*!< Extended line 5 */ | ||||
| #define LL_EXTI_LINE_6                 EXTI_IMR_IM6           /*!< Extended line 6 */ | ||||
| #define LL_EXTI_LINE_7                 EXTI_IMR_IM7           /*!< Extended line 7 */ | ||||
| #define LL_EXTI_LINE_8                 EXTI_IMR_IM8           /*!< Extended line 8 */ | ||||
| #define LL_EXTI_LINE_9                 EXTI_IMR_IM9           /*!< Extended line 9 */ | ||||
| #define LL_EXTI_LINE_10                EXTI_IMR_IM10          /*!< Extended line 10 */ | ||||
| #define LL_EXTI_LINE_11                EXTI_IMR_IM11          /*!< Extended line 11 */ | ||||
| #define LL_EXTI_LINE_12                EXTI_IMR_IM12          /*!< Extended line 12 */ | ||||
| #define LL_EXTI_LINE_13                EXTI_IMR_IM13          /*!< Extended line 13 */ | ||||
| #define LL_EXTI_LINE_14                EXTI_IMR_IM14          /*!< Extended line 14 */ | ||||
| #define LL_EXTI_LINE_15                EXTI_IMR_IM15          /*!< Extended line 15 */ | ||||
| #if defined(EXTI_IMR_IM16) | ||||
| #define LL_EXTI_LINE_16                EXTI_IMR_IM16          /*!< Extended line 16 */ | ||||
| #endif | ||||
| #define LL_EXTI_LINE_17                EXTI_IMR_IM17          /*!< Extended line 17 */ | ||||
| #if defined(EXTI_IMR_IM18) | ||||
| #define LL_EXTI_LINE_18                EXTI_IMR_IM18          /*!< Extended line 18 */ | ||||
| #endif | ||||
| #if defined(EXTI_IMR_IM19) | ||||
| #define LL_EXTI_LINE_19                EXTI_IMR_IM19          /*!< Extended line 19 */ | ||||
| #endif | ||||
| #if defined(EXTI_IMR_IM20) | ||||
| #define LL_EXTI_LINE_20                EXTI_IMR_IM20          /*!< Extended line 20 */ | ||||
| #endif | ||||
| #if defined(EXTI_IMR_IM21) | ||||
| #define LL_EXTI_LINE_21                EXTI_IMR_IM21          /*!< Extended line 21 */ | ||||
| #endif | ||||
| #if defined(EXTI_IMR_IM22) | ||||
| #define LL_EXTI_LINE_22                EXTI_IMR_IM22          /*!< Extended line 22 */ | ||||
| #endif | ||||
| #if defined(EXTI_IMR_IM23) | ||||
| #define LL_EXTI_LINE_23                EXTI_IMR_IM23          /*!< Extended line 23 */ | ||||
| #endif | ||||
| #if defined(EXTI_IMR_IM24) | ||||
| #define LL_EXTI_LINE_24                EXTI_IMR_IM24          /*!< Extended line 24 */ | ||||
| #endif | ||||
| #if defined(EXTI_IMR_IM25) | ||||
| #define LL_EXTI_LINE_25                EXTI_IMR_IM25          /*!< Extended line 25 */ | ||||
| #endif | ||||
| #if defined(EXTI_IMR_IM26) | ||||
| #define LL_EXTI_LINE_26                EXTI_IMR_IM26          /*!< Extended line 26 */ | ||||
| #endif | ||||
| #if defined(EXTI_IMR_IM27) | ||||
| #define LL_EXTI_LINE_27                EXTI_IMR_IM27          /*!< Extended line 27 */ | ||||
| #endif | ||||
| #if defined(EXTI_IMR_IM28) | ||||
| #define LL_EXTI_LINE_28                EXTI_IMR_IM28          /*!< Extended line 28 */ | ||||
| #endif | ||||
| #if defined(EXTI_IMR_IM29) | ||||
| #define LL_EXTI_LINE_29                EXTI_IMR_IM29          /*!< Extended line 29 */ | ||||
| #endif | ||||
| #if defined(EXTI_IMR_IM30) | ||||
| #define LL_EXTI_LINE_30                EXTI_IMR_IM30          /*!< Extended line 30 */ | ||||
| #endif | ||||
| #if defined(EXTI_IMR_IM31) | ||||
| #define LL_EXTI_LINE_31                EXTI_IMR_IM31          /*!< Extended line 31 */ | ||||
| #endif | ||||
| #define LL_EXTI_LINE_ALL_0_31          EXTI_IMR_IM            /*!< All Extended line not reserved*/ | ||||
| 
 | ||||
| 
 | ||||
| #define LL_EXTI_LINE_ALL               (0xFFFFFFFFU)  /*!< All Extended line */ | ||||
| 
 | ||||
| #if defined(USE_FULL_LL_DRIVER) | ||||
| #define LL_EXTI_LINE_NONE              (0x00000000U)  /*!< None Extended line */ | ||||
| #endif /*USE_FULL_LL_DRIVER*/ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| #if defined(USE_FULL_LL_DRIVER) | ||||
| 
 | ||||
| /** @defgroup EXTI_LL_EC_MODE Mode
 | ||||
|   * @{ | ||||
|   */ | ||||
| #define LL_EXTI_MODE_IT                 ((uint8_t)0x00) /*!< Interrupt Mode */ | ||||
| #define LL_EXTI_MODE_EVENT              ((uint8_t)0x01) /*!< Event Mode */ | ||||
| #define LL_EXTI_MODE_IT_EVENT           ((uint8_t)0x02) /*!< Interrupt & Event Mode */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup EXTI_LL_EC_TRIGGER Edge Trigger
 | ||||
|   * @{ | ||||
|   */ | ||||
| #define LL_EXTI_TRIGGER_NONE            ((uint8_t)0x00) /*!< No Trigger Mode */ | ||||
| #define LL_EXTI_TRIGGER_RISING          ((uint8_t)0x01) /*!< Trigger Rising Mode */ | ||||
| #define LL_EXTI_TRIGGER_FALLING         ((uint8_t)0x02) /*!< Trigger Falling Mode */ | ||||
| #define LL_EXTI_TRIGGER_RISING_FALLING  ((uint8_t)0x03) /*!< Trigger Rising & Falling Mode */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| 
 | ||||
| #endif /*USE_FULL_LL_DRIVER*/ | ||||
| 
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /* Exported macro ------------------------------------------------------------*/ | ||||
| /** @defgroup EXTI_LL_Exported_Macros EXTI Exported Macros
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup EXTI_LL_EM_WRITE_READ Common Write and read registers Macros
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Write a value in EXTI register | ||||
|   * @param  __REG__ Register to be written | ||||
|   * @param  __VALUE__ Value to be written in the register | ||||
|   * @retval None | ||||
|   */ | ||||
| #define LL_EXTI_WriteReg(__REG__, __VALUE__) WRITE_REG(EXTI->__REG__, (__VALUE__)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Read a value in EXTI register | ||||
|   * @param  __REG__ Register to be read | ||||
|   * @retval Register value | ||||
|   */ | ||||
| #define LL_EXTI_ReadReg(__REG__) READ_REG(EXTI->__REG__) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| /* Exported functions --------------------------------------------------------*/ | ||||
| /** @defgroup EXTI_LL_Exported_Functions EXTI Exported Functions
 | ||||
|  * @{ | ||||
|  */ | ||||
| /** @defgroup EXTI_LL_EF_IT_Management IT_Management
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enable ExtiLine Interrupt request for Lines in range 0 to 31 | ||||
|   * @note The reset value for the direct or internal lines (see RM) | ||||
|   *       is set to 1 in order to enable the interrupt by default. | ||||
|   *       Bits are set automatically at Power on. | ||||
|   * @rmtoll IMR         IMx           LL_EXTI_EnableIT_0_31 | ||||
|   * @param  ExtiLine This parameter can be one of the following values: | ||||
|   *         @arg @ref LL_EXTI_LINE_0 | ||||
|   *         @arg @ref LL_EXTI_LINE_1 | ||||
|   *         @arg @ref LL_EXTI_LINE_2 | ||||
|   *         @arg @ref LL_EXTI_LINE_3 | ||||
|   *         @arg @ref LL_EXTI_LINE_4 | ||||
|   *         @arg @ref LL_EXTI_LINE_5 | ||||
|   *         @arg @ref LL_EXTI_LINE_6 | ||||
|   *         @arg @ref LL_EXTI_LINE_7 | ||||
|   *         @arg @ref LL_EXTI_LINE_8 | ||||
|   *         @arg @ref LL_EXTI_LINE_9 | ||||
|   *         @arg @ref LL_EXTI_LINE_10 | ||||
|   *         @arg @ref LL_EXTI_LINE_11 | ||||
|   *         @arg @ref LL_EXTI_LINE_12 | ||||
|   *         @arg @ref LL_EXTI_LINE_13 | ||||
|   *         @arg @ref LL_EXTI_LINE_14 | ||||
|   *         @arg @ref LL_EXTI_LINE_15 | ||||
|   *         @arg @ref LL_EXTI_LINE_16 | ||||
|   *         @arg @ref LL_EXTI_LINE_17 | ||||
|   *         @arg @ref LL_EXTI_LINE_18 | ||||
|   *         @arg @ref LL_EXTI_LINE_19 | ||||
|   *         @arg @ref LL_EXTI_LINE_ALL_0_31 | ||||
|   * @note   Please check each device line mapping for EXTI Line availability | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_EXTI_EnableIT_0_31(uint32_t ExtiLine) | ||||
| { | ||||
|   SET_BIT(EXTI->IMR, ExtiLine); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Disable ExtiLine Interrupt request for Lines in range 0 to 31 | ||||
|   * @note The reset value for the direct or internal lines (see RM) | ||||
|   *       is set to 1 in order to enable the interrupt by default. | ||||
|   *       Bits are set automatically at Power on. | ||||
|   * @rmtoll IMR         IMx           LL_EXTI_DisableIT_0_31 | ||||
|   * @param  ExtiLine This parameter can be one of the following values: | ||||
|   *         @arg @ref LL_EXTI_LINE_0 | ||||
|   *         @arg @ref LL_EXTI_LINE_1 | ||||
|   *         @arg @ref LL_EXTI_LINE_2 | ||||
|   *         @arg @ref LL_EXTI_LINE_3 | ||||
|   *         @arg @ref LL_EXTI_LINE_4 | ||||
|   *         @arg @ref LL_EXTI_LINE_5 | ||||
|   *         @arg @ref LL_EXTI_LINE_6 | ||||
|   *         @arg @ref LL_EXTI_LINE_7 | ||||
|   *         @arg @ref LL_EXTI_LINE_8 | ||||
|   *         @arg @ref LL_EXTI_LINE_9 | ||||
|   *         @arg @ref LL_EXTI_LINE_10 | ||||
|   *         @arg @ref LL_EXTI_LINE_11 | ||||
|   *         @arg @ref LL_EXTI_LINE_12 | ||||
|   *         @arg @ref LL_EXTI_LINE_13 | ||||
|   *         @arg @ref LL_EXTI_LINE_14 | ||||
|   *         @arg @ref LL_EXTI_LINE_15 | ||||
|   *         @arg @ref LL_EXTI_LINE_16 | ||||
|   *         @arg @ref LL_EXTI_LINE_17 | ||||
|   *         @arg @ref LL_EXTI_LINE_18 | ||||
|   *         @arg @ref LL_EXTI_LINE_19 | ||||
|   *         @arg @ref LL_EXTI_LINE_ALL_0_31 | ||||
|   * @note   Please check each device line mapping for EXTI Line availability | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_EXTI_DisableIT_0_31(uint32_t ExtiLine) | ||||
| { | ||||
|   CLEAR_BIT(EXTI->IMR, ExtiLine); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Indicate if ExtiLine Interrupt request is enabled for Lines in range 0 to 31 | ||||
|   * @note The reset value for the direct or internal lines (see RM) | ||||
|   *       is set to 1 in order to enable the interrupt by default. | ||||
|   *       Bits are set automatically at Power on. | ||||
|   * @rmtoll IMR         IMx           LL_EXTI_IsEnabledIT_0_31 | ||||
|   * @param  ExtiLine This parameter can be one of the following values: | ||||
|   *         @arg @ref LL_EXTI_LINE_0 | ||||
|   *         @arg @ref LL_EXTI_LINE_1 | ||||
|   *         @arg @ref LL_EXTI_LINE_2 | ||||
|   *         @arg @ref LL_EXTI_LINE_3 | ||||
|   *         @arg @ref LL_EXTI_LINE_4 | ||||
|   *         @arg @ref LL_EXTI_LINE_5 | ||||
|   *         @arg @ref LL_EXTI_LINE_6 | ||||
|   *         @arg @ref LL_EXTI_LINE_7 | ||||
|   *         @arg @ref LL_EXTI_LINE_8 | ||||
|   *         @arg @ref LL_EXTI_LINE_9 | ||||
|   *         @arg @ref LL_EXTI_LINE_10 | ||||
|   *         @arg @ref LL_EXTI_LINE_11 | ||||
|   *         @arg @ref LL_EXTI_LINE_12 | ||||
|   *         @arg @ref LL_EXTI_LINE_13 | ||||
|   *         @arg @ref LL_EXTI_LINE_14 | ||||
|   *         @arg @ref LL_EXTI_LINE_15 | ||||
|   *         @arg @ref LL_EXTI_LINE_16 | ||||
|   *         @arg @ref LL_EXTI_LINE_17 | ||||
|   *         @arg @ref LL_EXTI_LINE_18 | ||||
|   *         @arg @ref LL_EXTI_LINE_19 | ||||
|   *         @arg @ref LL_EXTI_LINE_ALL_0_31 | ||||
|   * @note   Please check each device line mapping for EXTI Line availability | ||||
|   * @retval State of bit (1 or 0). | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_EXTI_IsEnabledIT_0_31(uint32_t ExtiLine) | ||||
| { | ||||
|   return (READ_BIT(EXTI->IMR, ExtiLine) == (ExtiLine)); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup EXTI_LL_EF_Event_Management Event_Management
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enable ExtiLine Event request for Lines in range 0 to 31 | ||||
|   * @rmtoll EMR         EMx           LL_EXTI_EnableEvent_0_31 | ||||
|   * @param  ExtiLine This parameter can be one of the following values: | ||||
|   *         @arg @ref LL_EXTI_LINE_0 | ||||
|   *         @arg @ref LL_EXTI_LINE_1 | ||||
|   *         @arg @ref LL_EXTI_LINE_2 | ||||
|   *         @arg @ref LL_EXTI_LINE_3 | ||||
|   *         @arg @ref LL_EXTI_LINE_4 | ||||
|   *         @arg @ref LL_EXTI_LINE_5 | ||||
|   *         @arg @ref LL_EXTI_LINE_6 | ||||
|   *         @arg @ref LL_EXTI_LINE_7 | ||||
|   *         @arg @ref LL_EXTI_LINE_8 | ||||
|   *         @arg @ref LL_EXTI_LINE_9 | ||||
|   *         @arg @ref LL_EXTI_LINE_10 | ||||
|   *         @arg @ref LL_EXTI_LINE_11 | ||||
|   *         @arg @ref LL_EXTI_LINE_12 | ||||
|   *         @arg @ref LL_EXTI_LINE_13 | ||||
|   *         @arg @ref LL_EXTI_LINE_14 | ||||
|   *         @arg @ref LL_EXTI_LINE_15 | ||||
|   *         @arg @ref LL_EXTI_LINE_16 | ||||
|   *         @arg @ref LL_EXTI_LINE_17 | ||||
|   *         @arg @ref LL_EXTI_LINE_18 | ||||
|   *         @arg @ref LL_EXTI_LINE_19 | ||||
|   *         @arg @ref LL_EXTI_LINE_ALL_0_31 | ||||
|   * @note   Please check each device line mapping for EXTI Line availability | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_EXTI_EnableEvent_0_31(uint32_t ExtiLine) | ||||
| { | ||||
|   SET_BIT(EXTI->EMR, ExtiLine); | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Disable ExtiLine Event request for Lines in range 0 to 31 | ||||
|   * @rmtoll EMR         EMx           LL_EXTI_DisableEvent_0_31 | ||||
|   * @param  ExtiLine This parameter can be one of the following values: | ||||
|   *         @arg @ref LL_EXTI_LINE_0 | ||||
|   *         @arg @ref LL_EXTI_LINE_1 | ||||
|   *         @arg @ref LL_EXTI_LINE_2 | ||||
|   *         @arg @ref LL_EXTI_LINE_3 | ||||
|   *         @arg @ref LL_EXTI_LINE_4 | ||||
|   *         @arg @ref LL_EXTI_LINE_5 | ||||
|   *         @arg @ref LL_EXTI_LINE_6 | ||||
|   *         @arg @ref LL_EXTI_LINE_7 | ||||
|   *         @arg @ref LL_EXTI_LINE_8 | ||||
|   *         @arg @ref LL_EXTI_LINE_9 | ||||
|   *         @arg @ref LL_EXTI_LINE_10 | ||||
|   *         @arg @ref LL_EXTI_LINE_11 | ||||
|   *         @arg @ref LL_EXTI_LINE_12 | ||||
|   *         @arg @ref LL_EXTI_LINE_13 | ||||
|   *         @arg @ref LL_EXTI_LINE_14 | ||||
|   *         @arg @ref LL_EXTI_LINE_15 | ||||
|   *         @arg @ref LL_EXTI_LINE_16 | ||||
|   *         @arg @ref LL_EXTI_LINE_17 | ||||
|   *         @arg @ref LL_EXTI_LINE_18 | ||||
|   *         @arg @ref LL_EXTI_LINE_19 | ||||
|   *         @arg @ref LL_EXTI_LINE_ALL_0_31 | ||||
|   * @note   Please check each device line mapping for EXTI Line availability | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_EXTI_DisableEvent_0_31(uint32_t ExtiLine) | ||||
| { | ||||
|   CLEAR_BIT(EXTI->EMR, ExtiLine); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Indicate if ExtiLine Event request is enabled for Lines in range 0 to 31 | ||||
|   * @rmtoll EMR         EMx           LL_EXTI_IsEnabledEvent_0_31 | ||||
|   * @param  ExtiLine This parameter can be one of the following values: | ||||
|   *         @arg @ref LL_EXTI_LINE_0 | ||||
|   *         @arg @ref LL_EXTI_LINE_1 | ||||
|   *         @arg @ref LL_EXTI_LINE_2 | ||||
|   *         @arg @ref LL_EXTI_LINE_3 | ||||
|   *         @arg @ref LL_EXTI_LINE_4 | ||||
|   *         @arg @ref LL_EXTI_LINE_5 | ||||
|   *         @arg @ref LL_EXTI_LINE_6 | ||||
|   *         @arg @ref LL_EXTI_LINE_7 | ||||
|   *         @arg @ref LL_EXTI_LINE_8 | ||||
|   *         @arg @ref LL_EXTI_LINE_9 | ||||
|   *         @arg @ref LL_EXTI_LINE_10 | ||||
|   *         @arg @ref LL_EXTI_LINE_11 | ||||
|   *         @arg @ref LL_EXTI_LINE_12 | ||||
|   *         @arg @ref LL_EXTI_LINE_13 | ||||
|   *         @arg @ref LL_EXTI_LINE_14 | ||||
|   *         @arg @ref LL_EXTI_LINE_15 | ||||
|   *         @arg @ref LL_EXTI_LINE_16 | ||||
|   *         @arg @ref LL_EXTI_LINE_17 | ||||
|   *         @arg @ref LL_EXTI_LINE_18 | ||||
|   *         @arg @ref LL_EXTI_LINE_19 | ||||
|   *         @arg @ref LL_EXTI_LINE_ALL_0_31 | ||||
|   * @note   Please check each device line mapping for EXTI Line availability | ||||
|   * @retval State of bit (1 or 0). | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_EXTI_IsEnabledEvent_0_31(uint32_t ExtiLine) | ||||
| { | ||||
|   return (READ_BIT(EXTI->EMR, ExtiLine) == (ExtiLine)); | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup EXTI_LL_EF_Rising_Trigger_Management Rising_Trigger_Management
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enable ExtiLine Rising Edge Trigger for Lines in range 0 to 31 | ||||
|   * @note The configurable wakeup lines are edge-triggered. No glitch must be | ||||
|   *       generated on these lines. If a rising edge on a configurable interrupt | ||||
|   *       line occurs during a write operation in the EXTI_RTSR register, the | ||||
|   *       pending bit is not set. | ||||
|   *       Rising and falling edge triggers can be set for | ||||
|   *       the same interrupt line. In this case, both generate a trigger | ||||
|   *       condition. | ||||
|   * @rmtoll RTSR        RTx           LL_EXTI_EnableRisingTrig_0_31 | ||||
|   * @param  ExtiLine This parameter can be a combination of the following values: | ||||
|   *         @arg @ref LL_EXTI_LINE_0 | ||||
|   *         @arg @ref LL_EXTI_LINE_1 | ||||
|   *         @arg @ref LL_EXTI_LINE_2 | ||||
|   *         @arg @ref LL_EXTI_LINE_3 | ||||
|   *         @arg @ref LL_EXTI_LINE_4 | ||||
|   *         @arg @ref LL_EXTI_LINE_5 | ||||
|   *         @arg @ref LL_EXTI_LINE_6 | ||||
|   *         @arg @ref LL_EXTI_LINE_7 | ||||
|   *         @arg @ref LL_EXTI_LINE_8 | ||||
|   *         @arg @ref LL_EXTI_LINE_9 | ||||
|   *         @arg @ref LL_EXTI_LINE_10 | ||||
|   *         @arg @ref LL_EXTI_LINE_11 | ||||
|   *         @arg @ref LL_EXTI_LINE_12 | ||||
|   *         @arg @ref LL_EXTI_LINE_13 | ||||
|   *         @arg @ref LL_EXTI_LINE_14 | ||||
|   *         @arg @ref LL_EXTI_LINE_15 | ||||
|   *         @arg @ref LL_EXTI_LINE_16 | ||||
|   *         @arg @ref LL_EXTI_LINE_18 | ||||
|   *         @arg @ref LL_EXTI_LINE_19 | ||||
|   * @note   Please check each device line mapping for EXTI Line availability | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_EXTI_EnableRisingTrig_0_31(uint32_t ExtiLine) | ||||
| { | ||||
|   SET_BIT(EXTI->RTSR, ExtiLine); | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Disable ExtiLine Rising Edge Trigger for Lines in range 0 to 31 | ||||
|   * @note The configurable wakeup lines are edge-triggered. No glitch must be | ||||
|   *       generated on these lines. If a rising edge on a configurable interrupt | ||||
|   *       line occurs during a write operation in the EXTI_RTSR register, the | ||||
|   *       pending bit is not set. | ||||
|   *       Rising and falling edge triggers can be set for | ||||
|   *       the same interrupt line. In this case, both generate a trigger | ||||
|   *       condition. | ||||
|   * @rmtoll RTSR        RTx           LL_EXTI_DisableRisingTrig_0_31 | ||||
|   * @param  ExtiLine This parameter can be a combination of the following values: | ||||
|   *         @arg @ref LL_EXTI_LINE_0 | ||||
|   *         @arg @ref LL_EXTI_LINE_1 | ||||
|   *         @arg @ref LL_EXTI_LINE_2 | ||||
|   *         @arg @ref LL_EXTI_LINE_3 | ||||
|   *         @arg @ref LL_EXTI_LINE_4 | ||||
|   *         @arg @ref LL_EXTI_LINE_5 | ||||
|   *         @arg @ref LL_EXTI_LINE_6 | ||||
|   *         @arg @ref LL_EXTI_LINE_7 | ||||
|   *         @arg @ref LL_EXTI_LINE_8 | ||||
|   *         @arg @ref LL_EXTI_LINE_9 | ||||
|   *         @arg @ref LL_EXTI_LINE_10 | ||||
|   *         @arg @ref LL_EXTI_LINE_11 | ||||
|   *         @arg @ref LL_EXTI_LINE_12 | ||||
|   *         @arg @ref LL_EXTI_LINE_13 | ||||
|   *         @arg @ref LL_EXTI_LINE_14 | ||||
|   *         @arg @ref LL_EXTI_LINE_15 | ||||
|   *         @arg @ref LL_EXTI_LINE_16 | ||||
|   *         @arg @ref LL_EXTI_LINE_18 | ||||
|   *         @arg @ref LL_EXTI_LINE_19 | ||||
|   * @note   Please check each device line mapping for EXTI Line availability | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_EXTI_DisableRisingTrig_0_31(uint32_t ExtiLine) | ||||
| { | ||||
|   CLEAR_BIT(EXTI->RTSR, ExtiLine); | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Check if rising edge trigger is enabled for Lines in range 0 to 31 | ||||
|   * @rmtoll RTSR        RTx           LL_EXTI_IsEnabledRisingTrig_0_31 | ||||
|   * @param  ExtiLine This parameter can be a combination of the following values: | ||||
|   *         @arg @ref LL_EXTI_LINE_0 | ||||
|   *         @arg @ref LL_EXTI_LINE_1 | ||||
|   *         @arg @ref LL_EXTI_LINE_2 | ||||
|   *         @arg @ref LL_EXTI_LINE_3 | ||||
|   *         @arg @ref LL_EXTI_LINE_4 | ||||
|   *         @arg @ref LL_EXTI_LINE_5 | ||||
|   *         @arg @ref LL_EXTI_LINE_6 | ||||
|   *         @arg @ref LL_EXTI_LINE_7 | ||||
|   *         @arg @ref LL_EXTI_LINE_8 | ||||
|   *         @arg @ref LL_EXTI_LINE_9 | ||||
|   *         @arg @ref LL_EXTI_LINE_10 | ||||
|   *         @arg @ref LL_EXTI_LINE_11 | ||||
|   *         @arg @ref LL_EXTI_LINE_12 | ||||
|   *         @arg @ref LL_EXTI_LINE_13 | ||||
|   *         @arg @ref LL_EXTI_LINE_14 | ||||
|   *         @arg @ref LL_EXTI_LINE_15 | ||||
|   *         @arg @ref LL_EXTI_LINE_16 | ||||
|   *         @arg @ref LL_EXTI_LINE_18 | ||||
|   *         @arg @ref LL_EXTI_LINE_19 | ||||
|   * @note   Please check each device line mapping for EXTI Line availability | ||||
|   * @retval State of bit (1 or 0). | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_EXTI_IsEnabledRisingTrig_0_31(uint32_t ExtiLine) | ||||
| { | ||||
|   return (READ_BIT(EXTI->RTSR, ExtiLine) == (ExtiLine)); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup EXTI_LL_EF_Falling_Trigger_Management Falling_Trigger_Management
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enable ExtiLine Falling Edge Trigger for Lines in range 0 to 31 | ||||
|   * @note The configurable wakeup lines are edge-triggered. No glitch must be | ||||
|   *       generated on these lines. If a falling edge on a configurable interrupt | ||||
|   *       line occurs during a write operation in the EXTI_FTSR register, the | ||||
|   *       pending bit is not set. | ||||
|   *       Rising and falling edge triggers can be set for | ||||
|   *       the same interrupt line. In this case, both generate a trigger | ||||
|   *       condition. | ||||
|   * @rmtoll FTSR        FTx           LL_EXTI_EnableFallingTrig_0_31 | ||||
|   * @param  ExtiLine This parameter can be a combination of the following values: | ||||
|   *         @arg @ref LL_EXTI_LINE_0 | ||||
|   *         @arg @ref LL_EXTI_LINE_1 | ||||
|   *         @arg @ref LL_EXTI_LINE_2 | ||||
|   *         @arg @ref LL_EXTI_LINE_3 | ||||
|   *         @arg @ref LL_EXTI_LINE_4 | ||||
|   *         @arg @ref LL_EXTI_LINE_5 | ||||
|   *         @arg @ref LL_EXTI_LINE_6 | ||||
|   *         @arg @ref LL_EXTI_LINE_7 | ||||
|   *         @arg @ref LL_EXTI_LINE_8 | ||||
|   *         @arg @ref LL_EXTI_LINE_9 | ||||
|   *         @arg @ref LL_EXTI_LINE_10 | ||||
|   *         @arg @ref LL_EXTI_LINE_11 | ||||
|   *         @arg @ref LL_EXTI_LINE_12 | ||||
|   *         @arg @ref LL_EXTI_LINE_13 | ||||
|   *         @arg @ref LL_EXTI_LINE_14 | ||||
|   *         @arg @ref LL_EXTI_LINE_15 | ||||
|   *         @arg @ref LL_EXTI_LINE_16 | ||||
|   *         @arg @ref LL_EXTI_LINE_18 | ||||
|   *         @arg @ref LL_EXTI_LINE_19 | ||||
|   * @note   Please check each device line mapping for EXTI Line availability | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_EXTI_EnableFallingTrig_0_31(uint32_t ExtiLine) | ||||
| { | ||||
|   SET_BIT(EXTI->FTSR, ExtiLine); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Disable ExtiLine Falling Edge Trigger for Lines in range 0 to 31 | ||||
|   * @note The configurable wakeup lines are edge-triggered. No glitch must be | ||||
|   *       generated on these lines. If a Falling edge on a configurable interrupt | ||||
|   *       line occurs during a write operation in the EXTI_FTSR register, the | ||||
|   *       pending bit is not set. | ||||
|   *       Rising and falling edge triggers can be set for the same interrupt line. | ||||
|   *       In this case, both generate a trigger condition. | ||||
|   * @rmtoll FTSR        FTx           LL_EXTI_DisableFallingTrig_0_31 | ||||
|   * @param  ExtiLine This parameter can be a combination of the following values: | ||||
|   *         @arg @ref LL_EXTI_LINE_0 | ||||
|   *         @arg @ref LL_EXTI_LINE_1 | ||||
|   *         @arg @ref LL_EXTI_LINE_2 | ||||
|   *         @arg @ref LL_EXTI_LINE_3 | ||||
|   *         @arg @ref LL_EXTI_LINE_4 | ||||
|   *         @arg @ref LL_EXTI_LINE_5 | ||||
|   *         @arg @ref LL_EXTI_LINE_6 | ||||
|   *         @arg @ref LL_EXTI_LINE_7 | ||||
|   *         @arg @ref LL_EXTI_LINE_8 | ||||
|   *         @arg @ref LL_EXTI_LINE_9 | ||||
|   *         @arg @ref LL_EXTI_LINE_10 | ||||
|   *         @arg @ref LL_EXTI_LINE_11 | ||||
|   *         @arg @ref LL_EXTI_LINE_12 | ||||
|   *         @arg @ref LL_EXTI_LINE_13 | ||||
|   *         @arg @ref LL_EXTI_LINE_14 | ||||
|   *         @arg @ref LL_EXTI_LINE_15 | ||||
|   *         @arg @ref LL_EXTI_LINE_16 | ||||
|   *         @arg @ref LL_EXTI_LINE_18 | ||||
|   *         @arg @ref LL_EXTI_LINE_19 | ||||
|   * @note   Please check each device line mapping for EXTI Line availability | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_EXTI_DisableFallingTrig_0_31(uint32_t ExtiLine) | ||||
| { | ||||
|   CLEAR_BIT(EXTI->FTSR, ExtiLine); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Check if falling edge trigger is enabled for Lines in range 0 to 31 | ||||
|   * @rmtoll FTSR        FTx           LL_EXTI_IsEnabledFallingTrig_0_31 | ||||
|   * @param  ExtiLine This parameter can be a combination of the following values: | ||||
|   *         @arg @ref LL_EXTI_LINE_0 | ||||
|   *         @arg @ref LL_EXTI_LINE_1 | ||||
|   *         @arg @ref LL_EXTI_LINE_2 | ||||
|   *         @arg @ref LL_EXTI_LINE_3 | ||||
|   *         @arg @ref LL_EXTI_LINE_4 | ||||
|   *         @arg @ref LL_EXTI_LINE_5 | ||||
|   *         @arg @ref LL_EXTI_LINE_6 | ||||
|   *         @arg @ref LL_EXTI_LINE_7 | ||||
|   *         @arg @ref LL_EXTI_LINE_8 | ||||
|   *         @arg @ref LL_EXTI_LINE_9 | ||||
|   *         @arg @ref LL_EXTI_LINE_10 | ||||
|   *         @arg @ref LL_EXTI_LINE_11 | ||||
|   *         @arg @ref LL_EXTI_LINE_12 | ||||
|   *         @arg @ref LL_EXTI_LINE_13 | ||||
|   *         @arg @ref LL_EXTI_LINE_14 | ||||
|   *         @arg @ref LL_EXTI_LINE_15 | ||||
|   *         @arg @ref LL_EXTI_LINE_16 | ||||
|   *         @arg @ref LL_EXTI_LINE_18 | ||||
|   *         @arg @ref LL_EXTI_LINE_19 | ||||
|   * @note   Please check each device line mapping for EXTI Line availability | ||||
|   * @retval State of bit (1 or 0). | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_EXTI_IsEnabledFallingTrig_0_31(uint32_t ExtiLine) | ||||
| { | ||||
|   return (READ_BIT(EXTI->FTSR, ExtiLine) == (ExtiLine)); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup EXTI_LL_EF_Software_Interrupt_Management Software_Interrupt_Management
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Generate a software Interrupt Event for Lines in range 0 to 31 | ||||
|   * @note If the interrupt is enabled on this line in the EXTI_IMR, writing a 1 to | ||||
|   *       this bit when it is at '0' sets the corresponding pending bit in EXTI_PR | ||||
|   *       resulting in an interrupt request generation. | ||||
|   *       This bit is cleared by clearing the corresponding bit in the EXTI_PR | ||||
|   *       register (by writing a 1 into the bit) | ||||
|   * @rmtoll SWIER       SWIx          LL_EXTI_GenerateSWI_0_31 | ||||
|   * @param  ExtiLine This parameter can be a combination of the following values: | ||||
|   *         @arg @ref LL_EXTI_LINE_0 | ||||
|   *         @arg @ref LL_EXTI_LINE_1 | ||||
|   *         @arg @ref LL_EXTI_LINE_2 | ||||
|   *         @arg @ref LL_EXTI_LINE_3 | ||||
|   *         @arg @ref LL_EXTI_LINE_4 | ||||
|   *         @arg @ref LL_EXTI_LINE_5 | ||||
|   *         @arg @ref LL_EXTI_LINE_6 | ||||
|   *         @arg @ref LL_EXTI_LINE_7 | ||||
|   *         @arg @ref LL_EXTI_LINE_8 | ||||
|   *         @arg @ref LL_EXTI_LINE_9 | ||||
|   *         @arg @ref LL_EXTI_LINE_10 | ||||
|   *         @arg @ref LL_EXTI_LINE_11 | ||||
|   *         @arg @ref LL_EXTI_LINE_12 | ||||
|   *         @arg @ref LL_EXTI_LINE_13 | ||||
|   *         @arg @ref LL_EXTI_LINE_14 | ||||
|   *         @arg @ref LL_EXTI_LINE_15 | ||||
|   *         @arg @ref LL_EXTI_LINE_16 | ||||
|   *         @arg @ref LL_EXTI_LINE_18 | ||||
|   *         @arg @ref LL_EXTI_LINE_19 | ||||
|   * @note   Please check each device line mapping for EXTI Line availability | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_EXTI_GenerateSWI_0_31(uint32_t ExtiLine) | ||||
| { | ||||
|   SET_BIT(EXTI->SWIER, ExtiLine); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup EXTI_LL_EF_Flag_Management Flag_Management
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Check if the ExtLine Flag is set or not for Lines in range 0 to 31 | ||||
|   * @note This bit is set when the selected edge event arrives on the interrupt | ||||
|   *       line. This bit is cleared by writing a 1 to the bit. | ||||
|   * @rmtoll PR          PIFx           LL_EXTI_IsActiveFlag_0_31 | ||||
|   * @param  ExtiLine This parameter can be a combination of the following values: | ||||
|   *         @arg @ref LL_EXTI_LINE_0 | ||||
|   *         @arg @ref LL_EXTI_LINE_1 | ||||
|   *         @arg @ref LL_EXTI_LINE_2 | ||||
|   *         @arg @ref LL_EXTI_LINE_3 | ||||
|   *         @arg @ref LL_EXTI_LINE_4 | ||||
|   *         @arg @ref LL_EXTI_LINE_5 | ||||
|   *         @arg @ref LL_EXTI_LINE_6 | ||||
|   *         @arg @ref LL_EXTI_LINE_7 | ||||
|   *         @arg @ref LL_EXTI_LINE_8 | ||||
|   *         @arg @ref LL_EXTI_LINE_9 | ||||
|   *         @arg @ref LL_EXTI_LINE_10 | ||||
|   *         @arg @ref LL_EXTI_LINE_11 | ||||
|   *         @arg @ref LL_EXTI_LINE_12 | ||||
|   *         @arg @ref LL_EXTI_LINE_13 | ||||
|   *         @arg @ref LL_EXTI_LINE_14 | ||||
|   *         @arg @ref LL_EXTI_LINE_15 | ||||
|   *         @arg @ref LL_EXTI_LINE_16 | ||||
|   *         @arg @ref LL_EXTI_LINE_18 | ||||
|   *         @arg @ref LL_EXTI_LINE_19 | ||||
|   * @note   Please check each device line mapping for EXTI Line availability | ||||
|   * @retval State of bit (1 or 0). | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_EXTI_IsActiveFlag_0_31(uint32_t ExtiLine) | ||||
| { | ||||
|   return (READ_BIT(EXTI->PR, ExtiLine) == (ExtiLine)); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Read ExtLine Combination Flag for Lines in range 0 to 31 | ||||
|   * @note This bit is set when the selected edge event arrives on the interrupt | ||||
|   *       line. This bit is cleared by writing a 1 to the bit. | ||||
|   * @rmtoll PR          PIFx           LL_EXTI_ReadFlag_0_31 | ||||
|   * @param  ExtiLine This parameter can be a combination of the following values: | ||||
|   *         @arg @ref LL_EXTI_LINE_0 | ||||
|   *         @arg @ref LL_EXTI_LINE_1 | ||||
|   *         @arg @ref LL_EXTI_LINE_2 | ||||
|   *         @arg @ref LL_EXTI_LINE_3 | ||||
|   *         @arg @ref LL_EXTI_LINE_4 | ||||
|   *         @arg @ref LL_EXTI_LINE_5 | ||||
|   *         @arg @ref LL_EXTI_LINE_6 | ||||
|   *         @arg @ref LL_EXTI_LINE_7 | ||||
|   *         @arg @ref LL_EXTI_LINE_8 | ||||
|   *         @arg @ref LL_EXTI_LINE_9 | ||||
|   *         @arg @ref LL_EXTI_LINE_10 | ||||
|   *         @arg @ref LL_EXTI_LINE_11 | ||||
|   *         @arg @ref LL_EXTI_LINE_12 | ||||
|   *         @arg @ref LL_EXTI_LINE_13 | ||||
|   *         @arg @ref LL_EXTI_LINE_14 | ||||
|   *         @arg @ref LL_EXTI_LINE_15 | ||||
|   *         @arg @ref LL_EXTI_LINE_16 | ||||
|   *         @arg @ref LL_EXTI_LINE_18 | ||||
|   *         @arg @ref LL_EXTI_LINE_19 | ||||
|   * @note   Please check each device line mapping for EXTI Line availability | ||||
|   * @retval @note This bit is set when the selected edge event arrives on the interrupt | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_EXTI_ReadFlag_0_31(uint32_t ExtiLine) | ||||
| { | ||||
|   return (uint32_t)(READ_BIT(EXTI->PR, ExtiLine)); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Clear ExtLine Flags  for Lines in range 0 to 31 | ||||
|   * @note This bit is set when the selected edge event arrives on the interrupt | ||||
|   *       line. This bit is cleared by writing a 1 to the bit. | ||||
|   * @rmtoll PR          PIFx           LL_EXTI_ClearFlag_0_31 | ||||
|   * @param  ExtiLine This parameter can be a combination of the following values: | ||||
|   *         @arg @ref LL_EXTI_LINE_0 | ||||
|   *         @arg @ref LL_EXTI_LINE_1 | ||||
|   *         @arg @ref LL_EXTI_LINE_2 | ||||
|   *         @arg @ref LL_EXTI_LINE_3 | ||||
|   *         @arg @ref LL_EXTI_LINE_4 | ||||
|   *         @arg @ref LL_EXTI_LINE_5 | ||||
|   *         @arg @ref LL_EXTI_LINE_6 | ||||
|   *         @arg @ref LL_EXTI_LINE_7 | ||||
|   *         @arg @ref LL_EXTI_LINE_8 | ||||
|   *         @arg @ref LL_EXTI_LINE_9 | ||||
|   *         @arg @ref LL_EXTI_LINE_10 | ||||
|   *         @arg @ref LL_EXTI_LINE_11 | ||||
|   *         @arg @ref LL_EXTI_LINE_12 | ||||
|   *         @arg @ref LL_EXTI_LINE_13 | ||||
|   *         @arg @ref LL_EXTI_LINE_14 | ||||
|   *         @arg @ref LL_EXTI_LINE_15 | ||||
|   *         @arg @ref LL_EXTI_LINE_16 | ||||
|   *         @arg @ref LL_EXTI_LINE_18 | ||||
|   *         @arg @ref LL_EXTI_LINE_19 | ||||
|   * @note   Please check each device line mapping for EXTI Line availability | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_EXTI_ClearFlag_0_31(uint32_t ExtiLine) | ||||
| { | ||||
|   WRITE_REG(EXTI->PR, ExtiLine); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| #if defined(USE_FULL_LL_DRIVER) | ||||
| /** @defgroup EXTI_LL_EF_Init Initialization and de-initialization functions
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| uint32_t LL_EXTI_Init(LL_EXTI_InitTypeDef *EXTI_InitStruct); | ||||
| uint32_t LL_EXTI_DeInit(void); | ||||
| void LL_EXTI_StructInit(LL_EXTI_InitTypeDef *EXTI_InitStruct); | ||||
| 
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| #endif /* USE_FULL_LL_DRIVER */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| #endif /* EXTI */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif /* STM32F1xx_LL_EXTI_H */ | ||||
| 
 | ||||
							
								
								
									
										2341
									
								
								Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_ll_gpio.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2341
									
								
								Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_ll_gpio.h
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										302
									
								
								Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_ll_iwdg.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										302
									
								
								Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_ll_iwdg.h
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,302 @@ | ||||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32f1xx_ll_iwdg.h | ||||
|   * @author  MCD Application Team | ||||
|   * @brief   Header file of IWDG LL module. | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * Copyright (c) 2016 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. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef STM32F1xx_LL_IWDG_H | ||||
| #define STM32F1xx_LL_IWDG_H | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32f1xx.h" | ||||
| 
 | ||||
| /** @addtogroup STM32F1xx_LL_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #if defined(IWDG) | ||||
| 
 | ||||
| /** @defgroup IWDG_LL IWDG
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /* Private types -------------------------------------------------------------*/ | ||||
| /* Private variables ---------------------------------------------------------*/ | ||||
| 
 | ||||
| /* Private constants ---------------------------------------------------------*/ | ||||
| /** @defgroup IWDG_LL_Private_Constants IWDG Private Constants
 | ||||
|   * @{ | ||||
|   */ | ||||
| #define LL_IWDG_KEY_RELOAD                 0x0000AAAAU               /*!< IWDG Reload Counter Enable   */ | ||||
| #define LL_IWDG_KEY_ENABLE                 0x0000CCCCU               /*!< IWDG Peripheral Enable       */ | ||||
| #define LL_IWDG_KEY_WR_ACCESS_ENABLE       0x00005555U               /*!< IWDG KR Write Access Enable  */ | ||||
| #define LL_IWDG_KEY_WR_ACCESS_DISABLE      0x00000000U               /*!< IWDG KR Write Access Disable */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /* Private macros ------------------------------------------------------------*/ | ||||
| 
 | ||||
| /* Exported types ------------------------------------------------------------*/ | ||||
| /* Exported constants --------------------------------------------------------*/ | ||||
| /** @defgroup IWDG_LL_Exported_Constants IWDG Exported Constants
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup IWDG_LL_EC_GET_FLAG Get Flags Defines
 | ||||
|   * @brief    Flags defines which can be used with LL_IWDG_ReadReg function | ||||
|   * @{ | ||||
|   */ | ||||
| #define LL_IWDG_SR_PVU                     IWDG_SR_PVU                           /*!< Watchdog prescaler value update */ | ||||
| #define LL_IWDG_SR_RVU                     IWDG_SR_RVU                           /*!< Watchdog counter reload value update */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup IWDG_LL_EC_PRESCALER  Prescaler Divider
 | ||||
|   * @{ | ||||
|   */ | ||||
| #define LL_IWDG_PRESCALER_4                0x00000000U                           /*!< Divider by 4   */ | ||||
| #define LL_IWDG_PRESCALER_8                (IWDG_PR_PR_0)                        /*!< Divider by 8   */ | ||||
| #define LL_IWDG_PRESCALER_16               (IWDG_PR_PR_1)                        /*!< Divider by 16  */ | ||||
| #define LL_IWDG_PRESCALER_32               (IWDG_PR_PR_1 | IWDG_PR_PR_0)         /*!< Divider by 32  */ | ||||
| #define LL_IWDG_PRESCALER_64               (IWDG_PR_PR_2)                        /*!< Divider by 64  */ | ||||
| #define LL_IWDG_PRESCALER_128              (IWDG_PR_PR_2 | IWDG_PR_PR_0)         /*!< Divider by 128 */ | ||||
| #define LL_IWDG_PRESCALER_256              (IWDG_PR_PR_2 | IWDG_PR_PR_1)         /*!< Divider by 256 */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /* Exported macro ------------------------------------------------------------*/ | ||||
| /** @defgroup IWDG_LL_Exported_Macros IWDG Exported Macros
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup IWDG_LL_EM_WRITE_READ Common Write and read registers Macros
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Write a value in IWDG register | ||||
|   * @param  __INSTANCE__ IWDG Instance | ||||
|   * @param  __REG__ Register to be written | ||||
|   * @param  __VALUE__ Value to be written in the register | ||||
|   * @retval None | ||||
|   */ | ||||
| #define LL_IWDG_WriteReg(__INSTANCE__, __REG__, __VALUE__) WRITE_REG(__INSTANCE__->__REG__, (__VALUE__)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Read a value in IWDG register | ||||
|   * @param  __INSTANCE__ IWDG Instance | ||||
|   * @param  __REG__ Register to be read | ||||
|   * @retval Register value | ||||
|   */ | ||||
| #define LL_IWDG_ReadReg(__INSTANCE__, __REG__) READ_REG(__INSTANCE__->__REG__) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| 
 | ||||
| /* Exported functions --------------------------------------------------------*/ | ||||
| /** @defgroup IWDG_LL_Exported_Functions IWDG Exported Functions
 | ||||
|   * @{ | ||||
|   */ | ||||
| /** @defgroup IWDG_LL_EF_Configuration Configuration
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Start the Independent Watchdog | ||||
|   * @note   Except if the hardware watchdog option is selected | ||||
|   * @rmtoll KR           KEY           LL_IWDG_Enable | ||||
|   * @param  IWDGx IWDG Instance | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_IWDG_Enable(IWDG_TypeDef *IWDGx) | ||||
| { | ||||
|   WRITE_REG(IWDGx->KR, LL_IWDG_KEY_ENABLE); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Reloads IWDG counter with value defined in the reload register | ||||
|   * @rmtoll KR           KEY           LL_IWDG_ReloadCounter | ||||
|   * @param  IWDGx IWDG Instance | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_IWDG_ReloadCounter(IWDG_TypeDef *IWDGx) | ||||
| { | ||||
|   WRITE_REG(IWDGx->KR, LL_IWDG_KEY_RELOAD); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enable write access to IWDG_PR, IWDG_RLR and IWDG_WINR registers | ||||
|   * @rmtoll KR           KEY           LL_IWDG_EnableWriteAccess | ||||
|   * @param  IWDGx IWDG Instance | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_IWDG_EnableWriteAccess(IWDG_TypeDef *IWDGx) | ||||
| { | ||||
|   WRITE_REG(IWDGx->KR, LL_IWDG_KEY_WR_ACCESS_ENABLE); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Disable write access to IWDG_PR, IWDG_RLR and IWDG_WINR registers | ||||
|   * @rmtoll KR           KEY           LL_IWDG_DisableWriteAccess | ||||
|   * @param  IWDGx IWDG Instance | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_IWDG_DisableWriteAccess(IWDG_TypeDef *IWDGx) | ||||
| { | ||||
|   WRITE_REG(IWDGx->KR, LL_IWDG_KEY_WR_ACCESS_DISABLE); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Select the prescaler of the IWDG | ||||
|   * @rmtoll PR           PR            LL_IWDG_SetPrescaler | ||||
|   * @param  IWDGx IWDG Instance | ||||
|   * @param  Prescaler This parameter can be one of the following values: | ||||
|   *         @arg @ref LL_IWDG_PRESCALER_4 | ||||
|   *         @arg @ref LL_IWDG_PRESCALER_8 | ||||
|   *         @arg @ref LL_IWDG_PRESCALER_16 | ||||
|   *         @arg @ref LL_IWDG_PRESCALER_32 | ||||
|   *         @arg @ref LL_IWDG_PRESCALER_64 | ||||
|   *         @arg @ref LL_IWDG_PRESCALER_128 | ||||
|   *         @arg @ref LL_IWDG_PRESCALER_256 | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_IWDG_SetPrescaler(IWDG_TypeDef *IWDGx, uint32_t Prescaler) | ||||
| { | ||||
|   WRITE_REG(IWDGx->PR, IWDG_PR_PR & Prescaler); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Get the selected prescaler of the IWDG | ||||
|   * @rmtoll PR           PR            LL_IWDG_GetPrescaler | ||||
|   * @param  IWDGx IWDG Instance | ||||
|   * @retval Returned value can be one of the following values: | ||||
|   *         @arg @ref LL_IWDG_PRESCALER_4 | ||||
|   *         @arg @ref LL_IWDG_PRESCALER_8 | ||||
|   *         @arg @ref LL_IWDG_PRESCALER_16 | ||||
|   *         @arg @ref LL_IWDG_PRESCALER_32 | ||||
|   *         @arg @ref LL_IWDG_PRESCALER_64 | ||||
|   *         @arg @ref LL_IWDG_PRESCALER_128 | ||||
|   *         @arg @ref LL_IWDG_PRESCALER_256 | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_IWDG_GetPrescaler(const IWDG_TypeDef *IWDGx) | ||||
| { | ||||
|   return (READ_REG(IWDGx->PR)); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Specify the IWDG down-counter reload value | ||||
|   * @rmtoll RLR          RL            LL_IWDG_SetReloadCounter | ||||
|   * @param  IWDGx IWDG Instance | ||||
|   * @param  Counter Value between Min_Data=0 and Max_Data=0x0FFF | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_IWDG_SetReloadCounter(IWDG_TypeDef *IWDGx, uint32_t Counter) | ||||
| { | ||||
|   WRITE_REG(IWDGx->RLR, IWDG_RLR_RL & Counter); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Get the specified IWDG down-counter reload value | ||||
|   * @rmtoll RLR          RL            LL_IWDG_GetReloadCounter | ||||
|   * @param  IWDGx IWDG Instance | ||||
|   * @retval Value between Min_Data=0 and Max_Data=0x0FFF | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_IWDG_GetReloadCounter(const IWDG_TypeDef *IWDGx) | ||||
| { | ||||
|   return (READ_REG(IWDGx->RLR)); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup IWDG_LL_EF_FLAG_Management FLAG_Management
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Check if flag Prescaler Value Update is set or not | ||||
|   * @rmtoll SR           PVU           LL_IWDG_IsActiveFlag_PVU | ||||
|   * @param  IWDGx IWDG Instance | ||||
|   * @retval State of bit (1 or 0). | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_IWDG_IsActiveFlag_PVU(const IWDG_TypeDef *IWDGx) | ||||
| { | ||||
|   return ((READ_BIT(IWDGx->SR, IWDG_SR_PVU) == (IWDG_SR_PVU)) ? 1UL : 0UL); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Check if flag Reload Value Update is set or not | ||||
|   * @rmtoll SR           RVU           LL_IWDG_IsActiveFlag_RVU | ||||
|   * @param  IWDGx IWDG Instance | ||||
|   * @retval State of bit (1 or 0). | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_IWDG_IsActiveFlag_RVU(const IWDG_TypeDef *IWDGx) | ||||
| { | ||||
|   return ((READ_BIT(IWDGx->SR, IWDG_SR_RVU) == (IWDG_SR_RVU)) ? 1UL : 0UL); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Check if flags Prescaler & Reload Value Update are reset or not | ||||
|   * @rmtoll SR           PVU           LL_IWDG_IsReady\n | ||||
|   *         SR           RVU           LL_IWDG_IsReady | ||||
|   * @param  IWDGx IWDG Instance | ||||
|   * @retval State of bits (1 or 0). | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_IWDG_IsReady(const IWDG_TypeDef *IWDGx) | ||||
| { | ||||
|   return ((READ_BIT(IWDGx->SR, IWDG_SR_PVU | IWDG_SR_RVU) == 0U) ? 1UL : 0UL); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| #endif /* IWDG */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif /* STM32F1xx_LL_IWDG_H */ | ||||
							
								
								
									
										437
									
								
								Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_ll_pwr.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										437
									
								
								Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_ll_pwr.h
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,437 @@ | ||||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32f1xx_ll_pwr.h | ||||
|   * @author  MCD Application Team | ||||
|   * @brief   Header file of PWR LL module. | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * Copyright (c) 2016 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. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef __STM32F1xx_LL_PWR_H | ||||
| #define __STM32F1xx_LL_PWR_H | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32f1xx.h" | ||||
| 
 | ||||
| /** @addtogroup STM32F1xx_LL_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #if defined(PWR) | ||||
| 
 | ||||
| /** @defgroup PWR_LL PWR
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /* Private types -------------------------------------------------------------*/ | ||||
| /* Private variables ---------------------------------------------------------*/ | ||||
| /* Private constants ---------------------------------------------------------*/ | ||||
| /* Private macros ------------------------------------------------------------*/ | ||||
| /* Exported types ------------------------------------------------------------*/ | ||||
| /* Exported constants --------------------------------------------------------*/ | ||||
| /** @defgroup PWR_LL_Exported_Constants PWR Exported Constants
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup PWR_LL_EC_CLEAR_FLAG Clear Flags Defines
 | ||||
|   * @brief    Flags defines which can be used with LL_PWR_WriteReg function | ||||
|   * @{ | ||||
|   */ | ||||
| #define LL_PWR_CR_CSBF                     PWR_CR_CSBF            /*!< Clear standby flag */ | ||||
| #define LL_PWR_CR_CWUF                     PWR_CR_CWUF            /*!< Clear wakeup flag */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup PWR_LL_EC_GET_FLAG Get Flags Defines
 | ||||
|   * @brief    Flags defines which can be used with LL_PWR_ReadReg function | ||||
|   * @{ | ||||
|   */ | ||||
| #define LL_PWR_CSR_WUF                     PWR_CSR_WUF            /*!< Wakeup flag */ | ||||
| #define LL_PWR_CSR_SBF                     PWR_CSR_SBF            /*!< Standby flag */ | ||||
| #define LL_PWR_CSR_PVDO                    PWR_CSR_PVDO           /*!< Power voltage detector output flag */ | ||||
| #define LL_PWR_CSR_EWUP1                   PWR_CSR_EWUP           /*!< Enable WKUP pin 1 */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| 
 | ||||
| /** @defgroup PWR_LL_EC_MODE_PWR Mode Power
 | ||||
|   * @{ | ||||
|   */ | ||||
| #define LL_PWR_MODE_STOP_MAINREGU             0x00000000U                    /*!< Enter Stop mode when the CPU enters deepsleep */ | ||||
| #define LL_PWR_MODE_STOP_LPREGU               (PWR_CR_LPDS)                  /*!< Enter Stop mode (with low power Regulator ON) when the CPU enters deepsleep */ | ||||
| #define LL_PWR_MODE_STANDBY                   (PWR_CR_PDDS)                  /*!< Enter Standby mode when the CPU enters deepsleep */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup PWR_LL_EC_REGU_MODE_DS_MODE  Regulator Mode In Deep Sleep Mode
 | ||||
|  * @{ | ||||
|  */ | ||||
| #define LL_PWR_REGU_DSMODE_MAIN        0x00000000U           /*!< Voltage Regulator in main mode during deepsleep mode */ | ||||
| #define LL_PWR_REGU_DSMODE_LOW_POWER   (PWR_CR_LPDS)         /*!< Voltage Regulator in low-power mode during deepsleep mode */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup PWR_LL_EC_PVDLEVEL Power Voltage Detector Level
 | ||||
|   * @{ | ||||
|   */ | ||||
| #define LL_PWR_PVDLEVEL_0                  (PWR_CR_PLS_LEV0)      /*!< Voltage threshold detected by PVD 2.2 V */ | ||||
| #define LL_PWR_PVDLEVEL_1                  (PWR_CR_PLS_LEV1)      /*!< Voltage threshold detected by PVD 2.3 V */ | ||||
| #define LL_PWR_PVDLEVEL_2                  (PWR_CR_PLS_LEV2)      /*!< Voltage threshold detected by PVD 2.4 V */ | ||||
| #define LL_PWR_PVDLEVEL_3                  (PWR_CR_PLS_LEV3)      /*!< Voltage threshold detected by PVD 2.5 V */ | ||||
| #define LL_PWR_PVDLEVEL_4                  (PWR_CR_PLS_LEV4)      /*!< Voltage threshold detected by PVD 2.6 V */ | ||||
| #define LL_PWR_PVDLEVEL_5                  (PWR_CR_PLS_LEV5)      /*!< Voltage threshold detected by PVD 2.7 V */ | ||||
| #define LL_PWR_PVDLEVEL_6                  (PWR_CR_PLS_LEV6)      /*!< Voltage threshold detected by PVD 2.8 V */ | ||||
| #define LL_PWR_PVDLEVEL_7                  (PWR_CR_PLS_LEV7)      /*!< Voltage threshold detected by PVD 2.9 V */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| /** @defgroup PWR_LL_EC_WAKEUP_PIN  Wakeup Pins
 | ||||
|   * @{ | ||||
|   */ | ||||
| #define LL_PWR_WAKEUP_PIN1                 (PWR_CSR_EWUP)         /*!< WKUP pin 1 : PA0 */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| 
 | ||||
| /* Exported macro ------------------------------------------------------------*/ | ||||
| /** @defgroup PWR_LL_Exported_Macros PWR Exported Macros
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup PWR_LL_EM_WRITE_READ Common write and read registers Macros
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Write a value in PWR register | ||||
|   * @param  __REG__ Register to be written | ||||
|   * @param  __VALUE__ Value to be written in the register | ||||
|   * @retval None | ||||
|   */ | ||||
| #define LL_PWR_WriteReg(__REG__, __VALUE__) WRITE_REG(PWR->__REG__, (__VALUE__)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Read a value in PWR register | ||||
|   * @param  __REG__ Register to be read | ||||
|   * @retval Register value | ||||
|   */ | ||||
| #define LL_PWR_ReadReg(__REG__) READ_REG(PWR->__REG__) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /* Exported functions --------------------------------------------------------*/ | ||||
| /** @defgroup PWR_LL_Exported_Functions PWR Exported Functions
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup PWR_LL_EF_Configuration Configuration
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enable access to the backup domain | ||||
|   * @rmtoll CR    DBP       LL_PWR_EnableBkUpAccess | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_PWR_EnableBkUpAccess(void) | ||||
| { | ||||
|   SET_BIT(PWR->CR, PWR_CR_DBP); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Disable access to the backup domain | ||||
|   * @rmtoll CR    DBP       LL_PWR_DisableBkUpAccess | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_PWR_DisableBkUpAccess(void) | ||||
| { | ||||
|   CLEAR_BIT(PWR->CR, PWR_CR_DBP); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Check if the backup domain is enabled | ||||
|   * @rmtoll CR    DBP       LL_PWR_IsEnabledBkUpAccess | ||||
|   * @retval State of bit (1 or 0). | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_PWR_IsEnabledBkUpAccess(void) | ||||
| { | ||||
|   return (READ_BIT(PWR->CR, PWR_CR_DBP) == (PWR_CR_DBP)); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Set voltage Regulator mode during deep sleep mode | ||||
|   * @rmtoll CR    LPDS         LL_PWR_SetRegulModeDS | ||||
|   * @param  RegulMode This parameter can be one of the following values: | ||||
|   *         @arg @ref LL_PWR_REGU_DSMODE_MAIN | ||||
|   *         @arg @ref LL_PWR_REGU_DSMODE_LOW_POWER | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_PWR_SetRegulModeDS(uint32_t RegulMode) | ||||
| { | ||||
|   MODIFY_REG(PWR->CR, PWR_CR_LPDS, RegulMode); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Get voltage Regulator mode during deep sleep mode | ||||
|   * @rmtoll CR    LPDS         LL_PWR_GetRegulModeDS | ||||
|   * @retval Returned value can be one of the following values: | ||||
|   *         @arg @ref LL_PWR_REGU_DSMODE_MAIN | ||||
|   *         @arg @ref LL_PWR_REGU_DSMODE_LOW_POWER | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_PWR_GetRegulModeDS(void) | ||||
| { | ||||
|   return (uint32_t)(READ_BIT(PWR->CR, PWR_CR_LPDS)); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Set Power Down mode when CPU enters deepsleep | ||||
|   * @rmtoll CR    PDDS         LL_PWR_SetPowerMode\n | ||||
|   * @rmtoll CR    LPDS         LL_PWR_SetPowerMode | ||||
|   * @param  PDMode This parameter can be one of the following values: | ||||
|   *         @arg @ref LL_PWR_MODE_STOP_MAINREGU | ||||
|   *         @arg @ref LL_PWR_MODE_STOP_LPREGU | ||||
|   *         @arg @ref LL_PWR_MODE_STANDBY | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_PWR_SetPowerMode(uint32_t PDMode) | ||||
| { | ||||
|   MODIFY_REG(PWR->CR, (PWR_CR_PDDS| PWR_CR_LPDS), PDMode); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Get Power Down mode when CPU enters deepsleep | ||||
|   * @rmtoll CR    PDDS         LL_PWR_GetPowerMode\n | ||||
|   * @rmtoll CR    LPDS         LL_PWR_GetPowerMode | ||||
|   * @retval Returned value can be one of the following values: | ||||
|   *         @arg @ref LL_PWR_MODE_STOP_MAINREGU | ||||
|   *         @arg @ref LL_PWR_MODE_STOP_LPREGU | ||||
|   *         @arg @ref LL_PWR_MODE_STANDBY | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_PWR_GetPowerMode(void) | ||||
| { | ||||
|   return (uint32_t)(READ_BIT(PWR->CR, (PWR_CR_PDDS| PWR_CR_LPDS))); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Configure the voltage threshold detected by the Power Voltage Detector | ||||
|   * @rmtoll CR    PLS       LL_PWR_SetPVDLevel | ||||
|   * @param  PVDLevel This parameter can be one of the following values: | ||||
|   *         @arg @ref LL_PWR_PVDLEVEL_0 | ||||
|   *         @arg @ref LL_PWR_PVDLEVEL_1 | ||||
|   *         @arg @ref LL_PWR_PVDLEVEL_2 | ||||
|   *         @arg @ref LL_PWR_PVDLEVEL_3 | ||||
|   *         @arg @ref LL_PWR_PVDLEVEL_4 | ||||
|   *         @arg @ref LL_PWR_PVDLEVEL_5 | ||||
|   *         @arg @ref LL_PWR_PVDLEVEL_6 | ||||
|   *         @arg @ref LL_PWR_PVDLEVEL_7 | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_PWR_SetPVDLevel(uint32_t PVDLevel) | ||||
| { | ||||
|   MODIFY_REG(PWR->CR, PWR_CR_PLS, PVDLevel); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Get the voltage threshold detection | ||||
|   * @rmtoll CR    PLS       LL_PWR_GetPVDLevel | ||||
|   * @retval Returned value can be one of the following values: | ||||
|   *         @arg @ref LL_PWR_PVDLEVEL_0 | ||||
|   *         @arg @ref LL_PWR_PVDLEVEL_1 | ||||
|   *         @arg @ref LL_PWR_PVDLEVEL_2 | ||||
|   *         @arg @ref LL_PWR_PVDLEVEL_3 | ||||
|   *         @arg @ref LL_PWR_PVDLEVEL_4 | ||||
|   *         @arg @ref LL_PWR_PVDLEVEL_5 | ||||
|   *         @arg @ref LL_PWR_PVDLEVEL_6 | ||||
|   *         @arg @ref LL_PWR_PVDLEVEL_7 | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_PWR_GetPVDLevel(void) | ||||
| { | ||||
|   return (uint32_t)(READ_BIT(PWR->CR, PWR_CR_PLS)); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enable Power Voltage Detector | ||||
|   * @rmtoll CR    PVDE       LL_PWR_EnablePVD | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_PWR_EnablePVD(void) | ||||
| { | ||||
|   SET_BIT(PWR->CR, PWR_CR_PVDE); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Disable Power Voltage Detector | ||||
|   * @rmtoll CR    PVDE       LL_PWR_DisablePVD | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_PWR_DisablePVD(void) | ||||
| { | ||||
|   CLEAR_BIT(PWR->CR, PWR_CR_PVDE); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Check if Power Voltage Detector is enabled | ||||
|   * @rmtoll CR    PVDE       LL_PWR_IsEnabledPVD | ||||
|   * @retval State of bit (1 or 0). | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_PWR_IsEnabledPVD(void) | ||||
| { | ||||
|   return (READ_BIT(PWR->CR, PWR_CR_PVDE) == (PWR_CR_PVDE)); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enable the WakeUp PINx functionality | ||||
|   * @rmtoll CSR   EWUP       LL_PWR_EnableWakeUpPin | ||||
|   * @param  WakeUpPin This parameter can be one of the following values: | ||||
|   *         @arg @ref LL_PWR_WAKEUP_PIN1 | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_PWR_EnableWakeUpPin(uint32_t WakeUpPin) | ||||
| { | ||||
|   SET_BIT(PWR->CSR, WakeUpPin); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Disable the WakeUp PINx functionality | ||||
|   * @rmtoll CSR   EWUP       LL_PWR_DisableWakeUpPin | ||||
|   * @param  WakeUpPin This parameter can be one of the following values: | ||||
|   *         @arg @ref LL_PWR_WAKEUP_PIN1 | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_PWR_DisableWakeUpPin(uint32_t WakeUpPin) | ||||
| { | ||||
|   CLEAR_BIT(PWR->CSR, WakeUpPin); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Check if the WakeUp PINx functionality is enabled | ||||
|   * @rmtoll CSR   EWUP       LL_PWR_IsEnabledWakeUpPin | ||||
|   * @param  WakeUpPin This parameter can be one of the following values: | ||||
|   *         @arg @ref LL_PWR_WAKEUP_PIN1 | ||||
|   * @retval State of bit (1 or 0). | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_PWR_IsEnabledWakeUpPin(uint32_t WakeUpPin) | ||||
| { | ||||
|   return (READ_BIT(PWR->CSR, WakeUpPin) == (WakeUpPin)); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup PWR_LL_EF_FLAG_Management FLAG_Management
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Get Wake-up Flag | ||||
|   * @rmtoll CSR   WUF       LL_PWR_IsActiveFlag_WU | ||||
|   * @retval State of bit (1 or 0). | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_PWR_IsActiveFlag_WU(void) | ||||
| { | ||||
|   return (READ_BIT(PWR->CSR, PWR_CSR_WUF) == (PWR_CSR_WUF)); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Get Standby Flag | ||||
|   * @rmtoll CSR   SBF       LL_PWR_IsActiveFlag_SB | ||||
|   * @retval State of bit (1 or 0). | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_PWR_IsActiveFlag_SB(void) | ||||
| { | ||||
|   return (READ_BIT(PWR->CSR, PWR_CSR_SBF) == (PWR_CSR_SBF)); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Indicate whether VDD voltage is below the selected PVD threshold | ||||
|   * @rmtoll CSR   PVDO       LL_PWR_IsActiveFlag_PVDO | ||||
|   * @retval State of bit (1 or 0). | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_PWR_IsActiveFlag_PVDO(void) | ||||
| { | ||||
|   return (READ_BIT(PWR->CSR, PWR_CSR_PVDO) == (PWR_CSR_PVDO)); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Clear Standby Flag | ||||
|   * @rmtoll CR   CSBF       LL_PWR_ClearFlag_SB | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_PWR_ClearFlag_SB(void) | ||||
| { | ||||
|   SET_BIT(PWR->CR, PWR_CR_CSBF); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Clear Wake-up Flags | ||||
|   * @rmtoll CR   CWUF       LL_PWR_ClearFlag_WU | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_PWR_ClearFlag_WU(void) | ||||
| { | ||||
|   SET_BIT(PWR->CR, PWR_CR_CWUF); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| #if defined(USE_FULL_LL_DRIVER) | ||||
| /** @defgroup PWR_LL_EF_Init De-initialization function
 | ||||
|   * @{ | ||||
|   */ | ||||
| ErrorStatus LL_PWR_DeInit(void); | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| #endif /* USE_FULL_LL_DRIVER */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| #endif /* defined(PWR) */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif /* __STM32F1xx_LL_PWR_H */ | ||||
							
								
								
									
										2309
									
								
								Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_ll_rcc.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2309
									
								
								Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_ll_rcc.h
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										575
									
								
								Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_ll_system.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										575
									
								
								Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_ll_system.h
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,575 @@ | ||||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32f1xx_ll_system.h | ||||
|   * @author  MCD Application Team | ||||
|   * @brief   Header file of SYSTEM LL module. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * Copyright (c) 2016 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. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   @verbatim | ||||
|   ============================================================================== | ||||
|                      ##### How to use this driver ##### | ||||
|   ============================================================================== | ||||
|     [..] | ||||
|     The LL SYSTEM driver contains a set of generic APIs that can be | ||||
|     used by user: | ||||
|       (+) Some of the FLASH features need to be handled in the SYSTEM file. | ||||
|       (+) Access to DBGCMU registers | ||||
|       (+) Access to SYSCFG registers | ||||
| 
 | ||||
|   @endverbatim | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef __STM32F1xx_LL_SYSTEM_H | ||||
| #define __STM32F1xx_LL_SYSTEM_H | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32f1xx.h" | ||||
| 
 | ||||
| /** @addtogroup STM32F1xx_LL_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #if defined (FLASH) || defined (DBGMCU) | ||||
| 
 | ||||
| /** @defgroup SYSTEM_LL SYSTEM
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /* Private types -------------------------------------------------------------*/ | ||||
| /* Private variables ---------------------------------------------------------*/ | ||||
| 
 | ||||
| /* Private constants ---------------------------------------------------------*/ | ||||
| /** @defgroup SYSTEM_LL_Private_Constants SYSTEM Private Constants
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /* Private macros ------------------------------------------------------------*/ | ||||
| 
 | ||||
| /* Exported types ------------------------------------------------------------*/ | ||||
| /* Exported constants --------------------------------------------------------*/ | ||||
| /** @defgroup SYSTEM_LL_Exported_Constants SYSTEM Exported Constants
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| /** @defgroup SYSTEM_LL_EC_TRACE DBGMCU TRACE Pin Assignment
 | ||||
|   * @{ | ||||
|   */ | ||||
| #define LL_DBGMCU_TRACE_NONE               0x00000000U                                     /*!< TRACE pins not assigned (default state) */ | ||||
| #define LL_DBGMCU_TRACE_ASYNCH             DBGMCU_CR_TRACE_IOEN                            /*!< TRACE pin assignment for Asynchronous Mode */ | ||||
| #define LL_DBGMCU_TRACE_SYNCH_SIZE1        (DBGMCU_CR_TRACE_IOEN | DBGMCU_CR_TRACE_MODE_0) /*!< TRACE pin assignment for Synchronous Mode with a TRACEDATA size of 1 */ | ||||
| #define LL_DBGMCU_TRACE_SYNCH_SIZE2        (DBGMCU_CR_TRACE_IOEN | DBGMCU_CR_TRACE_MODE_1) /*!< TRACE pin assignment for Synchronous Mode with a TRACEDATA size of 2 */ | ||||
| #define LL_DBGMCU_TRACE_SYNCH_SIZE4        (DBGMCU_CR_TRACE_IOEN | DBGMCU_CR_TRACE_MODE)   /*!< TRACE pin assignment for Synchronous Mode with a TRACEDATA size of 4 */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SYSTEM_LL_EC_APB1_GRP1_STOP_IP DBGMCU APB1 GRP1 STOP IP
 | ||||
|   * @{ | ||||
|   */ | ||||
| #define LL_DBGMCU_APB1_GRP1_TIM2_STOP      DBGMCU_CR_DBG_TIM2_STOP          /*!< TIM2 counter stopped when core is halted */ | ||||
| #define LL_DBGMCU_APB1_GRP1_TIM3_STOP      DBGMCU_CR_DBG_TIM3_STOP          /*!< TIM3 counter stopped when core is halted */ | ||||
| #define LL_DBGMCU_APB1_GRP1_TIM4_STOP      DBGMCU_CR_DBG_TIM4_STOP          /*!< TIM4 counter stopped when core is halted */ | ||||
| #if defined(DBGMCU_CR_DBG_TIM5_STOP) | ||||
| #define LL_DBGMCU_APB1_GRP1_TIM5_STOP      DBGMCU_CR_DBG_TIM5_STOP          /*!< TIM5 counter stopped when core is halted */ | ||||
| #endif /* DBGMCU_CR_DBG_TIM5_STOP */ | ||||
| #if defined(DBGMCU_CR_DBG_TIM6_STOP) | ||||
| #define LL_DBGMCU_APB1_GRP1_TIM6_STOP      DBGMCU_CR_DBG_TIM6_STOP          /*!< TIM6 counter stopped when core is halted */ | ||||
| #endif /* DBGMCU_CR_DBG_TIM6_STOP */ | ||||
| #if defined(DBGMCU_CR_DBG_TIM7_STOP) | ||||
| #define LL_DBGMCU_APB1_GRP1_TIM7_STOP      DBGMCU_CR_DBG_TIM7_STOP          /*!< TIM7 counter stopped when core is halted */ | ||||
| #endif /* DBGMCU_CR_DBG_TIM7_STOP */ | ||||
| #if defined(DBGMCU_CR_DBG_TIM12_STOP) | ||||
| #define LL_DBGMCU_APB1_GRP1_TIM12_STOP     DBGMCU_CR_DBG_TIM12_STOP         /*!< TIM12 counter stopped when core is halted */ | ||||
| #endif /* DBGMCU_CR_DBG_TIM12_STOP */ | ||||
| #if defined(DBGMCU_CR_DBG_TIM13_STOP) | ||||
| #define LL_DBGMCU_APB1_GRP1_TIM13_STOP     DBGMCU_CR_DBG_TIM13_STOP         /*!< TIM13 counter stopped when core is halted */ | ||||
| #endif /* DBGMCU_CR_DBG_TIM13_STOP */ | ||||
| #if defined(DBGMCU_CR_DBG_TIM14_STOP) | ||||
| #define LL_DBGMCU_APB1_GRP1_TIM14_STOP     DBGMCU_CR_DBG_TIM14_STOP         /*!< TIM14 counter stopped when core is halted */ | ||||
| #endif /* DBGMCU_CR_DBG_TIM14_STOP */ | ||||
| #define LL_DBGMCU_APB1_GRP1_WWDG_STOP      DBGMCU_CR_DBG_WWDG_STOP          /*!< Debug Window Watchdog stopped when Core is halted */ | ||||
| #define LL_DBGMCU_APB1_GRP1_IWDG_STOP      DBGMCU_CR_DBG_IWDG_STOP          /*!< Debug Independent Watchdog stopped when Core is halted */ | ||||
| #define LL_DBGMCU_APB1_GRP1_I2C1_STOP      DBGMCU_CR_DBG_I2C1_SMBUS_TIMEOUT /*!< I2C1 SMBUS timeout mode stopped when Core is halted */ | ||||
| #if defined(DBGMCU_CR_DBG_I2C2_SMBUS_TIMEOUT) | ||||
| #define LL_DBGMCU_APB1_GRP1_I2C2_STOP      DBGMCU_CR_DBG_I2C2_SMBUS_TIMEOUT /*!< I2C2 SMBUS timeout mode stopped when Core is halted */ | ||||
| #endif /* DBGMCU_CR_DBG_I2C2_SMBUS_TIMEOUT */ | ||||
| #if defined(DBGMCU_CR_DBG_CAN1_STOP) | ||||
| #define LL_DBGMCU_APB1_GRP1_CAN1_STOP      DBGMCU_CR_DBG_CAN1_STOP          /*!< CAN1 debug stopped when Core is halted  */ | ||||
| #endif /* DBGMCU_CR_DBG_CAN1_STOP */ | ||||
| #if defined(DBGMCU_CR_DBG_CAN2_STOP) | ||||
| #define LL_DBGMCU_APB1_GRP1_CAN2_STOP      DBGMCU_CR_DBG_CAN2_STOP          /*!< CAN2 debug stopped when Core is halted  */ | ||||
| #endif /* DBGMCU_CR_DBG_CAN2_STOP */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SYSTEM_LL_EC_APB2_GRP1_STOP_IP DBGMCU APB2 GRP1 STOP IP
 | ||||
|   * @{ | ||||
|   */ | ||||
| #define LL_DBGMCU_APB2_GRP1_TIM1_STOP      DBGMCU_CR_DBG_TIM1_STOP   /*!< TIM1 counter stopped when core is halted */ | ||||
| #if defined(DBGMCU_CR_DBG_TIM8_STOP) | ||||
| #define LL_DBGMCU_APB2_GRP1_TIM8_STOP      DBGMCU_CR_DBG_TIM8_STOP   /*!< TIM8 counter stopped when core is halted */ | ||||
| #endif /* DBGMCU_CR_DBG_CAN1_STOP */ | ||||
| #if defined(DBGMCU_CR_DBG_TIM9_STOP) | ||||
| #define LL_DBGMCU_APB2_GRP1_TIM9_STOP      DBGMCU_CR_DBG_TIM9_STOP   /*!< TIM9 counter stopped when core is halted */ | ||||
| #endif /* DBGMCU_CR_DBG_TIM9_STOP */ | ||||
| #if defined(DBGMCU_CR_DBG_TIM10_STOP) | ||||
| #define LL_DBGMCU_APB2_GRP1_TIM10_STOP     DBGMCU_CR_DBG_TIM10_STOP   /*!< TIM10 counter stopped when core is halted */ | ||||
| #endif /* DBGMCU_CR_DBG_TIM10_STOP */ | ||||
| #if defined(DBGMCU_CR_DBG_TIM11_STOP) | ||||
| #define LL_DBGMCU_APB2_GRP1_TIM11_STOP     DBGMCU_CR_DBG_TIM11_STOP   /*!< TIM11 counter stopped when core is halted */ | ||||
| #endif /* DBGMCU_CR_DBG_TIM11_STOP */ | ||||
| #if defined(DBGMCU_CR_DBG_TIM15_STOP) | ||||
| #define LL_DBGMCU_APB2_GRP1_TIM15_STOP     DBGMCU_CR_DBG_TIM15_STOP   /*!< TIM15 counter stopped when core is halted */ | ||||
| #endif /* DBGMCU_CR_DBG_TIM15_STOP */ | ||||
| #if defined(DBGMCU_CR_DBG_TIM16_STOP) | ||||
| #define LL_DBGMCU_APB2_GRP1_TIM16_STOP     DBGMCU_CR_DBG_TIM16_STOP   /*!< TIM16 counter stopped when core is halted */ | ||||
| #endif /* DBGMCU_CR_DBG_TIM16_STOP */ | ||||
| #if defined(DBGMCU_CR_DBG_TIM17_STOP) | ||||
| #define LL_DBGMCU_APB2_GRP1_TIM17_STOP     DBGMCU_CR_DBG_TIM17_STOP   /*!< TIM17 counter stopped when core is halted */ | ||||
| #endif /* DBGMCU_CR_DBG_TIM17_STOP */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SYSTEM_LL_EC_LATENCY FLASH LATENCY
 | ||||
|   * @{ | ||||
|   */ | ||||
| #if defined(FLASH_ACR_LATENCY) | ||||
| #define LL_FLASH_LATENCY_0                 0x00000000U             /*!< FLASH Zero Latency cycle */ | ||||
| #define LL_FLASH_LATENCY_1                 FLASH_ACR_LATENCY_0     /*!< FLASH One Latency cycle */ | ||||
| #define LL_FLASH_LATENCY_2                 FLASH_ACR_LATENCY_1     /*!< FLASH Two wait states */ | ||||
| #else | ||||
| #endif /* FLASH_ACR_LATENCY */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /* Exported macro ------------------------------------------------------------*/ | ||||
| 
 | ||||
| /* Exported functions --------------------------------------------------------*/ | ||||
| /** @defgroup SYSTEM_LL_Exported_Functions SYSTEM Exported Functions
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| /** @defgroup SYSTEM_LL_EF_DBGMCU DBGMCU
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Return the device identifier | ||||
|   * @note For Low Density devices, the device ID is 0x412 | ||||
|   * @note For Medium Density devices, the device ID is 0x410 | ||||
|   * @note For High Density devices, the device ID is 0x414 | ||||
|   * @note For XL Density devices, the device ID is 0x430 | ||||
|   * @note For Connectivity Line devices, the device ID is 0x418 | ||||
|   * @rmtoll DBGMCU_IDCODE DEV_ID        LL_DBGMCU_GetDeviceID | ||||
|   * @retval Values between Min_Data=0x00 and Max_Data=0xFFF | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_DBGMCU_GetDeviceID(void) | ||||
| { | ||||
|   return (uint32_t)(READ_BIT(DBGMCU->IDCODE, DBGMCU_IDCODE_DEV_ID)); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Return the device revision identifier | ||||
|   * @note This field indicates the revision of the device. | ||||
|           For example, it is read as revA -> 0x1000,for Low Density devices | ||||
|           For example, it is read as revA -> 0x0000, revB -> 0x2000, revZ -> 0x2001, rev1,2,3,X or Y -> 0x2003,for Medium Density devices | ||||
|           For example, it is read as revA or 1 -> 0x1000, revZ -> 0x1001,rev1,2,3,X or Y -> 0x1003,for Medium Density devices | ||||
|           For example, it is read as revA or 1 -> 0x1003,for XL Density devices | ||||
|           For example, it is read as revA -> 0x1000, revZ -> 0x1001 for  Connectivity line devices | ||||
|   * @rmtoll DBGMCU_IDCODE REV_ID        LL_DBGMCU_GetRevisionID | ||||
|   * @retval Values between Min_Data=0x00 and Max_Data=0xFFFF | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_DBGMCU_GetRevisionID(void) | ||||
| { | ||||
|   return (uint32_t)(READ_BIT(DBGMCU->IDCODE, DBGMCU_IDCODE_REV_ID) >> DBGMCU_IDCODE_REV_ID_Pos); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enable the Debug Module during SLEEP mode | ||||
|   * @rmtoll DBGMCU_CR    DBG_SLEEP     LL_DBGMCU_EnableDBGSleepMode | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_DBGMCU_EnableDBGSleepMode(void) | ||||
| { | ||||
|   SET_BIT(DBGMCU->CR, DBGMCU_CR_DBG_SLEEP); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Disable the Debug Module during SLEEP mode | ||||
|   * @rmtoll DBGMCU_CR    DBG_SLEEP     LL_DBGMCU_DisableDBGSleepMode | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_DBGMCU_DisableDBGSleepMode(void) | ||||
| { | ||||
|   CLEAR_BIT(DBGMCU->CR, DBGMCU_CR_DBG_SLEEP); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enable the Debug Module during STOP mode | ||||
|   * @rmtoll DBGMCU_CR    DBG_STOP      LL_DBGMCU_EnableDBGStopMode | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_DBGMCU_EnableDBGStopMode(void) | ||||
| { | ||||
|   SET_BIT(DBGMCU->CR, DBGMCU_CR_DBG_STOP); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Disable the Debug Module during STOP mode | ||||
|   * @rmtoll DBGMCU_CR    DBG_STOP      LL_DBGMCU_DisableDBGStopMode | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_DBGMCU_DisableDBGStopMode(void) | ||||
| { | ||||
|   CLEAR_BIT(DBGMCU->CR, DBGMCU_CR_DBG_STOP); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enable the Debug Module during STANDBY mode | ||||
|   * @rmtoll DBGMCU_CR    DBG_STANDBY   LL_DBGMCU_EnableDBGStandbyMode | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_DBGMCU_EnableDBGStandbyMode(void) | ||||
| { | ||||
|   SET_BIT(DBGMCU->CR, DBGMCU_CR_DBG_STANDBY); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Disable the Debug Module during STANDBY mode | ||||
|   * @rmtoll DBGMCU_CR    DBG_STANDBY   LL_DBGMCU_DisableDBGStandbyMode | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_DBGMCU_DisableDBGStandbyMode(void) | ||||
| { | ||||
|   CLEAR_BIT(DBGMCU->CR, DBGMCU_CR_DBG_STANDBY); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Set Trace pin assignment control | ||||
|   * @rmtoll DBGMCU_CR    TRACE_IOEN    LL_DBGMCU_SetTracePinAssignment\n | ||||
|   *         DBGMCU_CR    TRACE_MODE    LL_DBGMCU_SetTracePinAssignment | ||||
|   * @param  PinAssignment This parameter can be one of the following values: | ||||
|   *         @arg @ref LL_DBGMCU_TRACE_NONE | ||||
|   *         @arg @ref LL_DBGMCU_TRACE_ASYNCH | ||||
|   *         @arg @ref LL_DBGMCU_TRACE_SYNCH_SIZE1 | ||||
|   *         @arg @ref LL_DBGMCU_TRACE_SYNCH_SIZE2 | ||||
|   *         @arg @ref LL_DBGMCU_TRACE_SYNCH_SIZE4 | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_DBGMCU_SetTracePinAssignment(uint32_t PinAssignment) | ||||
| { | ||||
|   MODIFY_REG(DBGMCU->CR, DBGMCU_CR_TRACE_IOEN | DBGMCU_CR_TRACE_MODE, PinAssignment); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Get Trace pin assignment control | ||||
|   * @rmtoll DBGMCU_CR    TRACE_IOEN    LL_DBGMCU_GetTracePinAssignment\n | ||||
|   *         DBGMCU_CR    TRACE_MODE    LL_DBGMCU_GetTracePinAssignment | ||||
|   * @retval Returned value can be one of the following values: | ||||
|   *         @arg @ref LL_DBGMCU_TRACE_NONE | ||||
|   *         @arg @ref LL_DBGMCU_TRACE_ASYNCH | ||||
|   *         @arg @ref LL_DBGMCU_TRACE_SYNCH_SIZE1 | ||||
|   *         @arg @ref LL_DBGMCU_TRACE_SYNCH_SIZE2 | ||||
|   *         @arg @ref LL_DBGMCU_TRACE_SYNCH_SIZE4 | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_DBGMCU_GetTracePinAssignment(void) | ||||
| { | ||||
|   return (uint32_t)(READ_BIT(DBGMCU->CR, DBGMCU_CR_TRACE_IOEN | DBGMCU_CR_TRACE_MODE)); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Freeze APB1 peripherals (group1 peripherals) | ||||
|   * @rmtoll DBGMCU_CR_APB1      DBG_TIM2_STOP           LL_DBGMCU_APB1_GRP1_FreezePeriph\n | ||||
|   *         DBGMCU_CR_APB1      DBG_TIM3_STOP           LL_DBGMCU_APB1_GRP1_FreezePeriph\n | ||||
|   *         DBGMCU_CR_APB1      DBG_TIM4_STOP           LL_DBGMCU_APB1_GRP1_FreezePeriph\n | ||||
|   *         DBGMCU_CR_APB1      DBG_TIM5_STOP           LL_DBGMCU_APB1_GRP1_FreezePeriph\n | ||||
|   *         DBGMCU_CR_APB1      DBG_TIM6_STOP           LL_DBGMCU_APB1_GRP1_FreezePeriph\n | ||||
|   *         DBGMCU_CR_APB1      DBG_TIM7_STOP           LL_DBGMCU_APB1_GRP1_FreezePeriph\n | ||||
|   *         DBGMCU_CR_APB1      DBG_TIM12_STOP          LL_DBGMCU_APB1_GRP1_FreezePeriph\n | ||||
|   *         DBGMCU_CR_APB1      DBG_TIM13_STOP          LL_DBGMCU_APB1_GRP1_FreezePeriph\n | ||||
|   *         DBGMCU_CR_APB1      DBG_TIM14_STOP          LL_DBGMCU_APB1_GRP1_FreezePeriph\n | ||||
|   *         DBGMCU_CR_APB1      DBG_RTC_STOP            LL_DBGMCU_APB1_GRP1_FreezePeriph\n | ||||
|   *         DBGMCU_CR_APB1      DBG_WWDG_STOP           LL_DBGMCU_APB1_GRP1_FreezePeriph\n | ||||
|   *         DBGMCU_CR_APB1      DBG_IWDG_STOP           LL_DBGMCU_APB1_GRP1_FreezePeriph\n | ||||
|   *         DBGMCU_CR_APB1      DBG_I2C1_SMBUS_TIMEOUT  LL_DBGMCU_APB1_GRP1_FreezePeriph\n | ||||
|   *         DBGMCU_CR_APB1      DBG_I2C2_SMBUS_TIMEOUT  LL_DBGMCU_APB1_GRP1_FreezePeriph\n | ||||
|   *         DBGMCU_CR_APB1      DBG_CAN1_STOP           LL_DBGMCU_APB1_GRP1_FreezePeriph\n | ||||
|   *         DBGMCU_CR_APB1      DBG_CAN2_STOP           LL_DBGMCU_APB1_GRP1_FreezePeriph | ||||
|   * @param  Periphs This parameter can be a combination of the following values: | ||||
|   *         @arg @ref LL_DBGMCU_APB1_GRP1_TIM2_STOP | ||||
|   *         @arg @ref LL_DBGMCU_APB1_GRP1_TIM3_STOP | ||||
|   *         @arg @ref LL_DBGMCU_APB1_GRP1_TIM4_STOP | ||||
|   *         @arg @ref LL_DBGMCU_APB1_GRP1_TIM5_STOP | ||||
|   *         @arg @ref LL_DBGMCU_APB1_GRP1_TIM6_STOP | ||||
|   *         @arg @ref LL_DBGMCU_APB1_GRP1_TIM7_STOP | ||||
|   *         @arg @ref LL_DBGMCU_APB1_GRP1_TIM12_STOP | ||||
|   *         @arg @ref LL_DBGMCU_APB1_GRP1_TIM13_STOP | ||||
|   *         @arg @ref LL_DBGMCU_APB1_GRP1_TIM14_STOP | ||||
|   *         @arg @ref LL_DBGMCU_APB1_GRP1_WWDG_STOP | ||||
|   *         @arg @ref LL_DBGMCU_APB1_GRP1_IWDG_STOP | ||||
|   *         @arg @ref LL_DBGMCU_APB1_GRP1_I2C1_STOP | ||||
|   *         @arg @ref LL_DBGMCU_APB1_GRP1_I2C2_STOP (*) | ||||
|   *         @arg @ref LL_DBGMCU_APB1_GRP1_CAN1_STOP (*) | ||||
|   *         @arg @ref LL_DBGMCU_APB1_GRP1_CAN2_STOP (*) | ||||
|   * | ||||
|   *         (*) value not defined in all devices. | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_DBGMCU_APB1_GRP1_FreezePeriph(uint32_t Periphs) | ||||
| { | ||||
|   SET_BIT(DBGMCU->CR, Periphs); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Unfreeze APB1 peripherals (group1 peripherals) | ||||
|   * @rmtoll DBGMCU_CR_APB1      DBG_TIM2_STOP           LL_DBGMCU_APB1_GRP1_UnFreezePeriph\n | ||||
|   *         DBGMCU_CR_APB1      DBG_TIM3_STOP           LL_DBGMCU_APB1_GRP1_UnFreezePeriph\n | ||||
|   *         DBGMCU_CR_APB1      DBG_TIM4_STOP           LL_DBGMCU_APB1_GRP1_UnFreezePeriph\n | ||||
|   *         DBGMCU_CR_APB1      DBG_TIM5_STOP           LL_DBGMCU_APB1_GRP1_UnFreezePeriph\n | ||||
|   *         DBGMCU_CR_APB1      DBG_TIM6_STOP           LL_DBGMCU_APB1_GRP1_UnFreezePeriph\n | ||||
|   *         DBGMCU_CR_APB1      DBG_TIM7_STOP           LL_DBGMCU_APB1_GRP1_UnFreezePeriph\n | ||||
|   *         DBGMCU_CR_APB1      DBG_TIM12_STOP          LL_DBGMCU_APB1_GRP1_UnFreezePeriph\n | ||||
|   *         DBGMCU_CR_APB1      DBG_TIM13_STOP          LL_DBGMCU_APB1_GRP1_UnFreezePeriph\n | ||||
|   *         DBGMCU_CR_APB1      DBG_TIM14_STOP          LL_DBGMCU_APB1_GRP1_UnFreezePeriph\n | ||||
|   *         DBGMCU_CR_APB1      DBG_RTC_STOP            LL_DBGMCU_APB1_GRP1_UnFreezePeriph\n | ||||
|   *         DBGMCU_CR_APB1      DBG_WWDG_STOP           LL_DBGMCU_APB1_GRP1_UnFreezePeriph\n | ||||
|   *         DBGMCU_CR_APB1      DBG_IWDG_STOP           LL_DBGMCU_APB1_GRP1_UnFreezePeriph\n | ||||
|   *         DBGMCU_CR_APB1      DBG_I2C1_SMBUS_TIMEOUT  LL_DBGMCU_APB1_GRP1_UnFreezePeriph\n | ||||
|   *         DBGMCU_CR_APB1      DBG_I2C2_SMBUS_TIMEOUT  LL_DBGMCU_APB1_GRP1_UnFreezePeriph\n | ||||
|   *         DBGMCU_CR_APB1      DBG_CAN1_STOP           LL_DBGMCU_APB1_GRP1_UnFreezePeriph\n | ||||
|   *         DBGMCU_CR_APB1      DBG_CAN2_STOP           LL_DBGMCU_APB1_GRP1_UnFreezePeriph | ||||
|   * @param  Periphs This parameter can be a combination of the following values: | ||||
|   *         @arg @ref LL_DBGMCU_APB1_GRP1_TIM2_STOP | ||||
|   *         @arg @ref LL_DBGMCU_APB1_GRP1_TIM3_STOP | ||||
|   *         @arg @ref LL_DBGMCU_APB1_GRP1_TIM4_STOP | ||||
|   *         @arg @ref LL_DBGMCU_APB1_GRP1_TIM5_STOP | ||||
|   *         @arg @ref LL_DBGMCU_APB1_GRP1_TIM6_STOP | ||||
|   *         @arg @ref LL_DBGMCU_APB1_GRP1_TIM7_STOP | ||||
|   *         @arg @ref LL_DBGMCU_APB1_GRP1_TIM12_STOP | ||||
|   *         @arg @ref LL_DBGMCU_APB1_GRP1_TIM13_STOP | ||||
|   *         @arg @ref LL_DBGMCU_APB1_GRP1_TIM14_STOP | ||||
|   *         @arg @ref LL_DBGMCU_APB1_GRP1_RTC_STOP | ||||
|   *         @arg @ref LL_DBGMCU_APB1_GRP1_WWDG_STOP | ||||
|   *         @arg @ref LL_DBGMCU_APB1_GRP1_IWDG_STOP | ||||
|   *         @arg @ref LL_DBGMCU_APB1_GRP1_I2C1_STOP | ||||
|   *         @arg @ref LL_DBGMCU_APB1_GRP1_I2C2_STOP (*) | ||||
|   *         @arg @ref LL_DBGMCU_APB1_GRP1_CAN1_STOP (*) | ||||
|   *         @arg @ref LL_DBGMCU_APB1_GRP1_CAN2_STOP (*) | ||||
|   * | ||||
|   *         (*) value not defined in all devices. | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_DBGMCU_APB1_GRP1_UnFreezePeriph(uint32_t Periphs) | ||||
| { | ||||
|   CLEAR_BIT(DBGMCU->CR, Periphs); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Freeze APB2 peripherals | ||||
|   * @rmtoll DBGMCU_CR_APB2      DBG_TIM1_STOP    LL_DBGMCU_APB2_GRP1_FreezePeriph\n | ||||
|   *         DBGMCU_CR_APB2      DBG_TIM8_STOP    LL_DBGMCU_APB2_GRP1_FreezePeriph\n | ||||
|   *         DBGMCU_CR_APB2      DBG_TIM9_STOP    LL_DBGMCU_APB2_GRP1_FreezePeriph\n | ||||
|   *         DBGMCU_CR_APB2      DBG_TIM10_STOP   LL_DBGMCU_APB2_GRP1_FreezePeriph\n | ||||
|   *         DBGMCU_CR_APB2      DBG_TIM11_STOP   LL_DBGMCU_APB2_GRP1_FreezePeriph\n | ||||
|   *         DBGMCU_CR_APB2      DBG_TIM15_STOP   LL_DBGMCU_APB2_GRP1_FreezePeriph\n | ||||
|   *         DBGMCU_CR_APB2      DBG_TIM16_STOP   LL_DBGMCU_APB2_GRP1_FreezePeriph\n | ||||
|   *         DBGMCU_CR_APB2      DBG_TIM17_STOP   LL_DBGMCU_APB2_GRP1_FreezePeriph | ||||
|   * @param  Periphs This parameter can be a combination of the following values: | ||||
|   *         @arg @ref LL_DBGMCU_APB2_GRP1_TIM1_STOP | ||||
|   *         @arg @ref LL_DBGMCU_APB2_GRP1_TIM8_STOP (*) | ||||
|   *         @arg @ref LL_DBGMCU_APB2_GRP1_TIM9_STOP (*) | ||||
|   *         @arg @ref LL_DBGMCU_APB2_GRP1_TIM10_STOP (*) | ||||
|   *         @arg @ref LL_DBGMCU_APB2_GRP1_TIM11_STOP (*) | ||||
|   *         @arg @ref LL_DBGMCU_APB2_GRP1_TIM15_STOP (*) | ||||
|   *         @arg @ref LL_DBGMCU_APB2_GRP1_TIM16_STOP (*) | ||||
|   *         @arg @ref LL_DBGMCU_APB2_GRP1_TIM17_STOP (*) | ||||
|   * | ||||
|   *         (*) value not defined in all devices. | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_DBGMCU_APB2_GRP1_FreezePeriph(uint32_t Periphs) | ||||
| { | ||||
|   SET_BIT(DBGMCU->CR, Periphs); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Unfreeze APB2 peripherals | ||||
|   * @rmtoll DBGMCU_CR_APB2      DBG_TIM1_STOP    LL_DBGMCU_APB2_GRP1_FreezePeriph\n | ||||
|   *         DBGMCU_CR_APB2      DBG_TIM8_STOP    LL_DBGMCU_APB2_GRP1_FreezePeriph\n | ||||
|   *         DBGMCU_CR_APB2      DBG_TIM9_STOP    LL_DBGMCU_APB2_GRP1_FreezePeriph\n | ||||
|   *         DBGMCU_CR_APB2      DBG_TIM10_STOP   LL_DBGMCU_APB2_GRP1_FreezePeriph\n | ||||
|   *         DBGMCU_CR_APB2      DBG_TIM11_STOP   LL_DBGMCU_APB2_GRP1_FreezePeriph\n | ||||
|   *         DBGMCU_CR_APB2      DBG_TIM15_STOP   LL_DBGMCU_APB2_GRP1_FreezePeriph\n | ||||
|   *         DBGMCU_CR_APB2      DBG_TIM16_STOP   LL_DBGMCU_APB2_GRP1_FreezePeriph\n | ||||
|   *         DBGMCU_CR_APB2      DBG_TIM17_STOP   LL_DBGMCU_APB2_GRP1_FreezePeriph | ||||
|   * @param  Periphs This parameter can be a combination of the following values: | ||||
|   *         @arg @ref LL_DBGMCU_APB2_GRP1_TIM1_STOP | ||||
|   *         @arg @ref LL_DBGMCU_APB2_GRP1_TIM8_STOP (*) | ||||
|   *         @arg @ref LL_DBGMCU_APB2_GRP1_TIM9_STOP (*) | ||||
|   *         @arg @ref LL_DBGMCU_APB2_GRP1_TIM10_STOP (*) | ||||
|   *         @arg @ref LL_DBGMCU_APB2_GRP1_TIM11_STOP (*) | ||||
|   *         @arg @ref LL_DBGMCU_APB2_GRP1_TIM15_STOP (*) | ||||
|   *         @arg @ref LL_DBGMCU_APB2_GRP1_TIM16_STOP (*) | ||||
|   *         @arg @ref LL_DBGMCU_APB2_GRP1_TIM17_STOP (*) | ||||
|   * | ||||
|   *         (*) value not defined in all devices. | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_DBGMCU_APB2_GRP1_UnFreezePeriph(uint32_t Periphs) | ||||
| { | ||||
|   CLEAR_BIT(DBGMCU->CR, Periphs); | ||||
| } | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| #if defined(FLASH_ACR_LATENCY) | ||||
| /** @defgroup SYSTEM_LL_EF_FLASH FLASH
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Set FLASH Latency | ||||
|   * @rmtoll FLASH_ACR    LATENCY       LL_FLASH_SetLatency | ||||
|   * @param  Latency This parameter can be one of the following values: | ||||
|   *         @arg @ref LL_FLASH_LATENCY_0 | ||||
|   *         @arg @ref LL_FLASH_LATENCY_1 | ||||
|   *         @arg @ref LL_FLASH_LATENCY_2 | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_FLASH_SetLatency(uint32_t Latency) | ||||
| { | ||||
|   MODIFY_REG(FLASH->ACR, FLASH_ACR_LATENCY, Latency); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Get FLASH Latency | ||||
|   * @rmtoll FLASH_ACR    LATENCY       LL_FLASH_GetLatency | ||||
|   * @retval Returned value can be one of the following values: | ||||
|   *         @arg @ref LL_FLASH_LATENCY_0 | ||||
|   *         @arg @ref LL_FLASH_LATENCY_1 | ||||
|   *         @arg @ref LL_FLASH_LATENCY_2 | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_FLASH_GetLatency(void) | ||||
| { | ||||
|   return (uint32_t)(READ_BIT(FLASH->ACR, FLASH_ACR_LATENCY)); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enable Prefetch | ||||
|   * @rmtoll FLASH_ACR    PRFTBE        LL_FLASH_EnablePrefetch | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_FLASH_EnablePrefetch(void) | ||||
| { | ||||
|   SET_BIT(FLASH->ACR, FLASH_ACR_PRFTBE); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Disable Prefetch | ||||
|   * @rmtoll FLASH_ACR    PRFTBE        LL_FLASH_DisablePrefetch | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_FLASH_DisablePrefetch(void) | ||||
| { | ||||
|   CLEAR_BIT(FLASH->ACR, FLASH_ACR_PRFTBE); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Check if Prefetch buffer is enabled | ||||
|   * @rmtoll FLASH_ACR    PRFTBS        LL_FLASH_IsPrefetchEnabled | ||||
|   * @retval State of bit (1 or 0). | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_FLASH_IsPrefetchEnabled(void) | ||||
| { | ||||
|   return (READ_BIT(FLASH->ACR, FLASH_ACR_PRFTBS) == (FLASH_ACR_PRFTBS)); | ||||
| } | ||||
| 
 | ||||
| #endif /* FLASH_ACR_LATENCY */ | ||||
| /**
 | ||||
|   * @brief  Enable Flash Half Cycle Access | ||||
|   * @rmtoll FLASH_ACR    HLFCYA        LL_FLASH_EnableHalfCycleAccess | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_FLASH_EnableHalfCycleAccess(void) | ||||
| { | ||||
|   SET_BIT(FLASH->ACR, FLASH_ACR_HLFCYA); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Disable Flash Half Cycle Access | ||||
|   * @rmtoll FLASH_ACR    HLFCYA        LL_FLASH_DisableHalfCycleAccess | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_FLASH_DisableHalfCycleAccess(void) | ||||
| { | ||||
|   CLEAR_BIT(FLASH->ACR, FLASH_ACR_HLFCYA); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Check if  Flash Half Cycle Access is enabled or not | ||||
|   * @rmtoll FLASH_ACR    HLFCYA        LL_FLASH_IsHalfCycleAccessEnabled | ||||
|   * @retval State of bit (1 or 0). | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_FLASH_IsHalfCycleAccessEnabled(void) | ||||
| { | ||||
|   return (READ_BIT(FLASH->ACR, FLASH_ACR_HLFCYA) == (FLASH_ACR_HLFCYA)); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| #endif /* defined (FLASH) || defined (DBGMCU) */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif /* __STM32F1xx_LL_SYSTEM_H */ | ||||
| 
 | ||||
| 
 | ||||
							
								
								
									
										3901
									
								
								Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_ll_tim.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										3901
									
								
								Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_ll_tim.h
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										270
									
								
								Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_ll_utils.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										270
									
								
								Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_ll_utils.h
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,270 @@ | ||||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32f1xx_ll_utils.h | ||||
|   * @author  MCD Application Team | ||||
|   * @brief   Header file of UTILS LL module. | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * Copyright (c) 2016 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. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   @verbatim | ||||
|   ============================================================================== | ||||
|                      ##### How to use this driver ##### | ||||
|   ============================================================================== | ||||
|     [..] | ||||
|     The LL UTILS driver contains a set of generic APIs that can be | ||||
|     used by user: | ||||
|       (+) Device electronic signature | ||||
|       (+) Timing functions | ||||
|       (+) PLL configuration functions | ||||
| 
 | ||||
|   @endverbatim | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef __STM32F1xx_LL_UTILS_H | ||||
| #define __STM32F1xx_LL_UTILS_H | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32f1xx.h" | ||||
| 
 | ||||
| /** @addtogroup STM32F1xx_LL_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup UTILS_LL UTILS
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /* Private types -------------------------------------------------------------*/ | ||||
| /* Private variables ---------------------------------------------------------*/ | ||||
| 
 | ||||
| /* Private constants ---------------------------------------------------------*/ | ||||
| /** @defgroup UTILS_LL_Private_Constants UTILS Private Constants
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /* Max delay can be used in LL_mDelay */ | ||||
| #define LL_MAX_DELAY                  0xFFFFFFFFU | ||||
| 
 | ||||
| /**
 | ||||
|  * @brief Unique device ID register base address | ||||
|  */ | ||||
| #define UID_BASE_ADDRESS              UID_BASE | ||||
| 
 | ||||
| /**
 | ||||
|  * @brief Flash size data register base address | ||||
|  */ | ||||
| #define FLASHSIZE_BASE_ADDRESS        FLASHSIZE_BASE | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /* Private macros ------------------------------------------------------------*/ | ||||
| /** @defgroup UTILS_LL_Private_Macros UTILS Private Macros
 | ||||
|   * @{ | ||||
|   */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| /* Exported types ------------------------------------------------------------*/ | ||||
| /** @defgroup UTILS_LL_ES_INIT UTILS Exported structures
 | ||||
|   * @{ | ||||
|   */ | ||||
| /**
 | ||||
|   * @brief  UTILS PLL structure definition | ||||
|   */ | ||||
| typedef struct | ||||
| { | ||||
|   uint32_t PLLMul;   /*!< Multiplication factor for PLL VCO input clock.
 | ||||
|                           This parameter can be a value of @ref RCC_LL_EC_PLL_MUL | ||||
| 
 | ||||
|                           This feature can be modified afterwards using unitary function | ||||
|                           @ref LL_RCC_PLL_ConfigDomain_SYS(). */ | ||||
| 
 | ||||
|   uint32_t Prediv;   /*!< Division factor for HSE used as PLL clock source.
 | ||||
|                           This parameter can be a value of @ref RCC_LL_EC_PREDIV_DIV | ||||
| 
 | ||||
|                           This feature can be modified afterwards using unitary function | ||||
|                           @ref LL_RCC_PLL_ConfigDomain_SYS(). */ | ||||
| } LL_UTILS_PLLInitTypeDef; | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  UTILS System, AHB and APB buses clock configuration structure definition | ||||
|   */ | ||||
| typedef struct | ||||
| { | ||||
|   uint32_t AHBCLKDivider;         /*!< The AHB clock (HCLK) divider. This clock is derived from the system clock (SYSCLK).
 | ||||
|                                        This parameter can be a value of @ref RCC_LL_EC_SYSCLK_DIV | ||||
| 
 | ||||
|                                        This feature can be modified afterwards using unitary function | ||||
|                                        @ref LL_RCC_SetAHBPrescaler(). */ | ||||
| 
 | ||||
|   uint32_t APB1CLKDivider;        /*!< The APB1 clock (PCLK1) divider. This clock is derived from the AHB clock (HCLK).
 | ||||
|                                        This parameter can be a value of @ref RCC_LL_EC_APB1_DIV | ||||
| 
 | ||||
|                                        This feature can be modified afterwards using unitary function | ||||
|                                        @ref LL_RCC_SetAPB1Prescaler(). */ | ||||
| 
 | ||||
|   uint32_t APB2CLKDivider;        /*!< The APB2 clock (PCLK2) divider. This clock is derived from the AHB clock (HCLK).
 | ||||
|                                        This parameter can be a value of @ref RCC_LL_EC_APB2_DIV | ||||
| 
 | ||||
|                                        This feature can be modified afterwards using unitary function | ||||
|                                        @ref LL_RCC_SetAPB2Prescaler(). */ | ||||
| 
 | ||||
| } LL_UTILS_ClkInitTypeDef; | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /* Exported constants --------------------------------------------------------*/ | ||||
| /** @defgroup UTILS_LL_Exported_Constants UTILS Exported Constants
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup UTILS_EC_HSE_BYPASS HSE Bypass activation
 | ||||
|   * @{ | ||||
|   */ | ||||
| #define LL_UTILS_HSEBYPASS_OFF        0x00000000U       /*!< HSE Bypass is not enabled                */ | ||||
| #define LL_UTILS_HSEBYPASS_ON         0x00000001U       /*!< HSE Bypass is enabled                    */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /* Exported macro ------------------------------------------------------------*/ | ||||
| 
 | ||||
| /* Exported functions --------------------------------------------------------*/ | ||||
| /** @defgroup UTILS_LL_Exported_Functions UTILS Exported Functions
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup UTILS_EF_DEVICE_ELECTRONIC_SIGNATURE DEVICE ELECTRONIC SIGNATURE
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Get Word0 of the unique device identifier (UID based on 96 bits) | ||||
|   * @retval UID[31:0] | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_GetUID_Word0(void) | ||||
| { | ||||
|   return (uint32_t)(READ_REG(*((uint32_t *)UID_BASE_ADDRESS))); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Get Word1 of the unique device identifier (UID based on 96 bits) | ||||
|   * @retval UID[63:32] | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_GetUID_Word1(void) | ||||
| { | ||||
|   return (uint32_t)(READ_REG(*((uint32_t *)(UID_BASE_ADDRESS + 4U)))); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Get Word2 of the unique device identifier (UID based on 96 bits) | ||||
|   * @retval UID[95:64] | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_GetUID_Word2(void) | ||||
| { | ||||
|   return (uint32_t)(READ_REG(*((uint32_t *)(UID_BASE_ADDRESS + 8U)))); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Get Flash memory size | ||||
|   * @note   This bitfield indicates the size of the device Flash memory expressed in | ||||
|   *         Kbytes. As an example, 0x040 corresponds to 64 Kbytes. | ||||
|   * @retval FLASH_SIZE[15:0]: Flash memory size | ||||
|   */ | ||||
| __STATIC_INLINE uint32_t LL_GetFlashSize(void) | ||||
| { | ||||
|   return (uint16_t)(READ_REG(*((uint32_t *)FLASHSIZE_BASE_ADDRESS))); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup UTILS_LL_EF_DELAY DELAY
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  This function configures the Cortex-M SysTick source of the time base. | ||||
|   * @param  HCLKFrequency HCLK frequency in Hz (can be calculated thanks to RCC helper macro) | ||||
|   * @note   When a RTOS is used, it is recommended to avoid changing the SysTick | ||||
|   *         configuration by calling this function, for a delay use rather osDelay RTOS service. | ||||
|   * @param  Ticks Frequency of Ticks (Hz) | ||||
|   * @retval None | ||||
|   */ | ||||
| __STATIC_INLINE void LL_InitTick(uint32_t HCLKFrequency, uint32_t Ticks) | ||||
| { | ||||
|   /* Configure the SysTick to have interrupt in 1ms time base */ | ||||
|   SysTick->LOAD  = (uint32_t)((HCLKFrequency / Ticks) - 1UL);  /* set reload register */ | ||||
|   SysTick->VAL   = 0UL;                                       /* Load the SysTick Counter Value */ | ||||
|   SysTick->CTRL  = SysTick_CTRL_CLKSOURCE_Msk | | ||||
|                    SysTick_CTRL_ENABLE_Msk;                   /* Enable the Systick Timer */ | ||||
| } | ||||
| 
 | ||||
| void        LL_Init1msTick(uint32_t HCLKFrequency); | ||||
| void        LL_mDelay(uint32_t Delay); | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup UTILS_EF_SYSTEM SYSTEM
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| void        LL_SetSystemCoreClock(uint32_t HCLKFrequency); | ||||
| #if defined(FLASH_ACR_LATENCY) | ||||
| ErrorStatus LL_SetFlashLatency(uint32_t Frequency); | ||||
| #endif /* FLASH_ACR_LATENCY */ | ||||
| ErrorStatus LL_PLL_ConfigSystemClock_HSI(LL_UTILS_PLLInitTypeDef *UTILS_PLLInitStruct, | ||||
|                                          LL_UTILS_ClkInitTypeDef *UTILS_ClkInitStruct); | ||||
| ErrorStatus LL_PLL_ConfigSystemClock_HSE(uint32_t HSEFrequency, uint32_t HSEBypass, | ||||
|                                          LL_UTILS_PLLInitTypeDef *UTILS_PLLInitStruct, LL_UTILS_ClkInitTypeDef *UTILS_ClkInitStruct); | ||||
| #if defined(RCC_PLL2_SUPPORT) | ||||
| ErrorStatus LL_PLL_ConfigSystemClock_PLL2(uint32_t HSEFrequency, uint32_t HSEBypass, LL_UTILS_PLLInitTypeDef *UTILS_PLLInitStruct, | ||||
|                                           LL_UTILS_PLLInitTypeDef *UTILS_PLL2InitStruct, LL_UTILS_ClkInitTypeDef *UTILS_ClkInitStruct); | ||||
| #endif /* RCC_PLL2_SUPPORT */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif /* __STM32F1xx_LL_UTILS_H */ | ||||
							
								
								
									
										6
									
								
								Drivers/STM32F1xx_HAL_Driver/LICENSE.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								Drivers/STM32F1xx_HAL_Driver/LICENSE.txt
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,6 @@ | ||||
| This software component is provided to you as part of a software package and | ||||
| applicable license terms are in the  Package_license file. If you received this | ||||
| software component outside of a package or without applicable license terms, | ||||
| the terms of the BSD-3-Clause license shall apply.  | ||||
| You may obtain a copy of the BSD-3-Clause at: | ||||
| https://opensource.org/licenses/BSD-3-Clause | ||||
| @ -5,6 +5,17 @@ | ||||
|   * @brief   HAL module driver. | ||||
|   *          This is the common part of the HAL initialization | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * Copyright (c) 2016 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. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   @verbatim | ||||
|   ============================================================================== | ||||
|                      ##### How to use this driver ##### | ||||
| @ -19,17 +30,6 @@ | ||||
| 
 | ||||
|   @endverbatim | ||||
|   ****************************************************************************** | ||||
|   * @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 | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| @ -53,11 +53,11 @@ | ||||
|   * @{ | ||||
|   */ | ||||
| /**
 | ||||
|  * @brief STM32F1xx HAL Driver version number V1.1.7 | ||||
|  * @brief STM32F1xx HAL Driver version number | ||||
|    */ | ||||
| #define __STM32F1xx_HAL_VERSION_MAIN   (0x01U) /*!< [31:24] main version */ | ||||
| #define __STM32F1xx_HAL_VERSION_SUB1   (0x01U) /*!< [23:16] sub1 version */ | ||||
| #define __STM32F1xx_HAL_VERSION_SUB2   (0x07U) /*!< [15:8]  sub2 version */ | ||||
| #define __STM32F1xx_HAL_VERSION_SUB2   (0x0AU) /*!< [15:8]  sub2 version */ | ||||
| #define __STM32F1xx_HAL_VERSION_RC     (0x00U) /*!< [7:0]  release candidate */ | ||||
| #define __STM32F1xx_HAL_VERSION         ((__STM32F1xx_HAL_VERSION_MAIN << 24)\ | ||||
|                                         |(__STM32F1xx_HAL_VERSION_SUB1 << 16)\ | ||||
| @ -349,7 +349,8 @@ HAL_StatusTypeDef HAL_SetTickFreq(HAL_TickFreqTypeDef Freq) | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief Return tick frequency. | ||||
|   * @retval tick period in Hz | ||||
|   * @retval Tick frequency. | ||||
|   *         Value of @ref HAL_TickFreqTypeDef. | ||||
|   */ | ||||
| HAL_TickFreqTypeDef HAL_GetTickFreq(void) | ||||
| { | ||||
| @ -603,4 +604,4 @@ void HAL_DBGMCU_DisableDBGStandbyMode(void) | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
| 
 | ||||
|  | ||||
| @ -12,6 +12,17 @@ | ||||
|   *           + Callbacks functions | ||||
|   *           + Peripheral State and Error functions | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * Copyright (c) 2016 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. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   @verbatim | ||||
|   ============================================================================== | ||||
|                         ##### How to use this driver ##### | ||||
| @ -22,7 +33,7 @@ | ||||
|          (++) Enable the CAN interface clock using __HAL_RCC_CANx_CLK_ENABLE() | ||||
|          (++) Configure CAN pins | ||||
|              (+++) Enable the clock for the CAN GPIOs | ||||
|              (+++) Configure CAN pins as alternate function open-drain | ||||
|              (+++) Configure CAN pins as alternate function | ||||
|          (++) In case of using interrupts (e.g. HAL_CAN_ActivateNotification()) | ||||
|              (+++) Configure the CAN interrupt priority using | ||||
|                    HAL_NVIC_SetPriority() | ||||
| @ -120,7 +131,7 @@ | ||||
|           submitted (the sleep mode is not yet entered), and become | ||||
|           HAL_CAN_STATE_SLEEP_ACTIVE when the sleep mode is effective. | ||||
| 
 | ||||
|       (#) The wake-up from sleep mode can be trigged by two ways: | ||||
|       (#) The wake-up from sleep mode can be triggered by two ways: | ||||
|             (++) Using HAL_CAN_WakeUp(). When returning from this function, | ||||
|                  the sleep mode is exited (if return status is HAL_OK). | ||||
|             (++) When a start of Rx CAN frame is detected by the CAN peripheral, | ||||
| @ -131,9 +142,9 @@ | ||||
| 
 | ||||
|   The compilation define  USE_HAL_CAN_REGISTER_CALLBACKS when set to 1 | ||||
|   allows the user to configure dynamically the driver callbacks. | ||||
|   Use Function @ref HAL_CAN_RegisterCallback() to register an interrupt callback. | ||||
|   Use Function HAL_CAN_RegisterCallback() to register an interrupt callback. | ||||
| 
 | ||||
|   Function @ref HAL_CAN_RegisterCallback() allows to register following callbacks: | ||||
|   Function HAL_CAN_RegisterCallback() allows to register following callbacks: | ||||
|     (+) TxMailbox0CompleteCallback   : Tx Mailbox 0 Complete Callback. | ||||
|     (+) TxMailbox1CompleteCallback   : Tx Mailbox 1 Complete Callback. | ||||
|     (+) TxMailbox2CompleteCallback   : Tx Mailbox 2 Complete Callback. | ||||
| @ -152,9 +163,9 @@ | ||||
|   This function takes as parameters the HAL peripheral handle, the Callback ID | ||||
|   and a pointer to the user callback function. | ||||
| 
 | ||||
|   Use function @ref HAL_CAN_UnRegisterCallback() to reset a callback to the default | ||||
|   Use function HAL_CAN_UnRegisterCallback() to reset a callback to the default | ||||
|   weak function. | ||||
|   @ref HAL_CAN_UnRegisterCallback takes as parameters the HAL peripheral handle, | ||||
|   HAL_CAN_UnRegisterCallback takes as parameters the HAL peripheral handle, | ||||
|   and the Callback ID. | ||||
|   This function allows to reset following callbacks: | ||||
|     (+) TxMailbox0CompleteCallback   : Tx Mailbox 0 Complete Callback. | ||||
| @ -173,13 +184,13 @@ | ||||
|     (+) MspInitCallback              : CAN MspInit. | ||||
|     (+) MspDeInitCallback            : CAN MspDeInit. | ||||
| 
 | ||||
|   By default, after the @ref HAL_CAN_Init() and when the state is HAL_CAN_STATE_RESET, | ||||
|   By default, after the HAL_CAN_Init() and when the state is HAL_CAN_STATE_RESET, | ||||
|   all callbacks are set to the corresponding weak functions: | ||||
|   example @ref HAL_CAN_ErrorCallback(). | ||||
|   example HAL_CAN_ErrorCallback(). | ||||
|   Exception done for MspInit and MspDeInit functions that are | ||||
|   reset to the legacy weak function in the @ref HAL_CAN_Init()/ @ref HAL_CAN_DeInit() only when | ||||
|   reset to the legacy weak function in the HAL_CAN_Init()/ HAL_CAN_DeInit() only when | ||||
|   these callbacks are null (not registered beforehand). | ||||
|   if not, MspInit or MspDeInit are not null, the @ref HAL_CAN_Init()/ @ref HAL_CAN_DeInit() | ||||
|   if not, MspInit or MspDeInit are not null, the HAL_CAN_Init()/ HAL_CAN_DeInit() | ||||
|   keep and use the user MspInit/MspDeInit callbacks (registered beforehand) | ||||
| 
 | ||||
|   Callbacks can be registered/unregistered in HAL_CAN_STATE_READY state only. | ||||
| @ -187,8 +198,8 @@ | ||||
|   in HAL_CAN_STATE_READY or HAL_CAN_STATE_RESET state, | ||||
|   thus registered (user) MspInit/DeInit callbacks can be used during the Init/DeInit. | ||||
|   In that case first register the MspInit/MspDeInit user callbacks | ||||
|   using @ref HAL_CAN_RegisterCallback() before calling @ref HAL_CAN_DeInit() | ||||
|   or @ref HAL_CAN_Init() function. | ||||
|   using HAL_CAN_RegisterCallback() before calling HAL_CAN_DeInit() | ||||
|   or HAL_CAN_Init() function. | ||||
| 
 | ||||
|   When The compilation define USE_HAL_CAN_REGISTER_CALLBACKS is set to 0 or | ||||
|   not defined, the callback registration feature is not available and all callbacks | ||||
| @ -196,17 +207,6 @@ | ||||
| 
 | ||||
|   @endverbatim | ||||
|   ****************************************************************************** | ||||
|   * @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 | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| @ -226,8 +226,8 @@ | ||||
| #ifdef HAL_CAN_MODULE_ENABLED | ||||
| 
 | ||||
| #ifdef HAL_CAN_LEGACY_MODULE_ENABLED | ||||
|   #error "The CAN driver cannot be used with its legacy, Please enable only one CAN module at once" | ||||
| #endif | ||||
| #error "The CAN driver cannot be used with its legacy, Please enable only one CAN module at once" | ||||
| #endif /* HAL_CAN_LEGACY_MODULE_ENABLED */ | ||||
| 
 | ||||
| /* Private typedef -----------------------------------------------------------*/ | ||||
| /* Private define ------------------------------------------------------------*/ | ||||
| @ -235,6 +235,7 @@ | ||||
|   * @{ | ||||
|   */ | ||||
| #define CAN_TIMEOUT_VALUE 10U | ||||
| #define CAN_WAKEUP_TIMEOUT_COUNTER 1000000U | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| @ -248,8 +249,8 @@ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup CAN_Exported_Functions_Group1 Initialization and de-initialization functions
 | ||||
|  *  @brief    Initialization and Configuration functions | ||||
|  * | ||||
|   * @brief    Initialization and Configuration functions | ||||
|   * | ||||
| @verbatim | ||||
|   ============================================================================== | ||||
|               ##### Initialization and de-initialization functions ##### | ||||
| @ -328,16 +329,16 @@ HAL_StatusTypeDef HAL_CAN_Init(CAN_HandleTypeDef *hcan) | ||||
|     /* Init the low level hardware: CLOCK, NVIC */ | ||||
|     HAL_CAN_MspInit(hcan); | ||||
|   } | ||||
| #endif /* (USE_HAL_CAN_REGISTER_CALLBACKS) */ | ||||
| #endif /* USE_HAL_CAN_REGISTER_CALLBACKS */ | ||||
| 
 | ||||
|   /* Exit from sleep mode */ | ||||
|   CLEAR_BIT(hcan->Instance->MCR, CAN_MCR_SLEEP); | ||||
|   /* Request initialisation */ | ||||
|   SET_BIT(hcan->Instance->MCR, CAN_MCR_INRQ); | ||||
| 
 | ||||
|   /* Get tick */ | ||||
|   tickstart = HAL_GetTick(); | ||||
| 
 | ||||
|   /* Check Sleep mode leave acknowledge */ | ||||
|   while ((hcan->Instance->MSR & CAN_MSR_SLAK) != 0U) | ||||
|   /* Wait initialisation acknowledge */ | ||||
|   while ((hcan->Instance->MSR & CAN_MSR_INAK) == 0U) | ||||
|   { | ||||
|     if ((HAL_GetTick() - tickstart) > CAN_TIMEOUT_VALUE) | ||||
|     { | ||||
| @ -351,14 +352,14 @@ HAL_StatusTypeDef HAL_CAN_Init(CAN_HandleTypeDef *hcan) | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   /* Request initialisation */ | ||||
|   SET_BIT(hcan->Instance->MCR, CAN_MCR_INRQ); | ||||
|   /* Exit from sleep mode */ | ||||
|   CLEAR_BIT(hcan->Instance->MCR, CAN_MCR_SLEEP); | ||||
| 
 | ||||
|   /* Get tick */ | ||||
|   tickstart = HAL_GetTick(); | ||||
| 
 | ||||
|   /* Wait initialisation acknowledge */ | ||||
|   while ((hcan->Instance->MSR & CAN_MSR_INAK) == 0U) | ||||
|   /* Check Sleep mode leave acknowledge */ | ||||
|   while ((hcan->Instance->MSR & CAN_MSR_SLAK) != 0U) | ||||
|   { | ||||
|     if ((HAL_GetTick() - tickstart) > CAN_TIMEOUT_VALUE) | ||||
|     { | ||||
| @ -482,7 +483,7 @@ HAL_StatusTypeDef HAL_CAN_DeInit(CAN_HandleTypeDef *hcan) | ||||
| #else | ||||
|   /* DeInit the low level hardware: CLOCK, NVIC */ | ||||
|   HAL_CAN_MspDeInit(hcan); | ||||
| #endif /* (USE_HAL_CAN_REGISTER_CALLBACKS) */ | ||||
| #endif /* USE_HAL_CAN_REGISTER_CALLBACKS */ | ||||
| 
 | ||||
|   /* Reset the CAN peripheral */ | ||||
|   SET_BIT(hcan->Instance->MCR, CAN_MCR_RESET); | ||||
| @ -537,25 +538,26 @@ __weak void HAL_CAN_MspDeInit(CAN_HandleTypeDef *hcan) | ||||
|   *         the configuration information for CAN module | ||||
|   * @param  CallbackID ID of the callback to be registered | ||||
|   *         This parameter can be one of the following values: | ||||
|   *           @arg @ref HAL_CAN_TX_MAILBOX0_COMPLETE_CALLBACK_CB_ID Tx Mailbox 0 Complete callback ID | ||||
|   *           @arg @ref HAL_CAN_TX_MAILBOX1_COMPLETE_CALLBACK_CB_ID Tx Mailbox 1 Complete callback ID | ||||
|   *           @arg @ref HAL_CAN_TX_MAILBOX2_COMPLETE_CALLBACK_CB_ID Tx Mailbox 2 Complete callback ID | ||||
|   *           @arg @ref HAL_CAN_TX_MAILBOX0_ABORT_CALLBACK_CB_ID Tx Mailbox 0 Abort callback ID | ||||
|   *           @arg @ref HAL_CAN_TX_MAILBOX1_ABORT_CALLBACK_CB_ID Tx Mailbox 1 Abort callback ID | ||||
|   *           @arg @ref HAL_CAN_TX_MAILBOX2_ABORT_CALLBACK_CB_ID Tx Mailbox 2 Abort callback ID | ||||
|   *           @arg @ref HAL_CAN_RX_FIFO0_MSG_PENDING_CALLBACK_CB_ID Rx Fifo 0 message pending callback ID | ||||
|   *           @arg @ref HAL_CAN_RX_FIFO0_FULL_CALLBACK_CB_ID Rx Fifo 0 full callback ID | ||||
|   *           @arg @ref HAL_CAN_RX_FIFO1_MSGPENDING_CALLBACK_CB_ID Rx Fifo 1 message pending callback ID | ||||
|   *           @arg @ref HAL_CAN_RX_FIFO1_FULL_CALLBACK_CB_ID Rx Fifo 1 full callback ID | ||||
|   *           @arg @ref HAL_CAN_SLEEP_CALLBACK_CB_ID Sleep callback ID | ||||
|   *           @arg @ref HAL_CAN_WAKEUP_FROM_RX_MSG_CALLBACK_CB_ID Wake Up from Rx message callback ID | ||||
|   *           @arg @ref HAL_CAN_ERROR_CALLBACK_CB_ID Error callback ID | ||||
|   *           @arg @ref HAL_CAN_TX_MAILBOX0_COMPLETE_CB_ID Tx Mailbox 0 Complete callback ID | ||||
|   *           @arg @ref HAL_CAN_TX_MAILBOX1_COMPLETE_CB_ID Tx Mailbox 1 Complete callback ID | ||||
|   *           @arg @ref HAL_CAN_TX_MAILBOX2_COMPLETE_CB_ID Tx Mailbox 2 Complete callback ID | ||||
|   *           @arg @ref HAL_CAN_TX_MAILBOX0_ABORT_CB_ID Tx Mailbox 0 Abort callback ID | ||||
|   *           @arg @ref HAL_CAN_TX_MAILBOX1_ABORT_CB_ID Tx Mailbox 1 Abort callback ID | ||||
|   *           @arg @ref HAL_CAN_TX_MAILBOX2_ABORT_CB_ID Tx Mailbox 2 Abort callback ID | ||||
|   *           @arg @ref HAL_CAN_RX_FIFO0_MSG_PENDING_CB_ID Rx Fifo 0 message pending callback ID | ||||
|   *           @arg @ref HAL_CAN_RX_FIFO0_FULL_CB_ID Rx Fifo 0 full callback ID | ||||
|   *           @arg @ref HAL_CAN_RX_FIFO1_MSG_PENDING_CB_ID Rx Fifo 1 message pending callback ID | ||||
|   *           @arg @ref HAL_CAN_RX_FIFO1_FULL_CB_ID Rx Fifo 1 full callback ID | ||||
|   *           @arg @ref HAL_CAN_SLEEP_CB_ID Sleep callback ID | ||||
|   *           @arg @ref HAL_CAN_WAKEUP_FROM_RX_MSG_CB_ID Wake Up from Rx message callback ID | ||||
|   *           @arg @ref HAL_CAN_ERROR_CB_ID Error callback ID | ||||
|   *           @arg @ref HAL_CAN_MSPINIT_CB_ID MspInit callback ID | ||||
|   *           @arg @ref HAL_CAN_MSPDEINIT_CB_ID MspDeInit callback ID | ||||
|   * @param  pCallback pointer to the Callback function | ||||
|   * @retval HAL status | ||||
|   */ | ||||
| HAL_StatusTypeDef HAL_CAN_RegisterCallback(CAN_HandleTypeDef *hcan, HAL_CAN_CallbackIDTypeDef CallbackID, void (* pCallback)(CAN_HandleTypeDef *_hcan)) | ||||
| HAL_StatusTypeDef HAL_CAN_RegisterCallback(CAN_HandleTypeDef *hcan, HAL_CAN_CallbackIDTypeDef CallbackID, | ||||
|                                            void (* pCallback)(CAN_HandleTypeDef *_hcan)) | ||||
| { | ||||
|   HAL_StatusTypeDef status = HAL_OK; | ||||
| 
 | ||||
| @ -675,24 +677,24 @@ HAL_StatusTypeDef HAL_CAN_RegisterCallback(CAN_HandleTypeDef *hcan, HAL_CAN_Call | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Unregister a CAN CallBack. | ||||
|   *         CAN callabck is redirected to the weak predefined callback | ||||
|   *         CAN callback is redirected to the weak predefined callback | ||||
|   * @param  hcan pointer to a CAN_HandleTypeDef structure that contains | ||||
|   *         the configuration information for CAN module | ||||
|   * @param  CallbackID ID of the callback to be unregistered | ||||
|   *         This parameter can be one of the following values: | ||||
|   *           @arg @ref HAL_CAN_TX_MAILBOX0_COMPLETE_CALLBACK_CB_ID Tx Mailbox 0 Complete callback ID | ||||
|   *           @arg @ref HAL_CAN_TX_MAILBOX1_COMPLETE_CALLBACK_CB_ID Tx Mailbox 1 Complete callback ID | ||||
|   *           @arg @ref HAL_CAN_TX_MAILBOX2_COMPLETE_CALLBACK_CB_ID Tx Mailbox 2 Complete callback ID | ||||
|   *           @arg @ref HAL_CAN_TX_MAILBOX0_ABORT_CALLBACK_CB_ID Tx Mailbox 0 Abort callback ID | ||||
|   *           @arg @ref HAL_CAN_TX_MAILBOX1_ABORT_CALLBACK_CB_ID Tx Mailbox 1 Abort callback ID | ||||
|   *           @arg @ref HAL_CAN_TX_MAILBOX2_ABORT_CALLBACK_CB_ID Tx Mailbox 2 Abort callback ID | ||||
|   *           @arg @ref HAL_CAN_RX_FIFO0_MSG_PENDING_CALLBACK_CB_ID Rx Fifo 0 message pending callback ID | ||||
|   *           @arg @ref HAL_CAN_RX_FIFO0_FULL_CALLBACK_CB_ID Rx Fifo 0 full callback ID | ||||
|   *           @arg @ref HAL_CAN_RX_FIFO1_MSGPENDING_CALLBACK_CB_ID Rx Fifo 1 message pending callback ID | ||||
|   *           @arg @ref HAL_CAN_RX_FIFO1_FULL_CALLBACK_CB_ID Rx Fifo 1 full callback ID | ||||
|   *           @arg @ref HAL_CAN_SLEEP_CALLBACK_CB_ID Sleep callback ID | ||||
|   *           @arg @ref HAL_CAN_WAKEUP_FROM_RX_MSG_CALLBACK_CB_ID Wake Up from Rx message callback ID | ||||
|   *           @arg @ref HAL_CAN_ERROR_CALLBACK_CB_ID Error callback ID | ||||
|   *           @arg @ref HAL_CAN_TX_MAILBOX0_COMPLETE_CB_ID Tx Mailbox 0 Complete callback ID | ||||
|   *           @arg @ref HAL_CAN_TX_MAILBOX1_COMPLETE_CB_ID Tx Mailbox 1 Complete callback ID | ||||
|   *           @arg @ref HAL_CAN_TX_MAILBOX2_COMPLETE_CB_ID Tx Mailbox 2 Complete callback ID | ||||
|   *           @arg @ref HAL_CAN_TX_MAILBOX0_ABORT_CB_ID Tx Mailbox 0 Abort callback ID | ||||
|   *           @arg @ref HAL_CAN_TX_MAILBOX1_ABORT_CB_ID Tx Mailbox 1 Abort callback ID | ||||
|   *           @arg @ref HAL_CAN_TX_MAILBOX2_ABORT_CB_ID Tx Mailbox 2 Abort callback ID | ||||
|   *           @arg @ref HAL_CAN_RX_FIFO0_MSG_PENDING_CB_ID Rx Fifo 0 message pending callback ID | ||||
|   *           @arg @ref HAL_CAN_RX_FIFO0_FULL_CB_ID Rx Fifo 0 full callback ID | ||||
|   *           @arg @ref HAL_CAN_RX_FIFO1_MSG_PENDING_CB_ID Rx Fifo 1 message pending callback ID | ||||
|   *           @arg @ref HAL_CAN_RX_FIFO1_FULL_CB_ID Rx Fifo 1 full callback ID | ||||
|   *           @arg @ref HAL_CAN_SLEEP_CB_ID Sleep callback ID | ||||
|   *           @arg @ref HAL_CAN_WAKEUP_FROM_RX_MSG_CB_ID Wake Up from Rx message callback ID | ||||
|   *           @arg @ref HAL_CAN_ERROR_CB_ID Error callback ID | ||||
|   *           @arg @ref HAL_CAN_MSPINIT_CB_ID MspInit callback ID | ||||
|   *           @arg @ref HAL_CAN_MSPDEINIT_CB_ID MspDeInit callback ID | ||||
|   * @retval HAL status | ||||
| @ -813,8 +815,8 @@ HAL_StatusTypeDef HAL_CAN_UnRegisterCallback(CAN_HandleTypeDef *hcan, HAL_CAN_Ca | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup CAN_Exported_Functions_Group2 Configuration functions
 | ||||
|  *  @brief    Configuration functions. | ||||
|  * | ||||
|   * @brief    Configuration functions. | ||||
|   * | ||||
| @verbatim | ||||
|   ============================================================================== | ||||
|               ##### Configuration functions ##### | ||||
| @ -835,7 +837,7 @@ HAL_StatusTypeDef HAL_CAN_UnRegisterCallback(CAN_HandleTypeDef *hcan, HAL_CAN_Ca | ||||
|   *         contains the filter configuration information. | ||||
|   * @retval None | ||||
|   */ | ||||
| HAL_StatusTypeDef HAL_CAN_ConfigFilter(CAN_HandleTypeDef *hcan, CAN_FilterTypeDef *sFilterConfig) | ||||
| HAL_StatusTypeDef HAL_CAN_ConfigFilter(CAN_HandleTypeDef *hcan, const CAN_FilterTypeDef *sFilterConfig) | ||||
| { | ||||
|   uint32_t filternbrbitpos; | ||||
|   CAN_TypeDef *can_ip = hcan->Instance; | ||||
| @ -867,7 +869,7 @@ HAL_StatusTypeDef HAL_CAN_ConfigFilter(CAN_HandleTypeDef *hcan, CAN_FilterTypeDe | ||||
| 
 | ||||
|     /* Check the parameters */ | ||||
|     assert_param(IS_CAN_FILTER_BANK_SINGLE(sFilterConfig->FilterBank)); | ||||
| #endif | ||||
| #endif /* CAN3 */ | ||||
| 
 | ||||
|     /* Initialisation mode for the filter */ | ||||
|     SET_BIT(can_ip->FMR, CAN_FMR_FINIT); | ||||
| @ -877,7 +879,7 @@ HAL_StatusTypeDef HAL_CAN_ConfigFilter(CAN_HandleTypeDef *hcan, CAN_FilterTypeDe | ||||
|     CLEAR_BIT(can_ip->FMR, CAN_FMR_CAN2SB); | ||||
|     SET_BIT(can_ip->FMR, sFilterConfig->SlaveStartFilterBank << CAN_FMR_CAN2SB_Pos); | ||||
| 
 | ||||
| #endif | ||||
| #endif /* CAN3 */ | ||||
|     /* Convert filter number into bit position */ | ||||
|     filternbrbitpos = (uint32_t)1 << (sFilterConfig->FilterBank & 0x1FU); | ||||
| 
 | ||||
| @ -969,8 +971,8 @@ HAL_StatusTypeDef HAL_CAN_ConfigFilter(CAN_HandleTypeDef *hcan, CAN_FilterTypeDe | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup CAN_Exported_Functions_Group3 Control functions
 | ||||
|  *  @brief    Control functions | ||||
|  * | ||||
|   * @brief    Control functions | ||||
|   * | ||||
| @verbatim | ||||
|   ============================================================================== | ||||
|                       ##### Control functions ##### | ||||
| @ -1142,7 +1144,6 @@ HAL_StatusTypeDef HAL_CAN_RequestSleep(CAN_HandleTypeDef *hcan) | ||||
| HAL_StatusTypeDef HAL_CAN_WakeUp(CAN_HandleTypeDef *hcan) | ||||
| { | ||||
|   __IO uint32_t count = 0; | ||||
|   uint32_t timeout = 1000000U; | ||||
|   HAL_CAN_StateTypeDef state = hcan->State; | ||||
| 
 | ||||
|   if ((state == HAL_CAN_STATE_READY) || | ||||
| @ -1158,15 +1159,14 @@ HAL_StatusTypeDef HAL_CAN_WakeUp(CAN_HandleTypeDef *hcan) | ||||
|       count++; | ||||
| 
 | ||||
|       /* Check if timeout is reached */ | ||||
|       if (count > timeout) | ||||
|       if (count > CAN_WAKEUP_TIMEOUT_COUNTER) | ||||
|       { | ||||
|         /* Update error code */ | ||||
|         hcan->ErrorCode |= HAL_CAN_ERROR_TIMEOUT; | ||||
| 
 | ||||
|         return HAL_ERROR; | ||||
|       } | ||||
|     } | ||||
|     while ((hcan->Instance->MSR & CAN_MSR_SLAK) != 0U); | ||||
|     } while ((hcan->Instance->MSR & CAN_MSR_SLAK) != 0U); | ||||
| 
 | ||||
|     /* Return function status */ | ||||
|     return HAL_OK; | ||||
| @ -1188,7 +1188,7 @@ HAL_StatusTypeDef HAL_CAN_WakeUp(CAN_HandleTypeDef *hcan) | ||||
|   *          - 0 : Sleep mode is not active. | ||||
|   *          - 1 : Sleep mode is active. | ||||
|   */ | ||||
| uint32_t HAL_CAN_IsSleepActive(CAN_HandleTypeDef *hcan) | ||||
| uint32_t HAL_CAN_IsSleepActive(const CAN_HandleTypeDef *hcan) | ||||
| { | ||||
|   uint32_t status = 0U; | ||||
|   HAL_CAN_StateTypeDef state = hcan->State; | ||||
| @ -1219,7 +1219,8 @@ uint32_t HAL_CAN_IsSleepActive(CAN_HandleTypeDef *hcan) | ||||
|   *         This parameter can be a value of @arg CAN_Tx_Mailboxes. | ||||
|   * @retval HAL status | ||||
|   */ | ||||
| HAL_StatusTypeDef HAL_CAN_AddTxMessage(CAN_HandleTypeDef *hcan, CAN_TxHeaderTypeDef *pHeader, uint8_t aData[], uint32_t *pTxMailbox) | ||||
| HAL_StatusTypeDef HAL_CAN_AddTxMessage(CAN_HandleTypeDef *hcan, const CAN_TxHeaderTypeDef *pHeader, | ||||
|                                        const uint8_t aData[], uint32_t *pTxMailbox) | ||||
| { | ||||
|   uint32_t transmitmailbox; | ||||
|   HAL_CAN_StateTypeDef state = hcan->State; | ||||
| @ -1250,15 +1251,6 @@ HAL_StatusTypeDef HAL_CAN_AddTxMessage(CAN_HandleTypeDef *hcan, CAN_TxHeaderType | ||||
|       /* Select an empty transmit mailbox */ | ||||
|       transmitmailbox = (tsr & CAN_TSR_CODE) >> CAN_TSR_CODE_Pos; | ||||
| 
 | ||||
|       /* Check transmit mailbox value */ | ||||
|       if (transmitmailbox > 2U) | ||||
|       { | ||||
|         /* Update error code */ | ||||
|         hcan->ErrorCode |= HAL_CAN_ERROR_INTERNAL; | ||||
| 
 | ||||
|         return HAL_ERROR; | ||||
|       } | ||||
| 
 | ||||
|       /* Store the Tx mailbox */ | ||||
|       *pTxMailbox = (uint32_t)1 << transmitmailbox; | ||||
| 
 | ||||
| @ -1376,7 +1368,7 @@ HAL_StatusTypeDef HAL_CAN_AbortTxRequest(CAN_HandleTypeDef *hcan, uint32_t TxMai | ||||
|   *         the configuration information for the specified CAN. | ||||
|   * @retval Number of free Tx Mailboxes. | ||||
|   */ | ||||
| uint32_t HAL_CAN_GetTxMailboxesFreeLevel(CAN_HandleTypeDef *hcan) | ||||
| uint32_t HAL_CAN_GetTxMailboxesFreeLevel(const CAN_HandleTypeDef *hcan) | ||||
| { | ||||
|   uint32_t freelevel = 0U; | ||||
|   HAL_CAN_StateTypeDef state = hcan->State; | ||||
| @ -1419,7 +1411,7 @@ uint32_t HAL_CAN_GetTxMailboxesFreeLevel(CAN_HandleTypeDef *hcan) | ||||
|   *          - 1 : Pending transmission request on at least one of the selected | ||||
|   *                Tx Mailbox. | ||||
|   */ | ||||
| uint32_t HAL_CAN_IsTxMessagePending(CAN_HandleTypeDef *hcan, uint32_t TxMailboxes) | ||||
| uint32_t HAL_CAN_IsTxMessagePending(const CAN_HandleTypeDef *hcan, uint32_t TxMailboxes) | ||||
| { | ||||
|   uint32_t status = 0U; | ||||
|   HAL_CAN_StateTypeDef state = hcan->State; | ||||
| @ -1451,7 +1443,7 @@ uint32_t HAL_CAN_IsTxMessagePending(CAN_HandleTypeDef *hcan, uint32_t TxMailboxe | ||||
|   *         This parameter can be one value of @arg CAN_Tx_Mailboxes. | ||||
|   * @retval Timestamp of message sent from Tx Mailbox. | ||||
|   */ | ||||
| uint32_t HAL_CAN_GetTxTimestamp(CAN_HandleTypeDef *hcan, uint32_t TxMailbox) | ||||
| uint32_t HAL_CAN_GetTxTimestamp(const CAN_HandleTypeDef *hcan, uint32_t TxMailbox) | ||||
| { | ||||
|   uint32_t timestamp = 0U; | ||||
|   uint32_t transmitmailbox; | ||||
| @ -1485,7 +1477,8 @@ uint32_t HAL_CAN_GetTxTimestamp(CAN_HandleTypeDef *hcan, uint32_t TxMailbox) | ||||
|   * @param  aData array where the payload of the Rx frame will be stored. | ||||
|   * @retval HAL status | ||||
|   */ | ||||
| HAL_StatusTypeDef HAL_CAN_GetRxMessage(CAN_HandleTypeDef *hcan, uint32_t RxFifo, CAN_RxHeaderTypeDef *pHeader, uint8_t aData[]) | ||||
| HAL_StatusTypeDef HAL_CAN_GetRxMessage(CAN_HandleTypeDef *hcan, uint32_t RxFifo, | ||||
|                                        CAN_RxHeaderTypeDef *pHeader, uint8_t aData[]) | ||||
| { | ||||
|   HAL_CAN_StateTypeDef state = hcan->State; | ||||
| 
 | ||||
| @ -1526,10 +1519,19 @@ HAL_StatusTypeDef HAL_CAN_GetRxMessage(CAN_HandleTypeDef *hcan, uint32_t RxFifo, | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|       pHeader->ExtId = ((CAN_RI0R_EXID | CAN_RI0R_STID) & hcan->Instance->sFIFOMailBox[RxFifo].RIR) >> CAN_RI0R_EXID_Pos; | ||||
|       pHeader->ExtId = ((CAN_RI0R_EXID | CAN_RI0R_STID) & | ||||
|                         hcan->Instance->sFIFOMailBox[RxFifo].RIR) >> CAN_RI0R_EXID_Pos; | ||||
|     } | ||||
|     pHeader->RTR = (CAN_RI0R_RTR & hcan->Instance->sFIFOMailBox[RxFifo].RIR); | ||||
|     pHeader->DLC = (CAN_RDT0R_DLC & hcan->Instance->sFIFOMailBox[RxFifo].RDTR) >> CAN_RDT0R_DLC_Pos; | ||||
|     if (((CAN_RDT0R_DLC & hcan->Instance->sFIFOMailBox[RxFifo].RDTR) >> CAN_RDT0R_DLC_Pos) >= 8U) | ||||
|     { | ||||
|       /* Truncate DLC to 8 if received field is over range */ | ||||
|       pHeader->DLC = 8U; | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|       pHeader->DLC = (CAN_RDT0R_DLC & hcan->Instance->sFIFOMailBox[RxFifo].RDTR) >> CAN_RDT0R_DLC_Pos; | ||||
|     } | ||||
|     pHeader->FilterMatchIndex = (CAN_RDT0R_FMI & hcan->Instance->sFIFOMailBox[RxFifo].RDTR) >> CAN_RDT0R_FMI_Pos; | ||||
|     pHeader->Timestamp = (CAN_RDT0R_TIME & hcan->Instance->sFIFOMailBox[RxFifo].RDTR) >> CAN_RDT0R_TIME_Pos; | ||||
| 
 | ||||
| @ -1575,7 +1577,7 @@ HAL_StatusTypeDef HAL_CAN_GetRxMessage(CAN_HandleTypeDef *hcan, uint32_t RxFifo, | ||||
|   *         This parameter can be a value of @arg CAN_receive_FIFO_number. | ||||
|   * @retval Number of messages available in Rx FIFO. | ||||
|   */ | ||||
| uint32_t HAL_CAN_GetRxFifoFillLevel(CAN_HandleTypeDef *hcan, uint32_t RxFifo) | ||||
| uint32_t HAL_CAN_GetRxFifoFillLevel(const CAN_HandleTypeDef *hcan, uint32_t RxFifo) | ||||
| { | ||||
|   uint32_t filllevel = 0U; | ||||
|   HAL_CAN_StateTypeDef state = hcan->State; | ||||
| @ -1605,8 +1607,8 @@ uint32_t HAL_CAN_GetRxFifoFillLevel(CAN_HandleTypeDef *hcan, uint32_t RxFifo) | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup CAN_Exported_Functions_Group4 Interrupts management
 | ||||
|  *  @brief    Interrupts management | ||||
|  * | ||||
|   * @brief    Interrupts management | ||||
|   * | ||||
| @verbatim | ||||
|   ============================================================================== | ||||
|                        ##### Interrupts management ##### | ||||
| @ -1873,7 +1875,7 @@ void HAL_CAN_IRQHandler(CAN_HandleTypeDef *hcan) | ||||
|     /* Check if message is still pending */ | ||||
|     if ((hcan->Instance->RF0R & CAN_RF0R_FMP0) != 0U) | ||||
|     { | ||||
|       /* Receive FIFO 0 mesage pending Callback */ | ||||
|       /* Receive FIFO 0 message pending Callback */ | ||||
| #if USE_HAL_CAN_REGISTER_CALLBACKS == 1 | ||||
|       /* Call registered callback*/ | ||||
|       hcan->RxFifo0MsgPendingCallback(hcan); | ||||
| @ -1922,7 +1924,7 @@ void HAL_CAN_IRQHandler(CAN_HandleTypeDef *hcan) | ||||
|     /* Check if message is still pending */ | ||||
|     if ((hcan->Instance->RF1R & CAN_RF1R_FMP1) != 0U) | ||||
|     { | ||||
|       /* Receive FIFO 1 mesage pending Callback */ | ||||
|       /* Receive FIFO 1 message pending Callback */ | ||||
| #if USE_HAL_CAN_REGISTER_CALLBACKS == 1 | ||||
|       /* Call registered callback*/ | ||||
|       hcan->RxFifo1MsgPendingCallback(hcan); | ||||
| @ -2071,8 +2073,8 @@ void HAL_CAN_IRQHandler(CAN_HandleTypeDef *hcan) | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup CAN_Exported_Functions_Group5 Callback functions
 | ||||
|  *  @brief   CAN Callback functions | ||||
|  * | ||||
|   * @brief   CAN Callback functions | ||||
|   * | ||||
| @verbatim | ||||
|   ============================================================================== | ||||
|                           ##### Callback functions ##### | ||||
| @ -2321,8 +2323,8 @@ __weak void HAL_CAN_ErrorCallback(CAN_HandleTypeDef *hcan) | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup CAN_Exported_Functions_Group6 Peripheral State and Error functions
 | ||||
|  *  @brief   CAN Peripheral State functions | ||||
|  * | ||||
|   * @brief   CAN Peripheral State functions | ||||
|   * | ||||
| @verbatim | ||||
|   ============================================================================== | ||||
|             ##### Peripheral State and Error functions ##### | ||||
| @ -2343,7 +2345,7 @@ __weak void HAL_CAN_ErrorCallback(CAN_HandleTypeDef *hcan) | ||||
|   *         the configuration information for the specified CAN. | ||||
|   * @retval HAL state | ||||
|   */ | ||||
| HAL_CAN_StateTypeDef HAL_CAN_GetState(CAN_HandleTypeDef *hcan) | ||||
| HAL_CAN_StateTypeDef HAL_CAN_GetState(const CAN_HandleTypeDef *hcan) | ||||
| { | ||||
|   HAL_CAN_StateTypeDef state = hcan->State; | ||||
| 
 | ||||
| @ -2378,7 +2380,7 @@ HAL_CAN_StateTypeDef HAL_CAN_GetState(CAN_HandleTypeDef *hcan) | ||||
|   *         the configuration information for the specified CAN. | ||||
|   * @retval CAN Error Code | ||||
|   */ | ||||
| uint32_t HAL_CAN_GetError(CAN_HandleTypeDef *hcan) | ||||
| uint32_t HAL_CAN_GetError(const CAN_HandleTypeDef *hcan) | ||||
| { | ||||
|   /* Return CAN error code */ | ||||
|   return hcan->ErrorCode; | ||||
| @ -2432,5 +2434,3 @@ HAL_StatusTypeDef HAL_CAN_ResetError(CAN_HandleTypeDef *hcan) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | ||||
| @ -68,13 +68,12 @@ | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© Copyright (c) 2017 STMicroelectronics. | ||||
|   * All rights reserved.</center></h2> | ||||
|   * Copyright (c) 2017 STMicroelectronics. | ||||
|   * All rights reserved. | ||||
|   * | ||||
|   * 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 | ||||
|   * 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. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| @ -291,6 +290,38 @@ void HAL_MPU_Enable(uint32_t MPU_Control) | ||||
|   __ISB(); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enable the MPU Region. | ||||
|   * @retval None | ||||
|   */ | ||||
| void HAL_MPU_EnableRegion(uint32_t RegionNumber) | ||||
| { | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_MPU_REGION_NUMBER(RegionNumber)); | ||||
| 
 | ||||
|   /* Set the Region number */ | ||||
|   MPU->RNR = RegionNumber; | ||||
| 
 | ||||
|   /* Enable the Region */ | ||||
|   SET_BIT(MPU->RASR, MPU_RASR_ENABLE_Msk); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Disable the MPU Region. | ||||
|   * @retval None | ||||
|   */ | ||||
| void HAL_MPU_DisableRegion(uint32_t RegionNumber) | ||||
| { | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_MPU_REGION_NUMBER(RegionNumber)); | ||||
| 
 | ||||
|   /* Set the Region number */ | ||||
|   MPU->RNR = RegionNumber; | ||||
| 
 | ||||
|   /* Disable the Region */ | ||||
|   CLEAR_BIT(MPU->RASR, MPU_RASR_ENABLE_Msk); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Initializes and configures the Region and the memory to be protected. | ||||
|   * @param  MPU_Init: Pointer to a MPU_Region_InitTypeDef structure that contains | ||||
| @ -302,38 +333,32 @@ void HAL_MPU_ConfigRegion(MPU_Region_InitTypeDef *MPU_Init) | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_MPU_REGION_NUMBER(MPU_Init->Number)); | ||||
|   assert_param(IS_MPU_REGION_ENABLE(MPU_Init->Enable)); | ||||
|   assert_param(IS_MPU_INSTRUCTION_ACCESS(MPU_Init->DisableExec)); | ||||
|   assert_param(IS_MPU_REGION_PERMISSION_ATTRIBUTE(MPU_Init->AccessPermission)); | ||||
|   assert_param(IS_MPU_TEX_LEVEL(MPU_Init->TypeExtField)); | ||||
|   assert_param(IS_MPU_ACCESS_SHAREABLE(MPU_Init->IsShareable)); | ||||
|   assert_param(IS_MPU_ACCESS_CACHEABLE(MPU_Init->IsCacheable)); | ||||
|   assert_param(IS_MPU_ACCESS_BUFFERABLE(MPU_Init->IsBufferable)); | ||||
|   assert_param(IS_MPU_SUB_REGION_DISABLE(MPU_Init->SubRegionDisable)); | ||||
|   assert_param(IS_MPU_REGION_SIZE(MPU_Init->Size)); | ||||
| 
 | ||||
|   /* Set the Region number */ | ||||
|   MPU->RNR = MPU_Init->Number; | ||||
| 
 | ||||
|   if ((MPU_Init->Enable) != RESET) | ||||
|   { | ||||
|     /* Check the parameters */ | ||||
|     assert_param(IS_MPU_INSTRUCTION_ACCESS(MPU_Init->DisableExec)); | ||||
|     assert_param(IS_MPU_REGION_PERMISSION_ATTRIBUTE(MPU_Init->AccessPermission)); | ||||
|     assert_param(IS_MPU_TEX_LEVEL(MPU_Init->TypeExtField)); | ||||
|     assert_param(IS_MPU_ACCESS_SHAREABLE(MPU_Init->IsShareable)); | ||||
|     assert_param(IS_MPU_ACCESS_CACHEABLE(MPU_Init->IsCacheable)); | ||||
|     assert_param(IS_MPU_ACCESS_BUFFERABLE(MPU_Init->IsBufferable)); | ||||
|     assert_param(IS_MPU_SUB_REGION_DISABLE(MPU_Init->SubRegionDisable)); | ||||
|     assert_param(IS_MPU_REGION_SIZE(MPU_Init->Size)); | ||||
|      | ||||
|     MPU->RBAR = MPU_Init->BaseAddress; | ||||
|     MPU->RASR = ((uint32_t)MPU_Init->DisableExec             << MPU_RASR_XN_Pos)   | | ||||
|                 ((uint32_t)MPU_Init->AccessPermission        << MPU_RASR_AP_Pos)   | | ||||
|                 ((uint32_t)MPU_Init->TypeExtField            << MPU_RASR_TEX_Pos)  | | ||||
|                 ((uint32_t)MPU_Init->IsShareable             << MPU_RASR_S_Pos)    | | ||||
|                 ((uint32_t)MPU_Init->IsCacheable             << MPU_RASR_C_Pos)    | | ||||
|                 ((uint32_t)MPU_Init->IsBufferable            << MPU_RASR_B_Pos)    | | ||||
|                 ((uint32_t)MPU_Init->SubRegionDisable        << MPU_RASR_SRD_Pos)  | | ||||
|                 ((uint32_t)MPU_Init->Size                    << MPU_RASR_SIZE_Pos) | | ||||
|                 ((uint32_t)MPU_Init->Enable                  << MPU_RASR_ENABLE_Pos); | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     MPU->RBAR = 0x00U; | ||||
|     MPU->RASR = 0x00U; | ||||
|   } | ||||
|   /* Disable the Region */ | ||||
|   CLEAR_BIT(MPU->RASR, MPU_RASR_ENABLE_Msk); | ||||
| 
 | ||||
|   /* Apply configuration */ | ||||
|   MPU->RBAR = MPU_Init->BaseAddress; | ||||
|   MPU->RASR = ((uint32_t)MPU_Init->DisableExec             << MPU_RASR_XN_Pos)   | | ||||
|               ((uint32_t)MPU_Init->AccessPermission        << MPU_RASR_AP_Pos)   | | ||||
|               ((uint32_t)MPU_Init->TypeExtField            << MPU_RASR_TEX_Pos)  | | ||||
|               ((uint32_t)MPU_Init->IsShareable             << MPU_RASR_S_Pos)    | | ||||
|               ((uint32_t)MPU_Init->IsCacheable             << MPU_RASR_C_Pos)    | | ||||
|               ((uint32_t)MPU_Init->IsBufferable            << MPU_RASR_B_Pos)    | | ||||
|               ((uint32_t)MPU_Init->SubRegionDisable        << MPU_RASR_SRD_Pos)  | | ||||
|               ((uint32_t)MPU_Init->Size                    << MPU_RASR_SIZE_Pos) | | ||||
|               ((uint32_t)MPU_Init->Enable                  << MPU_RASR_ENABLE_Pos); | ||||
| } | ||||
| #endif /* __MPU_PRESENT */ | ||||
| 
 | ||||
| @ -502,4 +527,3 @@ __weak void HAL_SYSTICK_Callback(void) | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | ||||
| @ -70,13 +70,12 @@ | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© Copyright (c) 2016 STMicroelectronics. | ||||
|   * All rights reserved.</center></h2> | ||||
|   * Copyright (c) 2016 STMicroelectronics. | ||||
|   * All rights reserved. | ||||
|   * | ||||
|   * 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 | ||||
|   * 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. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| @ -684,9 +683,9 @@ void HAL_DMA_IRQHandler(DMA_HandleTypeDef *hdma) | ||||
|   * @brief Register callbacks | ||||
|   * @param hdma: pointer to a DMA_HandleTypeDef structure that contains | ||||
|   *              the configuration information for the specified DMA Channel. | ||||
|   * @param CallbackID: User Callback identifer | ||||
|   * @param CallbackID: User Callback identifier | ||||
|   *                    a HAL_DMA_CallbackIDTypeDef ENUM as parameter. | ||||
|   * @param pCallback: pointer to private callbacsk function which has pointer to  | ||||
|   * @param pCallback: pointer to private callback function which has pointer to  | ||||
|   *                   a DMA_HandleTypeDef structure as parameter. | ||||
|   * @retval HAL status | ||||
|   */                           | ||||
| @ -737,7 +736,7 @@ HAL_StatusTypeDef HAL_DMA_RegisterCallback(DMA_HandleTypeDef *hdma, HAL_DMA_Call | ||||
|   * @brief UnRegister callbacks | ||||
|   * @param hdma: pointer to a DMA_HandleTypeDef structure that contains | ||||
|   *              the configuration information for the specified DMA Channel. | ||||
|   * @param CallbackID: User Callback identifer | ||||
|   * @param CallbackID: User Callback identifier | ||||
|   *                    a HAL_DMA_CallbackIDTypeDef ENUM as parameter. | ||||
|   * @retval HAL status | ||||
|   */               | ||||
| @ -812,7 +811,7 @@ HAL_StatusTypeDef HAL_DMA_UnRegisterCallback(DMA_HandleTypeDef *hdma, HAL_DMA_Ca | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Return the DMA hande state. | ||||
|   * @brief  Return the DMA handle state. | ||||
|   * @param  hdma: pointer to a DMA_HandleTypeDef structure that contains | ||||
|   *               the configuration information for the specified DMA Channel. | ||||
|   * @retval HAL state | ||||
| @ -896,4 +895,3 @@ static void DMA_SetConfig(DMA_HandleTypeDef *hdma, uint32_t SrcAddress, uint32_t | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | ||||
| @ -8,6 +8,17 @@ | ||||
|   *           + Initialization and de-initialization functions | ||||
|   *           + IO operation functions | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * Copyright (c) 2019 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. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   @verbatim | ||||
|   ============================================================================== | ||||
|                     ##### EXTI Peripheral features ##### | ||||
| @ -53,7 +64,7 @@ | ||||
|         (++) Provide exiting handle as parameter. | ||||
|         (++) Provide pointer on EXTI_ConfigTypeDef structure as second parameter. | ||||
| 
 | ||||
|     (#) Clear Exti configuration of a dedicated line using HAL_EXTI_GetConfigLine(). | ||||
|     (#) Clear Exti configuration of a dedicated line using HAL_EXTI_ClearConfigLine(). | ||||
|         (++) Provide exiting handle as parameter. | ||||
| 
 | ||||
|     (#) Register callback to treat Exti interrupts using HAL_EXTI_RegisterCallback(). | ||||
| @ -64,23 +75,11 @@ | ||||
| 
 | ||||
|     (#) Get interrupt pending bit using HAL_EXTI_GetPending(). | ||||
| 
 | ||||
|     (#) Clear interrupt pending bit using HAL_EXTI_GetPending(). | ||||
|     (#) Clear interrupt pending bit using HAL_EXTI_ClearPending(). | ||||
| 
 | ||||
|     (#) Generate software interrupt using HAL_EXTI_GenerateSWI(). | ||||
| 
 | ||||
|   @endverbatim | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© Copyright (c) 2019 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 | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| @ -276,6 +275,10 @@ HAL_StatusTypeDef HAL_EXTI_GetConfigLine(EXTI_HandleTypeDef *hexti, EXTI_ConfigT | ||||
|     pExtiConfig->Mode |= EXTI_MODE_EVENT; | ||||
|   } | ||||
| 
 | ||||
|   /* Get default Trigger and GPIOSel configuration */ | ||||
|   pExtiConfig->Trigger = EXTI_TRIGGER_NONE; | ||||
|   pExtiConfig->GPIOSel = 0x00u; | ||||
| 
 | ||||
|   /* 2] Get trigger for configurable lines : rising */ | ||||
|   if ((pExtiConfig->Line & EXTI_CONFIG) != 0x00u) | ||||
|   { | ||||
| @ -284,10 +287,6 @@ HAL_StatusTypeDef HAL_EXTI_GetConfigLine(EXTI_HandleTypeDef *hexti, EXTI_ConfigT | ||||
|     { | ||||
|       pExtiConfig->Trigger = EXTI_TRIGGER_RISING; | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|       pExtiConfig->Trigger = EXTI_TRIGGER_NONE; | ||||
|     } | ||||
| 
 | ||||
|     /* Get falling configuration */ | ||||
|     /* Check if configuration of selected line is enable */ | ||||
| @ -302,18 +301,8 @@ HAL_StatusTypeDef HAL_EXTI_GetConfigLine(EXTI_HandleTypeDef *hexti, EXTI_ConfigT | ||||
|       assert_param(IS_EXTI_GPIO_PIN(linepos)); | ||||
| 
 | ||||
|       regval = AFIO->EXTICR[linepos >> 2u]; | ||||
|       pExtiConfig->GPIOSel = ((regval << (AFIO_EXTICR1_EXTI1_Pos * (3uL - (linepos & 0x03u)))) >> 24); | ||||
|       pExtiConfig->GPIOSel = (regval >> (AFIO_EXTICR1_EXTI1_Pos * (linepos & 0x03u))) & AFIO_EXTICR1_EXTI0; | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|       pExtiConfig->GPIOSel = 0x00u; | ||||
|     } | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     /* No Trigger selected */ | ||||
|     pExtiConfig->Trigger = EXTI_TRIGGER_NONE; | ||||
|     pExtiConfig->GPIOSel = 0x00u; | ||||
|   } | ||||
| 
 | ||||
|   return HAL_OK; | ||||
| @ -485,6 +474,9 @@ uint32_t HAL_EXTI_GetPending(EXTI_HandleTypeDef *hexti, uint32_t Edge) | ||||
|   assert_param(IS_EXTI_CONFIG_LINE(hexti->Line)); | ||||
|   assert_param(IS_EXTI_PENDING_EDGE(Edge)); | ||||
| 
 | ||||
|   /* Prevent unused argument compilation warning */ | ||||
|   UNUSED(Edge); | ||||
| 
 | ||||
|   /* Compute line mask */ | ||||
|   linepos = (hexti->Line & EXTI_PIN_MASK); | ||||
|   maskline = (1uL << linepos); | ||||
| @ -512,6 +504,9 @@ void HAL_EXTI_ClearPending(EXTI_HandleTypeDef *hexti, uint32_t Edge) | ||||
|   assert_param(IS_EXTI_CONFIG_LINE(hexti->Line)); | ||||
|   assert_param(IS_EXTI_PENDING_EDGE(Edge)); | ||||
| 
 | ||||
|   /* Prevent unused argument compilation warning */ | ||||
|   UNUSED(Edge); | ||||
| 
 | ||||
|   /* Compute line mask */ | ||||
|   maskline = (1uL << (hexti->Line & EXTI_PIN_MASK)); | ||||
| 
 | ||||
| @ -556,4 +551,3 @@ void HAL_EXTI_GenerateSWI(EXTI_HandleTypeDef *hexti) | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | ||||
| @ -70,14 +70,12 @@ | ||||
|   ****************************************************************************** | ||||
|   * @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 | ||||
|   * Copyright (c) 2016 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. | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| @ -267,9 +265,6 @@ HAL_StatusTypeDef HAL_FLASH_Program(uint32_t TypeProgram, uint32_t Address, uint | ||||
| HAL_StatusTypeDef HAL_FLASH_Program_IT(uint32_t TypeProgram, uint32_t Address, uint64_t Data) | ||||
| { | ||||
|   HAL_StatusTypeDef status = HAL_OK; | ||||
|    | ||||
|   /* Process Locked */ | ||||
|   __HAL_LOCK(&pFlash); | ||||
| 
 | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_FLASH_TYPEPROGRAM(TypeProgram)); | ||||
| @ -589,8 +584,6 @@ void HAL_FLASH_IRQHandler(void) | ||||
|     __HAL_FLASH_DISABLE_IT(FLASH_IT_EOP | FLASH_IT_ERR); | ||||
| #endif /* FLASH_BANK2_END */ | ||||
| 
 | ||||
|     /* Process Unlocked */ | ||||
|     __HAL_UNLOCK(&pFlash); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| @ -964,4 +957,3 @@ static void FLASH_SetErrorCode(void) | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | ||||
| @ -28,14 +28,12 @@ | ||||
|   ****************************************************************************** | ||||
|   * @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 | ||||
|   * Copyright (c) 2016 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. | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| @ -125,15 +123,15 @@ static uint8_t           FLASH_OB_GetUser(void); | ||||
|   ============================================================================== | ||||
| 
 | ||||
|     [..] The FLASH Memory Erasing functions, includes the following functions: | ||||
|     (+) @ref HAL_FLASHEx_Erase: return only when erase has been done | ||||
|     (+) @ref HAL_FLASHEx_Erase_IT: end of erase is done when @ref HAL_FLASH_EndOfOperationCallback  | ||||
|     (+) HAL_FLASHEx_Erase: return only when erase has been done | ||||
|     (+) HAL_FLASHEx_Erase_IT: end of erase is done when HAL_FLASH_EndOfOperationCallback  | ||||
|         is called with parameter 0xFFFFFFFF | ||||
| 
 | ||||
|     [..] Any operation of erase should follow these steps: | ||||
|     (#) Call the @ref HAL_FLASH_Unlock() function to enable the flash control register and  | ||||
|     (#) Call the HAL_FLASH_Unlock() function to enable the flash control register and  | ||||
|         program memory access. | ||||
|     (#) Call the desired function to erase page. | ||||
|     (#) Call the @ref HAL_FLASH_Lock() to disable the flash program memory access  | ||||
|     (#) Call the HAL_FLASH_Lock() to disable the flash program memory access  | ||||
|        (recommended to protect the FLASH memory against possible unwanted operation). | ||||
| 
 | ||||
| @endverbatim | ||||
| @ -320,9 +318,6 @@ HAL_StatusTypeDef HAL_FLASHEx_Erase_IT(FLASH_EraseInitTypeDef *pEraseInit) | ||||
| { | ||||
|   HAL_StatusTypeDef status = HAL_OK; | ||||
| 
 | ||||
|   /* Process Locked */ | ||||
|   __HAL_LOCK(&pFlash); | ||||
| 
 | ||||
|   /* If procedure already ongoing, reject the next one */ | ||||
|   if (pFlash.ProcedureOnGoing != FLASH_PROC_NONE) | ||||
|   { | ||||
| @ -1124,4 +1119,3 @@ void FLASH_PageErase(uint32_t PageAddress) | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | ||||
| @ -8,6 +8,17 @@ | ||||
|   *           + Initialization and de-initialization functions | ||||
|   *           + IO operation functions | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * Copyright (c) 2016 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. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   @verbatim | ||||
|   ============================================================================== | ||||
|                     ##### GPIO Peripheral features ##### | ||||
| @ -88,17 +99,6 @@ | ||||
| 
 | ||||
|   @endverbatim | ||||
|   ****************************************************************************** | ||||
|   * @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 | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| @ -295,26 +295,6 @@ void HAL_GPIO_Init(GPIO_TypeDef  *GPIOx, GPIO_InitTypeDef *GPIO_Init) | ||||
|         AFIO->EXTICR[position >> 2u] = temp; | ||||
| 
 | ||||
| 
 | ||||
|         /* Configure the interrupt mask */ | ||||
|         if ((GPIO_Init->Mode & GPIO_MODE_IT) == GPIO_MODE_IT) | ||||
|         { | ||||
|           SET_BIT(EXTI->IMR, iocurrent); | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|           CLEAR_BIT(EXTI->IMR, iocurrent); | ||||
|         } | ||||
| 
 | ||||
|         /* Configure the event mask */ | ||||
|         if ((GPIO_Init->Mode & GPIO_MODE_EVT) == GPIO_MODE_EVT) | ||||
|         { | ||||
|           SET_BIT(EXTI->EMR, iocurrent); | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|           CLEAR_BIT(EXTI->EMR, iocurrent); | ||||
|         } | ||||
| 
 | ||||
|         /* Enable or disable the rising trigger */ | ||||
|         if ((GPIO_Init->Mode & RISING_EDGE) == RISING_EDGE) | ||||
|         { | ||||
| @ -334,6 +314,26 @@ void HAL_GPIO_Init(GPIO_TypeDef  *GPIOx, GPIO_InitTypeDef *GPIO_Init) | ||||
|         { | ||||
|           CLEAR_BIT(EXTI->FTSR, iocurrent); | ||||
|         } | ||||
| 
 | ||||
|         /* Configure the event mask */ | ||||
|         if ((GPIO_Init->Mode & GPIO_MODE_EVT) == GPIO_MODE_EVT) | ||||
|         { | ||||
|           SET_BIT(EXTI->EMR, iocurrent); | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|           CLEAR_BIT(EXTI->EMR, iocurrent); | ||||
|         } | ||||
| 
 | ||||
|         /* Configure the interrupt mask */ | ||||
|         if ((GPIO_Init->Mode & GPIO_MODE_IT) == GPIO_MODE_IT) | ||||
|         { | ||||
|           SET_BIT(EXTI->IMR, iocurrent); | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|           CLEAR_BIT(EXTI->IMR, iocurrent); | ||||
|         } | ||||
|       } | ||||
|     } | ||||
| 
 | ||||
| @ -375,16 +375,16 @@ void HAL_GPIO_DeInit(GPIO_TypeDef  *GPIOx, uint32_t GPIO_Pin) | ||||
|       tmp &= 0x0FuL << (4u * (position & 0x03u)); | ||||
|       if (tmp == (GPIO_GET_INDEX(GPIOx) << (4u * (position & 0x03u)))) | ||||
|       { | ||||
|         tmp = 0x0FuL << (4u * (position & 0x03u)); | ||||
|         CLEAR_BIT(AFIO->EXTICR[position >> 2u], tmp); | ||||
| 
 | ||||
|         /* Clear EXTI line configuration */ | ||||
|         CLEAR_BIT(EXTI->IMR, (uint32_t)iocurrent); | ||||
|         CLEAR_BIT(EXTI->EMR, (uint32_t)iocurrent); | ||||
| 
 | ||||
|         /* Clear Rising Falling edge configuration */ | ||||
|         CLEAR_BIT(EXTI->RTSR, (uint32_t)iocurrent); | ||||
|         CLEAR_BIT(EXTI->FTSR, (uint32_t)iocurrent); | ||||
|         CLEAR_BIT(EXTI->RTSR, (uint32_t)iocurrent); | ||||
|          | ||||
|         tmp = 0x0FuL << (4u * (position & 0x03u)); | ||||
|         CLEAR_BIT(AFIO->EXTICR[position >> 2u], tmp); | ||||
|       } | ||||
|       /*------------------------- GPIO Mode Configuration --------------------*/ | ||||
|       /* Check if the current bit belongs to first half or last half of the pin count number
 | ||||
| @ -491,7 +491,7 @@ void HAL_GPIO_TogglePin(GPIO_TypeDef *GPIOx, uint16_t GPIO_Pin) | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_GPIO_PIN(GPIO_Pin)); | ||||
| 
 | ||||
|   /* get current Ouput Data Register value */ | ||||
|   /* get current Output Data Register value */ | ||||
|   odr = GPIOx->ODR; | ||||
| 
 | ||||
|   /* Set selected pins that were at low level, and reset ones that were high */ | ||||
| @ -505,7 +505,7 @@ void HAL_GPIO_TogglePin(GPIO_TypeDef *GPIOx, uint16_t GPIO_Pin) | ||||
| *         the next reset. | ||||
| * @param  GPIOx: where x can be (A..G depending on device used) to select the GPIO peripheral | ||||
| * @param  GPIO_Pin: specifies the port bit to be locked. | ||||
| *         This parameter can be any combination of GPIO_Pin_x where x can be (0..15). | ||||
| *         This parameter can be any combination of GPIO_PIN_x where x can be (0..15). | ||||
| * @retval None | ||||
| */ | ||||
| HAL_StatusTypeDef HAL_GPIO_LockPin(GPIO_TypeDef *GPIOx, uint16_t GPIO_Pin) | ||||
| @ -584,4 +584,3 @@ __weak void HAL_GPIO_EXTI_Callback(uint16_t GPIO_Pin) | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | ||||
| @ -7,6 +7,17 @@ | ||||
|   *          functionalities of the General Purpose Input/Output (GPIO) extension peripheral. | ||||
|   *           + Extended features functions | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * Copyright (c) 2016 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. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   @verbatim | ||||
|   ============================================================================== | ||||
|                     ##### GPIO Peripheral extension features ##### | ||||
| @ -23,17 +34,6 @@ | ||||
| 
 | ||||
|   @endverbatim | ||||
|   ****************************************************************************** | ||||
|   * @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 | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| @ -124,4 +124,3 @@ void HAL_GPIOEx_DisableEventout(void) | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | ||||
							
								
								
									
										263
									
								
								Drivers/STM32F1xx_HAL_Driver/Src/stm32f1xx_hal_iwdg.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										263
									
								
								Drivers/STM32F1xx_HAL_Driver/Src/stm32f1xx_hal_iwdg.c
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,263 @@ | ||||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32f1xx_hal_iwdg.c | ||||
|   * @author  MCD Application Team | ||||
|   * @brief   IWDG HAL module driver. | ||||
|   *          This file provides firmware functions to manage the following | ||||
|   *          functionalities of the Independent Watchdog (IWDG) peripheral: | ||||
|   *           + Initialization and Start functions | ||||
|   *           + IO operation functions | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * Copyright (c) 2016 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. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   @verbatim | ||||
|   ============================================================================== | ||||
|                     ##### IWDG Generic features ##### | ||||
|   ============================================================================== | ||||
|   [..] | ||||
|     (+) The IWDG can be started by either software or hardware (configurable | ||||
|         through option byte). | ||||
| 
 | ||||
|     (+) The IWDG is clocked by the Low-Speed Internal clock (LSI) and thus stays | ||||
|         active even if the main clock fails. | ||||
| 
 | ||||
|     (+) Once the IWDG is started, the LSI is forced ON and both cannot be | ||||
|         disabled. The counter starts counting down from the reset value (0xFFF). | ||||
|         When it reaches the end of count value (0x000) a reset signal is | ||||
|         generated (IWDG reset). | ||||
| 
 | ||||
|     (+) Whenever the key value 0x0000 AAAA is written in the IWDG_KR register, | ||||
|         the IWDG_RLR value is reloaded into the counter and the watchdog reset | ||||
|         is prevented. | ||||
| 
 | ||||
|     (+) The IWDG is implemented in the VDD voltage domain that is still functional | ||||
|         in STOP and STANDBY mode (IWDG reset can wake up the CPU from STANDBY). | ||||
|         IWDGRST flag in RCC_CSR register can be used to inform when an IWDG | ||||
|         reset occurs. | ||||
| 
 | ||||
|     (+) Debug mode: When the microcontroller enters debug mode (core halted), | ||||
|         the IWDG counter either continues to work normally or stops, depending | ||||
|         on DBG_IWDG_STOP configuration bit in DBG module, accessible through | ||||
|         __HAL_DBGMCU_FREEZE_IWDG() and __HAL_DBGMCU_UNFREEZE_IWDG() macros. | ||||
| 
 | ||||
|     [..] Min-max timeout value @32KHz (LSI): ~125us / ~32.7s | ||||
|          The IWDG timeout may vary due to LSI clock frequency dispersion. | ||||
|          STM32F1xx devices provide the capability to measure the LSI clock | ||||
|          frequency (LSI clock is internally connected to TIM5 CH4 input capture). | ||||
|          The measured value can be used to have an IWDG timeout with an | ||||
|          acceptable accuracy. | ||||
| 
 | ||||
|     [..] Default timeout value (necessary for IWDG_SR status register update): | ||||
|          Constant LSI_VALUE is defined based on the nominal LSI clock frequency. | ||||
|          This frequency being subject to variations as mentioned above, the | ||||
|          default timeout value (defined through constant HAL_IWDG_DEFAULT_TIMEOUT | ||||
|          below) may become too short or too long. | ||||
|          In such cases, this default timeout value can be tuned by redefining | ||||
|          the constant LSI_VALUE at user-application level (based, for instance, | ||||
|          on the measured LSI clock frequency as explained above). | ||||
| 
 | ||||
|                      ##### How to use this driver ##### | ||||
|   ============================================================================== | ||||
|   [..] | ||||
|     (#) Use IWDG using HAL_IWDG_Init() function to : | ||||
|       (++) Enable instance by writing Start keyword in IWDG_KEY register. LSI | ||||
|            clock is forced ON and IWDG counter starts counting down. | ||||
|       (++) Enable write access to configuration registers: | ||||
|           IWDG_PR and IWDG_RLR. | ||||
|       (++) Configure the IWDG prescaler and counter reload value. This reload | ||||
|            value will be loaded in the IWDG counter each time the watchdog is | ||||
|            reloaded, then the IWDG will start counting down from this value. | ||||
|       (++) Wait for status flags to be reset. | ||||
| 
 | ||||
|     (#) Then the application program must refresh the IWDG counter at regular | ||||
|         intervals during normal operation to prevent an MCU reset, using | ||||
|         HAL_IWDG_Refresh() function. | ||||
| 
 | ||||
|      *** IWDG HAL driver macros list *** | ||||
|      ==================================== | ||||
|      [..] | ||||
|        Below the list of most used macros in IWDG HAL driver: | ||||
|       (+) __HAL_IWDG_START: Enable the IWDG peripheral | ||||
|       (+) __HAL_IWDG_RELOAD_COUNTER: Reloads IWDG counter with value defined in | ||||
|           the reload register | ||||
| 
 | ||||
|   @endverbatim | ||||
|   */ | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32f1xx_hal.h" | ||||
| 
 | ||||
| /** @addtogroup STM32F1xx_HAL_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #ifdef HAL_IWDG_MODULE_ENABLED | ||||
| /** @addtogroup IWDG
 | ||||
|   * @brief IWDG HAL module driver. | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /* Private typedef -----------------------------------------------------------*/ | ||||
| /* Private define ------------------------------------------------------------*/ | ||||
| /** @defgroup IWDG_Private_Defines IWDG Private Defines
 | ||||
|   * @{ | ||||
|   */ | ||||
| /* Status register needs up to 5 LSI clock periods divided by the clock
 | ||||
|    prescaler to be updated. The number of LSI clock periods is upper-rounded to | ||||
|    6 for the timeout value calculation. | ||||
|    The timeout value is calculated using the highest prescaler (256) and | ||||
|    the LSI_VALUE constant. The value of this constant can be changed by the user | ||||
|    to take into account possible LSI clock period variations. | ||||
|    The timeout value is multiplied by 1000 to be converted in milliseconds. | ||||
|    LSI startup time is also considered here by adding LSI_STARTUP_TIME | ||||
|    converted in milliseconds. */ | ||||
| #define HAL_IWDG_DEFAULT_TIMEOUT        (((6UL * 256UL * 1000UL) / (LSI_VALUE / 128U)) + \ | ||||
|                                          ((LSI_STARTUP_TIME / 1000UL) + 1UL)) | ||||
| #define IWDG_KERNEL_UPDATE_FLAGS        (IWDG_SR_RVU | IWDG_SR_PVU) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /* Private macro -------------------------------------------------------------*/ | ||||
| /* Private variables ---------------------------------------------------------*/ | ||||
| /* Private function prototypes -----------------------------------------------*/ | ||||
| /* Exported functions --------------------------------------------------------*/ | ||||
| 
 | ||||
| /** @addtogroup IWDG_Exported_Functions
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup IWDG_Exported_Functions_Group1
 | ||||
|   *  @brief    Initialization and Start functions. | ||||
|   * | ||||
| @verbatim | ||||
|  =============================================================================== | ||||
|           ##### Initialization and Start functions ##### | ||||
|  =============================================================================== | ||||
|  [..]  This section provides functions allowing to: | ||||
|       (+) Initialize the IWDG according to the specified parameters in the | ||||
|           IWDG_InitTypeDef of associated handle. | ||||
|       (+) Once initialization is performed in HAL_IWDG_Init function, Watchdog | ||||
|           is reloaded in order to exit function with correct time base. | ||||
| 
 | ||||
| @endverbatim | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Initialize the IWDG according to the specified parameters in the | ||||
|   *         IWDG_InitTypeDef and start watchdog. Before exiting function, | ||||
|   *         watchdog is refreshed in order to have correct time base. | ||||
|   * @param  hiwdg  pointer to a IWDG_HandleTypeDef structure that contains | ||||
|   *                the configuration information for the specified IWDG module. | ||||
|   * @retval HAL status | ||||
|   */ | ||||
| HAL_StatusTypeDef HAL_IWDG_Init(IWDG_HandleTypeDef *hiwdg) | ||||
| { | ||||
|   uint32_t tickstart; | ||||
| 
 | ||||
|   /* Check the IWDG handle allocation */ | ||||
|   if (hiwdg == NULL) | ||||
|   { | ||||
|     return HAL_ERROR; | ||||
|   } | ||||
| 
 | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_IWDG_ALL_INSTANCE(hiwdg->Instance)); | ||||
|   assert_param(IS_IWDG_PRESCALER(hiwdg->Init.Prescaler)); | ||||
|   assert_param(IS_IWDG_RELOAD(hiwdg->Init.Reload)); | ||||
| 
 | ||||
|   /* Enable IWDG. LSI is turned on automatically */ | ||||
|   __HAL_IWDG_START(hiwdg); | ||||
| 
 | ||||
|   /* Enable write access to IWDG_PR and IWDG_RLR registers by writing
 | ||||
|   0x5555 in KR */ | ||||
|   IWDG_ENABLE_WRITE_ACCESS(hiwdg); | ||||
| 
 | ||||
|   /* Write to IWDG registers the Prescaler & Reload values to work with */ | ||||
|   hiwdg->Instance->PR = hiwdg->Init.Prescaler; | ||||
|   hiwdg->Instance->RLR = hiwdg->Init.Reload; | ||||
| 
 | ||||
|   /* Check pending flag, if previous update not done, return timeout */ | ||||
|   tickstart = HAL_GetTick(); | ||||
| 
 | ||||
|   /* Wait for register to be updated */ | ||||
|   while ((hiwdg->Instance->SR & IWDG_KERNEL_UPDATE_FLAGS) != 0x00u) | ||||
|   { | ||||
|     if ((HAL_GetTick() - tickstart) > HAL_IWDG_DEFAULT_TIMEOUT) | ||||
|     { | ||||
|       if ((hiwdg->Instance->SR & IWDG_KERNEL_UPDATE_FLAGS) != 0x00u) | ||||
|       { | ||||
|         return HAL_TIMEOUT; | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   /* Reload IWDG counter with value defined in the reload register */ | ||||
|   __HAL_IWDG_RELOAD_COUNTER(hiwdg); | ||||
| 
 | ||||
|   /* Return function status */ | ||||
|   return HAL_OK; | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| 
 | ||||
| /** @addtogroup IWDG_Exported_Functions_Group2
 | ||||
|   *  @brief   IO operation functions | ||||
|   * | ||||
| @verbatim | ||||
|  =============================================================================== | ||||
|                       ##### IO operation functions ##### | ||||
|  =============================================================================== | ||||
|  [..]  This section provides functions allowing to: | ||||
|       (+) Refresh the IWDG. | ||||
| 
 | ||||
| @endverbatim | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Refresh the IWDG. | ||||
|   * @param  hiwdg  pointer to a IWDG_HandleTypeDef structure that contains | ||||
|   *                the configuration information for the specified IWDG module. | ||||
|   * @retval HAL status | ||||
|   */ | ||||
| HAL_StatusTypeDef HAL_IWDG_Refresh(IWDG_HandleTypeDef *hiwdg) | ||||
| { | ||||
|   /* Reload IWDG counter with value defined in the reload register */ | ||||
|   __HAL_IWDG_RELOAD_COUNTER(hiwdg); | ||||
| 
 | ||||
|   /* Return function status */ | ||||
|   return HAL_OK; | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| #endif /* HAL_IWDG_MODULE_ENABLED */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| @ -12,13 +12,12 @@ | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© Copyright (c) 2016 STMicroelectronics. | ||||
|   * All rights reserved.</center></h2> | ||||
|   * Copyright (c) 2016 STMicroelectronics. | ||||
|   * All rights reserved. | ||||
|   * | ||||
|   * 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 | ||||
|   * 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. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| @ -617,5 +616,3 @@ __weak void HAL_PWR_PVDCallback(void) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | ||||
| @ -48,14 +48,12 @@ | ||||
|   ****************************************************************************** | ||||
|   * @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 | ||||
|   * Copyright (c) 2016 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. | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| @ -155,7 +153,7 @@ static void RCC_Delay(uint32_t mdelay); | ||||
|           on AHB bus (DMA, GPIO...). APB1 (PCLK1) and APB2 (PCLK2) clocks are derived | ||||
|           from AHB clock through configurable prescalers and used to clock | ||||
|           the peripherals mapped on these buses. You can use | ||||
|           "@ref HAL_RCC_GetSysClockFreq()" function to retrieve the frequencies of these clocks. | ||||
|           "HAL_RCC_GetSysClockFreq()" function to retrieve the frequencies of these clocks. | ||||
| 
 | ||||
|       -@- All the peripheral clocks are derived from the System clock (SYSCLK) except: | ||||
|           (+@) RTC: RTC clock can be derived either from the LSI, LSE or HSE clock | ||||
| @ -1082,14 +1080,14 @@ void HAL_RCC_DisableCSS(void) | ||||
| uint32_t HAL_RCC_GetSysClockFreq(void) | ||||
| { | ||||
| #if defined(RCC_CFGR2_PREDIV1SRC) | ||||
|   const uint8_t aPLLMULFactorTable[14] = {0, 0, 4, 5, 6, 7, 8, 9, 0, 0, 0, 0, 0, 13}; | ||||
|   const uint8_t aPredivFactorTable[16] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16}; | ||||
|   static const uint8_t aPLLMULFactorTable[14U] = {0, 0, 4, 5, 6, 7, 8, 9, 0, 0, 0, 0, 0, 13}; | ||||
|   static const uint8_t aPredivFactorTable[16U] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16}; | ||||
| #else | ||||
|   const uint8_t aPLLMULFactorTable[16] = {2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 16}; | ||||
|   static const uint8_t aPLLMULFactorTable[16U] = {2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 16}; | ||||
| #if defined(RCC_CFGR2_PREDIV1) | ||||
|   const uint8_t aPredivFactorTable[16] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16}; | ||||
|   static const uint8_t aPredivFactorTable[16U] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16}; | ||||
| #else | ||||
|   const uint8_t aPredivFactorTable[2] = {1, 2}; | ||||
|   static const uint8_t aPredivFactorTable[2U] = {1, 2}; | ||||
| #endif /*RCC_CFGR2_PREDIV1*/ | ||||
| 
 | ||||
| #endif | ||||
| @ -1400,4 +1398,3 @@ __weak void HAL_RCC_CSSCallback(void) | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | ||||
| @ -10,14 +10,12 @@ | ||||
|   ****************************************************************************** | ||||
|   * @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 | ||||
|   * Copyright (c) 2016 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. | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| @ -110,11 +108,11 @@ HAL_StatusTypeDef HAL_RCCEx_PeriphCLKConfig(RCC_PeriphCLKInitTypeDef  *PeriphClk | ||||
|   /*------------------------------- RTC/LCD Configuration ------------------------*/ | ||||
|   if ((((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_RTC) == RCC_PERIPHCLK_RTC)) | ||||
|   { | ||||
|     FlagStatus pwrclkchanged = RESET; | ||||
| 
 | ||||
|     /* check for RTC Parameters used to output RTCCLK */ | ||||
|     assert_param(IS_RCC_RTCCLKSOURCE(PeriphClkInit->RTCClockSelection)); | ||||
| 
 | ||||
|     FlagStatus       pwrclkchanged = RESET; | ||||
| 
 | ||||
|     /* As soon as function is called to change RTC clock source, activation of the
 | ||||
|        power domain is done. */ | ||||
|     /* Requires to enable write access to Backup Domain of necessary */ | ||||
| @ -387,16 +385,16 @@ void HAL_RCCEx_GetPeriphCLKConfig(RCC_PeriphCLKInitTypeDef  *PeriphClkInit) | ||||
| uint32_t HAL_RCCEx_GetPeriphCLKFreq(uint32_t PeriphClk) | ||||
| { | ||||
| #if defined(STM32F105xC) || defined(STM32F107xC) | ||||
|   const uint8_t aPLLMULFactorTable[14] = {0, 0, 4, 5, 6, 7, 8, 9, 0, 0, 0, 0, 0, 13}; | ||||
|   const uint8_t aPredivFactorTable[16] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16}; | ||||
|   static const uint8_t aPLLMULFactorTable[14U] = {0, 0, 4, 5, 6, 7, 8, 9, 0, 0, 0, 0, 0, 13}; | ||||
|   static const uint8_t aPredivFactorTable[16U] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16}; | ||||
| 
 | ||||
|   uint32_t prediv1 = 0U, pllclk = 0U, pllmul = 0U; | ||||
|   uint32_t pll2mul = 0U, pll3mul = 0U, prediv2 = 0U; | ||||
| #endif /* STM32F105xC || STM32F107xC */ | ||||
| #if defined(STM32F102x6) || defined(STM32F102xB) || defined(STM32F103x6) || \ | ||||
|     defined(STM32F103xB) || defined(STM32F103xE) || defined(STM32F103xG) | ||||
|   const uint8_t aPLLMULFactorTable[16] = {2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 16}; | ||||
|   const uint8_t aPredivFactorTable[2] = {1, 2}; | ||||
|   static const uint8_t aPLLMULFactorTable[16U] = {2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 16}; | ||||
|   static const uint8_t aPredivFactorTable[2U] = {1, 2}; | ||||
| 
 | ||||
|   uint32_t prediv1 = 0U, pllclk = 0U, pllmul = 0U; | ||||
| #endif /* STM32F102x6 || STM32F102xB || STM32F103x6 || STM32F103xB || STM32F103xE || STM32F103xG */ | ||||
| @ -859,5 +857,4 @@ HAL_StatusTypeDef HAL_RCCEx_DisablePLL2(void) | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
| 
 | ||||
|  | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @ -10,6 +10,17 @@ | ||||
|   *           + Time Complementary signal break and dead time configuration | ||||
|   *           + Time Master and Slave synchronization configuration | ||||
|   *           + Timer remapping capabilities configuration | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * Copyright (c) 2016 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. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   @verbatim | ||||
|   ============================================================================== | ||||
|                       ##### TIMER Extended features ##### | ||||
| @ -54,24 +65,16 @@ | ||||
|                the commutation event). | ||||
| 
 | ||||
|      (#) Activate the TIM peripheral using one of the start functions: | ||||
|            (++) Complementary Output Compare : HAL_TIMEx_OCN_Start(), HAL_TIMEx_OCN_Start_DMA(), HAL_TIMEx_OCN_Start_IT() | ||||
|            (++) Complementary PWM generation : HAL_TIMEx_PWMN_Start(), HAL_TIMEx_PWMN_Start_DMA(), HAL_TIMEx_PWMN_Start_IT() | ||||
|            (++) Complementary Output Compare : HAL_TIMEx_OCN_Start(), HAL_TIMEx_OCN_Start_DMA(), | ||||
|                 HAL_TIMEx_OCN_Start_IT() | ||||
|            (++) Complementary PWM generation : HAL_TIMEx_PWMN_Start(), HAL_TIMEx_PWMN_Start_DMA(), | ||||
|                 HAL_TIMEx_PWMN_Start_IT() | ||||
|            (++) Complementary One-pulse mode output : HAL_TIMEx_OnePulseN_Start(), HAL_TIMEx_OnePulseN_Start_IT() | ||||
|            (++) Hall Sensor output : HAL_TIMEx_HallSensor_Start(), HAL_TIMEx_HallSensor_Start_DMA(), HAL_TIMEx_HallSensor_Start_IT(). | ||||
|            (++) Hall Sensor output : HAL_TIMEx_HallSensor_Start(), HAL_TIMEx_HallSensor_Start_DMA(), | ||||
|                 HAL_TIMEx_HallSensor_Start_IT(). | ||||
| 
 | ||||
|   @endverbatim | ||||
|   ****************************************************************************** | ||||
|   * @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 | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| @ -132,7 +135,7 @@ static void TIM_CCxNChannelCmd(TIM_TypeDef *TIMx, uint32_t Channel, uint32_t Cha | ||||
|   * @param  sConfig TIM Hall Sensor configuration structure | ||||
|   * @retval HAL status | ||||
|   */ | ||||
| HAL_StatusTypeDef HAL_TIMEx_HallSensor_Init(TIM_HandleTypeDef *htim, TIM_HallSensor_InitTypeDef *sConfig) | ||||
| HAL_StatusTypeDef HAL_TIMEx_HallSensor_Init(TIM_HandleTypeDef *htim, const TIM_HallSensor_InitTypeDef *sConfig) | ||||
| { | ||||
|   TIM_OC_InitTypeDef OC_Config; | ||||
| 
 | ||||
| @ -148,6 +151,7 @@ HAL_StatusTypeDef HAL_TIMEx_HallSensor_Init(TIM_HandleTypeDef *htim, TIM_HallSen | ||||
|   assert_param(IS_TIM_CLOCKDIVISION_DIV(htim->Init.ClockDivision)); | ||||
|   assert_param(IS_TIM_AUTORELOAD_PRELOAD(htim->Init.AutoReloadPreload)); | ||||
|   assert_param(IS_TIM_IC_POLARITY(sConfig->IC1Polarity)); | ||||
|   assert_param(IS_TIM_PERIOD(htim->Init.Period)); | ||||
|   assert_param(IS_TIM_IC_PRESCALER(sConfig->IC1Prescaler)); | ||||
|   assert_param(IS_TIM_IC_FILTER(sConfig->IC1Filter)); | ||||
| 
 | ||||
| @ -335,7 +339,8 @@ HAL_StatusTypeDef HAL_TIMEx_HallSensor_Start(TIM_HandleTypeDef *htim) | ||||
|   TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_BUSY); | ||||
| 
 | ||||
|   /* Enable the Input Capture channel 1
 | ||||
|   (in the Hall Sensor Interface the three possible channels that can be used are TIM_CHANNEL_1, TIM_CHANNEL_2 and TIM_CHANNEL_3) */ | ||||
|   (in the Hall Sensor Interface the three possible channels that can be used are TIM_CHANNEL_1, | ||||
|   TIM_CHANNEL_2 and TIM_CHANNEL_3) */ | ||||
|   TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_1, TIM_CCx_ENABLE); | ||||
| 
 | ||||
|   /* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */ | ||||
| @ -367,7 +372,8 @@ HAL_StatusTypeDef HAL_TIMEx_HallSensor_Stop(TIM_HandleTypeDef *htim) | ||||
|   assert_param(IS_TIM_HALL_SENSOR_INTERFACE_INSTANCE(htim->Instance)); | ||||
| 
 | ||||
|   /* Disable the Input Capture channels 1, 2 and 3
 | ||||
|     (in the Hall Sensor Interface the three possible channels that can be used are TIM_CHANNEL_1, TIM_CHANNEL_2 and TIM_CHANNEL_3) */ | ||||
|   (in the Hall Sensor Interface the three possible channels that can be used are TIM_CHANNEL_1, | ||||
|   TIM_CHANNEL_2 and TIM_CHANNEL_3) */ | ||||
|   TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_1, TIM_CCx_DISABLE); | ||||
| 
 | ||||
|   /* Disable the Peripheral */ | ||||
| @ -418,7 +424,8 @@ HAL_StatusTypeDef HAL_TIMEx_HallSensor_Start_IT(TIM_HandleTypeDef *htim) | ||||
|   __HAL_TIM_ENABLE_IT(htim, TIM_IT_CC1); | ||||
| 
 | ||||
|   /* Enable the Input Capture channel 1
 | ||||
|     (in the Hall Sensor Interface the three possible channels that can be used are TIM_CHANNEL_1, TIM_CHANNEL_2 and TIM_CHANNEL_3) */ | ||||
|   (in the Hall Sensor Interface the three possible channels that can be used are TIM_CHANNEL_1, | ||||
|   TIM_CHANNEL_2 and TIM_CHANNEL_3) */ | ||||
|   TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_1, TIM_CCx_ENABLE); | ||||
| 
 | ||||
|   /* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */ | ||||
| @ -450,7 +457,8 @@ HAL_StatusTypeDef HAL_TIMEx_HallSensor_Stop_IT(TIM_HandleTypeDef *htim) | ||||
|   assert_param(IS_TIM_HALL_SENSOR_INTERFACE_INSTANCE(htim->Instance)); | ||||
| 
 | ||||
|   /* Disable the Input Capture channel 1
 | ||||
|     (in the Hall Sensor Interface the three possible channels that can be used are TIM_CHANNEL_1, TIM_CHANNEL_2 and TIM_CHANNEL_3) */ | ||||
|   (in the Hall Sensor Interface the three possible channels that can be used are TIM_CHANNEL_1, | ||||
|   TIM_CHANNEL_2 and TIM_CHANNEL_3) */ | ||||
|   TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_1, TIM_CCx_DISABLE); | ||||
| 
 | ||||
|   /* Disable the capture compare Interrupts event */ | ||||
| @ -494,7 +502,7 @@ HAL_StatusTypeDef HAL_TIMEx_HallSensor_Start_DMA(TIM_HandleTypeDef *htim, uint32 | ||||
|   else if ((channel_1_state == HAL_TIM_CHANNEL_STATE_READY) | ||||
|            && (complementary_channel_1_state == HAL_TIM_CHANNEL_STATE_READY)) | ||||
|   { | ||||
|     if ((pData == NULL) && (Length > 0U)) | ||||
|     if ((pData == NULL) || (Length == 0U)) | ||||
|     { | ||||
|       return HAL_ERROR; | ||||
|     } | ||||
| @ -510,7 +518,8 @@ HAL_StatusTypeDef HAL_TIMEx_HallSensor_Start_DMA(TIM_HandleTypeDef *htim, uint32 | ||||
|   } | ||||
| 
 | ||||
|   /* Enable the Input Capture channel 1
 | ||||
|     (in the Hall Sensor Interface the three possible channels that can be used are TIM_CHANNEL_1, TIM_CHANNEL_2 and TIM_CHANNEL_3) */ | ||||
|   (in the Hall Sensor Interface the three possible channels that can be used are TIM_CHANNEL_1, | ||||
|   TIM_CHANNEL_2 and TIM_CHANNEL_3) */ | ||||
|   TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_1, TIM_CCx_ENABLE); | ||||
| 
 | ||||
|   /* Set the DMA Input Capture 1 Callbacks */ | ||||
| @ -557,7 +566,8 @@ HAL_StatusTypeDef HAL_TIMEx_HallSensor_Stop_DMA(TIM_HandleTypeDef *htim) | ||||
|   assert_param(IS_TIM_HALL_SENSOR_INTERFACE_INSTANCE(htim->Instance)); | ||||
| 
 | ||||
|   /* Disable the Input Capture channel 1
 | ||||
|     (in the Hall Sensor Interface the three possible channels that can be used are TIM_CHANNEL_1, TIM_CHANNEL_2 and TIM_CHANNEL_3) */ | ||||
|   (in the Hall Sensor Interface the three possible channels that can be used are TIM_CHANNEL_1, | ||||
|   TIM_CHANNEL_2 and TIM_CHANNEL_3) */ | ||||
|   TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_1, TIM_CCx_DISABLE); | ||||
| 
 | ||||
| 
 | ||||
| @ -697,6 +707,7 @@ HAL_StatusTypeDef HAL_TIMEx_OCN_Stop(TIM_HandleTypeDef *htim, uint32_t Channel) | ||||
|   */ | ||||
| HAL_StatusTypeDef HAL_TIMEx_OCN_Start_IT(TIM_HandleTypeDef *htim, uint32_t Channel) | ||||
| { | ||||
|   HAL_StatusTypeDef status = HAL_OK; | ||||
|   uint32_t tmpsmcr; | ||||
| 
 | ||||
|   /* Check the parameters */ | ||||
| @ -736,34 +747,38 @@ HAL_StatusTypeDef HAL_TIMEx_OCN_Start_IT(TIM_HandleTypeDef *htim, uint32_t Chann | ||||
| 
 | ||||
| 
 | ||||
|     default: | ||||
|       status = HAL_ERROR; | ||||
|       break; | ||||
|   } | ||||
| 
 | ||||
|   /* Enable the TIM Break interrupt */ | ||||
|   __HAL_TIM_ENABLE_IT(htim, TIM_IT_BREAK); | ||||
| 
 | ||||
|   /* Enable the Capture compare channel N */ | ||||
|   TIM_CCxNChannelCmd(htim->Instance, Channel, TIM_CCxN_ENABLE); | ||||
| 
 | ||||
|   /* Enable the Main Output */ | ||||
|   __HAL_TIM_MOE_ENABLE(htim); | ||||
| 
 | ||||
|   /* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */ | ||||
|   if (IS_TIM_SLAVE_INSTANCE(htim->Instance)) | ||||
|   if (status == HAL_OK) | ||||
|   { | ||||
|     tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS; | ||||
|     if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr)) | ||||
|     /* Enable the TIM Break interrupt */ | ||||
|     __HAL_TIM_ENABLE_IT(htim, TIM_IT_BREAK); | ||||
| 
 | ||||
|     /* Enable the Capture compare channel N */ | ||||
|     TIM_CCxNChannelCmd(htim->Instance, Channel, TIM_CCxN_ENABLE); | ||||
| 
 | ||||
|     /* Enable the Main Output */ | ||||
|     __HAL_TIM_MOE_ENABLE(htim); | ||||
| 
 | ||||
|     /* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */ | ||||
|     if (IS_TIM_SLAVE_INSTANCE(htim->Instance)) | ||||
|     { | ||||
|       tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS; | ||||
|       if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr)) | ||||
|       { | ||||
|         __HAL_TIM_ENABLE(htim); | ||||
|       } | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|       __HAL_TIM_ENABLE(htim); | ||||
|     } | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     __HAL_TIM_ENABLE(htim); | ||||
|   } | ||||
| 
 | ||||
|   /* Return function status */ | ||||
|   return HAL_OK; | ||||
|   return status; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
| @ -779,7 +794,9 @@ HAL_StatusTypeDef HAL_TIMEx_OCN_Start_IT(TIM_HandleTypeDef *htim, uint32_t Chann | ||||
|   */ | ||||
| HAL_StatusTypeDef HAL_TIMEx_OCN_Stop_IT(TIM_HandleTypeDef *htim, uint32_t Channel) | ||||
| { | ||||
|   HAL_StatusTypeDef status = HAL_OK; | ||||
|   uint32_t tmpccer; | ||||
| 
 | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, Channel)); | ||||
| 
 | ||||
| @ -807,30 +824,34 @@ HAL_StatusTypeDef HAL_TIMEx_OCN_Stop_IT(TIM_HandleTypeDef *htim, uint32_t Channe | ||||
|     } | ||||
| 
 | ||||
|     default: | ||||
|       status = HAL_ERROR; | ||||
|       break; | ||||
|   } | ||||
| 
 | ||||
|   /* Disable the Capture compare channel N */ | ||||
|   TIM_CCxNChannelCmd(htim->Instance, Channel, TIM_CCxN_DISABLE); | ||||
| 
 | ||||
|   /* Disable the TIM Break interrupt (only if no more channel is active) */ | ||||
|   tmpccer = htim->Instance->CCER; | ||||
|   if ((tmpccer & (TIM_CCER_CC1NE | TIM_CCER_CC2NE | TIM_CCER_CC3NE)) == (uint32_t)RESET) | ||||
|   if (status == HAL_OK) | ||||
|   { | ||||
|     __HAL_TIM_DISABLE_IT(htim, TIM_IT_BREAK); | ||||
|     /* Disable the Capture compare channel N */ | ||||
|     TIM_CCxNChannelCmd(htim->Instance, Channel, TIM_CCxN_DISABLE); | ||||
| 
 | ||||
|     /* Disable the TIM Break interrupt (only if no more channel is active) */ | ||||
|     tmpccer = htim->Instance->CCER; | ||||
|     if ((tmpccer & TIM_CCER_CCxNE_MASK) == (uint32_t)RESET) | ||||
|     { | ||||
|       __HAL_TIM_DISABLE_IT(htim, TIM_IT_BREAK); | ||||
|     } | ||||
| 
 | ||||
|     /* Disable the Main Output */ | ||||
|     __HAL_TIM_MOE_DISABLE(htim); | ||||
| 
 | ||||
|     /* Disable the Peripheral */ | ||||
|     __HAL_TIM_DISABLE(htim); | ||||
| 
 | ||||
|     /* Set the TIM complementary channel state */ | ||||
|     TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY); | ||||
|   } | ||||
| 
 | ||||
|   /* Disable the Main Output */ | ||||
|   __HAL_TIM_MOE_DISABLE(htim); | ||||
| 
 | ||||
|   /* Disable the Peripheral */ | ||||
|   __HAL_TIM_DISABLE(htim); | ||||
| 
 | ||||
|   /* Set the TIM complementary channel state */ | ||||
|   TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY); | ||||
| 
 | ||||
|   /* Return function status */ | ||||
|   return HAL_OK; | ||||
|   return status; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
| @ -846,8 +867,10 @@ HAL_StatusTypeDef HAL_TIMEx_OCN_Stop_IT(TIM_HandleTypeDef *htim, uint32_t Channe | ||||
|   * @param  Length The length of data to be transferred from memory to TIM peripheral | ||||
|   * @retval HAL status | ||||
|   */ | ||||
| HAL_StatusTypeDef HAL_TIMEx_OCN_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Channel, uint32_t *pData, uint16_t Length) | ||||
| HAL_StatusTypeDef HAL_TIMEx_OCN_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Channel, const uint32_t *pData, | ||||
|                                           uint16_t Length) | ||||
| { | ||||
|   HAL_StatusTypeDef status = HAL_OK; | ||||
|   uint32_t tmpsmcr; | ||||
| 
 | ||||
|   /* Check the parameters */ | ||||
| @ -860,7 +883,7 @@ HAL_StatusTypeDef HAL_TIMEx_OCN_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Chan | ||||
|   } | ||||
|   else if (TIM_CHANNEL_N_STATE_GET(htim, Channel) == HAL_TIM_CHANNEL_STATE_READY) | ||||
|   { | ||||
|     if ((pData == NULL) && (Length > 0U)) | ||||
|     if ((pData == NULL) || (Length == 0U)) | ||||
|     { | ||||
|       return HAL_ERROR; | ||||
|     } | ||||
| @ -886,7 +909,8 @@ HAL_StatusTypeDef HAL_TIMEx_OCN_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Chan | ||||
|       htim->hdma[TIM_DMA_ID_CC1]->XferErrorCallback = TIM_DMAErrorCCxN ; | ||||
| 
 | ||||
|       /* Enable the DMA channel */ | ||||
|       if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC1], (uint32_t)pData, (uint32_t)&htim->Instance->CCR1, Length) != HAL_OK) | ||||
|       if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC1], (uint32_t)pData, (uint32_t)&htim->Instance->CCR1, | ||||
|                            Length) != HAL_OK) | ||||
|       { | ||||
|         /* Return error status */ | ||||
|         return HAL_ERROR; | ||||
| @ -906,7 +930,8 @@ HAL_StatusTypeDef HAL_TIMEx_OCN_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Chan | ||||
|       htim->hdma[TIM_DMA_ID_CC2]->XferErrorCallback = TIM_DMAErrorCCxN ; | ||||
| 
 | ||||
|       /* Enable the DMA channel */ | ||||
|       if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC2], (uint32_t)pData, (uint32_t)&htim->Instance->CCR2, Length) != HAL_OK) | ||||
|       if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC2], (uint32_t)pData, (uint32_t)&htim->Instance->CCR2, | ||||
|                            Length) != HAL_OK) | ||||
|       { | ||||
|         /* Return error status */ | ||||
|         return HAL_ERROR; | ||||
| @ -926,7 +951,8 @@ HAL_StatusTypeDef HAL_TIMEx_OCN_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Chan | ||||
|       htim->hdma[TIM_DMA_ID_CC3]->XferErrorCallback = TIM_DMAErrorCCxN ; | ||||
| 
 | ||||
|       /* Enable the DMA channel */ | ||||
|       if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC3], (uint32_t)pData, (uint32_t)&htim->Instance->CCR3, Length) != HAL_OK) | ||||
|       if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC3], (uint32_t)pData, (uint32_t)&htim->Instance->CCR3, | ||||
|                            Length) != HAL_OK) | ||||
|       { | ||||
|         /* Return error status */ | ||||
|         return HAL_ERROR; | ||||
| @ -937,31 +963,35 @@ HAL_StatusTypeDef HAL_TIMEx_OCN_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Chan | ||||
|     } | ||||
| 
 | ||||
|     default: | ||||
|       status = HAL_ERROR; | ||||
|       break; | ||||
|   } | ||||
| 
 | ||||
|   /* Enable the Capture compare channel N */ | ||||
|   TIM_CCxNChannelCmd(htim->Instance, Channel, TIM_CCxN_ENABLE); | ||||
| 
 | ||||
|   /* Enable the Main Output */ | ||||
|   __HAL_TIM_MOE_ENABLE(htim); | ||||
| 
 | ||||
|   /* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */ | ||||
|   if (IS_TIM_SLAVE_INSTANCE(htim->Instance)) | ||||
|   if (status == HAL_OK) | ||||
|   { | ||||
|     tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS; | ||||
|     if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr)) | ||||
|     /* Enable the Capture compare channel N */ | ||||
|     TIM_CCxNChannelCmd(htim->Instance, Channel, TIM_CCxN_ENABLE); | ||||
| 
 | ||||
|     /* Enable the Main Output */ | ||||
|     __HAL_TIM_MOE_ENABLE(htim); | ||||
| 
 | ||||
|     /* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */ | ||||
|     if (IS_TIM_SLAVE_INSTANCE(htim->Instance)) | ||||
|     { | ||||
|       tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS; | ||||
|       if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr)) | ||||
|       { | ||||
|         __HAL_TIM_ENABLE(htim); | ||||
|       } | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|       __HAL_TIM_ENABLE(htim); | ||||
|     } | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     __HAL_TIM_ENABLE(htim); | ||||
|   } | ||||
| 
 | ||||
|   /* Return function status */ | ||||
|   return HAL_OK; | ||||
|   return status; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
| @ -977,6 +1007,8 @@ HAL_StatusTypeDef HAL_TIMEx_OCN_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Chan | ||||
|   */ | ||||
| HAL_StatusTypeDef HAL_TIMEx_OCN_Stop_DMA(TIM_HandleTypeDef *htim, uint32_t Channel) | ||||
| { | ||||
|   HAL_StatusTypeDef status = HAL_OK; | ||||
| 
 | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, Channel)); | ||||
| 
 | ||||
| @ -1007,23 +1039,27 @@ HAL_StatusTypeDef HAL_TIMEx_OCN_Stop_DMA(TIM_HandleTypeDef *htim, uint32_t Chann | ||||
|     } | ||||
| 
 | ||||
|     default: | ||||
|       status = HAL_ERROR; | ||||
|       break; | ||||
|   } | ||||
| 
 | ||||
|   /* Disable the Capture compare channel N */ | ||||
|   TIM_CCxNChannelCmd(htim->Instance, Channel, TIM_CCxN_DISABLE); | ||||
|   if (status == HAL_OK) | ||||
|   { | ||||
|     /* Disable the Capture compare channel N */ | ||||
|     TIM_CCxNChannelCmd(htim->Instance, Channel, TIM_CCxN_DISABLE); | ||||
| 
 | ||||
|   /* Disable the Main Output */ | ||||
|   __HAL_TIM_MOE_DISABLE(htim); | ||||
|     /* Disable the Main Output */ | ||||
|     __HAL_TIM_MOE_DISABLE(htim); | ||||
| 
 | ||||
|   /* Disable the Peripheral */ | ||||
|   __HAL_TIM_DISABLE(htim); | ||||
|     /* Disable the Peripheral */ | ||||
|     __HAL_TIM_DISABLE(htim); | ||||
| 
 | ||||
|   /* Set the TIM complementary channel state */ | ||||
|   TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY); | ||||
|     /* Set the TIM complementary channel state */ | ||||
|     TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY); | ||||
|   } | ||||
| 
 | ||||
|   /* Return function status */ | ||||
|   return HAL_OK; | ||||
|   return status; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
| @ -1045,17 +1081,6 @@ HAL_StatusTypeDef HAL_TIMEx_OCN_Stop_DMA(TIM_HandleTypeDef *htim, uint32_t Chann | ||||
|     (+) Stop the Complementary PWM and disable interrupts. | ||||
|     (+) Start the Complementary PWM and enable DMA transfers. | ||||
|     (+) Stop the Complementary PWM and disable DMA transfers. | ||||
|     (+) Start the Complementary Input Capture measurement. | ||||
|     (+) Stop the Complementary Input Capture. | ||||
|     (+) Start the Complementary Input Capture and enable interrupts. | ||||
|     (+) Stop the Complementary Input Capture and disable interrupts. | ||||
|     (+) Start the Complementary Input Capture and enable DMA transfers. | ||||
|     (+) Stop the Complementary Input Capture and disable DMA transfers. | ||||
|     (+) Start the Complementary One Pulse generation. | ||||
|     (+) Stop the Complementary One Pulse. | ||||
|     (+) Start the Complementary One Pulse and enable interrupts. | ||||
|     (+) Stop the Complementary One Pulse and disable interrupts. | ||||
| 
 | ||||
| @endverbatim | ||||
|   * @{ | ||||
|   */ | ||||
| @ -1154,6 +1179,7 @@ HAL_StatusTypeDef HAL_TIMEx_PWMN_Stop(TIM_HandleTypeDef *htim, uint32_t Channel) | ||||
|   */ | ||||
| HAL_StatusTypeDef HAL_TIMEx_PWMN_Start_IT(TIM_HandleTypeDef *htim, uint32_t Channel) | ||||
| { | ||||
|   HAL_StatusTypeDef status = HAL_OK; | ||||
|   uint32_t tmpsmcr; | ||||
| 
 | ||||
|   /* Check the parameters */ | ||||
| @ -1192,34 +1218,38 @@ HAL_StatusTypeDef HAL_TIMEx_PWMN_Start_IT(TIM_HandleTypeDef *htim, uint32_t Chan | ||||
|     } | ||||
| 
 | ||||
|     default: | ||||
|       status = HAL_ERROR; | ||||
|       break; | ||||
|   } | ||||
| 
 | ||||
|   /* Enable the TIM Break interrupt */ | ||||
|   __HAL_TIM_ENABLE_IT(htim, TIM_IT_BREAK); | ||||
| 
 | ||||
|   /* Enable the complementary PWM output  */ | ||||
|   TIM_CCxNChannelCmd(htim->Instance, Channel, TIM_CCxN_ENABLE); | ||||
| 
 | ||||
|   /* Enable the Main Output */ | ||||
|   __HAL_TIM_MOE_ENABLE(htim); | ||||
| 
 | ||||
|   /* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */ | ||||
|   if (IS_TIM_SLAVE_INSTANCE(htim->Instance)) | ||||
|   if (status == HAL_OK) | ||||
|   { | ||||
|     tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS; | ||||
|     if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr)) | ||||
|     /* Enable the TIM Break interrupt */ | ||||
|     __HAL_TIM_ENABLE_IT(htim, TIM_IT_BREAK); | ||||
| 
 | ||||
|     /* Enable the complementary PWM output  */ | ||||
|     TIM_CCxNChannelCmd(htim->Instance, Channel, TIM_CCxN_ENABLE); | ||||
| 
 | ||||
|     /* Enable the Main Output */ | ||||
|     __HAL_TIM_MOE_ENABLE(htim); | ||||
| 
 | ||||
|     /* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */ | ||||
|     if (IS_TIM_SLAVE_INSTANCE(htim->Instance)) | ||||
|     { | ||||
|       tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS; | ||||
|       if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr)) | ||||
|       { | ||||
|         __HAL_TIM_ENABLE(htim); | ||||
|       } | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|       __HAL_TIM_ENABLE(htim); | ||||
|     } | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     __HAL_TIM_ENABLE(htim); | ||||
|   } | ||||
| 
 | ||||
|   /* Return function status */ | ||||
|   return HAL_OK; | ||||
|   return status; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
| @ -1235,6 +1265,7 @@ HAL_StatusTypeDef HAL_TIMEx_PWMN_Start_IT(TIM_HandleTypeDef *htim, uint32_t Chan | ||||
|   */ | ||||
| HAL_StatusTypeDef HAL_TIMEx_PWMN_Stop_IT(TIM_HandleTypeDef *htim, uint32_t Channel) | ||||
| { | ||||
|   HAL_StatusTypeDef status = HAL_OK; | ||||
|   uint32_t tmpccer; | ||||
| 
 | ||||
|   /* Check the parameters */ | ||||
| @ -1264,30 +1295,34 @@ HAL_StatusTypeDef HAL_TIMEx_PWMN_Stop_IT(TIM_HandleTypeDef *htim, uint32_t Chann | ||||
|     } | ||||
| 
 | ||||
|     default: | ||||
|       status = HAL_ERROR; | ||||
|       break; | ||||
|   } | ||||
| 
 | ||||
|   /* Disable the complementary PWM output  */ | ||||
|   TIM_CCxNChannelCmd(htim->Instance, Channel, TIM_CCxN_DISABLE); | ||||
| 
 | ||||
|   /* Disable the TIM Break interrupt (only if no more channel is active) */ | ||||
|   tmpccer = htim->Instance->CCER; | ||||
|   if ((tmpccer & (TIM_CCER_CC1NE | TIM_CCER_CC2NE | TIM_CCER_CC3NE)) == (uint32_t)RESET) | ||||
|   if (status == HAL_OK) | ||||
|   { | ||||
|     __HAL_TIM_DISABLE_IT(htim, TIM_IT_BREAK); | ||||
|     /* Disable the complementary PWM output  */ | ||||
|     TIM_CCxNChannelCmd(htim->Instance, Channel, TIM_CCxN_DISABLE); | ||||
| 
 | ||||
|     /* Disable the TIM Break interrupt (only if no more channel is active) */ | ||||
|     tmpccer = htim->Instance->CCER; | ||||
|     if ((tmpccer & TIM_CCER_CCxNE_MASK) == (uint32_t)RESET) | ||||
|     { | ||||
|       __HAL_TIM_DISABLE_IT(htim, TIM_IT_BREAK); | ||||
|     } | ||||
| 
 | ||||
|     /* Disable the Main Output */ | ||||
|     __HAL_TIM_MOE_DISABLE(htim); | ||||
| 
 | ||||
|     /* Disable the Peripheral */ | ||||
|     __HAL_TIM_DISABLE(htim); | ||||
| 
 | ||||
|     /* Set the TIM complementary channel state */ | ||||
|     TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY); | ||||
|   } | ||||
| 
 | ||||
|   /* Disable the Main Output */ | ||||
|   __HAL_TIM_MOE_DISABLE(htim); | ||||
| 
 | ||||
|   /* Disable the Peripheral */ | ||||
|   __HAL_TIM_DISABLE(htim); | ||||
| 
 | ||||
|   /* Set the TIM complementary channel state */ | ||||
|   TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY); | ||||
| 
 | ||||
|   /* Return function status */ | ||||
|   return HAL_OK; | ||||
|   return status; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
| @ -1303,8 +1338,10 @@ HAL_StatusTypeDef HAL_TIMEx_PWMN_Stop_IT(TIM_HandleTypeDef *htim, uint32_t Chann | ||||
|   * @param  Length The length of data to be transferred from memory to TIM peripheral | ||||
|   * @retval HAL status | ||||
|   */ | ||||
| HAL_StatusTypeDef HAL_TIMEx_PWMN_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Channel, uint32_t *pData, uint16_t Length) | ||||
| HAL_StatusTypeDef HAL_TIMEx_PWMN_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Channel, const uint32_t *pData, | ||||
|                                            uint16_t Length) | ||||
| { | ||||
|   HAL_StatusTypeDef status = HAL_OK; | ||||
|   uint32_t tmpsmcr; | ||||
| 
 | ||||
|   /* Check the parameters */ | ||||
| @ -1317,7 +1354,7 @@ HAL_StatusTypeDef HAL_TIMEx_PWMN_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Cha | ||||
|   } | ||||
|   else if (TIM_CHANNEL_N_STATE_GET(htim, Channel) == HAL_TIM_CHANNEL_STATE_READY) | ||||
|   { | ||||
|     if ((pData == NULL) && (Length > 0U)) | ||||
|     if ((pData == NULL) || (Length == 0U)) | ||||
|     { | ||||
|       return HAL_ERROR; | ||||
|     } | ||||
| @ -1343,7 +1380,8 @@ HAL_StatusTypeDef HAL_TIMEx_PWMN_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Cha | ||||
|       htim->hdma[TIM_DMA_ID_CC1]->XferErrorCallback = TIM_DMAErrorCCxN ; | ||||
| 
 | ||||
|       /* Enable the DMA channel */ | ||||
|       if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC1], (uint32_t)pData, (uint32_t)&htim->Instance->CCR1, Length) != HAL_OK) | ||||
|       if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC1], (uint32_t)pData, (uint32_t)&htim->Instance->CCR1, | ||||
|                            Length) != HAL_OK) | ||||
|       { | ||||
|         /* Return error status */ | ||||
|         return HAL_ERROR; | ||||
| @ -1363,7 +1401,8 @@ HAL_StatusTypeDef HAL_TIMEx_PWMN_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Cha | ||||
|       htim->hdma[TIM_DMA_ID_CC2]->XferErrorCallback = TIM_DMAErrorCCxN ; | ||||
| 
 | ||||
|       /* Enable the DMA channel */ | ||||
|       if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC2], (uint32_t)pData, (uint32_t)&htim->Instance->CCR2, Length) != HAL_OK) | ||||
|       if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC2], (uint32_t)pData, (uint32_t)&htim->Instance->CCR2, | ||||
|                            Length) != HAL_OK) | ||||
|       { | ||||
|         /* Return error status */ | ||||
|         return HAL_ERROR; | ||||
| @ -1383,7 +1422,8 @@ HAL_StatusTypeDef HAL_TIMEx_PWMN_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Cha | ||||
|       htim->hdma[TIM_DMA_ID_CC3]->XferErrorCallback = TIM_DMAErrorCCxN ; | ||||
| 
 | ||||
|       /* Enable the DMA channel */ | ||||
|       if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC3], (uint32_t)pData, (uint32_t)&htim->Instance->CCR3, Length) != HAL_OK) | ||||
|       if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC3], (uint32_t)pData, (uint32_t)&htim->Instance->CCR3, | ||||
|                            Length) != HAL_OK) | ||||
|       { | ||||
|         /* Return error status */ | ||||
|         return HAL_ERROR; | ||||
| @ -1394,31 +1434,35 @@ HAL_StatusTypeDef HAL_TIMEx_PWMN_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Cha | ||||
|     } | ||||
| 
 | ||||
|     default: | ||||
|       status = HAL_ERROR; | ||||
|       break; | ||||
|   } | ||||
| 
 | ||||
|   /* Enable the complementary PWM output  */ | ||||
|   TIM_CCxNChannelCmd(htim->Instance, Channel, TIM_CCxN_ENABLE); | ||||
| 
 | ||||
|   /* Enable the Main Output */ | ||||
|   __HAL_TIM_MOE_ENABLE(htim); | ||||
| 
 | ||||
|   /* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */ | ||||
|   if (IS_TIM_SLAVE_INSTANCE(htim->Instance)) | ||||
|   if (status == HAL_OK) | ||||
|   { | ||||
|     tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS; | ||||
|     if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr)) | ||||
|     /* Enable the complementary PWM output  */ | ||||
|     TIM_CCxNChannelCmd(htim->Instance, Channel, TIM_CCxN_ENABLE); | ||||
| 
 | ||||
|     /* Enable the Main Output */ | ||||
|     __HAL_TIM_MOE_ENABLE(htim); | ||||
| 
 | ||||
|     /* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */ | ||||
|     if (IS_TIM_SLAVE_INSTANCE(htim->Instance)) | ||||
|     { | ||||
|       tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS; | ||||
|       if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr)) | ||||
|       { | ||||
|         __HAL_TIM_ENABLE(htim); | ||||
|       } | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|       __HAL_TIM_ENABLE(htim); | ||||
|     } | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     __HAL_TIM_ENABLE(htim); | ||||
|   } | ||||
| 
 | ||||
|   /* Return function status */ | ||||
|   return HAL_OK; | ||||
|   return status; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
| @ -1434,6 +1478,8 @@ HAL_StatusTypeDef HAL_TIMEx_PWMN_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Cha | ||||
|   */ | ||||
| HAL_StatusTypeDef HAL_TIMEx_PWMN_Stop_DMA(TIM_HandleTypeDef *htim, uint32_t Channel) | ||||
| { | ||||
|   HAL_StatusTypeDef status = HAL_OK; | ||||
| 
 | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, Channel)); | ||||
| 
 | ||||
| @ -1464,23 +1510,27 @@ HAL_StatusTypeDef HAL_TIMEx_PWMN_Stop_DMA(TIM_HandleTypeDef *htim, uint32_t Chan | ||||
|     } | ||||
| 
 | ||||
|     default: | ||||
|       status = HAL_ERROR; | ||||
|       break; | ||||
|   } | ||||
| 
 | ||||
|   /* Disable the complementary PWM output */ | ||||
|   TIM_CCxNChannelCmd(htim->Instance, Channel, TIM_CCxN_DISABLE); | ||||
|   if (status == HAL_OK) | ||||
|   { | ||||
|     /* Disable the complementary PWM output */ | ||||
|     TIM_CCxNChannelCmd(htim->Instance, Channel, TIM_CCxN_DISABLE); | ||||
| 
 | ||||
|   /* Disable the Main Output */ | ||||
|   __HAL_TIM_MOE_DISABLE(htim); | ||||
|     /* Disable the Main Output */ | ||||
|     __HAL_TIM_MOE_DISABLE(htim); | ||||
| 
 | ||||
|   /* Disable the Peripheral */ | ||||
|   __HAL_TIM_DISABLE(htim); | ||||
|     /* Disable the Peripheral */ | ||||
|     __HAL_TIM_DISABLE(htim); | ||||
| 
 | ||||
|   /* Set the TIM complementary channel state */ | ||||
|   TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY); | ||||
|     /* Set the TIM complementary channel state */ | ||||
|     TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY); | ||||
|   } | ||||
| 
 | ||||
|   /* Return function status */ | ||||
|   return HAL_OK; | ||||
|   return status; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
| @ -1508,8 +1558,10 @@ HAL_StatusTypeDef HAL_TIMEx_PWMN_Stop_DMA(TIM_HandleTypeDef *htim, uint32_t Chan | ||||
| /**
 | ||||
|   * @brief  Starts the TIM One Pulse signal generation on the complementary | ||||
|   *         output. | ||||
|   * @note OutputChannel must match the pulse output channel chosen when calling | ||||
|   *       @ref HAL_TIM_OnePulse_ConfigChannel(). | ||||
|   * @param  htim TIM One Pulse handle | ||||
|   * @param  OutputChannel TIM Channel to be enabled | ||||
|   * @param  OutputChannel pulse output channel to enable | ||||
|   *          This parameter can be one of the following values: | ||||
|   *            @arg TIM_CHANNEL_1: TIM Channel 1 selected | ||||
|   *            @arg TIM_CHANNEL_2: TIM Channel 2 selected | ||||
| @ -1518,22 +1570,28 @@ HAL_StatusTypeDef HAL_TIMEx_PWMN_Stop_DMA(TIM_HandleTypeDef *htim, uint32_t Chan | ||||
| HAL_StatusTypeDef HAL_TIMEx_OnePulseN_Start(TIM_HandleTypeDef *htim, uint32_t OutputChannel) | ||||
| { | ||||
|   uint32_t input_channel = (OutputChannel == TIM_CHANNEL_1) ? TIM_CHANNEL_2 : TIM_CHANNEL_1; | ||||
|   HAL_TIM_ChannelStateTypeDef input_channel_state = TIM_CHANNEL_STATE_GET(htim, input_channel); | ||||
|   HAL_TIM_ChannelStateTypeDef output_channel_state = TIM_CHANNEL_N_STATE_GET(htim, OutputChannel); | ||||
|   HAL_TIM_ChannelStateTypeDef channel_1_state = TIM_CHANNEL_STATE_GET(htim, TIM_CHANNEL_1); | ||||
|   HAL_TIM_ChannelStateTypeDef channel_2_state = TIM_CHANNEL_STATE_GET(htim, TIM_CHANNEL_2); | ||||
|   HAL_TIM_ChannelStateTypeDef complementary_channel_1_state = TIM_CHANNEL_N_STATE_GET(htim, TIM_CHANNEL_1); | ||||
|   HAL_TIM_ChannelStateTypeDef complementary_channel_2_state = TIM_CHANNEL_N_STATE_GET(htim, TIM_CHANNEL_2); | ||||
| 
 | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, OutputChannel)); | ||||
| 
 | ||||
|   /* Check the TIM channels state */ | ||||
|   if ((output_channel_state != HAL_TIM_CHANNEL_STATE_READY) | ||||
|       || (input_channel_state != HAL_TIM_CHANNEL_STATE_READY)) | ||||
|   if ((channel_1_state != HAL_TIM_CHANNEL_STATE_READY) | ||||
|       || (channel_2_state != HAL_TIM_CHANNEL_STATE_READY) | ||||
|       || (complementary_channel_1_state != HAL_TIM_CHANNEL_STATE_READY) | ||||
|       || (complementary_channel_2_state != HAL_TIM_CHANNEL_STATE_READY)) | ||||
|   { | ||||
|     return HAL_ERROR; | ||||
|   } | ||||
| 
 | ||||
|   /* Set the TIM channels state */ | ||||
|   TIM_CHANNEL_N_STATE_SET(htim, OutputChannel, HAL_TIM_CHANNEL_STATE_BUSY); | ||||
|   TIM_CHANNEL_STATE_SET(htim, input_channel, HAL_TIM_CHANNEL_STATE_BUSY); | ||||
|   TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_BUSY); | ||||
|   TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_BUSY); | ||||
|   TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_BUSY); | ||||
|   TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_BUSY); | ||||
| 
 | ||||
|   /* Enable the complementary One Pulse output channel and the Input Capture channel */ | ||||
|   TIM_CCxNChannelCmd(htim->Instance, OutputChannel, TIM_CCxN_ENABLE); | ||||
| @ -1549,8 +1607,10 @@ HAL_StatusTypeDef HAL_TIMEx_OnePulseN_Start(TIM_HandleTypeDef *htim, uint32_t Ou | ||||
| /**
 | ||||
|   * @brief  Stops the TIM One Pulse signal generation on the complementary | ||||
|   *         output. | ||||
|   * @note OutputChannel must match the pulse output channel chosen when calling | ||||
|   *       @ref HAL_TIM_OnePulse_ConfigChannel(). | ||||
|   * @param  htim TIM One Pulse handle | ||||
|   * @param  OutputChannel TIM Channel to be disabled | ||||
|   * @param  OutputChannel pulse output channel to disable | ||||
|   *          This parameter can be one of the following values: | ||||
|   *            @arg TIM_CHANNEL_1: TIM Channel 1 selected | ||||
|   *            @arg TIM_CHANNEL_2: TIM Channel 2 selected | ||||
| @ -1574,8 +1634,10 @@ HAL_StatusTypeDef HAL_TIMEx_OnePulseN_Stop(TIM_HandleTypeDef *htim, uint32_t Out | ||||
|   __HAL_TIM_DISABLE(htim); | ||||
| 
 | ||||
|   /* Set the TIM  channels state */ | ||||
|   TIM_CHANNEL_N_STATE_SET(htim, OutputChannel, HAL_TIM_CHANNEL_STATE_READY); | ||||
|   TIM_CHANNEL_STATE_SET(htim, input_channel, HAL_TIM_CHANNEL_STATE_READY); | ||||
|   TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY); | ||||
|   TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY); | ||||
|   TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY); | ||||
|   TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY); | ||||
| 
 | ||||
|   /* Return function status */ | ||||
|   return HAL_OK; | ||||
| @ -1584,8 +1646,10 @@ HAL_StatusTypeDef HAL_TIMEx_OnePulseN_Stop(TIM_HandleTypeDef *htim, uint32_t Out | ||||
| /**
 | ||||
|   * @brief  Starts the TIM One Pulse signal generation in interrupt mode on the | ||||
|   *         complementary channel. | ||||
|   * @note OutputChannel must match the pulse output channel chosen when calling | ||||
|   *       @ref HAL_TIM_OnePulse_ConfigChannel(). | ||||
|   * @param  htim TIM One Pulse handle | ||||
|   * @param  OutputChannel TIM Channel to be enabled | ||||
|   * @param  OutputChannel pulse output channel to enable | ||||
|   *          This parameter can be one of the following values: | ||||
|   *            @arg TIM_CHANNEL_1: TIM Channel 1 selected | ||||
|   *            @arg TIM_CHANNEL_2: TIM Channel 2 selected | ||||
| @ -1594,22 +1658,28 @@ HAL_StatusTypeDef HAL_TIMEx_OnePulseN_Stop(TIM_HandleTypeDef *htim, uint32_t Out | ||||
| HAL_StatusTypeDef HAL_TIMEx_OnePulseN_Start_IT(TIM_HandleTypeDef *htim, uint32_t OutputChannel) | ||||
| { | ||||
|   uint32_t input_channel = (OutputChannel == TIM_CHANNEL_1) ? TIM_CHANNEL_2 : TIM_CHANNEL_1; | ||||
|   HAL_TIM_ChannelStateTypeDef input_channel_state = TIM_CHANNEL_STATE_GET(htim, input_channel); | ||||
|   HAL_TIM_ChannelStateTypeDef output_channel_state = TIM_CHANNEL_N_STATE_GET(htim, OutputChannel); | ||||
|   HAL_TIM_ChannelStateTypeDef channel_1_state = TIM_CHANNEL_STATE_GET(htim, TIM_CHANNEL_1); | ||||
|   HAL_TIM_ChannelStateTypeDef channel_2_state = TIM_CHANNEL_STATE_GET(htim, TIM_CHANNEL_2); | ||||
|   HAL_TIM_ChannelStateTypeDef complementary_channel_1_state = TIM_CHANNEL_N_STATE_GET(htim, TIM_CHANNEL_1); | ||||
|   HAL_TIM_ChannelStateTypeDef complementary_channel_2_state = TIM_CHANNEL_N_STATE_GET(htim, TIM_CHANNEL_2); | ||||
| 
 | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, OutputChannel)); | ||||
| 
 | ||||
|   /* Check the TIM channels state */ | ||||
|   if ((output_channel_state != HAL_TIM_CHANNEL_STATE_READY) | ||||
|       || (input_channel_state != HAL_TIM_CHANNEL_STATE_READY)) | ||||
|   if ((channel_1_state != HAL_TIM_CHANNEL_STATE_READY) | ||||
|       || (channel_2_state != HAL_TIM_CHANNEL_STATE_READY) | ||||
|       || (complementary_channel_1_state != HAL_TIM_CHANNEL_STATE_READY) | ||||
|       || (complementary_channel_2_state != HAL_TIM_CHANNEL_STATE_READY)) | ||||
|   { | ||||
|     return HAL_ERROR; | ||||
|   } | ||||
| 
 | ||||
|   /* Set the TIM channels state */ | ||||
|   TIM_CHANNEL_N_STATE_SET(htim, OutputChannel, HAL_TIM_CHANNEL_STATE_BUSY); | ||||
|   TIM_CHANNEL_STATE_SET(htim, input_channel, HAL_TIM_CHANNEL_STATE_BUSY); | ||||
|   TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_BUSY); | ||||
|   TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_BUSY); | ||||
|   TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_BUSY); | ||||
|   TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_BUSY); | ||||
| 
 | ||||
|   /* Enable the TIM Capture/Compare 1 interrupt */ | ||||
|   __HAL_TIM_ENABLE_IT(htim, TIM_IT_CC1); | ||||
| @ -1631,8 +1701,10 @@ HAL_StatusTypeDef HAL_TIMEx_OnePulseN_Start_IT(TIM_HandleTypeDef *htim, uint32_t | ||||
| /**
 | ||||
|   * @brief  Stops the TIM One Pulse signal generation in interrupt mode on the | ||||
|   *         complementary channel. | ||||
|   * @note OutputChannel must match the pulse output channel chosen when calling | ||||
|   *       @ref HAL_TIM_OnePulse_ConfigChannel(). | ||||
|   * @param  htim TIM One Pulse handle | ||||
|   * @param  OutputChannel TIM Channel to be disabled | ||||
|   * @param  OutputChannel pulse output channel to disable | ||||
|   *          This parameter can be one of the following values: | ||||
|   *            @arg TIM_CHANNEL_1: TIM Channel 1 selected | ||||
|   *            @arg TIM_CHANNEL_2: TIM Channel 2 selected | ||||
| @ -1662,8 +1734,10 @@ HAL_StatusTypeDef HAL_TIMEx_OnePulseN_Stop_IT(TIM_HandleTypeDef *htim, uint32_t | ||||
|   __HAL_TIM_DISABLE(htim); | ||||
| 
 | ||||
|   /* Set the TIM  channels state */ | ||||
|   TIM_CHANNEL_N_STATE_SET(htim, OutputChannel, HAL_TIM_CHANNEL_STATE_READY); | ||||
|   TIM_CHANNEL_STATE_SET(htim, input_channel, HAL_TIM_CHANNEL_STATE_READY); | ||||
|   TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY); | ||||
|   TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY); | ||||
|   TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY); | ||||
|   TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY); | ||||
| 
 | ||||
|   /* Return function status */ | ||||
|   return HAL_OK; | ||||
| @ -1878,7 +1952,7 @@ HAL_StatusTypeDef HAL_TIMEx_ConfigCommutEvent_DMA(TIM_HandleTypeDef *htim, uint3 | ||||
|   * @retval HAL status | ||||
|   */ | ||||
| HAL_StatusTypeDef HAL_TIMEx_MasterConfigSynchronization(TIM_HandleTypeDef *htim, | ||||
|                                                         TIM_MasterConfigTypeDef *sMasterConfig) | ||||
|                                                         const TIM_MasterConfigTypeDef *sMasterConfig) | ||||
| { | ||||
|   uint32_t tmpcr2; | ||||
|   uint32_t tmpsmcr; | ||||
| @ -1939,7 +2013,7 @@ HAL_StatusTypeDef HAL_TIMEx_MasterConfigSynchronization(TIM_HandleTypeDef *htim, | ||||
|   * @retval HAL status | ||||
|   */ | ||||
| HAL_StatusTypeDef HAL_TIMEx_ConfigBreakDeadTime(TIM_HandleTypeDef *htim, | ||||
|                                                 TIM_BreakDeadTimeConfigTypeDef *sBreakDeadTimeConfig) | ||||
|                                                 const TIM_BreakDeadTimeConfigTypeDef *sBreakDeadTimeConfig) | ||||
| { | ||||
|   /* Keep this variable initialized to 0 as it is used to configure BDTR register */ | ||||
|   uint32_t tmpbdtr = 0U; | ||||
| @ -2015,7 +2089,7 @@ HAL_StatusTypeDef HAL_TIMEx_RemapConfig(TIM_HandleTypeDef *htim, uint32_t Remap) | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Hall commutation changed callback in non-blocking mode | ||||
|   * @brief  Commutation callback in non-blocking mode | ||||
|   * @param  htim TIM handle | ||||
|   * @retval None | ||||
|   */ | ||||
| @ -2029,7 +2103,7 @@ __weak void HAL_TIMEx_CommutCallback(TIM_HandleTypeDef *htim) | ||||
|    */ | ||||
| } | ||||
| /**
 | ||||
|   * @brief  Hall commutation changed half complete callback in non-blocking mode | ||||
|   * @brief  Commutation half complete callback in non-blocking mode | ||||
|   * @param  htim TIM handle | ||||
|   * @retval None | ||||
|   */ | ||||
| @ -2044,7 +2118,7 @@ __weak void HAL_TIMEx_CommutHalfCpltCallback(TIM_HandleTypeDef *htim) | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Hall Break detection callback in non-blocking mode | ||||
|   * @brief  Break detection callback in non-blocking mode | ||||
|   * @param  htim TIM handle | ||||
|   * @retval None | ||||
|   */ | ||||
| @ -2081,7 +2155,7 @@ __weak void HAL_TIMEx_BreakCallback(TIM_HandleTypeDef *htim) | ||||
|   * @param  htim TIM Hall Sensor handle | ||||
|   * @retval HAL state | ||||
|   */ | ||||
| HAL_TIM_StateTypeDef HAL_TIMEx_HallSensor_GetState(TIM_HandleTypeDef *htim) | ||||
| HAL_TIM_StateTypeDef HAL_TIMEx_HallSensor_GetState(const TIM_HandleTypeDef *htim) | ||||
| { | ||||
|   return htim->State; | ||||
| } | ||||
| @ -2096,7 +2170,7 @@ HAL_TIM_StateTypeDef HAL_TIMEx_HallSensor_GetState(TIM_HandleTypeDef *htim) | ||||
|   *            @arg TIM_CHANNEL_3: TIM Channel 3 | ||||
|   * @retval TIM Complementary channel state | ||||
|   */ | ||||
| HAL_TIM_ChannelStateTypeDef HAL_TIMEx_GetChannelNState(TIM_HandleTypeDef *htim,  uint32_t ChannelN) | ||||
| HAL_TIM_ChannelStateTypeDef HAL_TIMEx_GetChannelNState(const TIM_HandleTypeDef *htim,  uint32_t ChannelN) | ||||
| { | ||||
|   HAL_TIM_ChannelStateTypeDef channel_state; | ||||
| 
 | ||||
| @ -2116,7 +2190,7 @@ HAL_TIM_ChannelStateTypeDef HAL_TIMEx_GetChannelNState(TIM_HandleTypeDef *htim, | ||||
|   */ | ||||
| 
 | ||||
| /* Private functions ---------------------------------------------------------*/ | ||||
| /** @defgroup TIMEx_Private_Functions TIMEx Private Functions
 | ||||
| /** @defgroup TIMEx_Private_Functions TIM Extended Private Functions
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| @ -2195,15 +2269,6 @@ static void TIM_DMADelayPulseNCplt(DMA_HandleTypeDef *hdma) | ||||
|       TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_3, HAL_TIM_CHANNEL_STATE_READY); | ||||
|     } | ||||
|   } | ||||
|   else if (hdma == htim->hdma[TIM_DMA_ID_CC4]) | ||||
|   { | ||||
|     htim->Channel = HAL_TIM_ACTIVE_CHANNEL_4; | ||||
| 
 | ||||
|     if (hdma->Init.Mode == DMA_NORMAL) | ||||
|     { | ||||
|       TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_4, HAL_TIM_CHANNEL_STATE_READY); | ||||
|     } | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     /* nothing to do */ | ||||
| @ -2272,13 +2337,13 @@ static void TIM_CCxNChannelCmd(TIM_TypeDef *TIMx, uint32_t Channel, uint32_t Cha | ||||
| { | ||||
|   uint32_t tmp; | ||||
| 
 | ||||
|   tmp = TIM_CCER_CC1NE << (Channel & 0x1FU); /* 0x1FU = 31 bits max shift */ | ||||
|   tmp = TIM_CCER_CC1NE << (Channel & 0xFU); /* 0xFU = 15 bits max shift */ | ||||
| 
 | ||||
|   /* Reset the CCxNE Bit */ | ||||
|   TIMx->CCER &=  ~tmp; | ||||
| 
 | ||||
|   /* Set or reset the CCxNE Bit */ | ||||
|   TIMx->CCER |= (uint32_t)(ChannelNState << (Channel & 0x1FU)); /* 0x1FU = 31 bits max shift */ | ||||
|   TIMx->CCER |= (uint32_t)(ChannelNState << (Channel & 0xFU)); /* 0xFU = 15 bits max shift */ | ||||
| } | ||||
| /**
 | ||||
|   * @} | ||||
| @ -2292,5 +2357,3 @@ static void TIM_CCxNChannelCmd(TIM_TypeDef *TIMx, uint32_t Channel, uint32_t Cha | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | ||||
							
								
								
									
										24966
									
								
								MDK-ARM/JLinkLog.txt
									
									
									
									
									
								
							
							
						
						
									
										24966
									
								
								MDK-ARM/JLinkLog.txt
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @ -556,12 +556,12 @@ ARM Macro Assembler    Page 9 | ||||
|               00000400  | ||||
|               00000200  | ||||
|               00000000  | ||||
| Command Line: --debug --xref --diag_suppress=9931 --cpu=Cortex-M3 --apcs=interw | ||||
| ork --depend=uksvep_2_2_v1\startup_stm32f103xe.d -ouksvep_2_2_v1\startup_stm32f | ||||
| 103xe.o -I.\RTE\_uksvep_2_2_v1 -Id:\Keil\ARM\PACK\ARM\CMSIS\5.6.0\CMSIS\Core\In | ||||
| clude -Id:\Keil\ARM\PACK\Keil\STM32F1xx_DFP\2.3.0\Device\Include --predefine="_ | ||||
| _UVISION_VERSION SETA 529" --predefine="_RTE_ SETA 1" --predefine="STM32F10X_HD | ||||
|  SETA 1" --list=startup_stm32f103xe.lst startup_stm32f103xe.s | ||||
| Command Line: --debug --xref --diag_suppress=9931,A1950W --cpu=Cortex-M3 --depe | ||||
| nd=uksvep_2_2_v1\startup_stm32f103xe.d -ouksvep_2_2_v1\startup_stm32f103xe.o -I | ||||
| .\RTE\_uksvep_2_2_v1 -IC:\Arm\Packs\ARM\CMSIS\5.9.0\CMSIS\Core\Include -IC:\Arm | ||||
| \Packs\Keil\STM32F1xx_DFP\2.4.0\Device\Include --predefine="__UVISION_VERSION S | ||||
| ETA 538" --predefine="_RTE_ SETA 1" --predefine="STM32F10X_HD SETA 1" --predefi | ||||
| ne="_RTE_ SETA 1" --list=startup_stm32f103xe.lst startup_stm32f103xe.s | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|  | ||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										3738
									
								
								MDK-ARM/uksvep_2_2_v1.uvguix.z
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										3738
									
								
								MDK-ARM/uksvep_2_2_v1.uvguix.z
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -10,7 +10,7 @@ | ||||
|     <aExt>*.s*; *.src; *.a*</aExt> | ||||
|     <oExt>*.obj; *.o</oExt> | ||||
|     <lExt>*.lib</lExt> | ||||
|     <tExt>*.txt; *.h; *.inc</tExt> | ||||
|     <tExt>*.txt; *.h; *.inc; *.md</tExt> | ||||
|     <pExt>*.plm</pExt> | ||||
|     <CppX>*.cpp</CppX> | ||||
|     <nMigrate>0</nMigrate> | ||||
| @ -103,7 +103,7 @@ | ||||
|         <bEvRecOn>1</bEvRecOn> | ||||
|         <bSchkAxf>0</bSchkAxf> | ||||
|         <bTchkAxf>0</bTchkAxf> | ||||
|         <nTsel>7</nTsel> | ||||
|         <nTsel>4</nTsel> | ||||
|         <sDll></sDll> | ||||
|         <sDllPa></sDllPa> | ||||
|         <sDlgDll></sDlgDll> | ||||
| @ -140,7 +140,7 @@ | ||||
|         <SetRegEntry> | ||||
|           <Number>0</Number> | ||||
|           <Key>JL2CM3</Key> | ||||
|           <Name>-U504301808 -O14 -S3 -ZTIFSpeedSel3000 -A0 -C0 -JU1 -JI127.0.0.1 -JP0 -RST0 -N00("ARM CoreSight JTAG-DP") -D00(4BA00477) -L00(4) -TO18 -TC10000000 -TP21 -TDS8007 -TDT0 -TDC1F -TIEFFFFFFFF -TIP8 -TB1 -TFE0 -FO7 -FD20000000 -FC1000 -FN1 -FF0STM32F10x_512.FLM -FS08000000 -FL080000 -FP0($$Device:STM32F103RC$Flash\STM32F10x_512.FLM)</Name> | ||||
|           <Name>-U60145543 -O14 -S3 -ZTIFSpeedSel3000 -A0 -C0 -JU1 -JI127.0.0.1 -JP0 -RST0 -N00("ARM CoreSight JTAG-DP") -D00(3BA00477) -L00(4) -N01("Unknown JTAG device") -D01(06414041) -L01(5) -TO18 -TC10000000 -TP21 -TDS8007 -TDT0 -TDC1F -TIEFFFFFFFF -TIP8 -TB1 -TFE0 -FO15 -FD20000000 -FC1000 -FN1 -FF0STM32F10x_512.FLM -FS08000000 -FL080000 -FP0($$Device:STM32F103RC$Flash\STM32F10x_512.FLM)</Name> | ||||
|         </SetRegEntry> | ||||
|         <SetRegEntry> | ||||
|           <Number>0</Number> | ||||
| @ -153,47 +153,60 @@ | ||||
|           <Name>-U52FF6D067188485535530767 -O2190 -SF268436581 -C0 -A0 -I0 -HNlocalhost -HP7184 -P1 -N00("ARM CoreSight JTAG-DP") -D00(3BA00477) -L00(0) -TO131090 -TC10000000 -TT10000000 -TP21 -TDS8000 -TDT0 -TDC1F -TIEFFFFFFFF -TIP8 -FO7 -FD20000000 -FC800 -FN1 -FF0STM32F10x_512.FLM -FS08000000 -FL040000 -FP0($$Device:STM32F103RC$Flash\STM32F10x_512.FLM)</Name> | ||||
|         </SetRegEntry> | ||||
|       </TargetDriverDllRegistry> | ||||
|       <Breakpoint/> | ||||
|       <Breakpoint> | ||||
|         <Bp> | ||||
|           <Number>0</Number> | ||||
|           <Type>0</Type> | ||||
|           <LineNumber>240</LineNumber> | ||||
|           <EnabledFlag>1</EnabledFlag> | ||||
|           <Address>26</Address> | ||||
|           <ByteObject>0</ByteObject> | ||||
|           <HtxType>0</HtxType> | ||||
|           <ManyObjects>0</ManyObjects> | ||||
|           <SizeOfObject>0</SizeOfObject> | ||||
|           <BreakByAccess>0</BreakByAccess> | ||||
|           <BreakIfRCount>1</BreakIfRCount> | ||||
|           <Filename>../Core/Src/system_stm32f1xx.c</Filename> | ||||
|           <ExecCommand></ExecCommand> | ||||
|           <Expression>\\uksvep_2_2_v1\../Core/Src/system_stm32f1xx.c\240</Expression> | ||||
|         </Bp> | ||||
|         <Bp> | ||||
|           <Number>1</Number> | ||||
|           <Type>0</Type> | ||||
|           <LineNumber>107</LineNumber> | ||||
|           <EnabledFlag>1</EnabledFlag> | ||||
|           <Address>134235170</Address> | ||||
|           <ByteObject>0</ByteObject> | ||||
|           <HtxType>0</HtxType> | ||||
|           <ManyObjects>0</ManyObjects> | ||||
|           <SizeOfObject>0</SizeOfObject> | ||||
|           <BreakByAccess>0</BreakByAccess> | ||||
|           <BreakIfRCount>1</BreakIfRCount> | ||||
|           <Filename>../Core/Src/main.c</Filename> | ||||
|           <ExecCommand></ExecCommand> | ||||
|           <Expression>\\uksvep_2_2_v1\../Core/Src/main.c\107</Expression> | ||||
|         </Bp> | ||||
|       </Breakpoint> | ||||
|       <WatchWindow1> | ||||
|         <Ww> | ||||
|           <count>0</count> | ||||
|           <WinNumber>1</WinNumber> | ||||
|           <ItemText>huart1</ItemText> | ||||
|           <ItemText>CanGo</ItemText> | ||||
|         </Ww> | ||||
|         <Ww> | ||||
|           <count>1</count> | ||||
|           <WinNumber>1</WinNumber> | ||||
|           <ItemText>mode</ItemText> | ||||
|           <ItemText>cancell[i]</ItemText> | ||||
|         </Ww> | ||||
|         <Ww> | ||||
|           <count>2</count> | ||||
|           <WinNumber>1</WinNumber> | ||||
|           <ItemText>RX_box_ID</ItemText> | ||||
|           <ItemText>hiwdg</ItemText> | ||||
|         </Ww> | ||||
|         <Ww> | ||||
|           <count>3</count> | ||||
|           <WinNumber>1</WinNumber> | ||||
|           <ItemText>BC_box_ID</ItemText> | ||||
|         </Ww> | ||||
|         <Ww> | ||||
|           <count>4</count> | ||||
|           <WinNumber>1</WinNumber> | ||||
|           <ItemText>msgHeader.ExtId</ItemText> | ||||
|         </Ww> | ||||
|         <Ww> | ||||
|           <count>5</count> | ||||
|           <WinNumber>1</WinNumber> | ||||
|           <ItemText>PercentU[0]</ItemText> | ||||
|         </Ww> | ||||
|         <Ww> | ||||
|           <count>6</count> | ||||
|           <WinNumber>1</WinNumber> | ||||
|           <ItemText>input.bit.bitA</ItemText> | ||||
|         </Ww> | ||||
|         <Ww> | ||||
|           <count>7</count> | ||||
|           <WinNumber>1</WinNumber> | ||||
|           <ItemText>sum_u</ItemText> | ||||
|           <ItemText>flag,0x0A</ItemText> | ||||
|         </Ww> | ||||
|       </WatchWindow1> | ||||
|       <WatchWindow2> | ||||
| @ -205,22 +218,12 @@ | ||||
|         <Ww> | ||||
|           <count>1</count> | ||||
|           <WinNumber>2</WinNumber> | ||||
|           <ItemText>norm_diod</ItemText> | ||||
|           <ItemText>~precom</ItemText> | ||||
|         </Ww> | ||||
|         <Ww> | ||||
|           <count>2</count> | ||||
|           <WinNumber>2</WinNumber> | ||||
|           <ItemText>work_diod</ItemText> | ||||
|         </Ww> | ||||
|         <Ww> | ||||
|           <count>3</count> | ||||
|           <WinNumber>2</WinNumber> | ||||
|           <ItemText>power_lamp</ItemText> | ||||
|         </Ww> | ||||
|         <Ww> | ||||
|           <count>4</count> | ||||
|           <WinNumber>2</WinNumber> | ||||
|           <ItemText>sysclk</ItemText> | ||||
|           <ItemText>params[128]</ItemText> | ||||
|         </Ww> | ||||
|       </WatchWindow2> | ||||
|       <MemoryWindow1> | ||||
| @ -237,7 +240,7 @@ | ||||
|       <DebugFlag> | ||||
|         <trace>0</trace> | ||||
|         <periodic>1</periodic> | ||||
|         <aLwin>0</aLwin> | ||||
|         <aLwin>1</aLwin> | ||||
|         <aCover>0</aCover> | ||||
|         <aSer1>0</aSer1> | ||||
|         <aSer2>0</aSer2> | ||||
| @ -275,9 +278,21 @@ | ||||
|       <pMultCmdsp></pMultCmdsp> | ||||
|       <SystemViewers> | ||||
|         <Entry> | ||||
|           <Name>System Viewer\TIM4</Name> | ||||
|           <Name>System Viewer\DBG</Name> | ||||
|           <WinId>35904</WinId> | ||||
|         </Entry> | ||||
|         <Entry> | ||||
|           <Name>System Viewer\GPIOC</Name> | ||||
|           <WinId>35903</WinId> | ||||
|         </Entry> | ||||
|         <Entry> | ||||
|           <Name>System Viewer\IWDG</Name> | ||||
|           <WinId>35905</WinId> | ||||
|         </Entry> | ||||
|         <Entry> | ||||
|           <Name>System Viewer\RCC</Name> | ||||
|           <WinId>35902</WinId> | ||||
|         </Entry> | ||||
|       </SystemViewers> | ||||
|       <DebugDescription> | ||||
|         <Enable>1</Enable> | ||||
| @ -355,7 +370,7 @@ | ||||
|       <GroupNumber>2</GroupNumber> | ||||
|       <FileNumber>5</FileNumber> | ||||
|       <FileType>1</FileType> | ||||
|       <tvExp>1</tvExp> | ||||
|       <tvExp>0</tvExp> | ||||
|       <tvExpOptDlg>0</tvExpOptDlg> | ||||
|       <bDave2>0</bDave2> | ||||
|       <PathWithFileName>..\Core\Src\message.c</PathWithFileName> | ||||
| @ -379,7 +394,7 @@ | ||||
|       <GroupNumber>2</GroupNumber> | ||||
|       <FileNumber>7</FileNumber> | ||||
|       <FileType>1</FileType> | ||||
|       <tvExp>0</tvExp> | ||||
|       <tvExp>1</tvExp> | ||||
|       <tvExpOptDlg>0</tvExpOptDlg> | ||||
|       <bDave2>0</bDave2> | ||||
|       <PathWithFileName>../Core/Src/gpio.c</PathWithFileName> | ||||
| @ -406,6 +421,18 @@ | ||||
|       <tvExp>0</tvExp> | ||||
|       <tvExpOptDlg>0</tvExpOptDlg> | ||||
|       <bDave2>0</bDave2> | ||||
|       <PathWithFileName>..\Core\Src\iwdg.c</PathWithFileName> | ||||
|       <FilenameWithoutPath>iwdg.c</FilenameWithoutPath> | ||||
|       <RteFlg>0</RteFlg> | ||||
|       <bShared>0</bShared> | ||||
|     </File> | ||||
|     <File> | ||||
|       <GroupNumber>2</GroupNumber> | ||||
|       <FileNumber>10</FileNumber> | ||||
|       <FileType>1</FileType> | ||||
|       <tvExp>0</tvExp> | ||||
|       <tvExpOptDlg>0</tvExpOptDlg> | ||||
|       <bDave2>0</bDave2> | ||||
|       <PathWithFileName>../Core/Src/tim.c</PathWithFileName> | ||||
|       <FilenameWithoutPath>tim.c</FilenameWithoutPath> | ||||
|       <RteFlg>0</RteFlg> | ||||
| @ -413,7 +440,7 @@ | ||||
|     </File> | ||||
|     <File> | ||||
|       <GroupNumber>2</GroupNumber> | ||||
|       <FileNumber>10</FileNumber> | ||||
|       <FileNumber>11</FileNumber> | ||||
|       <FileType>1</FileType> | ||||
|       <tvExp>0</tvExp> | ||||
|       <tvExpOptDlg>0</tvExpOptDlg> | ||||
| @ -425,7 +452,7 @@ | ||||
|     </File> | ||||
|     <File> | ||||
|       <GroupNumber>2</GroupNumber> | ||||
|       <FileNumber>11</FileNumber> | ||||
|       <FileNumber>12</FileNumber> | ||||
|       <FileType>1</FileType> | ||||
|       <tvExp>0</tvExp> | ||||
|       <tvExpOptDlg>0</tvExpOptDlg> | ||||
| @ -435,6 +462,18 @@ | ||||
|       <RteFlg>0</RteFlg> | ||||
|       <bShared>0</bShared> | ||||
|     </File> | ||||
|     <File> | ||||
|       <GroupNumber>2</GroupNumber> | ||||
|       <FileNumber>13</FileNumber> | ||||
|       <FileType>1</FileType> | ||||
|       <tvExp>0</tvExp> | ||||
|       <tvExpOptDlg>0</tvExpOptDlg> | ||||
|       <bDave2>0</bDave2> | ||||
|       <PathWithFileName>../Core/Src/stm32f1xx_hal_timebase_tim.c</PathWithFileName> | ||||
|       <FilenameWithoutPath>stm32f1xx_hal_timebase_tim.c</FilenameWithoutPath> | ||||
|       <RteFlg>0</RteFlg> | ||||
|       <bShared>0</bShared> | ||||
|     </File> | ||||
|   </Group> | ||||
| 
 | ||||
|   <Group> | ||||
| @ -445,7 +484,7 @@ | ||||
|     <RteFlg>0</RteFlg> | ||||
|     <File> | ||||
|       <GroupNumber>3</GroupNumber> | ||||
|       <FileNumber>12</FileNumber> | ||||
|       <FileNumber>14</FileNumber> | ||||
|       <FileType>1</FileType> | ||||
|       <tvExp>0</tvExp> | ||||
|       <tvExpOptDlg>0</tvExpOptDlg> | ||||
| @ -457,7 +496,7 @@ | ||||
|     </File> | ||||
|     <File> | ||||
|       <GroupNumber>3</GroupNumber> | ||||
|       <FileNumber>13</FileNumber> | ||||
|       <FileNumber>15</FileNumber> | ||||
|       <FileType>1</FileType> | ||||
|       <tvExp>0</tvExp> | ||||
|       <tvExpOptDlg>0</tvExpOptDlg> | ||||
| @ -469,7 +508,7 @@ | ||||
|     </File> | ||||
|     <File> | ||||
|       <GroupNumber>3</GroupNumber> | ||||
|       <FileNumber>14</FileNumber> | ||||
|       <FileNumber>16</FileNumber> | ||||
|       <FileType>1</FileType> | ||||
|       <tvExp>0</tvExp> | ||||
|       <tvExpOptDlg>0</tvExpOptDlg> | ||||
| @ -481,7 +520,7 @@ | ||||
|     </File> | ||||
|     <File> | ||||
|       <GroupNumber>3</GroupNumber> | ||||
|       <FileNumber>15</FileNumber> | ||||
|       <FileNumber>17</FileNumber> | ||||
|       <FileType>1</FileType> | ||||
|       <tvExp>0</tvExp> | ||||
|       <tvExpOptDlg>0</tvExpOptDlg> | ||||
| @ -493,7 +532,7 @@ | ||||
|     </File> | ||||
|     <File> | ||||
|       <GroupNumber>3</GroupNumber> | ||||
|       <FileNumber>16</FileNumber> | ||||
|       <FileNumber>18</FileNumber> | ||||
|       <FileType>1</FileType> | ||||
|       <tvExp>0</tvExp> | ||||
|       <tvExpOptDlg>0</tvExpOptDlg> | ||||
| @ -505,7 +544,7 @@ | ||||
|     </File> | ||||
|     <File> | ||||
|       <GroupNumber>3</GroupNumber> | ||||
|       <FileNumber>17</FileNumber> | ||||
|       <FileNumber>19</FileNumber> | ||||
|       <FileType>1</FileType> | ||||
|       <tvExp>0</tvExp> | ||||
|       <tvExpOptDlg>0</tvExpOptDlg> | ||||
| @ -517,7 +556,7 @@ | ||||
|     </File> | ||||
|     <File> | ||||
|       <GroupNumber>3</GroupNumber> | ||||
|       <FileNumber>18</FileNumber> | ||||
|       <FileNumber>20</FileNumber> | ||||
|       <FileType>1</FileType> | ||||
|       <tvExp>0</tvExp> | ||||
|       <tvExpOptDlg>0</tvExpOptDlg> | ||||
| @ -529,7 +568,7 @@ | ||||
|     </File> | ||||
|     <File> | ||||
|       <GroupNumber>3</GroupNumber> | ||||
|       <FileNumber>19</FileNumber> | ||||
|       <FileNumber>21</FileNumber> | ||||
|       <FileType>1</FileType> | ||||
|       <tvExp>0</tvExp> | ||||
|       <tvExpOptDlg>0</tvExpOptDlg> | ||||
| @ -541,7 +580,7 @@ | ||||
|     </File> | ||||
|     <File> | ||||
|       <GroupNumber>3</GroupNumber> | ||||
|       <FileNumber>20</FileNumber> | ||||
|       <FileNumber>22</FileNumber> | ||||
|       <FileType>1</FileType> | ||||
|       <tvExp>0</tvExp> | ||||
|       <tvExpOptDlg>0</tvExpOptDlg> | ||||
| @ -553,7 +592,7 @@ | ||||
|     </File> | ||||
|     <File> | ||||
|       <GroupNumber>3</GroupNumber> | ||||
|       <FileNumber>21</FileNumber> | ||||
|       <FileNumber>23</FileNumber> | ||||
|       <FileType>1</FileType> | ||||
|       <tvExp>0</tvExp> | ||||
|       <tvExpOptDlg>0</tvExpOptDlg> | ||||
| @ -565,7 +604,7 @@ | ||||
|     </File> | ||||
|     <File> | ||||
|       <GroupNumber>3</GroupNumber> | ||||
|       <FileNumber>22</FileNumber> | ||||
|       <FileNumber>24</FileNumber> | ||||
|       <FileType>1</FileType> | ||||
|       <tvExp>0</tvExp> | ||||
|       <tvExpOptDlg>0</tvExpOptDlg> | ||||
| @ -577,7 +616,7 @@ | ||||
|     </File> | ||||
|     <File> | ||||
|       <GroupNumber>3</GroupNumber> | ||||
|       <FileNumber>23</FileNumber> | ||||
|       <FileNumber>25</FileNumber> | ||||
|       <FileType>1</FileType> | ||||
|       <tvExp>0</tvExp> | ||||
|       <tvExpOptDlg>0</tvExpOptDlg> | ||||
| @ -589,7 +628,19 @@ | ||||
|     </File> | ||||
|     <File> | ||||
|       <GroupNumber>3</GroupNumber> | ||||
|       <FileNumber>24</FileNumber> | ||||
|       <FileNumber>26</FileNumber> | ||||
|       <FileType>1</FileType> | ||||
|       <tvExp>0</tvExp> | ||||
|       <tvExpOptDlg>0</tvExpOptDlg> | ||||
|       <bDave2>0</bDave2> | ||||
|       <PathWithFileName>..\Drivers\STM32F1xx_HAL_Driver\Src\stm32f1xx_hal_iwdg.c</PathWithFileName> | ||||
|       <FilenameWithoutPath>stm32f1xx_hal_iwdg.c</FilenameWithoutPath> | ||||
|       <RteFlg>0</RteFlg> | ||||
|       <bShared>0</bShared> | ||||
|     </File> | ||||
|     <File> | ||||
|       <GroupNumber>3</GroupNumber> | ||||
|       <FileNumber>27</FileNumber> | ||||
|       <FileType>1</FileType> | ||||
|       <tvExp>0</tvExp> | ||||
|       <tvExpOptDlg>0</tvExpOptDlg> | ||||
| @ -601,7 +652,7 @@ | ||||
|     </File> | ||||
|     <File> | ||||
|       <GroupNumber>3</GroupNumber> | ||||
|       <FileNumber>25</FileNumber> | ||||
|       <FileNumber>28</FileNumber> | ||||
|       <FileType>1</FileType> | ||||
|       <tvExp>0</tvExp> | ||||
|       <tvExpOptDlg>0</tvExpOptDlg> | ||||
| @ -621,7 +672,7 @@ | ||||
|     <RteFlg>0</RteFlg> | ||||
|     <File> | ||||
|       <GroupNumber>4</GroupNumber> | ||||
|       <FileNumber>26</FileNumber> | ||||
|       <FileNumber>29</FileNumber> | ||||
|       <FileType>1</FileType> | ||||
|       <tvExp>0</tvExp> | ||||
|       <tvExpOptDlg>0</tvExpOptDlg> | ||||
|  | ||||
| @ -10,13 +10,14 @@ | ||||
|       <TargetName>uksvep_2_2_v1</TargetName> | ||||
|       <ToolsetNumber>0x4</ToolsetNumber> | ||||
|       <ToolsetName>ARM-ADS</ToolsetName> | ||||
|       <pCCUsed>5060750::V5.06 update 6 (build 750)::ARMCC</pCCUsed> | ||||
|       <uAC6>0</uAC6> | ||||
|       <pArmCC>6190000::V6.19::ARMCLANG</pArmCC> | ||||
|       <pCCUsed>6190000::V6.19::ARMCLANG</pCCUsed> | ||||
|       <uAC6>1</uAC6> | ||||
|       <TargetOption> | ||||
|         <TargetCommonOption> | ||||
|           <Device>STM32F103RC</Device> | ||||
|           <Vendor>STMicroelectronics</Vendor> | ||||
|           <PackID>Keil.STM32F1xx_DFP.2.3.0</PackID> | ||||
|           <PackID>Keil.STM32F1xx_DFP.2.4.0</PackID> | ||||
|           <PackURL>http://www.keil.com/pack/</PackURL> | ||||
|           <Cpu>IRAM(0x20000000-0x2000BFFF) IROM(0x8000000-0x803FFFF) CLOCK(8000000) CPUTYPE("Cortex-M3") TZ</Cpu> | ||||
|           <FlashUtilSpec></FlashUtilSpec> | ||||
| @ -81,7 +82,7 @@ | ||||
|           </BeforeMake> | ||||
|           <AfterMake> | ||||
|             <RunUserProg1>0</RunUserProg1> | ||||
|             <RunUserProg2>0</RunUserProg2> | ||||
|             <RunUserProg2>1</RunUserProg2> | ||||
|             <UserProg1Name></UserProg1Name> | ||||
|             <UserProg2Name></UserProg2Name> | ||||
|             <UserProg1Dos16Mode>0</UserProg1Dos16Mode> | ||||
| @ -132,7 +133,7 @@ | ||||
|             <UseTargetDll>1</UseTargetDll> | ||||
|             <UseExternalTool>0</UseExternalTool> | ||||
|             <RunIndependent>0</RunIndependent> | ||||
|             <UpdateFlashBeforeDebugging>1</UpdateFlashBeforeDebugging> | ||||
|             <UpdateFlashBeforeDebugging>0</UpdateFlashBeforeDebugging> | ||||
|             <Capability>1</Capability> | ||||
|             <DriverSelection>4101</DriverSelection> | ||||
|           </Flash1> | ||||
| @ -185,6 +186,8 @@ | ||||
|             <uocXRam>0</uocXRam> | ||||
|             <RvdsVP>0</RvdsVP> | ||||
|             <RvdsMve>0</RvdsMve> | ||||
|             <RvdsCdeCp>0</RvdsCdeCp> | ||||
|             <nBranchProt>0</nBranchProt> | ||||
|             <hadIRAM2>0</hadIRAM2> | ||||
|             <hadIROM2>0</hadIROM2> | ||||
|             <StupSel>8</StupSel> | ||||
| @ -312,7 +315,7 @@ | ||||
|           </ArmAdsMisc> | ||||
|           <Cads> | ||||
|             <interw>1</interw> | ||||
|             <Optim>4</Optim> | ||||
|             <Optim>1</Optim> | ||||
|             <oTime>0</oTime> | ||||
|             <SplitLS>0</SplitLS> | ||||
|             <OneElfS>1</OneElfS> | ||||
| @ -328,7 +331,7 @@ | ||||
|             <uGnu>0</uGnu> | ||||
|             <useXO>0</useXO> | ||||
|             <v6Lang>5</v6Lang> | ||||
|             <v6LangP>3</v6LangP> | ||||
|             <v6LangP>5</v6LangP> | ||||
|             <vShortEn>1</vShortEn> | ||||
|             <vShortWch>1</vShortWch> | ||||
|             <v6Lto>0</v6Lto> | ||||
| @ -351,7 +354,7 @@ | ||||
|             <NoWarn>0</NoWarn> | ||||
|             <uSurpInc>0</uSurpInc> | ||||
|             <useXO>0</useXO> | ||||
|             <uClangAs>0</uClangAs> | ||||
|             <ClangAsOpt>4</ClangAsOpt> | ||||
|             <VariousControls> | ||||
|               <MiscControls></MiscControls> | ||||
|               <Define></Define> | ||||
| @ -529,6 +532,11 @@ | ||||
|                 </FileArmAds> | ||||
|               </FileOption> | ||||
|             </File> | ||||
|             <File> | ||||
|               <FileName>iwdg.c</FileName> | ||||
|               <FileType>1</FileType> | ||||
|               <FilePath>..\Core\Src\iwdg.c</FilePath> | ||||
|             </File> | ||||
|             <File> | ||||
|               <FileName>tim.c</FileName> | ||||
|               <FileType>1</FileType> | ||||
| @ -595,6 +603,62 @@ | ||||
|               <FileType>1</FileType> | ||||
|               <FilePath>../Core/Src/stm32f1xx_hal_msp.c</FilePath> | ||||
|             </File> | ||||
|             <File> | ||||
|               <FileName>stm32f1xx_hal_timebase_tim.c</FileName> | ||||
|               <FileType>1</FileType> | ||||
|               <FilePath>../Core/Src/stm32f1xx_hal_timebase_tim.c</FilePath> | ||||
|               <FileOption> | ||||
|                 <CommonProperty> | ||||
|                   <UseCPPCompiler>2</UseCPPCompiler> | ||||
|                   <RVCTCodeConst>0</RVCTCodeConst> | ||||
|                   <RVCTZI>0</RVCTZI> | ||||
|                   <RVCTOtherData>0</RVCTOtherData> | ||||
|                   <ModuleSelection>0</ModuleSelection> | ||||
|                   <IncludeInBuild>1</IncludeInBuild> | ||||
|                   <AlwaysBuild>2</AlwaysBuild> | ||||
|                   <GenerateAssemblyFile>2</GenerateAssemblyFile> | ||||
|                   <AssembleAssemblyFile>2</AssembleAssemblyFile> | ||||
|                   <PublicsOnly>2</PublicsOnly> | ||||
|                   <StopOnExitCode>11</StopOnExitCode> | ||||
|                   <CustomArgument></CustomArgument> | ||||
|                   <IncludeLibraryModules></IncludeLibraryModules> | ||||
|                   <ComprImg>1</ComprImg> | ||||
|                 </CommonProperty> | ||||
|                 <FileArmAds> | ||||
|                   <Cads> | ||||
|                     <interw>2</interw> | ||||
|                     <Optim>0</Optim> | ||||
|                     <oTime>2</oTime> | ||||
|                     <SplitLS>2</SplitLS> | ||||
|                     <OneElfS>2</OneElfS> | ||||
|                     <Strict>2</Strict> | ||||
|                     <EnumInt>2</EnumInt> | ||||
|                     <PlainCh>2</PlainCh> | ||||
|                     <Ropi>2</Ropi> | ||||
|                     <Rwpi>2</Rwpi> | ||||
|                     <wLevel>0</wLevel> | ||||
|                     <uThumb>2</uThumb> | ||||
|                     <uSurpInc>2</uSurpInc> | ||||
|                     <uC99>2</uC99> | ||||
|                     <uGnu>2</uGnu> | ||||
|                     <useXO>2</useXO> | ||||
|                     <v6Lang>0</v6Lang> | ||||
|                     <v6LangP>0</v6LangP> | ||||
|                     <vShortEn>2</vShortEn> | ||||
|                     <vShortWch>2</vShortWch> | ||||
|                     <v6Lto>2</v6Lto> | ||||
|                     <v6WtE>2</v6WtE> | ||||
|                     <v6Rtti>2</v6Rtti> | ||||
|                     <VariousControls> | ||||
|                       <MiscControls></MiscControls> | ||||
|                       <Define></Define> | ||||
|                       <Undefine></Undefine> | ||||
|                       <IncludePath></IncludePath> | ||||
|                     </VariousControls> | ||||
|                   </Cads> | ||||
|                 </FileArmAds> | ||||
|               </FileOption> | ||||
|             </File> | ||||
|           </Files> | ||||
|         </Group> | ||||
|         <Group> | ||||
| @ -658,7 +722,7 @@ | ||||
|                 <NoWarn>2</NoWarn> | ||||
|                 <uSurpInc>2</uSurpInc> | ||||
|                 <useXO>2</useXO> | ||||
|                 <uClangAs>2</uClangAs> | ||||
|                 <ClangAsOpt>0</ClangAsOpt> | ||||
|                 <VariousControls> | ||||
|                   <MiscControls></MiscControls> | ||||
|                   <Define></Define> | ||||
| @ -1341,6 +1405,11 @@ | ||||
|                 </FileArmAds> | ||||
|               </FileOption> | ||||
|             </File> | ||||
|             <File> | ||||
|               <FileName>stm32f1xx_hal_iwdg.c</FileName> | ||||
|               <FileType>1</FileType> | ||||
|               <FilePath>..\Drivers\STM32F1xx_HAL_Driver\Src\stm32f1xx_hal_iwdg.c</FilePath> | ||||
|             </File> | ||||
|             <File> | ||||
|               <FileName>stm32f1xx_hal_tim.c</FileName> | ||||
|               <FileType>1</FileType> | ||||
| @ -1516,7 +1585,7 @@ | ||||
|                 <NoWarn>2</NoWarn> | ||||
|                 <uSurpInc>2</uSurpInc> | ||||
|                 <useXO>2</useXO> | ||||
|                 <uClangAs>2</uClangAs> | ||||
|                 <ClangAsOpt>0</ClangAsOpt> | ||||
|                 <VariousControls> | ||||
|                   <MiscControls></MiscControls> | ||||
|                   <Define></Define> | ||||
| @ -1595,8 +1664,8 @@ | ||||
|   <RTE> | ||||
|     <apis/> | ||||
|     <components> | ||||
|       <component Cclass="CMSIS" Cgroup="CORE" Cvendor="ARM" Cversion="4.3.0" condition="CMSIS Core"> | ||||
|         <package name="CMSIS" schemaVersion="1.3" url="http://www.keil.com/pack/" vendor="ARM" version="4.5.0"/> | ||||
|       <component Cclass="CMSIS" Cgroup="CORE" Cvendor="ARM" Cversion="5.6.0" condition="ARMv6_7_8-M Device"> | ||||
|         <package name="CMSIS" schemaVersion="1.7.7" url="http://www.keil.com/pack/" vendor="ARM" version="5.9.0"/> | ||||
|         <targetInfos> | ||||
|           <targetInfo name="uksvep_2_2_v1"/> | ||||
|         </targetInfos> | ||||
|  | ||||
										
											Binary file not shown.
										
									
								
							| @ -1,34 +1,32 @@ | ||||
| uksvep_2_2_v1\can.o: ../Core/Src/can.c | ||||
| uksvep_2_2_v1\can.o: ../Core/Inc/can.h | ||||
| uksvep_2_2_v1\can.o: ../Core/Inc/main.h | ||||
| uksvep_2_2_v1\can.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal.h | ||||
| uksvep_2_2_v1\can.o: ../Core/Inc/stm32f1xx_hal_conf.h | ||||
| uksvep_2_2_v1\can.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_rcc.h | ||||
| uksvep_2_2_v1\can.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_def.h | ||||
| uksvep_2_2_v1\can.o: ../Drivers/CMSIS/Device/ST/STM32F1xx/Include/stm32f1xx.h | ||||
| uksvep_2_2_v1\can.o: ../Drivers/CMSIS/Device/ST/STM32F1xx/Include/stm32f103xe.h | ||||
| uksvep_2_2_v1\can.o: ../Drivers/CMSIS/Include/core_cm3.h | ||||
| uksvep_2_2_v1\can.o: d:\Keil\ARM\ARMCC\Bin\..\include\stdint.h | ||||
| uksvep_2_2_v1\can.o: ../Drivers/CMSIS/Include/cmsis_version.h | ||||
| uksvep_2_2_v1\can.o: ../Drivers/CMSIS/Include/cmsis_compiler.h | ||||
| uksvep_2_2_v1\can.o: ../Drivers/CMSIS/Include/cmsis_armcc.h | ||||
| uksvep_2_2_v1\can.o: ../Drivers/CMSIS/Device/ST/STM32F1xx/Include/system_stm32f1xx.h | ||||
| uksvep_2_2_v1\can.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal.h | ||||
| uksvep_2_2_v1\can.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/Legacy/stm32_hal_legacy.h | ||||
| uksvep_2_2_v1\can.o: d:\Keil\ARM\ARMCC\Bin\..\include\stddef.h | ||||
| uksvep_2_2_v1\can.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_rcc_ex.h | ||||
| uksvep_2_2_v1\can.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_gpio.h | ||||
| uksvep_2_2_v1\can.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_gpio_ex.h | ||||
| uksvep_2_2_v1\can.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_exti.h | ||||
| uksvep_2_2_v1\can.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_dma.h | ||||
| uksvep_2_2_v1\can.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_dma_ex.h | ||||
| uksvep_2_2_v1\can.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_can.h | ||||
| uksvep_2_2_v1\can.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_cortex.h | ||||
| uksvep_2_2_v1\can.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_flash.h | ||||
| uksvep_2_2_v1\can.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_flash_ex.h | ||||
| uksvep_2_2_v1\can.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_pwr.h | ||||
| uksvep_2_2_v1\can.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_tim.h | ||||
| uksvep_2_2_v1\can.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_tim_ex.h | ||||
| uksvep_2_2_v1\can.o: ../Core/Inc/gpio.h | ||||
| uksvep_2_2_v1\can.o: ../Core/Inc/message.h | ||||
| uksvep_2_2_v1\can.o: ../Core/Inc/struc.h | ||||
| uksvep_2_2_v1/can.o: ..\Core\Src\can.c ..\Core\Inc\can.h \ | ||||
|   ..\Core\Inc\main.h ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal.h \ | ||||
|   ..\Core\Inc\stm32f1xx_hal_conf.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_rcc.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_def.h \ | ||||
|   ..\Drivers\CMSIS\Device\ST\STM32F1xx\Include\stm32f1xx.h \ | ||||
|   ..\Drivers\CMSIS\Device\ST\STM32F1xx\Include\stm32f103xe.h \ | ||||
|   ..\Drivers\CMSIS\Include\core_cm3.h \ | ||||
|   C:\Keil_v5\ARM\ARMCLANG\Bin\..\include\stdint.h \ | ||||
|   ..\Drivers\CMSIS\Include\cmsis_version.h \ | ||||
|   ..\Drivers\CMSIS\Include\cmsis_compiler.h \ | ||||
|   ..\Drivers\CMSIS\Include\cmsis_armclang.h \ | ||||
|   C:\Keil_v5\ARM\ARMCLANG\Bin\..\include\arm_compat.h \ | ||||
|   C:\Keil_v5\ARM\ARMCLANG\Bin\..\include\arm_acle.h \ | ||||
|   ..\Drivers\CMSIS\Device\ST\STM32F1xx\Include\system_stm32f1xx.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\Legacy\stm32_hal_legacy.h \ | ||||
|   C:\Keil_v5\ARM\ARMCLANG\Bin\..\include\stddef.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_rcc_ex.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_gpio.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_gpio_ex.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_exti.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_dma.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_dma_ex.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_can.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_cortex.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_flash.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_flash_ex.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_iwdg.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_pwr.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_tim.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_tim_ex.h \ | ||||
|   ..\Core\Inc\gpio.h ..\Core\Inc\message.h ..\Core\Inc\struc.h | ||||
|  | ||||
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							| @ -1,3 +1,2 @@ | ||||
| uksvep_2_2_v1\crc16.o: ..\Core\Src\crc16.c | ||||
| uksvep_2_2_v1\crc16.o: ../Core/Inc/crc16.h | ||||
| uksvep_2_2_v1\crc16.o: d:\Keil\ARM\ARMCC\Bin\..\include\stdint.h | ||||
| uksvep_2_2_v1/crc16.o: ..\Core\Src\crc16.c ..\Core\Inc\crc16.h \ | ||||
|   C:\Keil_v5\ARM\ARMCLANG\Bin\..\include\stdint.h | ||||
|  | ||||
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							| @ -1,30 +1,31 @@ | ||||
| uksvep_2_2_v1\eeprom.o: ..\Core\Src\eeprom.c | ||||
| uksvep_2_2_v1\eeprom.o: ../Core/Inc/eeprom.h | ||||
| uksvep_2_2_v1\eeprom.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal.h | ||||
| uksvep_2_2_v1\eeprom.o: ../Core/Inc/stm32f1xx_hal_conf.h | ||||
| uksvep_2_2_v1\eeprom.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_rcc.h | ||||
| uksvep_2_2_v1\eeprom.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_def.h | ||||
| uksvep_2_2_v1\eeprom.o: ../Drivers/CMSIS/Device/ST/STM32F1xx/Include/stm32f1xx.h | ||||
| uksvep_2_2_v1\eeprom.o: ../Drivers/CMSIS/Device/ST/STM32F1xx/Include/stm32f103xe.h | ||||
| uksvep_2_2_v1\eeprom.o: ../Drivers/CMSIS/Include/core_cm3.h | ||||
| uksvep_2_2_v1\eeprom.o: d:\Keil\ARM\ARMCC\Bin\..\include\stdint.h | ||||
| uksvep_2_2_v1\eeprom.o: ../Drivers/CMSIS/Include/cmsis_version.h | ||||
| uksvep_2_2_v1\eeprom.o: ../Drivers/CMSIS/Include/cmsis_compiler.h | ||||
| uksvep_2_2_v1\eeprom.o: ../Drivers/CMSIS/Include/cmsis_armcc.h | ||||
| uksvep_2_2_v1\eeprom.o: ../Drivers/CMSIS/Device/ST/STM32F1xx/Include/system_stm32f1xx.h | ||||
| uksvep_2_2_v1\eeprom.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal.h | ||||
| uksvep_2_2_v1\eeprom.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/Legacy/stm32_hal_legacy.h | ||||
| uksvep_2_2_v1\eeprom.o: d:\Keil\ARM\ARMCC\Bin\..\include\stddef.h | ||||
| uksvep_2_2_v1\eeprom.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_rcc_ex.h | ||||
| uksvep_2_2_v1\eeprom.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_gpio.h | ||||
| uksvep_2_2_v1\eeprom.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_gpio_ex.h | ||||
| uksvep_2_2_v1\eeprom.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_exti.h | ||||
| uksvep_2_2_v1\eeprom.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_dma.h | ||||
| uksvep_2_2_v1\eeprom.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_dma_ex.h | ||||
| uksvep_2_2_v1\eeprom.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_can.h | ||||
| uksvep_2_2_v1\eeprom.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_cortex.h | ||||
| uksvep_2_2_v1\eeprom.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_flash.h | ||||
| uksvep_2_2_v1\eeprom.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_flash_ex.h | ||||
| uksvep_2_2_v1\eeprom.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_pwr.h | ||||
| uksvep_2_2_v1\eeprom.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_tim.h | ||||
| uksvep_2_2_v1\eeprom.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_tim_ex.h | ||||
| uksvep_2_2_v1/eeprom.o: ..\Core\Src\eeprom.c ..\Core\Inc\eeprom.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal.h \ | ||||
|   ..\Core\Inc\stm32f1xx_hal_conf.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_rcc.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_def.h \ | ||||
|   ..\Drivers\CMSIS\Device\ST\STM32F1xx\Include\stm32f1xx.h \ | ||||
|   ..\Drivers\CMSIS\Device\ST\STM32F1xx\Include\stm32f103xe.h \ | ||||
|   ..\Drivers\CMSIS\Include\core_cm3.h \ | ||||
|   C:\Keil_v5\ARM\ARMCLANG\Bin\..\include\stdint.h \ | ||||
|   ..\Drivers\CMSIS\Include\cmsis_version.h \ | ||||
|   ..\Drivers\CMSIS\Include\cmsis_compiler.h \ | ||||
|   ..\Drivers\CMSIS\Include\cmsis_armclang.h \ | ||||
|   C:\Keil_v5\ARM\ARMCLANG\Bin\..\include\arm_compat.h \ | ||||
|   C:\Keil_v5\ARM\ARMCLANG\Bin\..\include\arm_acle.h \ | ||||
|   ..\Drivers\CMSIS\Device\ST\STM32F1xx\Include\system_stm32f1xx.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\Legacy\stm32_hal_legacy.h \ | ||||
|   C:\Keil_v5\ARM\ARMCLANG\Bin\..\include\stddef.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_rcc_ex.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_gpio.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_gpio_ex.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_exti.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_dma.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_dma_ex.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_can.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_cortex.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_flash.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_flash_ex.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_iwdg.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_pwr.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_tim.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_tim_ex.h | ||||
|  | ||||
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							| @ -1,31 +1,31 @@ | ||||
| uksvep_2_2_v1\gpio.o: ../Core/Src/gpio.c | ||||
| uksvep_2_2_v1\gpio.o: ../Core/Inc/gpio.h | ||||
| uksvep_2_2_v1\gpio.o: ../Core/Inc/main.h | ||||
| uksvep_2_2_v1\gpio.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal.h | ||||
| uksvep_2_2_v1\gpio.o: ../Core/Inc/stm32f1xx_hal_conf.h | ||||
| uksvep_2_2_v1\gpio.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_rcc.h | ||||
| uksvep_2_2_v1\gpio.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_def.h | ||||
| uksvep_2_2_v1\gpio.o: ../Drivers/CMSIS/Device/ST/STM32F1xx/Include/stm32f1xx.h | ||||
| uksvep_2_2_v1\gpio.o: ../Drivers/CMSIS/Device/ST/STM32F1xx/Include/stm32f103xe.h | ||||
| uksvep_2_2_v1\gpio.o: ../Drivers/CMSIS/Include/core_cm3.h | ||||
| uksvep_2_2_v1\gpio.o: d:\Keil\ARM\ARMCC\Bin\..\include\stdint.h | ||||
| uksvep_2_2_v1\gpio.o: ../Drivers/CMSIS/Include/cmsis_version.h | ||||
| uksvep_2_2_v1\gpio.o: ../Drivers/CMSIS/Include/cmsis_compiler.h | ||||
| uksvep_2_2_v1\gpio.o: ../Drivers/CMSIS/Include/cmsis_armcc.h | ||||
| uksvep_2_2_v1\gpio.o: ../Drivers/CMSIS/Device/ST/STM32F1xx/Include/system_stm32f1xx.h | ||||
| uksvep_2_2_v1\gpio.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal.h | ||||
| uksvep_2_2_v1\gpio.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/Legacy/stm32_hal_legacy.h | ||||
| uksvep_2_2_v1\gpio.o: d:\Keil\ARM\ARMCC\Bin\..\include\stddef.h | ||||
| uksvep_2_2_v1\gpio.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_rcc_ex.h | ||||
| uksvep_2_2_v1\gpio.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_gpio.h | ||||
| uksvep_2_2_v1\gpio.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_gpio_ex.h | ||||
| uksvep_2_2_v1\gpio.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_exti.h | ||||
| uksvep_2_2_v1\gpio.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_dma.h | ||||
| uksvep_2_2_v1\gpio.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_dma_ex.h | ||||
| uksvep_2_2_v1\gpio.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_can.h | ||||
| uksvep_2_2_v1\gpio.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_cortex.h | ||||
| uksvep_2_2_v1\gpio.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_flash.h | ||||
| uksvep_2_2_v1\gpio.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_flash_ex.h | ||||
| uksvep_2_2_v1\gpio.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_pwr.h | ||||
| uksvep_2_2_v1\gpio.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_tim.h | ||||
| uksvep_2_2_v1\gpio.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_tim_ex.h | ||||
| uksvep_2_2_v1/gpio.o: ..\Core\Src\gpio.c ..\Core\Inc\gpio.h \ | ||||
|   ..\Core\Inc\main.h ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal.h \ | ||||
|   ..\Core\Inc\stm32f1xx_hal_conf.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_rcc.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_def.h \ | ||||
|   ..\Drivers\CMSIS\Device\ST\STM32F1xx\Include\stm32f1xx.h \ | ||||
|   ..\Drivers\CMSIS\Device\ST\STM32F1xx\Include\stm32f103xe.h \ | ||||
|   ..\Drivers\CMSIS\Include\core_cm3.h \ | ||||
|   C:\Keil_v5\ARM\ARMCLANG\Bin\..\include\stdint.h \ | ||||
|   ..\Drivers\CMSIS\Include\cmsis_version.h \ | ||||
|   ..\Drivers\CMSIS\Include\cmsis_compiler.h \ | ||||
|   ..\Drivers\CMSIS\Include\cmsis_armclang.h \ | ||||
|   C:\Keil_v5\ARM\ARMCLANG\Bin\..\include\arm_compat.h \ | ||||
|   C:\Keil_v5\ARM\ARMCLANG\Bin\..\include\arm_acle.h \ | ||||
|   ..\Drivers\CMSIS\Device\ST\STM32F1xx\Include\system_stm32f1xx.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\Legacy\stm32_hal_legacy.h \ | ||||
|   C:\Keil_v5\ARM\ARMCLANG\Bin\..\include\stddef.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_rcc_ex.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_gpio.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_gpio_ex.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_exti.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_dma.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_dma_ex.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_can.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_cortex.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_flash.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_flash_ex.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_iwdg.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_pwr.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_tim.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_tim_ex.h | ||||
|  | ||||
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								MDK-ARM/uksvep_2_2_v1/iwdg.crf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								MDK-ARM/uksvep_2_2_v1/iwdg.crf
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										31
									
								
								MDK-ARM/uksvep_2_2_v1/iwdg.d
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								MDK-ARM/uksvep_2_2_v1/iwdg.d
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,31 @@ | ||||
| uksvep_2_2_v1/iwdg.o: ..\Core\Src\iwdg.c ..\Core\Inc\iwdg.h \ | ||||
|   ..\Core\Inc\main.h ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal.h \ | ||||
|   ..\Core\Inc\stm32f1xx_hal_conf.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_rcc.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_def.h \ | ||||
|   ..\Drivers\CMSIS\Device\ST\STM32F1xx\Include\stm32f1xx.h \ | ||||
|   ..\Drivers\CMSIS\Device\ST\STM32F1xx\Include\stm32f103xe.h \ | ||||
|   ..\Drivers\CMSIS\Include\core_cm3.h \ | ||||
|   C:\Keil_v5\ARM\ARMCLANG\Bin\..\include\stdint.h \ | ||||
|   ..\Drivers\CMSIS\Include\cmsis_version.h \ | ||||
|   ..\Drivers\CMSIS\Include\cmsis_compiler.h \ | ||||
|   ..\Drivers\CMSIS\Include\cmsis_armclang.h \ | ||||
|   C:\Keil_v5\ARM\ARMCLANG\Bin\..\include\arm_compat.h \ | ||||
|   C:\Keil_v5\ARM\ARMCLANG\Bin\..\include\arm_acle.h \ | ||||
|   ..\Drivers\CMSIS\Device\ST\STM32F1xx\Include\system_stm32f1xx.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\Legacy\stm32_hal_legacy.h \ | ||||
|   C:\Keil_v5\ARM\ARMCLANG\Bin\..\include\stddef.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_rcc_ex.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_gpio.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_gpio_ex.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_exti.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_dma.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_dma_ex.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_can.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_cortex.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_flash.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_flash_ex.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_iwdg.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_pwr.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_tim.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_tim_ex.h | ||||
							
								
								
									
										
											BIN
										
									
								
								MDK-ARM/uksvep_2_2_v1/iwdg.o
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								MDK-ARM/uksvep_2_2_v1/iwdg.o
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							| @ -1,36 +1,33 @@ | ||||
| uksvep_2_2_v1\lampa.o: ..\Core\Src\lampa.c | ||||
| uksvep_2_2_v1\lampa.o: ../Core/Inc/gpio.h | ||||
| uksvep_2_2_v1\lampa.o: ../Core/Inc/main.h | ||||
| uksvep_2_2_v1\lampa.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal.h | ||||
| uksvep_2_2_v1\lampa.o: ../Core/Inc/stm32f1xx_hal_conf.h | ||||
| uksvep_2_2_v1\lampa.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_rcc.h | ||||
| uksvep_2_2_v1\lampa.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_def.h | ||||
| uksvep_2_2_v1\lampa.o: ../Drivers/CMSIS/Device/ST/STM32F1xx/Include/stm32f1xx.h | ||||
| uksvep_2_2_v1\lampa.o: ../Drivers/CMSIS/Device/ST/STM32F1xx/Include/stm32f103xe.h | ||||
| uksvep_2_2_v1\lampa.o: ../Drivers/CMSIS/Include/core_cm3.h | ||||
| uksvep_2_2_v1\lampa.o: d:\Keil\ARM\ARMCC\Bin\..\include\stdint.h | ||||
| uksvep_2_2_v1\lampa.o: ../Drivers/CMSIS/Include/cmsis_version.h | ||||
| uksvep_2_2_v1\lampa.o: ../Drivers/CMSIS/Include/cmsis_compiler.h | ||||
| uksvep_2_2_v1\lampa.o: ../Drivers/CMSIS/Include/cmsis_armcc.h | ||||
| uksvep_2_2_v1\lampa.o: ../Drivers/CMSIS/Device/ST/STM32F1xx/Include/system_stm32f1xx.h | ||||
| uksvep_2_2_v1\lampa.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal.h | ||||
| uksvep_2_2_v1\lampa.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/Legacy/stm32_hal_legacy.h | ||||
| uksvep_2_2_v1\lampa.o: d:\Keil\ARM\ARMCC\Bin\..\include\stddef.h | ||||
| uksvep_2_2_v1\lampa.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_rcc_ex.h | ||||
| uksvep_2_2_v1\lampa.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_gpio.h | ||||
| uksvep_2_2_v1\lampa.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_gpio_ex.h | ||||
| uksvep_2_2_v1\lampa.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_exti.h | ||||
| uksvep_2_2_v1\lampa.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_dma.h | ||||
| uksvep_2_2_v1\lampa.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_dma_ex.h | ||||
| uksvep_2_2_v1\lampa.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_can.h | ||||
| uksvep_2_2_v1\lampa.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_cortex.h | ||||
| uksvep_2_2_v1\lampa.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_flash.h | ||||
| uksvep_2_2_v1\lampa.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_flash_ex.h | ||||
| uksvep_2_2_v1\lampa.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_pwr.h | ||||
| uksvep_2_2_v1\lampa.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_tim.h | ||||
| uksvep_2_2_v1\lampa.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_tim_ex.h | ||||
| uksvep_2_2_v1\lampa.o: ../Core/Inc/lampa.h | ||||
| uksvep_2_2_v1\lampa.o: d:\Keil\ARM\ARMCC\Bin\..\include\stdbool.h | ||||
| uksvep_2_2_v1\lampa.o: ../Core/Inc/struc.h | ||||
| uksvep_2_2_v1\lampa.o: ../Core/Inc/message.h | ||||
| uksvep_2_2_v1\lampa.o: ../Core/Inc/package.h | ||||
| uksvep_2_2_v1/lampa.o: ..\Core\Src\lampa.c ..\Core\Inc\gpio.h \ | ||||
|   ..\Core\Inc\main.h ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal.h \ | ||||
|   ..\Core\Inc\stm32f1xx_hal_conf.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_rcc.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_def.h \ | ||||
|   ..\Drivers\CMSIS\Device\ST\STM32F1xx\Include\stm32f1xx.h \ | ||||
|   ..\Drivers\CMSIS\Device\ST\STM32F1xx\Include\stm32f103xe.h \ | ||||
|   ..\Drivers\CMSIS\Include\core_cm3.h \ | ||||
|   C:\Keil_v5\ARM\ARMCLANG\Bin\..\include\stdint.h \ | ||||
|   ..\Drivers\CMSIS\Include\cmsis_version.h \ | ||||
|   ..\Drivers\CMSIS\Include\cmsis_compiler.h \ | ||||
|   ..\Drivers\CMSIS\Include\cmsis_armclang.h \ | ||||
|   C:\Keil_v5\ARM\ARMCLANG\Bin\..\include\arm_compat.h \ | ||||
|   C:\Keil_v5\ARM\ARMCLANG\Bin\..\include\arm_acle.h \ | ||||
|   ..\Drivers\CMSIS\Device\ST\STM32F1xx\Include\system_stm32f1xx.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\Legacy\stm32_hal_legacy.h \ | ||||
|   C:\Keil_v5\ARM\ARMCLANG\Bin\..\include\stddef.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_rcc_ex.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_gpio.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_gpio_ex.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_exti.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_dma.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_dma_ex.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_can.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_cortex.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_flash.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_flash_ex.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_iwdg.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_pwr.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_tim.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_tim_ex.h \ | ||||
|   ..\Core\Inc\lampa.h C:\Keil_v5\ARM\ARMCLANG\Bin\..\include\stdbool.h \ | ||||
|   ..\Core\Inc\struc.h ..\Core\Inc\message.h ..\Core\Inc\package.h | ||||
|  | ||||
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							| @ -1,38 +1,35 @@ | ||||
| uksvep_2_2_v1\main.o: ../Core/Src/main.c | ||||
| uksvep_2_2_v1\main.o: ../Core/Inc/main.h | ||||
| uksvep_2_2_v1\main.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal.h | ||||
| uksvep_2_2_v1\main.o: ../Core/Inc/stm32f1xx_hal_conf.h | ||||
| uksvep_2_2_v1\main.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_rcc.h | ||||
| uksvep_2_2_v1\main.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_def.h | ||||
| uksvep_2_2_v1\main.o: ../Drivers/CMSIS/Device/ST/STM32F1xx/Include/stm32f1xx.h | ||||
| uksvep_2_2_v1\main.o: ../Drivers/CMSIS/Device/ST/STM32F1xx/Include/stm32f103xe.h | ||||
| uksvep_2_2_v1\main.o: ../Drivers/CMSIS/Include/core_cm3.h | ||||
| uksvep_2_2_v1\main.o: d:\Keil\ARM\ARMCC\Bin\..\include\stdint.h | ||||
| uksvep_2_2_v1\main.o: ../Drivers/CMSIS/Include/cmsis_version.h | ||||
| uksvep_2_2_v1\main.o: ../Drivers/CMSIS/Include/cmsis_compiler.h | ||||
| uksvep_2_2_v1\main.o: ../Drivers/CMSIS/Include/cmsis_armcc.h | ||||
| uksvep_2_2_v1\main.o: ../Drivers/CMSIS/Device/ST/STM32F1xx/Include/system_stm32f1xx.h | ||||
| uksvep_2_2_v1\main.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal.h | ||||
| uksvep_2_2_v1\main.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/Legacy/stm32_hal_legacy.h | ||||
| uksvep_2_2_v1\main.o: d:\Keil\ARM\ARMCC\Bin\..\include\stddef.h | ||||
| uksvep_2_2_v1\main.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_rcc_ex.h | ||||
| uksvep_2_2_v1\main.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_gpio.h | ||||
| uksvep_2_2_v1\main.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_gpio_ex.h | ||||
| uksvep_2_2_v1\main.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_exti.h | ||||
| uksvep_2_2_v1\main.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_dma.h | ||||
| uksvep_2_2_v1\main.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_dma_ex.h | ||||
| uksvep_2_2_v1\main.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_can.h | ||||
| uksvep_2_2_v1\main.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_cortex.h | ||||
| uksvep_2_2_v1\main.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_flash.h | ||||
| uksvep_2_2_v1\main.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_flash_ex.h | ||||
| uksvep_2_2_v1\main.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_pwr.h | ||||
| uksvep_2_2_v1\main.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_tim.h | ||||
| uksvep_2_2_v1\main.o: ../Drivers/STM32F1xx_HAL_Driver/Inc/stm32f1xx_hal_tim_ex.h | ||||
| uksvep_2_2_v1\main.o: ../Core/Inc/can.h | ||||
| uksvep_2_2_v1\main.o: ../Core/Inc/tim.h | ||||
| uksvep_2_2_v1\main.o: ../Core/Inc/gpio.h | ||||
| uksvep_2_2_v1\main.o: ../Core/Inc/package.h | ||||
| uksvep_2_2_v1\main.o: ../Core/Inc/message.h | ||||
| uksvep_2_2_v1\main.o: ../Core/Inc/struc.h | ||||
| uksvep_2_2_v1\main.o: ../Core/Inc/lampa.h | ||||
| uksvep_2_2_v1\main.o: d:\Keil\ARM\ARMCC\Bin\..\include\stdbool.h | ||||
| uksvep_2_2_v1/main.o: ..\Core\Src\main.c ..\Core\Inc\main.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal.h \ | ||||
|   ..\Core\Inc\stm32f1xx_hal_conf.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_rcc.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_def.h \ | ||||
|   ..\Drivers\CMSIS\Device\ST\STM32F1xx\Include\stm32f1xx.h \ | ||||
|   ..\Drivers\CMSIS\Device\ST\STM32F1xx\Include\stm32f103xe.h \ | ||||
|   ..\Drivers\CMSIS\Include\core_cm3.h \ | ||||
|   C:\Keil_v5\ARM\ARMCLANG\Bin\..\include\stdint.h \ | ||||
|   ..\Drivers\CMSIS\Include\cmsis_version.h \ | ||||
|   ..\Drivers\CMSIS\Include\cmsis_compiler.h \ | ||||
|   ..\Drivers\CMSIS\Include\cmsis_armclang.h \ | ||||
|   C:\Keil_v5\ARM\ARMCLANG\Bin\..\include\arm_compat.h \ | ||||
|   C:\Keil_v5\ARM\ARMCLANG\Bin\..\include\arm_acle.h \ | ||||
|   ..\Drivers\CMSIS\Device\ST\STM32F1xx\Include\system_stm32f1xx.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\Legacy\stm32_hal_legacy.h \ | ||||
|   C:\Keil_v5\ARM\ARMCLANG\Bin\..\include\stddef.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_rcc_ex.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_gpio.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_gpio_ex.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_exti.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_dma.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_dma_ex.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_can.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_cortex.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_flash.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_flash_ex.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_iwdg.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_pwr.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_tim.h \ | ||||
|   ..\Drivers\STM32F1xx_HAL_Driver\Inc\stm32f1xx_hal_tim_ex.h \ | ||||
|   ..\Core\Inc\can.h ..\Core\Inc\iwdg.h ..\Core\Inc\tim.h \ | ||||
|   ..\Core\Inc\gpio.h ..\Core\Inc\package.h ..\Core\Inc\message.h \ | ||||
|   ..\Core\Inc\struc.h ..\Core\Inc\lampa.h \ | ||||
|   C:\Keil_v5\ARM\ARMCLANG\Bin\..\include\stdbool.h | ||||
|  | ||||
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							Some files were not shown because too many files have changed in this diff Show More
		Loading…
	
		Reference in New Issue
	
	Block a user