Committer:
Sergunb
Date:
Mon Sep 04 12:04:13 2017 +0000
Revision:
0:8f0d870509fe
Initial commit

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Sergunb 0:8f0d870509fe 1 /**
Sergunb 0:8f0d870509fe 2 ******************************************************************************
Sergunb 0:8f0d870509fe 3 * @file stm32f10x_tim.h
Sergunb 0:8f0d870509fe 4 * @author MCD Application Team
Sergunb 0:8f0d870509fe 5 * @version V3.4.0
Sergunb 0:8f0d870509fe 6 * @date 10/15/2010
Sergunb 0:8f0d870509fe 7 * @brief This file contains all the functions prototypes for the TIM firmware
Sergunb 0:8f0d870509fe 8 * library.
Sergunb 0:8f0d870509fe 9 ******************************************************************************
Sergunb 0:8f0d870509fe 10 * @copy
Sergunb 0:8f0d870509fe 11 *
Sergunb 0:8f0d870509fe 12 * THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
Sergunb 0:8f0d870509fe 13 * WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
Sergunb 0:8f0d870509fe 14 * TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
Sergunb 0:8f0d870509fe 15 * DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
Sergunb 0:8f0d870509fe 16 * FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
Sergunb 0:8f0d870509fe 17 * CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
Sergunb 0:8f0d870509fe 18 *
Sergunb 0:8f0d870509fe 19 * <h2><center>&copy; COPYRIGHT 2010 STMicroelectronics</center></h2>
Sergunb 0:8f0d870509fe 20 */
Sergunb 0:8f0d870509fe 21
Sergunb 0:8f0d870509fe 22 /* Define to prevent recursive inclusion -------------------------------------*/
Sergunb 0:8f0d870509fe 23 #ifndef __STM32F10x_TIM_H
Sergunb 0:8f0d870509fe 24 #define __STM32F10x_TIM_H
Sergunb 0:8f0d870509fe 25
Sergunb 0:8f0d870509fe 26 #ifdef __cplusplus
Sergunb 0:8f0d870509fe 27 extern "C" {
Sergunb 0:8f0d870509fe 28 #endif
Sergunb 0:8f0d870509fe 29
Sergunb 0:8f0d870509fe 30 /* Includes ------------------------------------------------------------------*/
Sergunb 0:8f0d870509fe 31 #include "stm32f10x.h"
Sergunb 0:8f0d870509fe 32
Sergunb 0:8f0d870509fe 33 /** @addtogroup STM32F10x_StdPeriph_Driver
Sergunb 0:8f0d870509fe 34 * @{
Sergunb 0:8f0d870509fe 35 */
Sergunb 0:8f0d870509fe 36
Sergunb 0:8f0d870509fe 37 /** @addtogroup TIM
Sergunb 0:8f0d870509fe 38 * @{
Sergunb 0:8f0d870509fe 39 */
Sergunb 0:8f0d870509fe 40
Sergunb 0:8f0d870509fe 41 /** @defgroup TIM_Exported_Types
Sergunb 0:8f0d870509fe 42 * @{
Sergunb 0:8f0d870509fe 43 */
Sergunb 0:8f0d870509fe 44
Sergunb 0:8f0d870509fe 45 /**
Sergunb 0:8f0d870509fe 46 * @brief TIM Time Base Init structure definition
Sergunb 0:8f0d870509fe 47 * @note This sturcture is used with all TIMx except for TIM6 and TIM7.
Sergunb 0:8f0d870509fe 48 */
Sergunb 0:8f0d870509fe 49
Sergunb 0:8f0d870509fe 50 typedef struct
Sergunb 0:8f0d870509fe 51 {
Sergunb 0:8f0d870509fe 52 uint16_t TIM_Prescaler; /*!< Specifies the prescaler value used to divide the TIM clock.
Sergunb 0:8f0d870509fe 53 This parameter can be a number between 0x0000 and 0xFFFF */
Sergunb 0:8f0d870509fe 54
Sergunb 0:8f0d870509fe 55 uint16_t TIM_CounterMode; /*!< Specifies the counter mode.
Sergunb 0:8f0d870509fe 56 This parameter can be a value of @ref TIM_Counter_Mode */
Sergunb 0:8f0d870509fe 57
Sergunb 0:8f0d870509fe 58 uint16_t TIM_Period; /*!< Specifies the period value to be loaded into the active
Sergunb 0:8f0d870509fe 59 Auto-Reload Register at the next update event.
Sergunb 0:8f0d870509fe 60 This parameter must be a number between 0x0000 and 0xFFFF. */
Sergunb 0:8f0d870509fe 61
Sergunb 0:8f0d870509fe 62 uint16_t TIM_ClockDivision; /*!< Specifies the clock division.
Sergunb 0:8f0d870509fe 63 This parameter can be a value of @ref TIM_Clock_Division_CKD */
Sergunb 0:8f0d870509fe 64
Sergunb 0:8f0d870509fe 65 uint8_t TIM_RepetitionCounter; /*!< Specifies the repetition counter value. Each time the RCR downcounter
Sergunb 0:8f0d870509fe 66 reaches zero, an update event is generated and counting restarts
Sergunb 0:8f0d870509fe 67 from the RCR value (N).
Sergunb 0:8f0d870509fe 68 This means in PWM mode that (N+1) corresponds to:
Sergunb 0:8f0d870509fe 69 - the number of PWM periods in edge-aligned mode
Sergunb 0:8f0d870509fe 70 - the number of half PWM period in center-aligned mode
Sergunb 0:8f0d870509fe 71 This parameter must be a number between 0x00 and 0xFF.
Sergunb 0:8f0d870509fe 72 @note This parameter is valid only for TIM1 and TIM8. */
Sergunb 0:8f0d870509fe 73 } TIM_TimeBaseInitTypeDef;
Sergunb 0:8f0d870509fe 74
Sergunb 0:8f0d870509fe 75 /**
Sergunb 0:8f0d870509fe 76 * @brief TIM Output Compare Init structure definition
Sergunb 0:8f0d870509fe 77 */
Sergunb 0:8f0d870509fe 78
Sergunb 0:8f0d870509fe 79 typedef struct
Sergunb 0:8f0d870509fe 80 {
Sergunb 0:8f0d870509fe 81 uint16_t TIM_OCMode; /*!< Specifies the TIM mode.
Sergunb 0:8f0d870509fe 82 This parameter can be a value of @ref TIM_Output_Compare_and_PWM_modes */
Sergunb 0:8f0d870509fe 83
Sergunb 0:8f0d870509fe 84 uint16_t TIM_OutputState; /*!< Specifies the TIM Output Compare state.
Sergunb 0:8f0d870509fe 85 This parameter can be a value of @ref TIM_Output_Compare_state */
Sergunb 0:8f0d870509fe 86
Sergunb 0:8f0d870509fe 87 uint16_t TIM_OutputNState; /*!< Specifies the TIM complementary Output Compare state.
Sergunb 0:8f0d870509fe 88 This parameter can be a value of @ref TIM_Output_Compare_N_state
Sergunb 0:8f0d870509fe 89 @note This parameter is valid only for TIM1 and TIM8. */
Sergunb 0:8f0d870509fe 90
Sergunb 0:8f0d870509fe 91 uint16_t TIM_Pulse; /*!< Specifies the pulse value to be loaded into the Capture Compare Register.
Sergunb 0:8f0d870509fe 92 This parameter can be a number between 0x0000 and 0xFFFF */
Sergunb 0:8f0d870509fe 93
Sergunb 0:8f0d870509fe 94 uint16_t TIM_OCPolarity; /*!< Specifies the output polarity.
Sergunb 0:8f0d870509fe 95 This parameter can be a value of @ref TIM_Output_Compare_Polarity */
Sergunb 0:8f0d870509fe 96
Sergunb 0:8f0d870509fe 97 uint16_t TIM_OCNPolarity; /*!< Specifies the complementary output polarity.
Sergunb 0:8f0d870509fe 98 This parameter can be a value of @ref TIM_Output_Compare_N_Polarity
Sergunb 0:8f0d870509fe 99 @note This parameter is valid only for TIM1 and TIM8. */
Sergunb 0:8f0d870509fe 100
Sergunb 0:8f0d870509fe 101 uint16_t TIM_OCIdleState; /*!< Specifies the TIM Output Compare pin state during Idle state.
Sergunb 0:8f0d870509fe 102 This parameter can be a value of @ref TIM_Output_Compare_Idle_State
Sergunb 0:8f0d870509fe 103 @note This parameter is valid only for TIM1 and TIM8. */
Sergunb 0:8f0d870509fe 104
Sergunb 0:8f0d870509fe 105 uint16_t TIM_OCNIdleState; /*!< Specifies the TIM Output Compare pin state during Idle state.
Sergunb 0:8f0d870509fe 106 This parameter can be a value of @ref TIM_Output_Compare_N_Idle_State
Sergunb 0:8f0d870509fe 107 @note This parameter is valid only for TIM1 and TIM8. */
Sergunb 0:8f0d870509fe 108 } TIM_OCInitTypeDef;
Sergunb 0:8f0d870509fe 109
Sergunb 0:8f0d870509fe 110 /**
Sergunb 0:8f0d870509fe 111 * @brief TIM Input Capture Init structure definition
Sergunb 0:8f0d870509fe 112 */
Sergunb 0:8f0d870509fe 113
Sergunb 0:8f0d870509fe 114 typedef struct
Sergunb 0:8f0d870509fe 115 {
Sergunb 0:8f0d870509fe 116
Sergunb 0:8f0d870509fe 117 uint16_t TIM_Channel; /*!< Specifies the TIM channel.
Sergunb 0:8f0d870509fe 118 This parameter can be a value of @ref TIM_Channel */
Sergunb 0:8f0d870509fe 119
Sergunb 0:8f0d870509fe 120 uint16_t TIM_ICPolarity; /*!< Specifies the active edge of the input signal.
Sergunb 0:8f0d870509fe 121 This parameter can be a value of @ref TIM_Input_Capture_Polarity */
Sergunb 0:8f0d870509fe 122
Sergunb 0:8f0d870509fe 123 uint16_t TIM_ICSelection; /*!< Specifies the input.
Sergunb 0:8f0d870509fe 124 This parameter can be a value of @ref TIM_Input_Capture_Selection */
Sergunb 0:8f0d870509fe 125
Sergunb 0:8f0d870509fe 126 uint16_t TIM_ICPrescaler; /*!< Specifies the Input Capture Prescaler.
Sergunb 0:8f0d870509fe 127 This parameter can be a value of @ref TIM_Input_Capture_Prescaler */
Sergunb 0:8f0d870509fe 128
Sergunb 0:8f0d870509fe 129 uint16_t TIM_ICFilter; /*!< Specifies the input capture filter.
Sergunb 0:8f0d870509fe 130 This parameter can be a number between 0x0 and 0xF */
Sergunb 0:8f0d870509fe 131 } TIM_ICInitTypeDef;
Sergunb 0:8f0d870509fe 132
Sergunb 0:8f0d870509fe 133 /**
Sergunb 0:8f0d870509fe 134 * @brief BDTR structure definition
Sergunb 0:8f0d870509fe 135 * @note This sturcture is used only with TIM1 and TIM8.
Sergunb 0:8f0d870509fe 136 */
Sergunb 0:8f0d870509fe 137
Sergunb 0:8f0d870509fe 138 typedef struct
Sergunb 0:8f0d870509fe 139 {
Sergunb 0:8f0d870509fe 140
Sergunb 0:8f0d870509fe 141 uint16_t TIM_OSSRState; /*!< Specifies the Off-State selection used in Run mode.
Sergunb 0:8f0d870509fe 142 This parameter can be a value of @ref OSSR_Off_State_Selection_for_Run_mode_state */
Sergunb 0:8f0d870509fe 143
Sergunb 0:8f0d870509fe 144 uint16_t TIM_OSSIState; /*!< Specifies the Off-State used in Idle state.
Sergunb 0:8f0d870509fe 145 This parameter can be a value of @ref OSSI_Off_State_Selection_for_Idle_mode_state */
Sergunb 0:8f0d870509fe 146
Sergunb 0:8f0d870509fe 147 uint16_t TIM_LOCKLevel; /*!< Specifies the LOCK level parameters.
Sergunb 0:8f0d870509fe 148 This parameter can be a value of @ref Lock_level */
Sergunb 0:8f0d870509fe 149
Sergunb 0:8f0d870509fe 150 uint16_t TIM_DeadTime; /*!< Specifies the delay time between the switching-off and the
Sergunb 0:8f0d870509fe 151 switching-on of the outputs.
Sergunb 0:8f0d870509fe 152 This parameter can be a number between 0x00 and 0xFF */
Sergunb 0:8f0d870509fe 153
Sergunb 0:8f0d870509fe 154 uint16_t TIM_Break; /*!< Specifies whether the TIM Break input is enabled or not.
Sergunb 0:8f0d870509fe 155 This parameter can be a value of @ref Break_Input_enable_disable */
Sergunb 0:8f0d870509fe 156
Sergunb 0:8f0d870509fe 157 uint16_t TIM_BreakPolarity; /*!< Specifies the TIM Break Input pin polarity.
Sergunb 0:8f0d870509fe 158 This parameter can be a value of @ref Break_Polarity */
Sergunb 0:8f0d870509fe 159
Sergunb 0:8f0d870509fe 160 uint16_t TIM_AutomaticOutput; /*!< Specifies whether the TIM Automatic Output feature is enabled or not.
Sergunb 0:8f0d870509fe 161 This parameter can be a value of @ref TIM_AOE_Bit_Set_Reset */
Sergunb 0:8f0d870509fe 162 } TIM_BDTRInitTypeDef;
Sergunb 0:8f0d870509fe 163
Sergunb 0:8f0d870509fe 164 /** @defgroup TIM_Exported_constants
Sergunb 0:8f0d870509fe 165 * @{
Sergunb 0:8f0d870509fe 166 */
Sergunb 0:8f0d870509fe 167
Sergunb 0:8f0d870509fe 168 #define IS_TIM_ALL_PERIPH(PERIPH) (((PERIPH) == TIM1) || \
Sergunb 0:8f0d870509fe 169 ((PERIPH) == TIM2) || \
Sergunb 0:8f0d870509fe 170 ((PERIPH) == TIM3) || \
Sergunb 0:8f0d870509fe 171 ((PERIPH) == TIM4) || \
Sergunb 0:8f0d870509fe 172 ((PERIPH) == TIM5) || \
Sergunb 0:8f0d870509fe 173 ((PERIPH) == TIM6) || \
Sergunb 0:8f0d870509fe 174 ((PERIPH) == TIM7) || \
Sergunb 0:8f0d870509fe 175 ((PERIPH) == TIM8) || \
Sergunb 0:8f0d870509fe 176 ((PERIPH) == TIM9) || \
Sergunb 0:8f0d870509fe 177 ((PERIPH) == TIM10)|| \
Sergunb 0:8f0d870509fe 178 ((PERIPH) == TIM11)|| \
Sergunb 0:8f0d870509fe 179 ((PERIPH) == TIM12)|| \
Sergunb 0:8f0d870509fe 180 ((PERIPH) == TIM13)|| \
Sergunb 0:8f0d870509fe 181 ((PERIPH) == TIM14)|| \
Sergunb 0:8f0d870509fe 182 ((PERIPH) == TIM15)|| \
Sergunb 0:8f0d870509fe 183 ((PERIPH) == TIM16)|| \
Sergunb 0:8f0d870509fe 184 ((PERIPH) == TIM17))
Sergunb 0:8f0d870509fe 185
Sergunb 0:8f0d870509fe 186 /* LIST1: TIM 1 and 8 */
Sergunb 0:8f0d870509fe 187 #define IS_TIM_LIST1_PERIPH(PERIPH) (((PERIPH) == TIM1) || \
Sergunb 0:8f0d870509fe 188 ((PERIPH) == TIM8))
Sergunb 0:8f0d870509fe 189
Sergunb 0:8f0d870509fe 190 /* LIST2: TIM 1, 8, 15 16 and 17 */
Sergunb 0:8f0d870509fe 191 #define IS_TIM_LIST2_PERIPH(PERIPH) (((PERIPH) == TIM1) || \
Sergunb 0:8f0d870509fe 192 ((PERIPH) == TIM8) || \
Sergunb 0:8f0d870509fe 193 ((PERIPH) == TIM15)|| \
Sergunb 0:8f0d870509fe 194 ((PERIPH) == TIM16)|| \
Sergunb 0:8f0d870509fe 195 ((PERIPH) == TIM17))
Sergunb 0:8f0d870509fe 196
Sergunb 0:8f0d870509fe 197 /* LIST3: TIM 1, 2, 3, 4, 5 and 8 */
Sergunb 0:8f0d870509fe 198 #define IS_TIM_LIST3_PERIPH(PERIPH) (((PERIPH) == TIM1) || \
Sergunb 0:8f0d870509fe 199 ((PERIPH) == TIM2) || \
Sergunb 0:8f0d870509fe 200 ((PERIPH) == TIM3) || \
Sergunb 0:8f0d870509fe 201 ((PERIPH) == TIM4) || \
Sergunb 0:8f0d870509fe 202 ((PERIPH) == TIM5) || \
Sergunb 0:8f0d870509fe 203 ((PERIPH) == TIM8))
Sergunb 0:8f0d870509fe 204
Sergunb 0:8f0d870509fe 205 /* LIST4: TIM 1, 2, 3, 4, 5, 8, 15, 16 and 17 */
Sergunb 0:8f0d870509fe 206 #define IS_TIM_LIST4_PERIPH(PERIPH) (((PERIPH) == TIM1) || \
Sergunb 0:8f0d870509fe 207 ((PERIPH) == TIM2) || \
Sergunb 0:8f0d870509fe 208 ((PERIPH) == TIM3) || \
Sergunb 0:8f0d870509fe 209 ((PERIPH) == TIM4) || \
Sergunb 0:8f0d870509fe 210 ((PERIPH) == TIM5) || \
Sergunb 0:8f0d870509fe 211 ((PERIPH) == TIM8) || \
Sergunb 0:8f0d870509fe 212 ((PERIPH) == TIM15)|| \
Sergunb 0:8f0d870509fe 213 ((PERIPH) == TIM16)|| \
Sergunb 0:8f0d870509fe 214 ((PERIPH) == TIM17))
Sergunb 0:8f0d870509fe 215
Sergunb 0:8f0d870509fe 216 /* LIST5: TIM 1, 2, 3, 4, 5, 8 and 15 */
Sergunb 0:8f0d870509fe 217 #define IS_TIM_LIST5_PERIPH(PERIPH) (((PERIPH) == TIM1) || \
Sergunb 0:8f0d870509fe 218 ((PERIPH) == TIM2) || \
Sergunb 0:8f0d870509fe 219 ((PERIPH) == TIM3) || \
Sergunb 0:8f0d870509fe 220 ((PERIPH) == TIM4) || \
Sergunb 0:8f0d870509fe 221 ((PERIPH) == TIM5) || \
Sergunb 0:8f0d870509fe 222 ((PERIPH) == TIM8) || \
Sergunb 0:8f0d870509fe 223 ((PERIPH) == TIM15))
Sergunb 0:8f0d870509fe 224
Sergunb 0:8f0d870509fe 225 /* LIST6: TIM 1, 2, 3, 4, 5, 8, 9, 12 and 15 */
Sergunb 0:8f0d870509fe 226 #define IS_TIM_LIST6_PERIPH(PERIPH) (((PERIPH) == TIM1) || \
Sergunb 0:8f0d870509fe 227 ((PERIPH) == TIM2) || \
Sergunb 0:8f0d870509fe 228 ((PERIPH) == TIM3) || \
Sergunb 0:8f0d870509fe 229 ((PERIPH) == TIM4) || \
Sergunb 0:8f0d870509fe 230 ((PERIPH) == TIM5) || \
Sergunb 0:8f0d870509fe 231 ((PERIPH) == TIM8) || \
Sergunb 0:8f0d870509fe 232 ((PERIPH) == TIM9) || \
Sergunb 0:8f0d870509fe 233 ((PERIPH) == TIM12)|| \
Sergunb 0:8f0d870509fe 234 ((PERIPH) == TIM15))
Sergunb 0:8f0d870509fe 235
Sergunb 0:8f0d870509fe 236 /* LIST7: TIM 1, 2, 3, 4, 5, 6, 7, 8, 9, 12 and 15 */
Sergunb 0:8f0d870509fe 237 #define IS_TIM_LIST7_PERIPH(PERIPH) (((PERIPH) == TIM1) || \
Sergunb 0:8f0d870509fe 238 ((PERIPH) == TIM2) || \
Sergunb 0:8f0d870509fe 239 ((PERIPH) == TIM3) || \
Sergunb 0:8f0d870509fe 240 ((PERIPH) == TIM4) || \
Sergunb 0:8f0d870509fe 241 ((PERIPH) == TIM5) || \
Sergunb 0:8f0d870509fe 242 ((PERIPH) == TIM6) || \
Sergunb 0:8f0d870509fe 243 ((PERIPH) == TIM7) || \
Sergunb 0:8f0d870509fe 244 ((PERIPH) == TIM8) || \
Sergunb 0:8f0d870509fe 245 ((PERIPH) == TIM9) || \
Sergunb 0:8f0d870509fe 246 ((PERIPH) == TIM12)|| \
Sergunb 0:8f0d870509fe 247 ((PERIPH) == TIM15))
Sergunb 0:8f0d870509fe 248
Sergunb 0:8f0d870509fe 249 /* LIST8: TIM 1, 2, 3, 4, 5, 8, 9, 10, 11, 12, 13, 14, 15, 16 and 17 */
Sergunb 0:8f0d870509fe 250 #define IS_TIM_LIST8_PERIPH(PERIPH) (((PERIPH) == TIM1) || \
Sergunb 0:8f0d870509fe 251 ((PERIPH) == TIM2) || \
Sergunb 0:8f0d870509fe 252 ((PERIPH) == TIM3) || \
Sergunb 0:8f0d870509fe 253 ((PERIPH) == TIM4) || \
Sergunb 0:8f0d870509fe 254 ((PERIPH) == TIM5) || \
Sergunb 0:8f0d870509fe 255 ((PERIPH) == TIM8) || \
Sergunb 0:8f0d870509fe 256 ((PERIPH) == TIM9) || \
Sergunb 0:8f0d870509fe 257 ((PERIPH) == TIM10)|| \
Sergunb 0:8f0d870509fe 258 ((PERIPH) == TIM11)|| \
Sergunb 0:8f0d870509fe 259 ((PERIPH) == TIM12)|| \
Sergunb 0:8f0d870509fe 260 ((PERIPH) == TIM13)|| \
Sergunb 0:8f0d870509fe 261 ((PERIPH) == TIM14)|| \
Sergunb 0:8f0d870509fe 262 ((PERIPH) == TIM15)|| \
Sergunb 0:8f0d870509fe 263 ((PERIPH) == TIM16)|| \
Sergunb 0:8f0d870509fe 264 ((PERIPH) == TIM17))
Sergunb 0:8f0d870509fe 265
Sergunb 0:8f0d870509fe 266 /* LIST9: TIM 1, 2, 3, 4, 5, 6, 7, 8, 15, 16, and 17 */
Sergunb 0:8f0d870509fe 267 #define IS_TIM_LIST9_PERIPH(PERIPH) (((PERIPH) == TIM1) || \
Sergunb 0:8f0d870509fe 268 ((PERIPH) == TIM2) || \
Sergunb 0:8f0d870509fe 269 ((PERIPH) == TIM3) || \
Sergunb 0:8f0d870509fe 270 ((PERIPH) == TIM4) || \
Sergunb 0:8f0d870509fe 271 ((PERIPH) == TIM5) || \
Sergunb 0:8f0d870509fe 272 ((PERIPH) == TIM6) || \
Sergunb 0:8f0d870509fe 273 ((PERIPH) == TIM7) || \
Sergunb 0:8f0d870509fe 274 ((PERIPH) == TIM8) || \
Sergunb 0:8f0d870509fe 275 ((PERIPH) == TIM15)|| \
Sergunb 0:8f0d870509fe 276 ((PERIPH) == TIM16)|| \
Sergunb 0:8f0d870509fe 277 ((PERIPH) == TIM17))
Sergunb 0:8f0d870509fe 278
Sergunb 0:8f0d870509fe 279 /**
Sergunb 0:8f0d870509fe 280 * @}
Sergunb 0:8f0d870509fe 281 */
Sergunb 0:8f0d870509fe 282
Sergunb 0:8f0d870509fe 283 /** @defgroup TIM_Output_Compare_and_PWM_modes
Sergunb 0:8f0d870509fe 284 * @{
Sergunb 0:8f0d870509fe 285 */
Sergunb 0:8f0d870509fe 286
Sergunb 0:8f0d870509fe 287 #define TIM_OCMode_Timing ((uint16_t)0x0000)
Sergunb 0:8f0d870509fe 288 #define TIM_OCMode_Active ((uint16_t)0x0010)
Sergunb 0:8f0d870509fe 289 #define TIM_OCMode_Inactive ((uint16_t)0x0020)
Sergunb 0:8f0d870509fe 290 #define TIM_OCMode_Toggle ((uint16_t)0x0030)
Sergunb 0:8f0d870509fe 291 #define TIM_OCMode_PWM1 ((uint16_t)0x0060)
Sergunb 0:8f0d870509fe 292 #define TIM_OCMode_PWM2 ((uint16_t)0x0070)
Sergunb 0:8f0d870509fe 293 #define IS_TIM_OC_MODE(MODE) (((MODE) == TIM_OCMode_Timing) || \
Sergunb 0:8f0d870509fe 294 ((MODE) == TIM_OCMode_Active) || \
Sergunb 0:8f0d870509fe 295 ((MODE) == TIM_OCMode_Inactive) || \
Sergunb 0:8f0d870509fe 296 ((MODE) == TIM_OCMode_Toggle)|| \
Sergunb 0:8f0d870509fe 297 ((MODE) == TIM_OCMode_PWM1) || \
Sergunb 0:8f0d870509fe 298 ((MODE) == TIM_OCMode_PWM2))
Sergunb 0:8f0d870509fe 299 #define IS_TIM_OCM(MODE) (((MODE) == TIM_OCMode_Timing) || \
Sergunb 0:8f0d870509fe 300 ((MODE) == TIM_OCMode_Active) || \
Sergunb 0:8f0d870509fe 301 ((MODE) == TIM_OCMode_Inactive) || \
Sergunb 0:8f0d870509fe 302 ((MODE) == TIM_OCMode_Toggle)|| \
Sergunb 0:8f0d870509fe 303 ((MODE) == TIM_OCMode_PWM1) || \
Sergunb 0:8f0d870509fe 304 ((MODE) == TIM_OCMode_PWM2) || \
Sergunb 0:8f0d870509fe 305 ((MODE) == TIM_ForcedAction_Active) || \
Sergunb 0:8f0d870509fe 306 ((MODE) == TIM_ForcedAction_InActive))
Sergunb 0:8f0d870509fe 307 /**
Sergunb 0:8f0d870509fe 308 * @}
Sergunb 0:8f0d870509fe 309 */
Sergunb 0:8f0d870509fe 310
Sergunb 0:8f0d870509fe 311 /** @defgroup TIM_One_Pulse_Mode
Sergunb 0:8f0d870509fe 312 * @{
Sergunb 0:8f0d870509fe 313 */
Sergunb 0:8f0d870509fe 314
Sergunb 0:8f0d870509fe 315 #define TIM_OPMode_Single ((uint16_t)0x0008)
Sergunb 0:8f0d870509fe 316 #define TIM_OPMode_Repetitive ((uint16_t)0x0000)
Sergunb 0:8f0d870509fe 317 #define IS_TIM_OPM_MODE(MODE) (((MODE) == TIM_OPMode_Single) || \
Sergunb 0:8f0d870509fe 318 ((MODE) == TIM_OPMode_Repetitive))
Sergunb 0:8f0d870509fe 319 /**
Sergunb 0:8f0d870509fe 320 * @}
Sergunb 0:8f0d870509fe 321 */
Sergunb 0:8f0d870509fe 322
Sergunb 0:8f0d870509fe 323 /** @defgroup TIM_Channel
Sergunb 0:8f0d870509fe 324 * @{
Sergunb 0:8f0d870509fe 325 */
Sergunb 0:8f0d870509fe 326
Sergunb 0:8f0d870509fe 327 #define TIM_Channel_1 ((uint16_t)0x0000)
Sergunb 0:8f0d870509fe 328 #define TIM_Channel_2 ((uint16_t)0x0004)
Sergunb 0:8f0d870509fe 329 #define TIM_Channel_3 ((uint16_t)0x0008)
Sergunb 0:8f0d870509fe 330 #define TIM_Channel_4 ((uint16_t)0x000C)
Sergunb 0:8f0d870509fe 331 #define IS_TIM_CHANNEL(CHANNEL) (((CHANNEL) == TIM_Channel_1) || \
Sergunb 0:8f0d870509fe 332 ((CHANNEL) == TIM_Channel_2) || \
Sergunb 0:8f0d870509fe 333 ((CHANNEL) == TIM_Channel_3) || \
Sergunb 0:8f0d870509fe 334 ((CHANNEL) == TIM_Channel_4))
Sergunb 0:8f0d870509fe 335 #define IS_TIM_PWMI_CHANNEL(CHANNEL) (((CHANNEL) == TIM_Channel_1) || \
Sergunb 0:8f0d870509fe 336 ((CHANNEL) == TIM_Channel_2))
Sergunb 0:8f0d870509fe 337 #define IS_TIM_COMPLEMENTARY_CHANNEL(CHANNEL) (((CHANNEL) == TIM_Channel_1) || \
Sergunb 0:8f0d870509fe 338 ((CHANNEL) == TIM_Channel_2) || \
Sergunb 0:8f0d870509fe 339 ((CHANNEL) == TIM_Channel_3))
Sergunb 0:8f0d870509fe 340 /**
Sergunb 0:8f0d870509fe 341 * @}
Sergunb 0:8f0d870509fe 342 */
Sergunb 0:8f0d870509fe 343
Sergunb 0:8f0d870509fe 344 /** @defgroup TIM_Clock_Division_CKD
Sergunb 0:8f0d870509fe 345 * @{
Sergunb 0:8f0d870509fe 346 */
Sergunb 0:8f0d870509fe 347
Sergunb 0:8f0d870509fe 348 #define TIM_CKD_DIV1 ((uint16_t)0x0000)
Sergunb 0:8f0d870509fe 349 #define TIM_CKD_DIV2 ((uint16_t)0x0100)
Sergunb 0:8f0d870509fe 350 #define TIM_CKD_DIV4 ((uint16_t)0x0200)
Sergunb 0:8f0d870509fe 351 #define IS_TIM_CKD_DIV(DIV) (((DIV) == TIM_CKD_DIV1) || \
Sergunb 0:8f0d870509fe 352 ((DIV) == TIM_CKD_DIV2) || \
Sergunb 0:8f0d870509fe 353 ((DIV) == TIM_CKD_DIV4))
Sergunb 0:8f0d870509fe 354 /**
Sergunb 0:8f0d870509fe 355 * @}
Sergunb 0:8f0d870509fe 356 */
Sergunb 0:8f0d870509fe 357
Sergunb 0:8f0d870509fe 358 /** @defgroup TIM_Counter_Mode
Sergunb 0:8f0d870509fe 359 * @{
Sergunb 0:8f0d870509fe 360 */
Sergunb 0:8f0d870509fe 361
Sergunb 0:8f0d870509fe 362 #define TIM_CounterMode_Up ((uint16_t)0x0000)
Sergunb 0:8f0d870509fe 363 #define TIM_CounterMode_Down ((uint16_t)0x0010)
Sergunb 0:8f0d870509fe 364 #define TIM_CounterMode_CenterAligned1 ((uint16_t)0x0020)
Sergunb 0:8f0d870509fe 365 #define TIM_CounterMode_CenterAligned2 ((uint16_t)0x0040)
Sergunb 0:8f0d870509fe 366 #define TIM_CounterMode_CenterAligned3 ((uint16_t)0x0060)
Sergunb 0:8f0d870509fe 367 #define IS_TIM_COUNTER_MODE(MODE) (((MODE) == TIM_CounterMode_Up) || \
Sergunb 0:8f0d870509fe 368 ((MODE) == TIM_CounterMode_Down) || \
Sergunb 0:8f0d870509fe 369 ((MODE) == TIM_CounterMode_CenterAligned1) || \
Sergunb 0:8f0d870509fe 370 ((MODE) == TIM_CounterMode_CenterAligned2) || \
Sergunb 0:8f0d870509fe 371 ((MODE) == TIM_CounterMode_CenterAligned3))
Sergunb 0:8f0d870509fe 372 /**
Sergunb 0:8f0d870509fe 373 * @}
Sergunb 0:8f0d870509fe 374 */
Sergunb 0:8f0d870509fe 375
Sergunb 0:8f0d870509fe 376 /** @defgroup TIM_Output_Compare_Polarity
Sergunb 0:8f0d870509fe 377 * @{
Sergunb 0:8f0d870509fe 378 */
Sergunb 0:8f0d870509fe 379
Sergunb 0:8f0d870509fe 380 #define TIM_OCPolarity_High ((uint16_t)0x0000)
Sergunb 0:8f0d870509fe 381 #define TIM_OCPolarity_Low ((uint16_t)0x0002)
Sergunb 0:8f0d870509fe 382 #define IS_TIM_OC_POLARITY(POLARITY) (((POLARITY) == TIM_OCPolarity_High) || \
Sergunb 0:8f0d870509fe 383 ((POLARITY) == TIM_OCPolarity_Low))
Sergunb 0:8f0d870509fe 384 /**
Sergunb 0:8f0d870509fe 385 * @}
Sergunb 0:8f0d870509fe 386 */
Sergunb 0:8f0d870509fe 387
Sergunb 0:8f0d870509fe 388 /** @defgroup TIM_Output_Compare_N_Polarity
Sergunb 0:8f0d870509fe 389 * @{
Sergunb 0:8f0d870509fe 390 */
Sergunb 0:8f0d870509fe 391
Sergunb 0:8f0d870509fe 392 #define TIM_OCNPolarity_High ((uint16_t)0x0000)
Sergunb 0:8f0d870509fe 393 #define TIM_OCNPolarity_Low ((uint16_t)0x0008)
Sergunb 0:8f0d870509fe 394 #define IS_TIM_OCN_POLARITY(POLARITY) (((POLARITY) == TIM_OCNPolarity_High) || \
Sergunb 0:8f0d870509fe 395 ((POLARITY) == TIM_OCNPolarity_Low))
Sergunb 0:8f0d870509fe 396 /**
Sergunb 0:8f0d870509fe 397 * @}
Sergunb 0:8f0d870509fe 398 */
Sergunb 0:8f0d870509fe 399
Sergunb 0:8f0d870509fe 400 /** @defgroup TIM_Output_Compare_state
Sergunb 0:8f0d870509fe 401 * @{
Sergunb 0:8f0d870509fe 402 */
Sergunb 0:8f0d870509fe 403
Sergunb 0:8f0d870509fe 404 #define TIM_OutputState_Disable ((uint16_t)0x0000)
Sergunb 0:8f0d870509fe 405 #define TIM_OutputState_Enable ((uint16_t)0x0001)
Sergunb 0:8f0d870509fe 406 #define IS_TIM_OUTPUT_STATE(STATE) (((STATE) == TIM_OutputState_Disable) || \
Sergunb 0:8f0d870509fe 407 ((STATE) == TIM_OutputState_Enable))
Sergunb 0:8f0d870509fe 408 /**
Sergunb 0:8f0d870509fe 409 * @}
Sergunb 0:8f0d870509fe 410 */
Sergunb 0:8f0d870509fe 411
Sergunb 0:8f0d870509fe 412 /** @defgroup TIM_Output_Compare_N_state
Sergunb 0:8f0d870509fe 413 * @{
Sergunb 0:8f0d870509fe 414 */
Sergunb 0:8f0d870509fe 415
Sergunb 0:8f0d870509fe 416 #define TIM_OutputNState_Disable ((uint16_t)0x0000)
Sergunb 0:8f0d870509fe 417 #define TIM_OutputNState_Enable ((uint16_t)0x0004)
Sergunb 0:8f0d870509fe 418 #define IS_TIM_OUTPUTN_STATE(STATE) (((STATE) == TIM_OutputNState_Disable) || \
Sergunb 0:8f0d870509fe 419 ((STATE) == TIM_OutputNState_Enable))
Sergunb 0:8f0d870509fe 420 /**
Sergunb 0:8f0d870509fe 421 * @}
Sergunb 0:8f0d870509fe 422 */
Sergunb 0:8f0d870509fe 423
Sergunb 0:8f0d870509fe 424 /** @defgroup TIM_Capture_Compare_state
Sergunb 0:8f0d870509fe 425 * @{
Sergunb 0:8f0d870509fe 426 */
Sergunb 0:8f0d870509fe 427
Sergunb 0:8f0d870509fe 428 #define TIM_CCx_Enable ((uint16_t)0x0001)
Sergunb 0:8f0d870509fe 429 #define TIM_CCx_Disable ((uint16_t)0x0000)
Sergunb 0:8f0d870509fe 430 #define IS_TIM_CCX(CCX) (((CCX) == TIM_CCx_Enable) || \
Sergunb 0:8f0d870509fe 431 ((CCX) == TIM_CCx_Disable))
Sergunb 0:8f0d870509fe 432 /**
Sergunb 0:8f0d870509fe 433 * @}
Sergunb 0:8f0d870509fe 434 */
Sergunb 0:8f0d870509fe 435
Sergunb 0:8f0d870509fe 436 /** @defgroup TIM_Capture_Compare_N_state
Sergunb 0:8f0d870509fe 437 * @{
Sergunb 0:8f0d870509fe 438 */
Sergunb 0:8f0d870509fe 439
Sergunb 0:8f0d870509fe 440 #define TIM_CCxN_Enable ((uint16_t)0x0004)
Sergunb 0:8f0d870509fe 441 #define TIM_CCxN_Disable ((uint16_t)0x0000)
Sergunb 0:8f0d870509fe 442 #define IS_TIM_CCXN(CCXN) (((CCXN) == TIM_CCxN_Enable) || \
Sergunb 0:8f0d870509fe 443 ((CCXN) == TIM_CCxN_Disable))
Sergunb 0:8f0d870509fe 444 /**
Sergunb 0:8f0d870509fe 445 * @}
Sergunb 0:8f0d870509fe 446 */
Sergunb 0:8f0d870509fe 447
Sergunb 0:8f0d870509fe 448 /** @defgroup Break_Input_enable_disable
Sergunb 0:8f0d870509fe 449 * @{
Sergunb 0:8f0d870509fe 450 */
Sergunb 0:8f0d870509fe 451
Sergunb 0:8f0d870509fe 452 #define TIM_Break_Enable ((uint16_t)0x1000)
Sergunb 0:8f0d870509fe 453 #define TIM_Break_Disable ((uint16_t)0x0000)
Sergunb 0:8f0d870509fe 454 #define IS_TIM_BREAK_STATE(STATE) (((STATE) == TIM_Break_Enable) || \
Sergunb 0:8f0d870509fe 455 ((STATE) == TIM_Break_Disable))
Sergunb 0:8f0d870509fe 456 /**
Sergunb 0:8f0d870509fe 457 * @}
Sergunb 0:8f0d870509fe 458 */
Sergunb 0:8f0d870509fe 459
Sergunb 0:8f0d870509fe 460 /** @defgroup Break_Polarity
Sergunb 0:8f0d870509fe 461 * @{
Sergunb 0:8f0d870509fe 462 */
Sergunb 0:8f0d870509fe 463
Sergunb 0:8f0d870509fe 464 #define TIM_BreakPolarity_Low ((uint16_t)0x0000)
Sergunb 0:8f0d870509fe 465 #define TIM_BreakPolarity_High ((uint16_t)0x2000)
Sergunb 0:8f0d870509fe 466 #define IS_TIM_BREAK_POLARITY(POLARITY) (((POLARITY) == TIM_BreakPolarity_Low) || \
Sergunb 0:8f0d870509fe 467 ((POLARITY) == TIM_BreakPolarity_High))
Sergunb 0:8f0d870509fe 468 /**
Sergunb 0:8f0d870509fe 469 * @}
Sergunb 0:8f0d870509fe 470 */
Sergunb 0:8f0d870509fe 471
Sergunb 0:8f0d870509fe 472 /** @defgroup TIM_AOE_Bit_Set_Reset
Sergunb 0:8f0d870509fe 473 * @{
Sergunb 0:8f0d870509fe 474 */
Sergunb 0:8f0d870509fe 475
Sergunb 0:8f0d870509fe 476 #define TIM_AutomaticOutput_Enable ((uint16_t)0x4000)
Sergunb 0:8f0d870509fe 477 #define TIM_AutomaticOutput_Disable ((uint16_t)0x0000)
Sergunb 0:8f0d870509fe 478 #define IS_TIM_AUTOMATIC_OUTPUT_STATE(STATE) (((STATE) == TIM_AutomaticOutput_Enable) || \
Sergunb 0:8f0d870509fe 479 ((STATE) == TIM_AutomaticOutput_Disable))
Sergunb 0:8f0d870509fe 480 /**
Sergunb 0:8f0d870509fe 481 * @}
Sergunb 0:8f0d870509fe 482 */
Sergunb 0:8f0d870509fe 483
Sergunb 0:8f0d870509fe 484 /** @defgroup Lock_level
Sergunb 0:8f0d870509fe 485 * @{
Sergunb 0:8f0d870509fe 486 */
Sergunb 0:8f0d870509fe 487
Sergunb 0:8f0d870509fe 488 #define TIM_LOCKLevel_OFF ((uint16_t)0x0000)
Sergunb 0:8f0d870509fe 489 #define TIM_LOCKLevel_1 ((uint16_t)0x0100)
Sergunb 0:8f0d870509fe 490 #define TIM_LOCKLevel_2 ((uint16_t)0x0200)
Sergunb 0:8f0d870509fe 491 #define TIM_LOCKLevel_3 ((uint16_t)0x0300)
Sergunb 0:8f0d870509fe 492 #define IS_TIM_LOCK_LEVEL(LEVEL) (((LEVEL) == TIM_LOCKLevel_OFF) || \
Sergunb 0:8f0d870509fe 493 ((LEVEL) == TIM_LOCKLevel_1) || \
Sergunb 0:8f0d870509fe 494 ((LEVEL) == TIM_LOCKLevel_2) || \
Sergunb 0:8f0d870509fe 495 ((LEVEL) == TIM_LOCKLevel_3))
Sergunb 0:8f0d870509fe 496 /**
Sergunb 0:8f0d870509fe 497 * @}
Sergunb 0:8f0d870509fe 498 */
Sergunb 0:8f0d870509fe 499
Sergunb 0:8f0d870509fe 500 /** @defgroup OSSI_Off_State_Selection_for_Idle_mode_state
Sergunb 0:8f0d870509fe 501 * @{
Sergunb 0:8f0d870509fe 502 */
Sergunb 0:8f0d870509fe 503
Sergunb 0:8f0d870509fe 504 #define TIM_OSSIState_Enable ((uint16_t)0x0400)
Sergunb 0:8f0d870509fe 505 #define TIM_OSSIState_Disable ((uint16_t)0x0000)
Sergunb 0:8f0d870509fe 506 #define IS_TIM_OSSI_STATE(STATE) (((STATE) == TIM_OSSIState_Enable) || \
Sergunb 0:8f0d870509fe 507 ((STATE) == TIM_OSSIState_Disable))
Sergunb 0:8f0d870509fe 508 /**
Sergunb 0:8f0d870509fe 509 * @}
Sergunb 0:8f0d870509fe 510 */
Sergunb 0:8f0d870509fe 511
Sergunb 0:8f0d870509fe 512 /** @defgroup OSSR_Off_State_Selection_for_Run_mode_state
Sergunb 0:8f0d870509fe 513 * @{
Sergunb 0:8f0d870509fe 514 */
Sergunb 0:8f0d870509fe 515
Sergunb 0:8f0d870509fe 516 #define TIM_OSSRState_Enable ((uint16_t)0x0800)
Sergunb 0:8f0d870509fe 517 #define TIM_OSSRState_Disable ((uint16_t)0x0000)
Sergunb 0:8f0d870509fe 518 #define IS_TIM_OSSR_STATE(STATE) (((STATE) == TIM_OSSRState_Enable) || \
Sergunb 0:8f0d870509fe 519 ((STATE) == TIM_OSSRState_Disable))
Sergunb 0:8f0d870509fe 520 /**
Sergunb 0:8f0d870509fe 521 * @}
Sergunb 0:8f0d870509fe 522 */
Sergunb 0:8f0d870509fe 523
Sergunb 0:8f0d870509fe 524 /** @defgroup TIM_Output_Compare_Idle_State
Sergunb 0:8f0d870509fe 525 * @{
Sergunb 0:8f0d870509fe 526 */
Sergunb 0:8f0d870509fe 527
Sergunb 0:8f0d870509fe 528 #define TIM_OCIdleState_Set ((uint16_t)0x0100)
Sergunb 0:8f0d870509fe 529 #define TIM_OCIdleState_Reset ((uint16_t)0x0000)
Sergunb 0:8f0d870509fe 530 #define IS_TIM_OCIDLE_STATE(STATE) (((STATE) == TIM_OCIdleState_Set) || \
Sergunb 0:8f0d870509fe 531 ((STATE) == TIM_OCIdleState_Reset))
Sergunb 0:8f0d870509fe 532 /**
Sergunb 0:8f0d870509fe 533 * @}
Sergunb 0:8f0d870509fe 534 */
Sergunb 0:8f0d870509fe 535
Sergunb 0:8f0d870509fe 536 /** @defgroup TIM_Output_Compare_N_Idle_State
Sergunb 0:8f0d870509fe 537 * @{
Sergunb 0:8f0d870509fe 538 */
Sergunb 0:8f0d870509fe 539
Sergunb 0:8f0d870509fe 540 #define TIM_OCNIdleState_Set ((uint16_t)0x0200)
Sergunb 0:8f0d870509fe 541 #define TIM_OCNIdleState_Reset ((uint16_t)0x0000)
Sergunb 0:8f0d870509fe 542 #define IS_TIM_OCNIDLE_STATE(STATE) (((STATE) == TIM_OCNIdleState_Set) || \
Sergunb 0:8f0d870509fe 543 ((STATE) == TIM_OCNIdleState_Reset))
Sergunb 0:8f0d870509fe 544 /**
Sergunb 0:8f0d870509fe 545 * @}
Sergunb 0:8f0d870509fe 546 */
Sergunb 0:8f0d870509fe 547
Sergunb 0:8f0d870509fe 548 /** @defgroup TIM_Input_Capture_Polarity
Sergunb 0:8f0d870509fe 549 * @{
Sergunb 0:8f0d870509fe 550 */
Sergunb 0:8f0d870509fe 551
Sergunb 0:8f0d870509fe 552 #define TIM_ICPolarity_Rising ((uint16_t)0x0000)
Sergunb 0:8f0d870509fe 553 #define TIM_ICPolarity_Falling ((uint16_t)0x0002)
Sergunb 0:8f0d870509fe 554 #define TIM_ICPolarity_BothEdge ((uint16_t)0x000A)
Sergunb 0:8f0d870509fe 555 #define IS_TIM_IC_POLARITY(POLARITY) (((POLARITY) == TIM_ICPolarity_Rising) || \
Sergunb 0:8f0d870509fe 556 ((POLARITY) == TIM_ICPolarity_Falling))
Sergunb 0:8f0d870509fe 557 #define IS_TIM_IC_POLARITY_LITE(POLARITY) (((POLARITY) == TIM_ICPolarity_Rising) || \
Sergunb 0:8f0d870509fe 558 ((POLARITY) == TIM_ICPolarity_Falling)|| \
Sergunb 0:8f0d870509fe 559 ((POLARITY) == TIM_ICPolarity_BothEdge))
Sergunb 0:8f0d870509fe 560 /**
Sergunb 0:8f0d870509fe 561 * @}
Sergunb 0:8f0d870509fe 562 */
Sergunb 0:8f0d870509fe 563
Sergunb 0:8f0d870509fe 564 /** @defgroup TIM_Input_Capture_Selection
Sergunb 0:8f0d870509fe 565 * @{
Sergunb 0:8f0d870509fe 566 */
Sergunb 0:8f0d870509fe 567
Sergunb 0:8f0d870509fe 568 #define TIM_ICSelection_DirectTI ((uint16_t)0x0001) /*!< TIM Input 1, 2, 3 or 4 is selected to be
Sergunb 0:8f0d870509fe 569 connected to IC1, IC2, IC3 or IC4, respectively */
Sergunb 0:8f0d870509fe 570 #define TIM_ICSelection_IndirectTI ((uint16_t)0x0002) /*!< TIM Input 1, 2, 3 or 4 is selected to be
Sergunb 0:8f0d870509fe 571 connected to IC2, IC1, IC4 or IC3, respectively. */
Sergunb 0:8f0d870509fe 572 #define TIM_ICSelection_TRC ((uint16_t)0x0003) /*!< TIM Input 1, 2, 3 or 4 is selected to be connected to TRC. */
Sergunb 0:8f0d870509fe 573 #define IS_TIM_IC_SELECTION(SELECTION) (((SELECTION) == TIM_ICSelection_DirectTI) || \
Sergunb 0:8f0d870509fe 574 ((SELECTION) == TIM_ICSelection_IndirectTI) || \
Sergunb 0:8f0d870509fe 575 ((SELECTION) == TIM_ICSelection_TRC))
Sergunb 0:8f0d870509fe 576 /**
Sergunb 0:8f0d870509fe 577 * @}
Sergunb 0:8f0d870509fe 578 */
Sergunb 0:8f0d870509fe 579
Sergunb 0:8f0d870509fe 580 /** @defgroup TIM_Input_Capture_Prescaler
Sergunb 0:8f0d870509fe 581 * @{
Sergunb 0:8f0d870509fe 582 */
Sergunb 0:8f0d870509fe 583
Sergunb 0:8f0d870509fe 584 #define TIM_ICPSC_DIV1 ((uint16_t)0x0000) /*!< Capture performed each time an edge is detected on the capture input. */
Sergunb 0:8f0d870509fe 585 #define TIM_ICPSC_DIV2 ((uint16_t)0x0004) /*!< Capture performed once every 2 events. */
Sergunb 0:8f0d870509fe 586 #define TIM_ICPSC_DIV4 ((uint16_t)0x0008) /*!< Capture performed once every 4 events. */
Sergunb 0:8f0d870509fe 587 #define TIM_ICPSC_DIV8 ((uint16_t)0x000C) /*!< Capture performed once every 8 events. */
Sergunb 0:8f0d870509fe 588 #define IS_TIM_IC_PRESCALER(PRESCALER) (((PRESCALER) == TIM_ICPSC_DIV1) || \
Sergunb 0:8f0d870509fe 589 ((PRESCALER) == TIM_ICPSC_DIV2) || \
Sergunb 0:8f0d870509fe 590 ((PRESCALER) == TIM_ICPSC_DIV4) || \
Sergunb 0:8f0d870509fe 591 ((PRESCALER) == TIM_ICPSC_DIV8))
Sergunb 0:8f0d870509fe 592 /**
Sergunb 0:8f0d870509fe 593 * @}
Sergunb 0:8f0d870509fe 594 */
Sergunb 0:8f0d870509fe 595
Sergunb 0:8f0d870509fe 596 /** @defgroup TIM_interrupt_sources
Sergunb 0:8f0d870509fe 597 * @{
Sergunb 0:8f0d870509fe 598 */
Sergunb 0:8f0d870509fe 599
Sergunb 0:8f0d870509fe 600 #define TIM_IT_Update ((uint16_t)0x0001)
Sergunb 0:8f0d870509fe 601 #define TIM_IT_CC1 ((uint16_t)0x0002)
Sergunb 0:8f0d870509fe 602 #define TIM_IT_CC2 ((uint16_t)0x0004)
Sergunb 0:8f0d870509fe 603 #define TIM_IT_CC3 ((uint16_t)0x0008)
Sergunb 0:8f0d870509fe 604 #define TIM_IT_CC4 ((uint16_t)0x0010)
Sergunb 0:8f0d870509fe 605 #define TIM_IT_COM ((uint16_t)0x0020)
Sergunb 0:8f0d870509fe 606 #define TIM_IT_Trigger ((uint16_t)0x0040)
Sergunb 0:8f0d870509fe 607 #define TIM_IT_Break ((uint16_t)0x0080)
Sergunb 0:8f0d870509fe 608 #define IS_TIM_IT(IT) ((((IT) & (uint16_t)0xFF00) == 0x0000) && ((IT) != 0x0000))
Sergunb 0:8f0d870509fe 609
Sergunb 0:8f0d870509fe 610 #define IS_TIM_GET_IT(IT) (((IT) == TIM_IT_Update) || \
Sergunb 0:8f0d870509fe 611 ((IT) == TIM_IT_CC1) || \
Sergunb 0:8f0d870509fe 612 ((IT) == TIM_IT_CC2) || \
Sergunb 0:8f0d870509fe 613 ((IT) == TIM_IT_CC3) || \
Sergunb 0:8f0d870509fe 614 ((IT) == TIM_IT_CC4) || \
Sergunb 0:8f0d870509fe 615 ((IT) == TIM_IT_COM) || \
Sergunb 0:8f0d870509fe 616 ((IT) == TIM_IT_Trigger) || \
Sergunb 0:8f0d870509fe 617 ((IT) == TIM_IT_Break))
Sergunb 0:8f0d870509fe 618 /**
Sergunb 0:8f0d870509fe 619 * @}
Sergunb 0:8f0d870509fe 620 */
Sergunb 0:8f0d870509fe 621
Sergunb 0:8f0d870509fe 622 /** @defgroup TIM_DMA_Base_address
Sergunb 0:8f0d870509fe 623 * @{
Sergunb 0:8f0d870509fe 624 */
Sergunb 0:8f0d870509fe 625
Sergunb 0:8f0d870509fe 626 #define TIM_DMABase_CR1 ((uint16_t)0x0000)
Sergunb 0:8f0d870509fe 627 #define TIM_DMABase_CR2 ((uint16_t)0x0001)
Sergunb 0:8f0d870509fe 628 #define TIM_DMABase_SMCR ((uint16_t)0x0002)
Sergunb 0:8f0d870509fe 629 #define TIM_DMABase_DIER ((uint16_t)0x0003)
Sergunb 0:8f0d870509fe 630 #define TIM_DMABase_SR ((uint16_t)0x0004)
Sergunb 0:8f0d870509fe 631 #define TIM_DMABase_EGR ((uint16_t)0x0005)
Sergunb 0:8f0d870509fe 632 #define TIM_DMABase_CCMR1 ((uint16_t)0x0006)
Sergunb 0:8f0d870509fe 633 #define TIM_DMABase_CCMR2 ((uint16_t)0x0007)
Sergunb 0:8f0d870509fe 634 #define TIM_DMABase_CCER ((uint16_t)0x0008)
Sergunb 0:8f0d870509fe 635 #define TIM_DMABase_CNT ((uint16_t)0x0009)
Sergunb 0:8f0d870509fe 636 #define TIM_DMABase_PSC ((uint16_t)0x000A)
Sergunb 0:8f0d870509fe 637 #define TIM_DMABase_ARR ((uint16_t)0x000B)
Sergunb 0:8f0d870509fe 638 #define TIM_DMABase_RCR ((uint16_t)0x000C)
Sergunb 0:8f0d870509fe 639 #define TIM_DMABase_CCR1 ((uint16_t)0x000D)
Sergunb 0:8f0d870509fe 640 #define TIM_DMABase_CCR2 ((uint16_t)0x000E)
Sergunb 0:8f0d870509fe 641 #define TIM_DMABase_CCR3 ((uint16_t)0x000F)
Sergunb 0:8f0d870509fe 642 #define TIM_DMABase_CCR4 ((uint16_t)0x0010)
Sergunb 0:8f0d870509fe 643 #define TIM_DMABase_BDTR ((uint16_t)0x0011)
Sergunb 0:8f0d870509fe 644 #define TIM_DMABase_DCR ((uint16_t)0x0012)
Sergunb 0:8f0d870509fe 645 #define IS_TIM_DMA_BASE(BASE) (((BASE) == TIM_DMABase_CR1) || \
Sergunb 0:8f0d870509fe 646 ((BASE) == TIM_DMABase_CR2) || \
Sergunb 0:8f0d870509fe 647 ((BASE) == TIM_DMABase_SMCR) || \
Sergunb 0:8f0d870509fe 648 ((BASE) == TIM_DMABase_DIER) || \
Sergunb 0:8f0d870509fe 649 ((BASE) == TIM_DMABase_SR) || \
Sergunb 0:8f0d870509fe 650 ((BASE) == TIM_DMABase_EGR) || \
Sergunb 0:8f0d870509fe 651 ((BASE) == TIM_DMABase_CCMR1) || \
Sergunb 0:8f0d870509fe 652 ((BASE) == TIM_DMABase_CCMR2) || \
Sergunb 0:8f0d870509fe 653 ((BASE) == TIM_DMABase_CCER) || \
Sergunb 0:8f0d870509fe 654 ((BASE) == TIM_DMABase_CNT) || \
Sergunb 0:8f0d870509fe 655 ((BASE) == TIM_DMABase_PSC) || \
Sergunb 0:8f0d870509fe 656 ((BASE) == TIM_DMABase_ARR) || \
Sergunb 0:8f0d870509fe 657 ((BASE) == TIM_DMABase_RCR) || \
Sergunb 0:8f0d870509fe 658 ((BASE) == TIM_DMABase_CCR1) || \
Sergunb 0:8f0d870509fe 659 ((BASE) == TIM_DMABase_CCR2) || \
Sergunb 0:8f0d870509fe 660 ((BASE) == TIM_DMABase_CCR3) || \
Sergunb 0:8f0d870509fe 661 ((BASE) == TIM_DMABase_CCR4) || \
Sergunb 0:8f0d870509fe 662 ((BASE) == TIM_DMABase_BDTR) || \
Sergunb 0:8f0d870509fe 663 ((BASE) == TIM_DMABase_DCR))
Sergunb 0:8f0d870509fe 664 /**
Sergunb 0:8f0d870509fe 665 * @}
Sergunb 0:8f0d870509fe 666 */
Sergunb 0:8f0d870509fe 667
Sergunb 0:8f0d870509fe 668 /** @defgroup TIM_DMA_Burst_Length
Sergunb 0:8f0d870509fe 669 * @{
Sergunb 0:8f0d870509fe 670 */
Sergunb 0:8f0d870509fe 671
Sergunb 0:8f0d870509fe 672 #define TIM_DMABurstLength_1Byte ((uint16_t)0x0000)
Sergunb 0:8f0d870509fe 673 #define TIM_DMABurstLength_2Bytes ((uint16_t)0x0100)
Sergunb 0:8f0d870509fe 674 #define TIM_DMABurstLength_3Bytes ((uint16_t)0x0200)
Sergunb 0:8f0d870509fe 675 #define TIM_DMABurstLength_4Bytes ((uint16_t)0x0300)
Sergunb 0:8f0d870509fe 676 #define TIM_DMABurstLength_5Bytes ((uint16_t)0x0400)
Sergunb 0:8f0d870509fe 677 #define TIM_DMABurstLength_6Bytes ((uint16_t)0x0500)
Sergunb 0:8f0d870509fe 678 #define TIM_DMABurstLength_7Bytes ((uint16_t)0x0600)
Sergunb 0:8f0d870509fe 679 #define TIM_DMABurstLength_8Bytes ((uint16_t)0x0700)
Sergunb 0:8f0d870509fe 680 #define TIM_DMABurstLength_9Bytes ((uint16_t)0x0800)
Sergunb 0:8f0d870509fe 681 #define TIM_DMABurstLength_10Bytes ((uint16_t)0x0900)
Sergunb 0:8f0d870509fe 682 #define TIM_DMABurstLength_11Bytes ((uint16_t)0x0A00)
Sergunb 0:8f0d870509fe 683 #define TIM_DMABurstLength_12Bytes ((uint16_t)0x0B00)
Sergunb 0:8f0d870509fe 684 #define TIM_DMABurstLength_13Bytes ((uint16_t)0x0C00)
Sergunb 0:8f0d870509fe 685 #define TIM_DMABurstLength_14Bytes ((uint16_t)0x0D00)
Sergunb 0:8f0d870509fe 686 #define TIM_DMABurstLength_15Bytes ((uint16_t)0x0E00)
Sergunb 0:8f0d870509fe 687 #define TIM_DMABurstLength_16Bytes ((uint16_t)0x0F00)
Sergunb 0:8f0d870509fe 688 #define TIM_DMABurstLength_17Bytes ((uint16_t)0x1000)
Sergunb 0:8f0d870509fe 689 #define TIM_DMABurstLength_18Bytes ((uint16_t)0x1100)
Sergunb 0:8f0d870509fe 690 #define IS_TIM_DMA_LENGTH(LENGTH) (((LENGTH) == TIM_DMABurstLength_1Byte) || \
Sergunb 0:8f0d870509fe 691 ((LENGTH) == TIM_DMABurstLength_2Bytes) || \
Sergunb 0:8f0d870509fe 692 ((LENGTH) == TIM_DMABurstLength_3Bytes) || \
Sergunb 0:8f0d870509fe 693 ((LENGTH) == TIM_DMABurstLength_4Bytes) || \
Sergunb 0:8f0d870509fe 694 ((LENGTH) == TIM_DMABurstLength_5Bytes) || \
Sergunb 0:8f0d870509fe 695 ((LENGTH) == TIM_DMABurstLength_6Bytes) || \
Sergunb 0:8f0d870509fe 696 ((LENGTH) == TIM_DMABurstLength_7Bytes) || \
Sergunb 0:8f0d870509fe 697 ((LENGTH) == TIM_DMABurstLength_8Bytes) || \
Sergunb 0:8f0d870509fe 698 ((LENGTH) == TIM_DMABurstLength_9Bytes) || \
Sergunb 0:8f0d870509fe 699 ((LENGTH) == TIM_DMABurstLength_10Bytes) || \
Sergunb 0:8f0d870509fe 700 ((LENGTH) == TIM_DMABurstLength_11Bytes) || \
Sergunb 0:8f0d870509fe 701 ((LENGTH) == TIM_DMABurstLength_12Bytes) || \
Sergunb 0:8f0d870509fe 702 ((LENGTH) == TIM_DMABurstLength_13Bytes) || \
Sergunb 0:8f0d870509fe 703 ((LENGTH) == TIM_DMABurstLength_14Bytes) || \
Sergunb 0:8f0d870509fe 704 ((LENGTH) == TIM_DMABurstLength_15Bytes) || \
Sergunb 0:8f0d870509fe 705 ((LENGTH) == TIM_DMABurstLength_16Bytes) || \
Sergunb 0:8f0d870509fe 706 ((LENGTH) == TIM_DMABurstLength_17Bytes) || \
Sergunb 0:8f0d870509fe 707 ((LENGTH) == TIM_DMABurstLength_18Bytes))
Sergunb 0:8f0d870509fe 708 /**
Sergunb 0:8f0d870509fe 709 * @}
Sergunb 0:8f0d870509fe 710 */
Sergunb 0:8f0d870509fe 711
Sergunb 0:8f0d870509fe 712 /** @defgroup TIM_DMA_sources
Sergunb 0:8f0d870509fe 713 * @{
Sergunb 0:8f0d870509fe 714 */
Sergunb 0:8f0d870509fe 715
Sergunb 0:8f0d870509fe 716 #define TIM_DMA_Update ((uint16_t)0x0100)
Sergunb 0:8f0d870509fe 717 #define TIM_DMA_CC1 ((uint16_t)0x0200)
Sergunb 0:8f0d870509fe 718 #define TIM_DMA_CC2 ((uint16_t)0x0400)
Sergunb 0:8f0d870509fe 719 #define TIM_DMA_CC3 ((uint16_t)0x0800)
Sergunb 0:8f0d870509fe 720 #define TIM_DMA_CC4 ((uint16_t)0x1000)
Sergunb 0:8f0d870509fe 721 #define TIM_DMA_COM ((uint16_t)0x2000)
Sergunb 0:8f0d870509fe 722 #define TIM_DMA_Trigger ((uint16_t)0x4000)
Sergunb 0:8f0d870509fe 723 #define IS_TIM_DMA_SOURCE(SOURCE) ((((SOURCE) & (uint16_t)0x80FF) == 0x0000) && ((SOURCE) != 0x0000))
Sergunb 0:8f0d870509fe 724
Sergunb 0:8f0d870509fe 725 /**
Sergunb 0:8f0d870509fe 726 * @}
Sergunb 0:8f0d870509fe 727 */
Sergunb 0:8f0d870509fe 728
Sergunb 0:8f0d870509fe 729 /** @defgroup TIM_External_Trigger_Prescaler
Sergunb 0:8f0d870509fe 730 * @{
Sergunb 0:8f0d870509fe 731 */
Sergunb 0:8f0d870509fe 732
Sergunb 0:8f0d870509fe 733 #define TIM_ExtTRGPSC_OFF ((uint16_t)0x0000)
Sergunb 0:8f0d870509fe 734 #define TIM_ExtTRGPSC_DIV2 ((uint16_t)0x1000)
Sergunb 0:8f0d870509fe 735 #define TIM_ExtTRGPSC_DIV4 ((uint16_t)0x2000)
Sergunb 0:8f0d870509fe 736 #define TIM_ExtTRGPSC_DIV8 ((uint16_t)0x3000)
Sergunb 0:8f0d870509fe 737 #define IS_TIM_EXT_PRESCALER(PRESCALER) (((PRESCALER) == TIM_ExtTRGPSC_OFF) || \
Sergunb 0:8f0d870509fe 738 ((PRESCALER) == TIM_ExtTRGPSC_DIV2) || \
Sergunb 0:8f0d870509fe 739 ((PRESCALER) == TIM_ExtTRGPSC_DIV4) || \
Sergunb 0:8f0d870509fe 740 ((PRESCALER) == TIM_ExtTRGPSC_DIV8))
Sergunb 0:8f0d870509fe 741 /**
Sergunb 0:8f0d870509fe 742 * @}
Sergunb 0:8f0d870509fe 743 */
Sergunb 0:8f0d870509fe 744
Sergunb 0:8f0d870509fe 745 /** @defgroup TIM_Internal_Trigger_Selection
Sergunb 0:8f0d870509fe 746 * @{
Sergunb 0:8f0d870509fe 747 */
Sergunb 0:8f0d870509fe 748
Sergunb 0:8f0d870509fe 749 #define TIM_TS_ITR0 ((uint16_t)0x0000)
Sergunb 0:8f0d870509fe 750 #define TIM_TS_ITR1 ((uint16_t)0x0010)
Sergunb 0:8f0d870509fe 751 #define TIM_TS_ITR2 ((uint16_t)0x0020)
Sergunb 0:8f0d870509fe 752 #define TIM_TS_ITR3 ((uint16_t)0x0030)
Sergunb 0:8f0d870509fe 753 #define TIM_TS_TI1F_ED ((uint16_t)0x0040)
Sergunb 0:8f0d870509fe 754 #define TIM_TS_TI1FP1 ((uint16_t)0x0050)
Sergunb 0:8f0d870509fe 755 #define TIM_TS_TI2FP2 ((uint16_t)0x0060)
Sergunb 0:8f0d870509fe 756 #define TIM_TS_ETRF ((uint16_t)0x0070)
Sergunb 0:8f0d870509fe 757 #define IS_TIM_TRIGGER_SELECTION(SELECTION) (((SELECTION) == TIM_TS_ITR0) || \
Sergunb 0:8f0d870509fe 758 ((SELECTION) == TIM_TS_ITR1) || \
Sergunb 0:8f0d870509fe 759 ((SELECTION) == TIM_TS_ITR2) || \
Sergunb 0:8f0d870509fe 760 ((SELECTION) == TIM_TS_ITR3) || \
Sergunb 0:8f0d870509fe 761 ((SELECTION) == TIM_TS_TI1F_ED) || \
Sergunb 0:8f0d870509fe 762 ((SELECTION) == TIM_TS_TI1FP1) || \
Sergunb 0:8f0d870509fe 763 ((SELECTION) == TIM_TS_TI2FP2) || \
Sergunb 0:8f0d870509fe 764 ((SELECTION) == TIM_TS_ETRF))
Sergunb 0:8f0d870509fe 765 #define IS_TIM_INTERNAL_TRIGGER_SELECTION(SELECTION) (((SELECTION) == TIM_TS_ITR0) || \
Sergunb 0:8f0d870509fe 766 ((SELECTION) == TIM_TS_ITR1) || \
Sergunb 0:8f0d870509fe 767 ((SELECTION) == TIM_TS_ITR2) || \
Sergunb 0:8f0d870509fe 768 ((SELECTION) == TIM_TS_ITR3))
Sergunb 0:8f0d870509fe 769 /**
Sergunb 0:8f0d870509fe 770 * @}
Sergunb 0:8f0d870509fe 771 */
Sergunb 0:8f0d870509fe 772
Sergunb 0:8f0d870509fe 773 /** @defgroup TIM_TIx_External_Clock_Source
Sergunb 0:8f0d870509fe 774 * @{
Sergunb 0:8f0d870509fe 775 */
Sergunb 0:8f0d870509fe 776
Sergunb 0:8f0d870509fe 777 #define TIM_TIxExternalCLK1Source_TI1 ((uint16_t)0x0050)
Sergunb 0:8f0d870509fe 778 #define TIM_TIxExternalCLK1Source_TI2 ((uint16_t)0x0060)
Sergunb 0:8f0d870509fe 779 #define TIM_TIxExternalCLK1Source_TI1ED ((uint16_t)0x0040)
Sergunb 0:8f0d870509fe 780 #define IS_TIM_TIXCLK_SOURCE(SOURCE) (((SOURCE) == TIM_TIxExternalCLK1Source_TI1) || \
Sergunb 0:8f0d870509fe 781 ((SOURCE) == TIM_TIxExternalCLK1Source_TI2) || \
Sergunb 0:8f0d870509fe 782 ((SOURCE) == TIM_TIxExternalCLK1Source_TI1ED))
Sergunb 0:8f0d870509fe 783 /**
Sergunb 0:8f0d870509fe 784 * @}
Sergunb 0:8f0d870509fe 785 */
Sergunb 0:8f0d870509fe 786
Sergunb 0:8f0d870509fe 787 /** @defgroup TIM_External_Trigger_Polarity
Sergunb 0:8f0d870509fe 788 * @{
Sergunb 0:8f0d870509fe 789 */
Sergunb 0:8f0d870509fe 790 #define TIM_ExtTRGPolarity_Inverted ((uint16_t)0x8000)
Sergunb 0:8f0d870509fe 791 #define TIM_ExtTRGPolarity_NonInverted ((uint16_t)0x0000)
Sergunb 0:8f0d870509fe 792 #define IS_TIM_EXT_POLARITY(POLARITY) (((POLARITY) == TIM_ExtTRGPolarity_Inverted) || \
Sergunb 0:8f0d870509fe 793 ((POLARITY) == TIM_ExtTRGPolarity_NonInverted))
Sergunb 0:8f0d870509fe 794 /**
Sergunb 0:8f0d870509fe 795 * @}
Sergunb 0:8f0d870509fe 796 */
Sergunb 0:8f0d870509fe 797
Sergunb 0:8f0d870509fe 798 /** @defgroup TIM_Prescaler_Reload_Mode
Sergunb 0:8f0d870509fe 799 * @{
Sergunb 0:8f0d870509fe 800 */
Sergunb 0:8f0d870509fe 801
Sergunb 0:8f0d870509fe 802 #define TIM_PSCReloadMode_Update ((uint16_t)0x0000)
Sergunb 0:8f0d870509fe 803 #define TIM_PSCReloadMode_Immediate ((uint16_t)0x0001)
Sergunb 0:8f0d870509fe 804 #define IS_TIM_PRESCALER_RELOAD(RELOAD) (((RELOAD) == TIM_PSCReloadMode_Update) || \
Sergunb 0:8f0d870509fe 805 ((RELOAD) == TIM_PSCReloadMode_Immediate))
Sergunb 0:8f0d870509fe 806 /**
Sergunb 0:8f0d870509fe 807 * @}
Sergunb 0:8f0d870509fe 808 */
Sergunb 0:8f0d870509fe 809
Sergunb 0:8f0d870509fe 810 /** @defgroup TIM_Forced_Action
Sergunb 0:8f0d870509fe 811 * @{
Sergunb 0:8f0d870509fe 812 */
Sergunb 0:8f0d870509fe 813
Sergunb 0:8f0d870509fe 814 #define TIM_ForcedAction_Active ((uint16_t)0x0050)
Sergunb 0:8f0d870509fe 815 #define TIM_ForcedAction_InActive ((uint16_t)0x0040)
Sergunb 0:8f0d870509fe 816 #define IS_TIM_FORCED_ACTION(ACTION) (((ACTION) == TIM_ForcedAction_Active) || \
Sergunb 0:8f0d870509fe 817 ((ACTION) == TIM_ForcedAction_InActive))
Sergunb 0:8f0d870509fe 818 /**
Sergunb 0:8f0d870509fe 819 * @}
Sergunb 0:8f0d870509fe 820 */
Sergunb 0:8f0d870509fe 821
Sergunb 0:8f0d870509fe 822 /** @defgroup TIM_Encoder_Mode
Sergunb 0:8f0d870509fe 823 * @{
Sergunb 0:8f0d870509fe 824 */
Sergunb 0:8f0d870509fe 825
Sergunb 0:8f0d870509fe 826 #define TIM_EncoderMode_TI1 ((uint16_t)0x0001)
Sergunb 0:8f0d870509fe 827 #define TIM_EncoderMode_TI2 ((uint16_t)0x0002)
Sergunb 0:8f0d870509fe 828 #define TIM_EncoderMode_TI12 ((uint16_t)0x0003)
Sergunb 0:8f0d870509fe 829 #define IS_TIM_ENCODER_MODE(MODE) (((MODE) == TIM_EncoderMode_TI1) || \
Sergunb 0:8f0d870509fe 830 ((MODE) == TIM_EncoderMode_TI2) || \
Sergunb 0:8f0d870509fe 831 ((MODE) == TIM_EncoderMode_TI12))
Sergunb 0:8f0d870509fe 832 /**
Sergunb 0:8f0d870509fe 833 * @}
Sergunb 0:8f0d870509fe 834 */
Sergunb 0:8f0d870509fe 835
Sergunb 0:8f0d870509fe 836
Sergunb 0:8f0d870509fe 837 /** @defgroup TIM_Event_Source
Sergunb 0:8f0d870509fe 838 * @{
Sergunb 0:8f0d870509fe 839 */
Sergunb 0:8f0d870509fe 840
Sergunb 0:8f0d870509fe 841 #define TIM_EventSource_Update ((uint16_t)0x0001)
Sergunb 0:8f0d870509fe 842 #define TIM_EventSource_CC1 ((uint16_t)0x0002)
Sergunb 0:8f0d870509fe 843 #define TIM_EventSource_CC2 ((uint16_t)0x0004)
Sergunb 0:8f0d870509fe 844 #define TIM_EventSource_CC3 ((uint16_t)0x0008)
Sergunb 0:8f0d870509fe 845 #define TIM_EventSource_CC4 ((uint16_t)0x0010)
Sergunb 0:8f0d870509fe 846 #define TIM_EventSource_COM ((uint16_t)0x0020)
Sergunb 0:8f0d870509fe 847 #define TIM_EventSource_Trigger ((uint16_t)0x0040)
Sergunb 0:8f0d870509fe 848 #define TIM_EventSource_Break ((uint16_t)0x0080)
Sergunb 0:8f0d870509fe 849 #define IS_TIM_EVENT_SOURCE(SOURCE) ((((SOURCE) & (uint16_t)0xFF00) == 0x0000) && ((SOURCE) != 0x0000))
Sergunb 0:8f0d870509fe 850
Sergunb 0:8f0d870509fe 851 /**
Sergunb 0:8f0d870509fe 852 * @}
Sergunb 0:8f0d870509fe 853 */
Sergunb 0:8f0d870509fe 854
Sergunb 0:8f0d870509fe 855 /** @defgroup TIM_Update_Source
Sergunb 0:8f0d870509fe 856 * @{
Sergunb 0:8f0d870509fe 857 */
Sergunb 0:8f0d870509fe 858
Sergunb 0:8f0d870509fe 859 #define TIM_UpdateSource_Global ((uint16_t)0x0000) /*!< Source of update is the counter overflow/underflow
Sergunb 0:8f0d870509fe 860 or the setting of UG bit, or an update generation
Sergunb 0:8f0d870509fe 861 through the slave mode controller. */
Sergunb 0:8f0d870509fe 862 #define TIM_UpdateSource_Regular ((uint16_t)0x0001) /*!< Source of update is counter overflow/underflow. */
Sergunb 0:8f0d870509fe 863 #define IS_TIM_UPDATE_SOURCE(SOURCE) (((SOURCE) == TIM_UpdateSource_Global) || \
Sergunb 0:8f0d870509fe 864 ((SOURCE) == TIM_UpdateSource_Regular))
Sergunb 0:8f0d870509fe 865 /**
Sergunb 0:8f0d870509fe 866 * @}
Sergunb 0:8f0d870509fe 867 */
Sergunb 0:8f0d870509fe 868
Sergunb 0:8f0d870509fe 869 /** @defgroup TIM_Ouput_Compare_Preload_State
Sergunb 0:8f0d870509fe 870 * @{
Sergunb 0:8f0d870509fe 871 */
Sergunb 0:8f0d870509fe 872
Sergunb 0:8f0d870509fe 873 #define TIM_OCPreload_Enable ((uint16_t)0x0008)
Sergunb 0:8f0d870509fe 874 #define TIM_OCPreload_Disable ((uint16_t)0x0000)
Sergunb 0:8f0d870509fe 875 #define IS_TIM_OCPRELOAD_STATE(STATE) (((STATE) == TIM_OCPreload_Enable) || \
Sergunb 0:8f0d870509fe 876 ((STATE) == TIM_OCPreload_Disable))
Sergunb 0:8f0d870509fe 877 /**
Sergunb 0:8f0d870509fe 878 * @}
Sergunb 0:8f0d870509fe 879 */
Sergunb 0:8f0d870509fe 880
Sergunb 0:8f0d870509fe 881 /** @defgroup TIM_Ouput_Compare_Fast_State
Sergunb 0:8f0d870509fe 882 * @{
Sergunb 0:8f0d870509fe 883 */
Sergunb 0:8f0d870509fe 884
Sergunb 0:8f0d870509fe 885 #define TIM_OCFast_Enable ((uint16_t)0x0004)
Sergunb 0:8f0d870509fe 886 #define TIM_OCFast_Disable ((uint16_t)0x0000)
Sergunb 0:8f0d870509fe 887 #define IS_TIM_OCFAST_STATE(STATE) (((STATE) == TIM_OCFast_Enable) || \
Sergunb 0:8f0d870509fe 888 ((STATE) == TIM_OCFast_Disable))
Sergunb 0:8f0d870509fe 889
Sergunb 0:8f0d870509fe 890 /**
Sergunb 0:8f0d870509fe 891 * @}
Sergunb 0:8f0d870509fe 892 */
Sergunb 0:8f0d870509fe 893
Sergunb 0:8f0d870509fe 894 /** @defgroup TIM_Ouput_Compare_Clear_State
Sergunb 0:8f0d870509fe 895 * @{
Sergunb 0:8f0d870509fe 896 */
Sergunb 0:8f0d870509fe 897
Sergunb 0:8f0d870509fe 898 #define TIM_OCClear_Enable ((uint16_t)0x0080)
Sergunb 0:8f0d870509fe 899 #define TIM_OCClear_Disable ((uint16_t)0x0000)
Sergunb 0:8f0d870509fe 900 #define IS_TIM_OCCLEAR_STATE(STATE) (((STATE) == TIM_OCClear_Enable) || \
Sergunb 0:8f0d870509fe 901 ((STATE) == TIM_OCClear_Disable))
Sergunb 0:8f0d870509fe 902 /**
Sergunb 0:8f0d870509fe 903 * @}
Sergunb 0:8f0d870509fe 904 */
Sergunb 0:8f0d870509fe 905
Sergunb 0:8f0d870509fe 906 /** @defgroup TIM_Trigger_Output_Source
Sergunb 0:8f0d870509fe 907 * @{
Sergunb 0:8f0d870509fe 908 */
Sergunb 0:8f0d870509fe 909
Sergunb 0:8f0d870509fe 910 #define TIM_TRGOSource_Reset ((uint16_t)0x0000)
Sergunb 0:8f0d870509fe 911 #define TIM_TRGOSource_Enable ((uint16_t)0x0010)
Sergunb 0:8f0d870509fe 912 #define TIM_TRGOSource_Update ((uint16_t)0x0020)
Sergunb 0:8f0d870509fe 913 #define TIM_TRGOSource_OC1 ((uint16_t)0x0030)
Sergunb 0:8f0d870509fe 914 #define TIM_TRGOSource_OC1Ref ((uint16_t)0x0040)
Sergunb 0:8f0d870509fe 915 #define TIM_TRGOSource_OC2Ref ((uint16_t)0x0050)
Sergunb 0:8f0d870509fe 916 #define TIM_TRGOSource_OC3Ref ((uint16_t)0x0060)
Sergunb 0:8f0d870509fe 917 #define TIM_TRGOSource_OC4Ref ((uint16_t)0x0070)
Sergunb 0:8f0d870509fe 918 #define IS_TIM_TRGO_SOURCE(SOURCE) (((SOURCE) == TIM_TRGOSource_Reset) || \
Sergunb 0:8f0d870509fe 919 ((SOURCE) == TIM_TRGOSource_Enable) || \
Sergunb 0:8f0d870509fe 920 ((SOURCE) == TIM_TRGOSource_Update) || \
Sergunb 0:8f0d870509fe 921 ((SOURCE) == TIM_TRGOSource_OC1) || \
Sergunb 0:8f0d870509fe 922 ((SOURCE) == TIM_TRGOSource_OC1Ref) || \
Sergunb 0:8f0d870509fe 923 ((SOURCE) == TIM_TRGOSource_OC2Ref) || \
Sergunb 0:8f0d870509fe 924 ((SOURCE) == TIM_TRGOSource_OC3Ref) || \
Sergunb 0:8f0d870509fe 925 ((SOURCE) == TIM_TRGOSource_OC4Ref))
Sergunb 0:8f0d870509fe 926 /**
Sergunb 0:8f0d870509fe 927 * @}
Sergunb 0:8f0d870509fe 928 */
Sergunb 0:8f0d870509fe 929
Sergunb 0:8f0d870509fe 930 /** @defgroup TIM_Slave_Mode
Sergunb 0:8f0d870509fe 931 * @{
Sergunb 0:8f0d870509fe 932 */
Sergunb 0:8f0d870509fe 933
Sergunb 0:8f0d870509fe 934 #define TIM_SlaveMode_Reset ((uint16_t)0x0004)
Sergunb 0:8f0d870509fe 935 #define TIM_SlaveMode_Gated ((uint16_t)0x0005)
Sergunb 0:8f0d870509fe 936 #define TIM_SlaveMode_Trigger ((uint16_t)0x0006)
Sergunb 0:8f0d870509fe 937 #define TIM_SlaveMode_External1 ((uint16_t)0x0007)
Sergunb 0:8f0d870509fe 938 #define IS_TIM_SLAVE_MODE(MODE) (((MODE) == TIM_SlaveMode_Reset) || \
Sergunb 0:8f0d870509fe 939 ((MODE) == TIM_SlaveMode_Gated) || \
Sergunb 0:8f0d870509fe 940 ((MODE) == TIM_SlaveMode_Trigger) || \
Sergunb 0:8f0d870509fe 941 ((MODE) == TIM_SlaveMode_External1))
Sergunb 0:8f0d870509fe 942 /**
Sergunb 0:8f0d870509fe 943 * @}
Sergunb 0:8f0d870509fe 944 */
Sergunb 0:8f0d870509fe 945
Sergunb 0:8f0d870509fe 946 /** @defgroup TIM_Master_Slave_Mode
Sergunb 0:8f0d870509fe 947 * @{
Sergunb 0:8f0d870509fe 948 */
Sergunb 0:8f0d870509fe 949
Sergunb 0:8f0d870509fe 950 #define TIM_MasterSlaveMode_Enable ((uint16_t)0x0080)
Sergunb 0:8f0d870509fe 951 #define TIM_MasterSlaveMode_Disable ((uint16_t)0x0000)
Sergunb 0:8f0d870509fe 952 #define IS_TIM_MSM_STATE(STATE) (((STATE) == TIM_MasterSlaveMode_Enable) || \
Sergunb 0:8f0d870509fe 953 ((STATE) == TIM_MasterSlaveMode_Disable))
Sergunb 0:8f0d870509fe 954 /**
Sergunb 0:8f0d870509fe 955 * @}
Sergunb 0:8f0d870509fe 956 */
Sergunb 0:8f0d870509fe 957
Sergunb 0:8f0d870509fe 958 /** @defgroup TIM_Flags
Sergunb 0:8f0d870509fe 959 * @{
Sergunb 0:8f0d870509fe 960 */
Sergunb 0:8f0d870509fe 961
Sergunb 0:8f0d870509fe 962 #define TIM_FLAG_Update ((uint16_t)0x0001)
Sergunb 0:8f0d870509fe 963 #define TIM_FLAG_CC1 ((uint16_t)0x0002)
Sergunb 0:8f0d870509fe 964 #define TIM_FLAG_CC2 ((uint16_t)0x0004)
Sergunb 0:8f0d870509fe 965 #define TIM_FLAG_CC3 ((uint16_t)0x0008)
Sergunb 0:8f0d870509fe 966 #define TIM_FLAG_CC4 ((uint16_t)0x0010)
Sergunb 0:8f0d870509fe 967 #define TIM_FLAG_COM ((uint16_t)0x0020)
Sergunb 0:8f0d870509fe 968 #define TIM_FLAG_Trigger ((uint16_t)0x0040)
Sergunb 0:8f0d870509fe 969 #define TIM_FLAG_Break ((uint16_t)0x0080)
Sergunb 0:8f0d870509fe 970 #define TIM_FLAG_CC1OF ((uint16_t)0x0200)
Sergunb 0:8f0d870509fe 971 #define TIM_FLAG_CC2OF ((uint16_t)0x0400)
Sergunb 0:8f0d870509fe 972 #define TIM_FLAG_CC3OF ((uint16_t)0x0800)
Sergunb 0:8f0d870509fe 973 #define TIM_FLAG_CC4OF ((uint16_t)0x1000)
Sergunb 0:8f0d870509fe 974 #define IS_TIM_GET_FLAG(FLAG) (((FLAG) == TIM_FLAG_Update) || \
Sergunb 0:8f0d870509fe 975 ((FLAG) == TIM_FLAG_CC1) || \
Sergunb 0:8f0d870509fe 976 ((FLAG) == TIM_FLAG_CC2) || \
Sergunb 0:8f0d870509fe 977 ((FLAG) == TIM_FLAG_CC3) || \
Sergunb 0:8f0d870509fe 978 ((FLAG) == TIM_FLAG_CC4) || \
Sergunb 0:8f0d870509fe 979 ((FLAG) == TIM_FLAG_COM) || \
Sergunb 0:8f0d870509fe 980 ((FLAG) == TIM_FLAG_Trigger) || \
Sergunb 0:8f0d870509fe 981 ((FLAG) == TIM_FLAG_Break) || \
Sergunb 0:8f0d870509fe 982 ((FLAG) == TIM_FLAG_CC1OF) || \
Sergunb 0:8f0d870509fe 983 ((FLAG) == TIM_FLAG_CC2OF) || \
Sergunb 0:8f0d870509fe 984 ((FLAG) == TIM_FLAG_CC3OF) || \
Sergunb 0:8f0d870509fe 985 ((FLAG) == TIM_FLAG_CC4OF))
Sergunb 0:8f0d870509fe 986
Sergunb 0:8f0d870509fe 987
Sergunb 0:8f0d870509fe 988 #define IS_TIM_CLEAR_FLAG(TIM_FLAG) ((((TIM_FLAG) & (uint16_t)0xE100) == 0x0000) && ((TIM_FLAG) != 0x0000))
Sergunb 0:8f0d870509fe 989 /**
Sergunb 0:8f0d870509fe 990 * @}
Sergunb 0:8f0d870509fe 991 */
Sergunb 0:8f0d870509fe 992
Sergunb 0:8f0d870509fe 993 /** @defgroup TIM_Input_Capture_Filer_Value
Sergunb 0:8f0d870509fe 994 * @{
Sergunb 0:8f0d870509fe 995 */
Sergunb 0:8f0d870509fe 996
Sergunb 0:8f0d870509fe 997 #define IS_TIM_IC_FILTER(ICFILTER) ((ICFILTER) <= 0xF)
Sergunb 0:8f0d870509fe 998 /**
Sergunb 0:8f0d870509fe 999 * @}
Sergunb 0:8f0d870509fe 1000 */
Sergunb 0:8f0d870509fe 1001
Sergunb 0:8f0d870509fe 1002 /** @defgroup TIM_External_Trigger_Filter
Sergunb 0:8f0d870509fe 1003 * @{
Sergunb 0:8f0d870509fe 1004 */
Sergunb 0:8f0d870509fe 1005
Sergunb 0:8f0d870509fe 1006 #define IS_TIM_EXT_FILTER(EXTFILTER) ((EXTFILTER) <= 0xF)
Sergunb 0:8f0d870509fe 1007 /**
Sergunb 0:8f0d870509fe 1008 * @}
Sergunb 0:8f0d870509fe 1009 */
Sergunb 0:8f0d870509fe 1010
Sergunb 0:8f0d870509fe 1011 /**
Sergunb 0:8f0d870509fe 1012 * @}
Sergunb 0:8f0d870509fe 1013 */
Sergunb 0:8f0d870509fe 1014
Sergunb 0:8f0d870509fe 1015 /** @defgroup TIM_Exported_Macros
Sergunb 0:8f0d870509fe 1016 * @{
Sergunb 0:8f0d870509fe 1017 */
Sergunb 0:8f0d870509fe 1018
Sergunb 0:8f0d870509fe 1019 /**
Sergunb 0:8f0d870509fe 1020 * @}
Sergunb 0:8f0d870509fe 1021 */
Sergunb 0:8f0d870509fe 1022
Sergunb 0:8f0d870509fe 1023 /** @defgroup TIM_Exported_Functions
Sergunb 0:8f0d870509fe 1024 * @{
Sergunb 0:8f0d870509fe 1025 */
Sergunb 0:8f0d870509fe 1026
Sergunb 0:8f0d870509fe 1027 void TIM_DeInit(TIM_TypeDef* TIMx);
Sergunb 0:8f0d870509fe 1028 void TIM_TimeBaseInit(TIM_TypeDef* TIMx, TIM_TimeBaseInitTypeDef* TIM_TimeBaseInitStruct);
Sergunb 0:8f0d870509fe 1029 void TIM_OC1Init(TIM_TypeDef* TIMx, TIM_OCInitTypeDef* TIM_OCInitStruct);
Sergunb 0:8f0d870509fe 1030 void TIM_OC2Init(TIM_TypeDef* TIMx, TIM_OCInitTypeDef* TIM_OCInitStruct);
Sergunb 0:8f0d870509fe 1031 void TIM_OC3Init(TIM_TypeDef* TIMx, TIM_OCInitTypeDef* TIM_OCInitStruct);
Sergunb 0:8f0d870509fe 1032 void TIM_OC4Init(TIM_TypeDef* TIMx, TIM_OCInitTypeDef* TIM_OCInitStruct);
Sergunb 0:8f0d870509fe 1033 void TIM_ICInit(TIM_TypeDef* TIMx, TIM_ICInitTypeDef* TIM_ICInitStruct);
Sergunb 0:8f0d870509fe 1034 void TIM_PWMIConfig(TIM_TypeDef* TIMx, TIM_ICInitTypeDef* TIM_ICInitStruct);
Sergunb 0:8f0d870509fe 1035 void TIM_BDTRConfig(TIM_TypeDef* TIMx, TIM_BDTRInitTypeDef *TIM_BDTRInitStruct);
Sergunb 0:8f0d870509fe 1036 void TIM_TimeBaseStructInit(TIM_TimeBaseInitTypeDef* TIM_TimeBaseInitStruct);
Sergunb 0:8f0d870509fe 1037 void TIM_OCStructInit(TIM_OCInitTypeDef* TIM_OCInitStruct);
Sergunb 0:8f0d870509fe 1038 void TIM_ICStructInit(TIM_ICInitTypeDef* TIM_ICInitStruct);
Sergunb 0:8f0d870509fe 1039 void TIM_BDTRStructInit(TIM_BDTRInitTypeDef* TIM_BDTRInitStruct);
Sergunb 0:8f0d870509fe 1040 void TIM_Cmd(TIM_TypeDef* TIMx, FunctionalState NewState);
Sergunb 0:8f0d870509fe 1041 void TIM_CtrlPWMOutputs(TIM_TypeDef* TIMx, FunctionalState NewState);
Sergunb 0:8f0d870509fe 1042 void TIM_ITConfig(TIM_TypeDef* TIMx, uint16_t TIM_IT, FunctionalState NewState);
Sergunb 0:8f0d870509fe 1043 void TIM_GenerateEvent(TIM_TypeDef* TIMx, uint16_t TIM_EventSource);
Sergunb 0:8f0d870509fe 1044 void TIM_DMAConfig(TIM_TypeDef* TIMx, uint16_t TIM_DMABase, uint16_t TIM_DMABurstLength);
Sergunb 0:8f0d870509fe 1045 void TIM_DMACmd(TIM_TypeDef* TIMx, uint16_t TIM_DMASource, FunctionalState NewState);
Sergunb 0:8f0d870509fe 1046 void TIM_InternalClockConfig(TIM_TypeDef* TIMx);
Sergunb 0:8f0d870509fe 1047 void TIM_ITRxExternalClockConfig(TIM_TypeDef* TIMx, uint16_t TIM_InputTriggerSource);
Sergunb 0:8f0d870509fe 1048 void TIM_TIxExternalClockConfig(TIM_TypeDef* TIMx, uint16_t TIM_TIxExternalCLKSource,
Sergunb 0:8f0d870509fe 1049 uint16_t TIM_ICPolarity, uint16_t ICFilter);
Sergunb 0:8f0d870509fe 1050 void TIM_ETRClockMode1Config(TIM_TypeDef* TIMx, uint16_t TIM_ExtTRGPrescaler, uint16_t TIM_ExtTRGPolarity,
Sergunb 0:8f0d870509fe 1051 uint16_t ExtTRGFilter);
Sergunb 0:8f0d870509fe 1052 void TIM_ETRClockMode2Config(TIM_TypeDef* TIMx, uint16_t TIM_ExtTRGPrescaler,
Sergunb 0:8f0d870509fe 1053 uint16_t TIM_ExtTRGPolarity, uint16_t ExtTRGFilter);
Sergunb 0:8f0d870509fe 1054 void TIM_ETRConfig(TIM_TypeDef* TIMx, uint16_t TIM_ExtTRGPrescaler, uint16_t TIM_ExtTRGPolarity,
Sergunb 0:8f0d870509fe 1055 uint16_t ExtTRGFilter);
Sergunb 0:8f0d870509fe 1056 void TIM_PrescalerConfig(TIM_TypeDef* TIMx, uint16_t Prescaler, uint16_t TIM_PSCReloadMode);
Sergunb 0:8f0d870509fe 1057 void TIM_CounterModeConfig(TIM_TypeDef* TIMx, uint16_t TIM_CounterMode);
Sergunb 0:8f0d870509fe 1058 void TIM_SelectInputTrigger(TIM_TypeDef* TIMx, uint16_t TIM_InputTriggerSource);
Sergunb 0:8f0d870509fe 1059 void TIM_EncoderInterfaceConfig(TIM_TypeDef* TIMx, uint16_t TIM_EncoderMode,
Sergunb 0:8f0d870509fe 1060 uint16_t TIM_IC1Polarity, uint16_t TIM_IC2Polarity);
Sergunb 0:8f0d870509fe 1061 void TIM_ForcedOC1Config(TIM_TypeDef* TIMx, uint16_t TIM_ForcedAction);
Sergunb 0:8f0d870509fe 1062 void TIM_ForcedOC2Config(TIM_TypeDef* TIMx, uint16_t TIM_ForcedAction);
Sergunb 0:8f0d870509fe 1063 void TIM_ForcedOC3Config(TIM_TypeDef* TIMx, uint16_t TIM_ForcedAction);
Sergunb 0:8f0d870509fe 1064 void TIM_ForcedOC4Config(TIM_TypeDef* TIMx, uint16_t TIM_ForcedAction);
Sergunb 0:8f0d870509fe 1065 void TIM_ARRPreloadConfig(TIM_TypeDef* TIMx, FunctionalState NewState);
Sergunb 0:8f0d870509fe 1066 void TIM_SelectCOM(TIM_TypeDef* TIMx, FunctionalState NewState);
Sergunb 0:8f0d870509fe 1067 void TIM_SelectCCDMA(TIM_TypeDef* TIMx, FunctionalState NewState);
Sergunb 0:8f0d870509fe 1068 void TIM_CCPreloadControl(TIM_TypeDef* TIMx, FunctionalState NewState);
Sergunb 0:8f0d870509fe 1069 void TIM_OC1PreloadConfig(TIM_TypeDef* TIMx, uint16_t TIM_OCPreload);
Sergunb 0:8f0d870509fe 1070 void TIM_OC2PreloadConfig(TIM_TypeDef* TIMx, uint16_t TIM_OCPreload);
Sergunb 0:8f0d870509fe 1071 void TIM_OC3PreloadConfig(TIM_TypeDef* TIMx, uint16_t TIM_OCPreload);
Sergunb 0:8f0d870509fe 1072 void TIM_OC4PreloadConfig(TIM_TypeDef* TIMx, uint16_t TIM_OCPreload);
Sergunb 0:8f0d870509fe 1073 void TIM_OC1FastConfig(TIM_TypeDef* TIMx, uint16_t TIM_OCFast);
Sergunb 0:8f0d870509fe 1074 void TIM_OC2FastConfig(TIM_TypeDef* TIMx, uint16_t TIM_OCFast);
Sergunb 0:8f0d870509fe 1075 void TIM_OC3FastConfig(TIM_TypeDef* TIMx, uint16_t TIM_OCFast);
Sergunb 0:8f0d870509fe 1076 void TIM_OC4FastConfig(TIM_TypeDef* TIMx, uint16_t TIM_OCFast);
Sergunb 0:8f0d870509fe 1077 void TIM_ClearOC1Ref(TIM_TypeDef* TIMx, uint16_t TIM_OCClear);
Sergunb 0:8f0d870509fe 1078 void TIM_ClearOC2Ref(TIM_TypeDef* TIMx, uint16_t TIM_OCClear);
Sergunb 0:8f0d870509fe 1079 void TIM_ClearOC3Ref(TIM_TypeDef* TIMx, uint16_t TIM_OCClear);
Sergunb 0:8f0d870509fe 1080 void TIM_ClearOC4Ref(TIM_TypeDef* TIMx, uint16_t TIM_OCClear);
Sergunb 0:8f0d870509fe 1081 void TIM_OC1PolarityConfig(TIM_TypeDef* TIMx, uint16_t TIM_OCPolarity);
Sergunb 0:8f0d870509fe 1082 void TIM_OC1NPolarityConfig(TIM_TypeDef* TIMx, uint16_t TIM_OCNPolarity);
Sergunb 0:8f0d870509fe 1083 void TIM_OC2PolarityConfig(TIM_TypeDef* TIMx, uint16_t TIM_OCPolarity);
Sergunb 0:8f0d870509fe 1084 void TIM_OC2NPolarityConfig(TIM_TypeDef* TIMx, uint16_t TIM_OCNPolarity);
Sergunb 0:8f0d870509fe 1085 void TIM_OC3PolarityConfig(TIM_TypeDef* TIMx, uint16_t TIM_OCPolarity);
Sergunb 0:8f0d870509fe 1086 void TIM_OC3NPolarityConfig(TIM_TypeDef* TIMx, uint16_t TIM_OCNPolarity);
Sergunb 0:8f0d870509fe 1087 void TIM_OC4PolarityConfig(TIM_TypeDef* TIMx, uint16_t TIM_OCPolarity);
Sergunb 0:8f0d870509fe 1088 void TIM_CCxCmd(TIM_TypeDef* TIMx, uint16_t TIM_Channel, uint16_t TIM_CCx);
Sergunb 0:8f0d870509fe 1089 void TIM_CCxNCmd(TIM_TypeDef* TIMx, uint16_t TIM_Channel, uint16_t TIM_CCxN);
Sergunb 0:8f0d870509fe 1090 void TIM_SelectOCxM(TIM_TypeDef* TIMx, uint16_t TIM_Channel, uint16_t TIM_OCMode);
Sergunb 0:8f0d870509fe 1091 void TIM_UpdateDisableConfig(TIM_TypeDef* TIMx, FunctionalState NewState);
Sergunb 0:8f0d870509fe 1092 void TIM_UpdateRequestConfig(TIM_TypeDef* TIMx, uint16_t TIM_UpdateSource);
Sergunb 0:8f0d870509fe 1093 void TIM_SelectHallSensor(TIM_TypeDef* TIMx, FunctionalState NewState);
Sergunb 0:8f0d870509fe 1094 void TIM_SelectOnePulseMode(TIM_TypeDef* TIMx, uint16_t TIM_OPMode);
Sergunb 0:8f0d870509fe 1095 void TIM_SelectOutputTrigger(TIM_TypeDef* TIMx, uint16_t TIM_TRGOSource);
Sergunb 0:8f0d870509fe 1096 void TIM_SelectSlaveMode(TIM_TypeDef* TIMx, uint16_t TIM_SlaveMode);
Sergunb 0:8f0d870509fe 1097 void TIM_SelectMasterSlaveMode(TIM_TypeDef* TIMx, uint16_t TIM_MasterSlaveMode);
Sergunb 0:8f0d870509fe 1098 void TIM_SetCounter(TIM_TypeDef* TIMx, uint16_t Counter);
Sergunb 0:8f0d870509fe 1099 void TIM_SetAutoreload(TIM_TypeDef* TIMx, uint16_t Autoreload);
Sergunb 0:8f0d870509fe 1100 void TIM_SetCompare1(TIM_TypeDef* TIMx, uint16_t Compare1);
Sergunb 0:8f0d870509fe 1101 void TIM_SetCompare2(TIM_TypeDef* TIMx, uint16_t Compare2);
Sergunb 0:8f0d870509fe 1102 void TIM_SetCompare3(TIM_TypeDef* TIMx, uint16_t Compare3);
Sergunb 0:8f0d870509fe 1103 void TIM_SetCompare4(TIM_TypeDef* TIMx, uint16_t Compare4);
Sergunb 0:8f0d870509fe 1104 void TIM_SetIC1Prescaler(TIM_TypeDef* TIMx, uint16_t TIM_ICPSC);
Sergunb 0:8f0d870509fe 1105 void TIM_SetIC2Prescaler(TIM_TypeDef* TIMx, uint16_t TIM_ICPSC);
Sergunb 0:8f0d870509fe 1106 void TIM_SetIC3Prescaler(TIM_TypeDef* TIMx, uint16_t TIM_ICPSC);
Sergunb 0:8f0d870509fe 1107 void TIM_SetIC4Prescaler(TIM_TypeDef* TIMx, uint16_t TIM_ICPSC);
Sergunb 0:8f0d870509fe 1108 void TIM_SetClockDivision(TIM_TypeDef* TIMx, uint16_t TIM_CKD);
Sergunb 0:8f0d870509fe 1109 uint16_t TIM_GetCapture1(TIM_TypeDef* TIMx);
Sergunb 0:8f0d870509fe 1110 uint16_t TIM_GetCapture2(TIM_TypeDef* TIMx);
Sergunb 0:8f0d870509fe 1111 uint16_t TIM_GetCapture3(TIM_TypeDef* TIMx);
Sergunb 0:8f0d870509fe 1112 uint16_t TIM_GetCapture4(TIM_TypeDef* TIMx);
Sergunb 0:8f0d870509fe 1113 uint16_t TIM_GetCounter(TIM_TypeDef* TIMx);
Sergunb 0:8f0d870509fe 1114 uint16_t TIM_GetPrescaler(TIM_TypeDef* TIMx);
Sergunb 0:8f0d870509fe 1115 FlagStatus TIM_GetFlagStatus(TIM_TypeDef* TIMx, uint16_t TIM_FLAG);
Sergunb 0:8f0d870509fe 1116 void TIM_ClearFlag(TIM_TypeDef* TIMx, uint16_t TIM_FLAG);
Sergunb 0:8f0d870509fe 1117 ITStatus TIM_GetITStatus(TIM_TypeDef* TIMx, uint16_t TIM_IT);
Sergunb 0:8f0d870509fe 1118 void TIM_ClearITPendingBit(TIM_TypeDef* TIMx, uint16_t TIM_IT);
Sergunb 0:8f0d870509fe 1119
Sergunb 0:8f0d870509fe 1120 #ifdef __cplusplus
Sergunb 0:8f0d870509fe 1121 }
Sergunb 0:8f0d870509fe 1122 #endif
Sergunb 0:8f0d870509fe 1123
Sergunb 0:8f0d870509fe 1124 #endif /*__STM32F10x_TIM_H */
Sergunb 0:8f0d870509fe 1125 /**
Sergunb 0:8f0d870509fe 1126 * @}
Sergunb 0:8f0d870509fe 1127 */
Sergunb 0:8f0d870509fe 1128
Sergunb 0:8f0d870509fe 1129 /**
Sergunb 0:8f0d870509fe 1130 * @}
Sergunb 0:8f0d870509fe 1131 */
Sergunb 0:8f0d870509fe 1132
Sergunb 0:8f0d870509fe 1133 /**
Sergunb 0:8f0d870509fe 1134 * @}
Sergunb 0:8f0d870509fe 1135 */
Sergunb 0:8f0d870509fe 1136
Sergunb 0:8f0d870509fe 1137 /******************* (C) COPYRIGHT 2010 STMicroelectronics *****END OF FILE****/