1 /** 2 ****************************************************************************** 3 * @file stm32h7xx_hal_tim_ex.h 4 * @author MCD Application Team 5 * @brief Header file of TIM HAL Extended module. 6 ****************************************************************************** 7 * @attention 8 * 9 * Copyright (c) 2017 STMicroelectronics. 10 * All rights reserved. 11 * 12 * This software is licensed under terms that can be found in the LICENSE file 13 * in the root directory of this software component. 14 * If no LICENSE file comes with this software, it is provided AS-IS. 15 * 16 ****************************************************************************** 17 */ 18 19 /* Define to prevent recursive inclusion -------------------------------------*/ 20 #ifndef STM32H7xx_HAL_TIM_EX_H 21 #define STM32H7xx_HAL_TIM_EX_H 22 23 #ifdef __cplusplus 24 extern "C" { 25 #endif 26 27 /* Includes ------------------------------------------------------------------*/ 28 #include "stm32h7xx_hal_def.h" 29 30 /** @addtogroup STM32H7xx_HAL_Driver 31 * @{ 32 */ 33 34 /** @addtogroup TIMEx 35 * @{ 36 */ 37 38 /* Exported types ------------------------------------------------------------*/ 39 /** @defgroup TIMEx_Exported_Types TIM Extended Exported Types 40 * @{ 41 */ 42 43 /** 44 * @brief TIM Hall sensor Configuration Structure definition 45 */ 46 47 typedef struct 48 { 49 uint32_t IC1Polarity; /*!< Specifies the active edge of the input signal. 50 This parameter can be a value of @ref TIM_Input_Capture_Polarity */ 51 52 uint32_t IC1Prescaler; /*!< Specifies the Input Capture Prescaler. 53 This parameter can be a value of @ref TIM_Input_Capture_Prescaler */ 54 55 uint32_t IC1Filter; /*!< Specifies the input capture filter. 56 This parameter can be a number between Min_Data = 0x0 and Max_Data = 0xF */ 57 58 uint32_t Commutation_Delay; /*!< Specifies the pulse value to be loaded into the Capture Compare Register. 59 This parameter can be a number between Min_Data = 0x0000 and Max_Data = 0xFFFF */ 60 } TIM_HallSensor_InitTypeDef; 61 #if defined(TIM_BREAK_INPUT_SUPPORT) 62 63 /** 64 * @brief TIM Break/Break2 input configuration 65 */ 66 typedef struct 67 { 68 uint32_t Source; /*!< Specifies the source of the timer break input. 69 This parameter can be a value of @ref TIMEx_Break_Input_Source */ 70 uint32_t Enable; /*!< Specifies whether or not the break input source is enabled. 71 This parameter can be a value of @ref TIMEx_Break_Input_Source_Enable */ 72 uint32_t Polarity; /*!< Specifies the break input source polarity. 73 This parameter can be a value of @ref TIMEx_Break_Input_Source_Polarity 74 Not relevant when analog watchdog output of the DFSDM1 used as break input source */ 75 } TIMEx_BreakInputConfigTypeDef; 76 77 #endif /* TIM_BREAK_INPUT_SUPPORT */ 78 /** 79 * @} 80 */ 81 /* End of exported types -----------------------------------------------------*/ 82 83 /* Exported constants --------------------------------------------------------*/ 84 /** @defgroup TIMEx_Exported_Constants TIM Extended Exported Constants 85 * @{ 86 */ 87 88 /** @defgroup TIMEx_Remap TIM Extended Remapping 89 * @{ 90 */ 91 #define TIM_TIM1_ETR_GPIO 0x00000000U /*!< TIM1_ETR is connected to GPIO */ 92 #define TIM_TIM1_ETR_COMP1 TIM1_AF1_ETRSEL_0 /*!< TIM1_ETR is connected to COMP1 OUT */ 93 #define TIM_TIM1_ETR_COMP2 TIM1_AF1_ETRSEL_1 /*!< TIM1_ETR is connected to COMP2 OUT */ 94 #define TIM_TIM1_ETR_ADC1_AWD1 (TIM1_AF1_ETRSEL_1 | TIM1_AF1_ETRSEL_0) /*!< TIM1_ETR is connected to ADC1 AWD1 */ 95 #define TIM_TIM1_ETR_ADC1_AWD2 (TIM1_AF1_ETRSEL_2) /*!< TIM1_ETR is connected to ADC1 AWD2 */ 96 #define TIM_TIM1_ETR_ADC1_AWD3 (TIM1_AF1_ETRSEL_2 | TIM1_AF1_ETRSEL_0) /*!< TIM1_ETR is connected to ADC1 AWD3 */ 97 #define TIM_TIM1_ETR_ADC3_AWD1 (TIM1_AF1_ETRSEL_2 | TIM1_AF1_ETRSEL_1) /*!< TIM1_ETR is connected to ADC3 AWD1 */ 98 #define TIM_TIM1_ETR_ADC3_AWD2 (TIM1_AF1_ETRSEL_2 | TIM1_AF1_ETRSEL_1 | TIM1_AF1_ETRSEL_0) /*!< TIM1_ETR is connected to ADC3 AWD2 */ 99 #define TIM_TIM1_ETR_ADC3_AWD3 TIM1_AF1_ETRSEL_3 /*!< TIM1_ETR is connected to ADC3 AWD3 */ 100 101 #define TIM_TIM8_ETR_GPIO 0x00000000U /*!< TIM8_ETR is connected to GPIO */ 102 #define TIM_TIM8_ETR_COMP1 TIM8_AF1_ETRSEL_0 /*!< TIM8_ETR is connected to COMP1 OUT */ 103 #define TIM_TIM8_ETR_COMP2 TIM8_AF1_ETRSEL_1 /*!< TIM8_ETR is connected to COMP2 OUT */ 104 #define TIM_TIM8_ETR_ADC2_AWD1 (TIM8_AF1_ETRSEL_1 | TIM8_AF1_ETRSEL_0) /*!< TIM8_ETR is connected to ADC2 AWD1 */ 105 #define TIM_TIM8_ETR_ADC2_AWD2 (TIM8_AF1_ETRSEL_2) /*!< TIM8_ETR is connected to ADC2 AWD2 */ 106 #define TIM_TIM8_ETR_ADC2_AWD3 (TIM8_AF1_ETRSEL_2 | TIM8_AF1_ETRSEL_0) /*!< TIM8_ETR is connected to ADC2 AWD3 */ 107 #define TIM_TIM8_ETR_ADC3_AWD1 (TIM8_AF1_ETRSEL_2 | TIM8_AF1_ETRSEL_1) /*!< TIM8_ETR is connected to ADC3 AWD1 */ 108 #define TIM_TIM8_ETR_ADC3_AWD2 (TIM8_AF1_ETRSEL_2 | TIM8_AF1_ETRSEL_1 | TIM8_AF1_ETRSEL_0) /*!< TIM8_ETR is connected to ADC3 AWD2 */ 109 #define TIM_TIM8_ETR_ADC3_AWD3 TIM8_AF1_ETRSEL_3 /*!< TIM8_ETR is connected to ADC3 AWD3 */ 110 111 #define TIM_TIM2_ETR_GPIO 0x00000000U /*!< TIM2_ETR is connected to GPIO */ 112 #define TIM_TIM2_ETR_COMP1 (TIM2_AF1_ETRSEL_0) /*!< TIM2_ETR is connected to COMP1 OUT */ 113 #define TIM_TIM2_ETR_COMP2 (TIM2_AF1_ETRSEL_1) /*!< TIM2_ETR is connected to COMP2 OUT */ 114 #define TIM_TIM2_ETR_RCC_LSE (TIM2_AF1_ETRSEL_1 | TIM8_AF1_ETRSEL_0) /*!< TIM2_ETR is connected to RCC LSE */ 115 #define TIM_TIM2_ETR_SAI1_FSA TIM2_AF1_ETRSEL_2 /*!< TIM2_ETR is connected to SAI1 FS_A */ 116 #define TIM_TIM2_ETR_SAI1_FSB (TIM2_AF1_ETRSEL_2 | TIM8_AF1_ETRSEL_0) /*!< TIM2_ETR is connected to SAI1 FS_B */ 117 118 #define TIM_TIM3_ETR_GPIO 0x00000000U /*!< TIM3_ETR is connected to GPIO */ 119 #define TIM_TIM3_ETR_COMP1 TIM3_AF1_ETRSEL_0 /*!< TIM3_ETR is connected to COMP1 OUT */ 120 121 #define TIM_TIM5_ETR_GPIO 0x00000000U /*!< TIM5_ETR is connected to GPIO */ 122 #define TIM_TIM5_ETR_SAI2_FSA TIM5_AF1_ETRSEL_0 /*!< TIM5_ETR is connected to SAI2 FS_A */ 123 #define TIM_TIM5_ETR_SAI2_FSB TIM5_AF1_ETRSEL_1 /*!< TIM5_ETR is connected to SAI2 FS_B */ 124 #define TIM_TIM5_ETR_SAI4_FSA TIM5_AF1_ETRSEL_0 /*!< TIM5_ETR is connected to SAI4 FS_A */ 125 #define TIM_TIM5_ETR_SAI4_FSB TIM5_AF1_ETRSEL_1 /*!< TIM5_ETR is connected to SAI4 FS_B */ 126 127 #define TIM_TIM23_ETR_GPIO 0x00000000U /*!< TIM23_ETR is connected to GPIO */ 128 #define TIM_TIM23_ETR_COMP1 (TIM2_AF1_ETRSEL_0) /*!< TIM23_ETR is connected to COMP1 OUT */ 129 #define TIM_TIM23_ETR_COMP2 (TIM2_AF1_ETRSEL_1) /*!< TIM23_ETR is connected to COMP2 OUT */ 130 131 #define TIM_TIM24_ETR_GPIO 0x00000000U /*!< TIM24_ETR is connected to GPIO */ 132 #define TIM_TIM24_ETR_SAI4_FSA TIM5_AF1_ETRSEL_0 /*!< TIM24_ETR is connected to SAI4 FS_A */ 133 #define TIM_TIM24_ETR_SAI4_FSB TIM5_AF1_ETRSEL_1 /*!< TIM24_ETR is connected to SAI4 FS_B */ 134 #define TIM_TIM24_ETR_SAI1_FSA (TIM2_AF1_ETRSEL_1 | TIM8_AF1_ETRSEL_0) /*!< TIM24_ETR is connected to SAI1 FS_A */ 135 #define TIM_TIM24_ETR_SAI1_FSB TIM2_AF1_ETRSEL_2 /*!< TIM24_ETR is connected to SAI1 FS_B */ 136 /** 137 * @} 138 */ 139 #if defined(TIM_BREAK_INPUT_SUPPORT) 140 141 /** @defgroup TIMEx_Break_Input TIM Extended Break input 142 * @{ 143 */ 144 #define TIM_BREAKINPUT_BRK 0x00000001U /*!< Timer break input */ 145 #define TIM_BREAKINPUT_BRK2 0x00000002U /*!< Timer break2 input */ 146 /** 147 * @} 148 */ 149 150 /** @defgroup TIMEx_Break_Input_Source TIM Extended Break input source 151 * @{ 152 */ 153 #define TIM_BREAKINPUTSOURCE_BKIN 0x00000001U /*!< An external source (GPIO) is connected to the BKIN pin */ 154 #define TIM_BREAKINPUTSOURCE_COMP1 0x00000002U /*!< The COMP1 output is connected to the break input */ 155 #define TIM_BREAKINPUTSOURCE_COMP2 0x00000004U /*!< The COMP2 output is connected to the break input */ 156 #define TIM_BREAKINPUTSOURCE_DFSDM1 0x00000008U /*!< The analog watchdog output of the DFSDM1 peripheral is connected to the break input */ 157 /** 158 * @} 159 */ 160 161 /** @defgroup TIMEx_Break_Input_Source_Enable TIM Extended Break input source enabling 162 * @{ 163 */ 164 #define TIM_BREAKINPUTSOURCE_DISABLE 0x00000000U /*!< Break input source is disabled */ 165 #define TIM_BREAKINPUTSOURCE_ENABLE 0x00000001U /*!< Break input source is enabled */ 166 /** 167 * @} 168 */ 169 170 /** @defgroup TIMEx_Break_Input_Source_Polarity TIM Extended Break input polarity 171 * @{ 172 */ 173 #define TIM_BREAKINPUTSOURCE_POLARITY_LOW 0x00000001U /*!< Break input source is active low */ 174 #define TIM_BREAKINPUTSOURCE_POLARITY_HIGH 0x00000000U /*!< Break input source is active_high */ 175 /** 176 * @} 177 */ 178 #endif /* TIM_BREAK_INPUT_SUPPORT */ 179 180 /** @defgroup TIMEx_Timer_Input_Selection TIM Extended Timer input selection 181 * @{ 182 */ 183 #define TIM_TIM1_TI1_GPIO 0x00000000U /*!< TIM1_TI1 is connected to GPIO */ 184 #define TIM_TIM1_TI1_COMP1 TIM_TISEL_TI1SEL_0 /*!< TIM1_TI1 is connected to COMP1 OUT */ 185 186 #define TIM_TIM8_TI1_GPIO 0x00000000U /*!< TIM8_TI1 is connected to GPIO */ 187 #define TIM_TIM8_TI1_COMP2 TIM_TISEL_TI1SEL_0 /*!< TIM8_TI1 is connected to COMP2 OUT */ 188 189 #define TIM_TIM2_TI4_GPIO 0x00000000U /*!< TIM2_TI4 is connected to GPIO */ 190 #define TIM_TIM2_TI4_COMP1 TIM_TISEL_TI4SEL_0 /*!< TIM2_TI4 is connected to COMP1 OUT */ 191 #define TIM_TIM2_TI4_COMP2 TIM_TISEL_TI4SEL_1 /*!< TIM2_TI4 is connected to COMP2 OUT */ 192 #define TIM_TIM2_TI4_COMP1_COMP2 (TIM_TISEL_TI4SEL_0 | TIM_TISEL_TI4SEL_1) /*!< TIM2_TI4 is connected to COMP2 OUT OR COMP2 OUT */ 193 194 #define TIM_TIM3_TI1_GPIO 0x00000000U /*!< TIM3_TI1 is connected to GPIO */ 195 #define TIM_TIM3_TI1_COMP1 TIM_TISEL_TI1SEL_0 /*!< TIM3_TI1 is connected to COMP1 OUT */ 196 #define TIM_TIM3_TI1_COMP2 TIM_TISEL_TI1SEL_1 /*!< TIM3_TI1 is connected to COMP2 OUT */ 197 #define TIM_TIM3_TI1_COMP1_COMP2 (TIM_TISEL_TI1SEL_0 | TIM_TISEL_TI1SEL_1) /*!< TIM3_TI1 is connected to COMP1 OUT or COMP2 OUT */ 198 199 #define TIM_TIM5_TI1_GPIO 0x00000000U /*!< TIM5_TI1 is connected to GPIO */ 200 #define TIM_TIM5_TI1_CAN_TMP TIM_TISEL_TI1SEL_0 /*!< TIM5_TI1 is connected to CAN TMP */ 201 #define TIM_TIM5_TI1_CAN_RTP TIM_TISEL_TI1SEL_1 /*!< TIM5_TI1 is connected to CAN RTP */ 202 203 #define TIM_TIM12_TI1_GPIO 0x00000000U /*!< TIM12 TI1 is connected to GPIO */ 204 #define TIM_TIM12_TI1_SPDIF_FS TIM_TISEL_TI1SEL_0 /*!< TIM12 TI1 is connected to SPDIF FS */ 205 206 #define TIM_TIM15_TI1_GPIO 0x00000000U /*!< TIM15_TI1 is connected to GPIO */ 207 #define TIM_TIM15_TI1_TIM2_CH1 TIM_TISEL_TI1SEL_0 /*!< TIM15_TI1 is connected to TIM2 CH1 */ 208 #define TIM_TIM15_TI1_TIM3_CH1 TIM_TISEL_TI1SEL_1 /*!< TIM15_TI1 is connected to TIM3 CH1 */ 209 #define TIM_TIM15_TI1_TIM4_CH1 (TIM_TISEL_TI1SEL_0 | TIM_TISEL_TI1SEL_1) /*!< TIM15_TI1 is connected to TIM4 CH1 */ 210 #define TIM_TIM15_TI1_RCC_LSE (TIM_TISEL_TI1SEL_2) /*!< TIM15_TI1 is connected to RCC LSE */ 211 #define TIM_TIM15_TI1_RCC_CSI (TIM_TISEL_TI1SEL_2 | TIM_TISEL_TI1SEL_0) /*!< TIM15_TI1 is connected to RCC CSI */ 212 #define TIM_TIM15_TI1_RCC_MCO2 (TIM_TISEL_TI1SEL_2 | TIM_TISEL_TI1SEL_1) /*!< TIM15_TI1 is connected to RCC MCO2 */ 213 214 #define TIM_TIM15_TI2_GPIO 0x00000000U /*!< TIM15_TI2 is connected to GPIO */ 215 #define TIM_TIM15_TI2_TIM2_CH2 (TIM_TISEL_TI2SEL_0) /*!< TIM15_TI2 is connected to TIM2 CH2 */ 216 #define TIM_TIM15_TI2_TIM3_CH2 (TIM_TISEL_TI2SEL_1) /*!< TIM15_TI2 is connected to TIM3 CH2 */ 217 #define TIM_TIM15_TI2_TIM4_CH2 (TIM_TISEL_TI2SEL_0 | TIM_TISEL_TI2SEL_1) /*!< TIM15_TI2 is connected to TIM4 CH2 */ 218 219 #define TIM_TIM16_TI1_GPIO 0x00000000U /*!< TIM16 TI1 is connected to GPIO */ 220 #define TIM_TIM16_TI1_RCC_LSI TIM_TISEL_TI1SEL_0 /*!< TIM16 TI1 is connected to RCC LSI */ 221 #define TIM_TIM16_TI1_RCC_LSE TIM_TISEL_TI1SEL_1 /*!< TIM16 TI1 is connected to RCC LSE */ 222 #define TIM_TIM16_TI1_WKUP_IT (TIM_TISEL_TI1SEL_0 | TIM_TISEL_TI1SEL_1) /*!< TIM16 TI1 is connected to WKUP_IT */ 223 224 #define TIM_TIM17_TI1_GPIO 0x00000000U /*!< TIM17 TI1 is connected to GPIO */ 225 #define TIM_TIM17_TI1_SPDIF_FS TIM_TISEL_TI1SEL_0 /*!< TIM17 TI1 is connected to SPDIF FS */ 226 #define TIM_TIM17_TI1_RCC_HSE1MHZ TIM_TISEL_TI1SEL_1 /*!< TIM17 TI1 is connected to RCC HSE 1Mhz */ 227 #define TIM_TIM17_TI1_RCC_MCO1 (TIM_TISEL_TI1SEL_0 | TIM_TISEL_TI1SEL_1) /*!< TIM17 TI1 is connected to RCC MCO1 */ 228 229 #define TIM_TIM23_TI4_GPIO 0x00000000U /*!< TIM23_TI4 is connected to GPIO */ 230 #define TIM_TIM23_TI4_COMP1 TIM_TISEL_TI4SEL_0 /*!< TIM23_TI4 is connected to COMP1 OUT */ 231 #define TIM_TIM23_TI4_COMP2 TIM_TISEL_TI4SEL_1 /*!< TIM23_TI4 is connected to COMP2 OUT */ 232 #define TIM_TIM23_TI4_COMP1_COMP2 (TIM_TISEL_TI4SEL_0 | TIM_TISEL_TI4SEL_1) /*!< TIM23_TI4 is connected to COMP1 OUT or COMP2 OUT */ 233 234 #define TIM_TIM24_TI1_GPIO 0x00000000U /*!< TIM24_TI1 is connected to GPIO */ 235 #define TIM_TIM24_TI1_CAN_TMP TIM_TISEL_TI1SEL_0 /*!< TIM24_TI1 is connected to CAN TMP */ 236 #define TIM_TIM24_TI1_CAN_RTP TIM_TISEL_TI1SEL_1 /*!< TIM24_TI1 is connected to CAN RTP */ 237 #define TIM_TIM24_TI1_CAN_SOC (TIM_TISEL_TI4SEL_0 | TIM_TISEL_TI4SEL_1) /*!< TIM24_TI1 is connected to CAN SOC */ 238 /** 239 * @} 240 */ 241 242 /** 243 * @} 244 */ 245 /* End of exported constants -------------------------------------------------*/ 246 247 /* Exported macro ------------------------------------------------------------*/ 248 /** @defgroup TIMEx_Exported_Macros TIM Extended Exported Macros 249 * @{ 250 */ 251 252 /** 253 * @} 254 */ 255 /* End of exported macro -----------------------------------------------------*/ 256 257 /* Private macro -------------------------------------------------------------*/ 258 /** @defgroup TIMEx_Private_Macros TIM Extended Private Macros 259 * @{ 260 */ 261 #define IS_TIM_BREAKINPUT(__BREAKINPUT__) (((__BREAKINPUT__) == TIM_BREAKINPUT_BRK) || \ 262 ((__BREAKINPUT__) == TIM_BREAKINPUT_BRK2)) 263 264 #define IS_TIM_BREAKINPUTSOURCE(__SOURCE__) (((__SOURCE__) == TIM_BREAKINPUTSOURCE_BKIN) || \ 265 ((__SOURCE__) == TIM_BREAKINPUTSOURCE_COMP1) || \ 266 ((__SOURCE__) == TIM_BREAKINPUTSOURCE_COMP2) || \ 267 ((__SOURCE__) == TIM_BREAKINPUTSOURCE_DFSDM1)) 268 269 #define IS_TIM_BREAKINPUTSOURCE_STATE(__STATE__) (((__STATE__) == TIM_BREAKINPUTSOURCE_DISABLE) || \ 270 ((__STATE__) == TIM_BREAKINPUTSOURCE_ENABLE)) 271 272 #define IS_TIM_BREAKINPUTSOURCE_POLARITY(__POLARITY__) (((__POLARITY__) == TIM_BREAKINPUTSOURCE_POLARITY_LOW) || \ 273 ((__POLARITY__) == TIM_BREAKINPUTSOURCE_POLARITY_HIGH)) 274 275 #define IS_TIM_TISEL(__TISEL__) (((__TISEL__) == TIM_TIM1_TI1_GPIO) ||\ 276 ((__TISEL__) == TIM_TIM1_TI1_COMP1) ||\ 277 ((__TISEL__) == TIM_TIM8_TI1_GPIO) ||\ 278 ((__TISEL__) == TIM_TIM8_TI1_COMP2) ||\ 279 ((__TISEL__) == TIM_TIM2_TI4_GPIO) ||\ 280 ((__TISEL__) == TIM_TIM2_TI4_COMP1) ||\ 281 ((__TISEL__) == TIM_TIM2_TI4_COMP2) ||\ 282 ((__TISEL__) == TIM_TIM2_TI4_COMP1_COMP2) ||\ 283 ((__TISEL__) == TIM_TIM3_TI1_GPIO) ||\ 284 ((__TISEL__) == TIM_TIM3_TI1_COMP1) ||\ 285 ((__TISEL__) == TIM_TIM3_TI1_COMP2) ||\ 286 ((__TISEL__) == TIM_TIM3_TI1_COMP1_COMP2) ||\ 287 ((__TISEL__) == TIM_TIM5_TI1_GPIO) ||\ 288 ((__TISEL__) == TIM_TIM5_TI1_CAN_TMP) ||\ 289 ((__TISEL__) == TIM_TIM5_TI1_CAN_RTP) ||\ 290 ((__TISEL__) == TIM_TIM12_TI1_SPDIF_FS) ||\ 291 ((__TISEL__) == TIM_TIM12_TI1_GPIO) ||\ 292 ((__TISEL__) == TIM_TIM15_TI1_GPIO) ||\ 293 ((__TISEL__) == TIM_TIM15_TI1_TIM2_CH1) ||\ 294 ((__TISEL__) == TIM_TIM15_TI1_TIM3_CH1) ||\ 295 ((__TISEL__) == TIM_TIM15_TI1_TIM4_CH1) ||\ 296 ((__TISEL__) == TIM_TIM15_TI1_RCC_LSE) ||\ 297 ((__TISEL__) == TIM_TIM15_TI1_RCC_CSI) ||\ 298 ((__TISEL__) == TIM_TIM15_TI1_RCC_MCO2) ||\ 299 ((__TISEL__) == TIM_TIM15_TI2_GPIO) ||\ 300 ((__TISEL__) == TIM_TIM15_TI2_TIM2_CH2) ||\ 301 ((__TISEL__) == TIM_TIM15_TI2_TIM3_CH2) ||\ 302 ((__TISEL__) == TIM_TIM15_TI2_TIM4_CH2) ||\ 303 ((__TISEL__) == TIM_TIM16_TI1_GPIO) ||\ 304 ((__TISEL__) == TIM_TIM16_TI1_RCC_LSI) ||\ 305 ((__TISEL__) == TIM_TIM16_TI1_RCC_LSE) ||\ 306 ((__TISEL__) == TIM_TIM16_TI1_WKUP_IT) ||\ 307 ((__TISEL__) == TIM_TIM17_TI1_GPIO) ||\ 308 ((__TISEL__) == TIM_TIM17_TI1_SPDIF_FS) ||\ 309 ((__TISEL__) == TIM_TIM17_TI1_RCC_HSE1MHZ) ||\ 310 ((__TISEL__) == TIM_TIM17_TI1_RCC_MCO1) ||\ 311 ((__TISEL__) == TIM_TIM23_TI4_GPIO) ||\ 312 ((__TISEL__) == TIM_TIM23_TI4_COMP1) ||\ 313 ((__TISEL__) == TIM_TIM23_TI4_COMP2) ||\ 314 ((__TISEL__) == TIM_TIM23_TI4_COMP1_COMP2) ||\ 315 ((__TISEL__) == TIM_TIM24_TI1_GPIO) ||\ 316 ((__TISEL__) == TIM_TIM24_TI1_CAN_TMP) ||\ 317 ((__TISEL__) == TIM_TIM24_TI1_CAN_RTP) ||\ 318 ((__TISEL__) == TIM_TIM24_TI1_CAN_SOC)) 319 320 #define IS_TIM_REMAP(__RREMAP__) (((__RREMAP__) == TIM_TIM1_ETR_GPIO) ||\ 321 ((__RREMAP__) == TIM_TIM1_ETR_ADC1_AWD1) ||\ 322 ((__RREMAP__) == TIM_TIM1_ETR_ADC1_AWD2) ||\ 323 ((__RREMAP__) == TIM_TIM1_ETR_ADC1_AWD3) ||\ 324 ((__RREMAP__) == TIM_TIM1_ETR_ADC3_AWD1) ||\ 325 ((__RREMAP__) == TIM_TIM1_ETR_ADC3_AWD2) ||\ 326 ((__RREMAP__) == TIM_TIM1_ETR_ADC3_AWD3) ||\ 327 ((__RREMAP__) == TIM_TIM1_ETR_COMP1) ||\ 328 ((__RREMAP__) == TIM_TIM1_ETR_COMP2) ||\ 329 ((__RREMAP__) == TIM_TIM8_ETR_GPIO) ||\ 330 ((__RREMAP__) == TIM_TIM8_ETR_ADC2_AWD1) ||\ 331 ((__RREMAP__) == TIM_TIM8_ETR_ADC2_AWD2) ||\ 332 ((__RREMAP__) == TIM_TIM8_ETR_ADC2_AWD3) ||\ 333 ((__RREMAP__) == TIM_TIM8_ETR_ADC3_AWD1) ||\ 334 ((__RREMAP__) == TIM_TIM8_ETR_ADC3_AWD2) ||\ 335 ((__RREMAP__) == TIM_TIM8_ETR_ADC3_AWD3) ||\ 336 ((__RREMAP__) == TIM_TIM8_ETR_COMP1) ||\ 337 ((__RREMAP__) == TIM_TIM8_ETR_COMP2) ||\ 338 ((__RREMAP__) == TIM_TIM2_ETR_GPIO) ||\ 339 ((__RREMAP__) == TIM_TIM2_ETR_COMP1) ||\ 340 ((__RREMAP__) == TIM_TIM2_ETR_COMP2) ||\ 341 ((__RREMAP__) == TIM_TIM2_ETR_RCC_LSE) ||\ 342 ((__RREMAP__) == TIM_TIM2_ETR_SAI1_FSA) ||\ 343 ((__RREMAP__) == TIM_TIM2_ETR_SAI1_FSB) ||\ 344 ((__RREMAP__) == TIM_TIM3_ETR_GPIO) ||\ 345 ((__RREMAP__) == TIM_TIM3_ETR_COMP1) ||\ 346 ((__RREMAP__) == TIM_TIM5_ETR_GPIO) ||\ 347 ((__RREMAP__) == TIM_TIM5_ETR_SAI2_FSA) ||\ 348 ((__RREMAP__) == TIM_TIM5_ETR_SAI2_FSB) ||\ 349 ((__RREMAP__) == TIM_TIM23_ETR_GPIO) ||\ 350 ((__RREMAP__) == TIM_TIM23_ETR_COMP1) ||\ 351 ((__RREMAP__) == TIM_TIM23_ETR_COMP2) ||\ 352 ((__RREMAP__) == TIM_TIM24_ETR_GPIO) ||\ 353 ((__RREMAP__) == TIM_TIM24_ETR_SAI4_FSA) ||\ 354 ((__RREMAP__) == TIM_TIM24_ETR_SAI4_FSB) ||\ 355 ((__RREMAP__) == TIM_TIM24_ETR_SAI1_FSA) ||\ 356 ((__RREMAP__) == TIM_TIM24_ETR_SAI1_FSB)) 357 358 /** 359 * @} 360 */ 361 /* End of private macro ------------------------------------------------------*/ 362 363 /* Exported functions --------------------------------------------------------*/ 364 /** @addtogroup TIMEx_Exported_Functions TIM Extended Exported Functions 365 * @{ 366 */ 367 368 /** @addtogroup TIMEx_Exported_Functions_Group1 Extended Timer Hall Sensor functions 369 * @brief Timer Hall Sensor functions 370 * @{ 371 */ 372 /* Timer Hall Sensor functions **********************************************/ 373 HAL_StatusTypeDef HAL_TIMEx_HallSensor_Init(TIM_HandleTypeDef *htim, const TIM_HallSensor_InitTypeDef *sConfig); 374 HAL_StatusTypeDef HAL_TIMEx_HallSensor_DeInit(TIM_HandleTypeDef *htim); 375 376 void HAL_TIMEx_HallSensor_MspInit(TIM_HandleTypeDef *htim); 377 void HAL_TIMEx_HallSensor_MspDeInit(TIM_HandleTypeDef *htim); 378 379 /* Blocking mode: Polling */ 380 HAL_StatusTypeDef HAL_TIMEx_HallSensor_Start(TIM_HandleTypeDef *htim); 381 HAL_StatusTypeDef HAL_TIMEx_HallSensor_Stop(TIM_HandleTypeDef *htim); 382 /* Non-Blocking mode: Interrupt */ 383 HAL_StatusTypeDef HAL_TIMEx_HallSensor_Start_IT(TIM_HandleTypeDef *htim); 384 HAL_StatusTypeDef HAL_TIMEx_HallSensor_Stop_IT(TIM_HandleTypeDef *htim); 385 /* Non-Blocking mode: DMA */ 386 HAL_StatusTypeDef HAL_TIMEx_HallSensor_Start_DMA(TIM_HandleTypeDef *htim, uint32_t *pData, uint16_t Length); 387 HAL_StatusTypeDef HAL_TIMEx_HallSensor_Stop_DMA(TIM_HandleTypeDef *htim); 388 /** 389 * @} 390 */ 391 392 /** @addtogroup TIMEx_Exported_Functions_Group2 Extended Timer Complementary Output Compare functions 393 * @brief Timer Complementary Output Compare functions 394 * @{ 395 */ 396 /* Timer Complementary Output Compare functions *****************************/ 397 /* Blocking mode: Polling */ 398 HAL_StatusTypeDef HAL_TIMEx_OCN_Start(TIM_HandleTypeDef *htim, uint32_t Channel); 399 HAL_StatusTypeDef HAL_TIMEx_OCN_Stop(TIM_HandleTypeDef *htim, uint32_t Channel); 400 401 /* Non-Blocking mode: Interrupt */ 402 HAL_StatusTypeDef HAL_TIMEx_OCN_Start_IT(TIM_HandleTypeDef *htim, uint32_t Channel); 403 HAL_StatusTypeDef HAL_TIMEx_OCN_Stop_IT(TIM_HandleTypeDef *htim, uint32_t Channel); 404 405 /* Non-Blocking mode: DMA */ 406 HAL_StatusTypeDef HAL_TIMEx_OCN_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Channel, const uint32_t *pData, 407 uint16_t Length); 408 HAL_StatusTypeDef HAL_TIMEx_OCN_Stop_DMA(TIM_HandleTypeDef *htim, uint32_t Channel); 409 /** 410 * @} 411 */ 412 413 /** @addtogroup TIMEx_Exported_Functions_Group3 Extended Timer Complementary PWM functions 414 * @brief Timer Complementary PWM functions 415 * @{ 416 */ 417 /* Timer Complementary PWM functions ****************************************/ 418 /* Blocking mode: Polling */ 419 HAL_StatusTypeDef HAL_TIMEx_PWMN_Start(TIM_HandleTypeDef *htim, uint32_t Channel); 420 HAL_StatusTypeDef HAL_TIMEx_PWMN_Stop(TIM_HandleTypeDef *htim, uint32_t Channel); 421 422 /* Non-Blocking mode: Interrupt */ 423 HAL_StatusTypeDef HAL_TIMEx_PWMN_Start_IT(TIM_HandleTypeDef *htim, uint32_t Channel); 424 HAL_StatusTypeDef HAL_TIMEx_PWMN_Stop_IT(TIM_HandleTypeDef *htim, uint32_t Channel); 425 /* Non-Blocking mode: DMA */ 426 HAL_StatusTypeDef HAL_TIMEx_PWMN_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Channel, const uint32_t *pData, 427 uint16_t Length); 428 HAL_StatusTypeDef HAL_TIMEx_PWMN_Stop_DMA(TIM_HandleTypeDef *htim, uint32_t Channel); 429 /** 430 * @} 431 */ 432 433 /** @addtogroup TIMEx_Exported_Functions_Group4 Extended Timer Complementary One Pulse functions 434 * @brief Timer Complementary One Pulse functions 435 * @{ 436 */ 437 /* Timer Complementary One Pulse functions **********************************/ 438 /* Blocking mode: Polling */ 439 HAL_StatusTypeDef HAL_TIMEx_OnePulseN_Start(TIM_HandleTypeDef *htim, uint32_t OutputChannel); 440 HAL_StatusTypeDef HAL_TIMEx_OnePulseN_Stop(TIM_HandleTypeDef *htim, uint32_t OutputChannel); 441 442 /* Non-Blocking mode: Interrupt */ 443 HAL_StatusTypeDef HAL_TIMEx_OnePulseN_Start_IT(TIM_HandleTypeDef *htim, uint32_t OutputChannel); 444 HAL_StatusTypeDef HAL_TIMEx_OnePulseN_Stop_IT(TIM_HandleTypeDef *htim, uint32_t OutputChannel); 445 /** 446 * @} 447 */ 448 449 /** @addtogroup TIMEx_Exported_Functions_Group5 Extended Peripheral Control functions 450 * @brief Peripheral Control functions 451 * @{ 452 */ 453 /* Extended Control functions ************************************************/ 454 HAL_StatusTypeDef HAL_TIMEx_ConfigCommutEvent(TIM_HandleTypeDef *htim, uint32_t InputTrigger, 455 uint32_t CommutationSource); 456 HAL_StatusTypeDef HAL_TIMEx_ConfigCommutEvent_IT(TIM_HandleTypeDef *htim, uint32_t InputTrigger, 457 uint32_t CommutationSource); 458 HAL_StatusTypeDef HAL_TIMEx_ConfigCommutEvent_DMA(TIM_HandleTypeDef *htim, uint32_t InputTrigger, 459 uint32_t CommutationSource); 460 HAL_StatusTypeDef HAL_TIMEx_MasterConfigSynchronization(TIM_HandleTypeDef *htim, 461 const TIM_MasterConfigTypeDef *sMasterConfig); 462 HAL_StatusTypeDef HAL_TIMEx_ConfigBreakDeadTime(TIM_HandleTypeDef *htim, 463 const TIM_BreakDeadTimeConfigTypeDef *sBreakDeadTimeConfig); 464 #if defined(TIM_BREAK_INPUT_SUPPORT) 465 HAL_StatusTypeDef HAL_TIMEx_ConfigBreakInput(TIM_HandleTypeDef *htim, uint32_t BreakInput, 466 const TIMEx_BreakInputConfigTypeDef *sBreakInputConfig); 467 #endif /* TIM_BREAK_INPUT_SUPPORT */ 468 HAL_StatusTypeDef HAL_TIMEx_GroupChannel5(TIM_HandleTypeDef *htim, uint32_t Channels); 469 HAL_StatusTypeDef HAL_TIMEx_RemapConfig(TIM_HandleTypeDef *htim, uint32_t Remap); 470 HAL_StatusTypeDef HAL_TIMEx_TISelection(TIM_HandleTypeDef *htim, uint32_t TISelection, uint32_t Channel); 471 #if defined(TIM_BDTR_BKBID) 472 473 HAL_StatusTypeDef HAL_TIMEx_DisarmBreakInput(TIM_HandleTypeDef *htim, uint32_t BreakInput); 474 HAL_StatusTypeDef HAL_TIMEx_ReArmBreakInput(TIM_HandleTypeDef *htim, uint32_t BreakInput); 475 #endif /* TIM_BDTR_BKBID */ 476 /** 477 * @} 478 */ 479 480 /** @addtogroup TIMEx_Exported_Functions_Group6 Extended Callbacks functions 481 * @brief Extended Callbacks functions 482 * @{ 483 */ 484 /* Extended Callback **********************************************************/ 485 void HAL_TIMEx_CommutCallback(TIM_HandleTypeDef *htim); 486 void HAL_TIMEx_CommutHalfCpltCallback(TIM_HandleTypeDef *htim); 487 void HAL_TIMEx_BreakCallback(TIM_HandleTypeDef *htim); 488 void HAL_TIMEx_Break2Callback(TIM_HandleTypeDef *htim); 489 /** 490 * @} 491 */ 492 493 /** @addtogroup TIMEx_Exported_Functions_Group7 Extended Peripheral State functions 494 * @brief Extended Peripheral State functions 495 * @{ 496 */ 497 /* Extended Peripheral State functions ***************************************/ 498 HAL_TIM_StateTypeDef HAL_TIMEx_HallSensor_GetState(const TIM_HandleTypeDef *htim); 499 HAL_TIM_ChannelStateTypeDef HAL_TIMEx_GetChannelNState(const TIM_HandleTypeDef *htim, uint32_t ChannelN); 500 /** 501 * @} 502 */ 503 504 /** 505 * @} 506 */ 507 /* End of exported functions -------------------------------------------------*/ 508 509 /* Private functions----------------------------------------------------------*/ 510 /** @addtogroup TIMEx_Private_Functions TIM Extended Private Functions 511 * @{ 512 */ 513 void TIMEx_DMACommutationCplt(DMA_HandleTypeDef *hdma); 514 void TIMEx_DMACommutationHalfCplt(DMA_HandleTypeDef *hdma); 515 /** 516 * @} 517 */ 518 /* End of private functions --------------------------------------------------*/ 519 520 /** 521 * @} 522 */ 523 524 /** 525 * @} 526 */ 527 528 #ifdef __cplusplus 529 } 530 #endif 531 532 533 #endif /* STM32H7xx_HAL_TIM_EX_H */ 534