www.pudn.com > Micrium-ST-uCOS-II-LCD-STM32-SK.rar > stm32f10x_tim.h


/******************** (C) COPYRIGHT 2007 STMicroelectronics ******************** 
* File Name          : stm32f10x_tim.h 
* Author             : MCD Application Team 
* Date First Issued  : 09/29/2006 
* Description        : This file contains all the functions prototypes for the  
*                      TIM firmware library. 
******************************************************************************** 
* History: 
* 05/21/2007: V0.3 
* 04/02/2007: V0.2 
* 02/05/2007: V0.1 
* 09/29/2006: V0.01 
******************************************************************************** 
* THE PRESENT SOFTWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS 
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE TIME. 
* AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY DIRECT, 
* INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING FROM THE 
* CONTENT OF SUCH SOFTWARE AND/OR THE USE MADE BY CUSTOMERS OF THE CODING 
* INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS. 
*******************************************************************************/ 
 
/* Define to prevent recursive inclusion -------------------------------------*/ 
#ifndef __STM32F10x_TIM_H 
#define __STM32F10x_TIM_H 
 
/* Includes ------------------------------------------------------------------*/ 
#include "stm32f10x_map.h" 
 
/* Exported types ------------------------------------------------------------*/ 
 
/* TIM Base Init structure definition */ 
typedef struct 
{ 
  u16 TIM_Period;          /* Period value */ 
  u16 TIM_Prescaler;       /* Prescaler value */ 
  u16 TIM_ClockDivision;   /* Timer clock division */ 
  u16 TIM_CounterMode;     /* Timer Counter mode */ 
} TIM_TimeBaseInitTypeDef; 
 
/* TIM Output Compare Init structure definition */ 
typedef struct 
{ 
  u16 TIM_OCMode;          /* Timer Output Compare Mode */ 
  u16 TIM_Channel;          /* Timer Channel */ 
  u16 TIM_Pulse;           /* PWM or OC Channel pulse length */ 
  u16 TIM_OCPolarity;       /* PWM, OCM or OPM Channel polarity */ 
} TIM_OCInitTypeDef; 
 
/* TIM Input Capture Init structure definition */ 
typedef struct 
{ 
  u16 TIM_ICMode;            /* Timer Input Capture Mode */ 
  u16 TIM_Channel;           /* Timer Channel */ 
  u16 TIM_ICPolarity;        /* Input Capture polarity */  
  u16 TIM_ICSelection;       /* Input Capture selection */ 
  u16 TIM_ICPrescaler;       /* Input Capture prescaler */ 
  u8 TIM_ICFilter;          /* Input Capture filter */ 
} TIM_ICInitTypeDef; 
 
/* Exported constants -------------------------------------------------------*/ 
/* TIM Ouput Compare modes --------------------------------------------------*/ 
#define TIM_OCMode_Timing                 ((u16)0x0000) 
#define TIM_OCMode_Active                 ((u16)0x0010) 
#define TIM_OCMode_Inactive               ((u16)0x0020) 
#define TIM_OCMode_Toggle                 ((u16)0x0030) 
#define TIM_OCMode_PWM1                   ((u16)0x0060) 
#define TIM_OCMode_PWM2                   ((u16)0x0070) 
 
#define IS_TIM_OC_MODE(MODE) ((MODE == TIM_OCMode_Timing) || \ 
                              (MODE == TIM_OCMode_Active) || \ 
                              (MODE == TIM_OCMode_Inactive) || \ 
                              (MODE == TIM_OCMode_Toggle)|| \ 
                              (MODE == TIM_OCMode_PWM1) || \ 
                              (MODE == TIM_OCMode_PWM2)) 
 
/* TIM Input Capture modes --------------------------------------------------*/ 
#define TIM_ICMode_ICAP                   ((u16)0x0007) 
#define TIM_ICMode_PWMI                   ((u16)0x0006) 
 
#define IS_TIM_IC_MODE(MODE) ((MODE == TIM_ICMode_ICAP) || \ 
                              (MODE == TIM_ICMode_PWMI)) 
 
/* TIM One Pulse Mode -------------------------------------------------------*/ 
#define TIM_OPMode_Single                 ((u16)0x0008) 
#define TIM_OPMode_Repetitive             ((u16)0x0000) 
 
#define IS_TIM_OPM_MODE(MODE) ((MODE == TIM_OPMode_Single) || \ 
                               (MODE == TIM_OPMode_Repetitive)) 
                              
/* TIM Channel --------------------------------------------------------------*/ 
#define TIM_Channel_1                     ((u16)0x0000) 
#define TIM_Channel_2                     ((u16)0x0001) 
#define TIM_Channel_3                     ((u16)0x0002) 
#define TIM_Channel_4                     ((u16)0x0003) 
 
#define IS_TIM_CHANNEL(CHANNEL) ((CHANNEL == TIM_Channel_1) || \ 
                                 (CHANNEL == TIM_Channel_2) || \ 
                                 (CHANNEL == TIM_Channel_3) || \ 
                                 (CHANNEL == TIM_Channel_4)) 
 
/* TIM Clock Division CKD ---------------------------------------------------*/ 
#define TIM_CKD_DIV1                      ((u16)0x0000) 
#define TIM_CKD_DIV2                      ((u16)0x0100) 
#define TIM_CKD_DIV4                      ((u16)0x0200) 
 
#define IS_TIM_CKD_DIV(DIV) ((DIV == TIM_CKD_DIV1) || \ 
                             (DIV == TIM_CKD_DIV2) || \ 
                             (DIV == TIM_CKD_DIV4)) 
 
/* TIM Counter Mode ---------------------------------------------------------*/ 
#define TIM_CounterMode_Up                ((u16)0x0000) 
#define TIM_CounterMode_Down              ((u16)0x0010) 
#define TIM_CounterMode_CenterAligned1    ((u16)0x0020) 
#define TIM_CounterMode_CenterAligned2    ((u16)0x0040) 
#define TIM_CounterMode_CenterAligned3    ((u16)0x0060) 
 
#define IS_TIM_COUNTER_MODE(MODE) ((MODE == TIM_CounterMode_Up) ||  \ 
                                   (MODE == TIM_CounterMode_Down) || \ 
                                   (MODE == TIM_CounterMode_CenterAligned1) || \ 
                                   (MODE == TIM_CounterMode_CenterAligned2) || \ 
                                   (MODE == TIM_CounterMode_CenterAligned3)) 
 
/* TIM Output Compare Polarity ----------------------------------------------*/ 
#define TIM_OCPolarity_High               ((u16)0x0000) 
#define TIM_OCPolarity_Low                ((u16)0x0002) 
 
#define IS_TIM_OC_POLARITY(POLARITY) ((POLARITY == TIM_OCPolarity_High) || \ 
                                     (POLARITY == TIM_OCPolarity_Low)) 
 
/* TIM Input Capture Polarity -----------------------------------------------*/ 
#define  TIM_ICPolarity_Rising            ((u16)0x0000) 
#define  TIM_ICPolarity_Falling           ((u16)0x0002) 
 
#define IS_TIM_IC_POLARITY(POLARITY) ((POLARITY == TIM_ICPolarity_Rising) || \ 
                                     (POLARITY == TIM_ICPolarity_Falling)) 
 
/* TIM Input Capture Channel  Selection -------------------------------------*/ 
#define TIM_ICSelection_DirectTI          ((u16)0x0001) 
#define TIM_ICSelection_IndirectTI        ((u16)0x0002) 
#define TIM_ICSelection_TRGI              ((u16)0x0003) 
 
#define IS_TIM_IC_SELECTION(SELECTION) ((SELECTION == TIM_ICSelection_DirectTI) || \ 
                                       (SELECTION == TIM_ICSelection_IndirectTI) || \ 
                                       (SELECTION == TIM_ICSelection_TRGI)) 
 
/* TIM Input Capture Prescaler ----------------------------------------------*/ 
#define TIM_ICPSC_DIV1                    ((u16)0x0000) 
#define TIM_ICPSC_DIV2                    ((u16)0x0004) 
#define TIM_ICPSC_DIV4                    ((u16)0x0008) 
#define TIM_ICPSC_DIV8                    ((u16)0x000C) 
 
#define IS_TIM_IC_PRESCALER(PRESCALER) ((PRESCALER == TIM_ICPSC_DIV1) || \ 
                                       (PRESCALER == TIM_ICPSC_DIV2) || \ 
                                       (PRESCALER == TIM_ICPSC_DIV4) || \ 
                                       (PRESCALER == TIM_ICPSC_DIV8)) 
 
/* TIM Input Capture Filer Value ---------------------------------------------*/ 
#define IS_TIM_IC_FILTER(ICFILTER) (ICFILTER <= 0xF)                                       
 
/* TIM interrupt sources ----------------------------------------------------*/ 
#define TIM_IT_Update                     ((u16)0x0001) 
#define TIM_IT_CC1                        ((u16)0x0002) 
#define TIM_IT_CC2                        ((u16)0x0004) 
#define TIM_IT_CC3                        ((u16)0x0008) 
#define TIM_IT_CC4                        ((u16)0x0010) 
#define TIM_IT_Trigger                    ((u16)0x0040) 
 
#define IS_TIM_IT(IT) (((IT & (u16)0xFFA0) == 0x0000) && (IT != 0x0000)) 
 
#define IS_TIM_GET_IT(IT) ((IT == TIM_IT_Update) || \ 
                           (IT == TIM_IT_CC1) || \ 
                           (IT == TIM_IT_CC2) || \ 
                           (IT == TIM_IT_CC3) || \ 
                           (IT == TIM_IT_CC4) || \ 
                           (IT == TIM_IT_Trigger)) 
 
/* TIM DMA Base address -----------------------------------------------------*/ 
#define TIM_DMABase_CR1                   ((u16)0x0000) 
#define TIM_DMABase_CR2                   ((u16)0x0001) 
#define TIM_DMABase_SMCR                  ((u16)0x0002) 
#define TIM_DMABase_DIER                  ((u16)0x0003) 
#define TIM_DMABase_SR                    ((u16)0x0004) 
#define TIM_DMABase_EGR                   ((u16)0x0005) 
#define TIM_DMABase_CCMR1                 ((u16)0x0006) 
#define TIM_DMABase_CCMR2                 ((u16)0x0007) 
#define TIM_DMABase_CCER                  ((u16)0x0008) 
#define TIM_DMABase_CNT                   ((u16)0x0009) 
#define TIM_DMABase_PSC                   ((u16)0x000A) 
#define TIM_DMABase_ARR                   ((u16)0x000B) 
#define TIM_DMABase_CCR1                  ((u16)0x000D) 
#define TIM_DMABase_CCR2                  ((u16)0x000E) 
#define TIM_DMABase_CCR3                  ((u16)0x000F) 
#define TIM_DMABase_CCR4                  ((u16)0x0010) 
#define TIM_DMABase_DCR                   ((u16)0x0012) 
 
#define IS_TIM_DMA_BASE(BASE) ((BASE == TIM_DMABase_CR1) || \ 
                               (BASE == TIM_DMABase_CR2) || \ 
                               (BASE == TIM_DMABase_SMCR) || \ 
                               (BASE == TIM_DMABase_DIER) || \ 
                               (BASE == TIM_DMABase_SR) || \ 
                               (BASE == TIM_DMABase_EGR) || \ 
                               (BASE == TIM_DMABase_CCMR1) || \ 
                               (BASE == TIM_DMABase_CCMR2) || \ 
                               (BASE == TIM_DMABase_CCER) || \ 
                               (BASE == TIM_DMABase_CNT) || \ 
                               (BASE == TIM_DMABase_PSC) || \ 
                               (BASE == TIM_DMABase_ARR) || \ 
                               (BASE == TIM_DMABase_CCR1) || \ 
                               (BASE == TIM_DMABase_CCR2) || \ 
                               (BASE == TIM_DMABase_CCR3) || \ 
                               (BASE == TIM_DMABase_CCR4) || \ 
                               (BASE == TIM_DMABase_DCR)) 
 
/* TIM DMA Burst Length -----------------------------------------------------*/ 
#define TIM_DMABurstLength_1Byte          ((u16)0x0000) 
#define TIM_DMABurstLength_2Bytes         ((u16)0x0100) 
#define TIM_DMABurstLength_3Bytes         ((u16)0x0200) 
#define TIM_DMABurstLength_4Bytes         ((u16)0x0300) 
#define TIM_DMABurstLength_5Bytes         ((u16)0x0400) 
#define TIM_DMABurstLength_6Bytes         ((u16)0x0500) 
#define TIM_DMABurstLength_7Bytes         ((u16)0x0600) 
#define TIM_DMABurstLength_8Bytes         ((u16)0x0700) 
#define TIM_DMABurstLength_9Bytes         ((u16)0x0800) 
#define TIM_DMABurstLength_10Bytes        ((u16)0x0900) 
#define TIM_DMABurstLength_11Bytes        ((u16)0x0A00) 
#define TIM_DMABurstLength_12Bytes        ((u16)0x0B00) 
#define TIM_DMABurstLength_13Bytes        ((u16)0x0C00) 
#define TIM_DMABurstLength_14Bytes        ((u16)0x0D00) 
#define TIM_DMABurstLength_15Bytes        ((u16)0x0E00) 
#define TIM_DMABurstLength_16Bytes        ((u16)0x0F00) 
#define TIM_DMABurstLength_17Bytes        ((u16)0x1000) 
#define TIM_DMABurstLength_18Bytes        ((u16)0x1100) 
 
#define IS_TIM_DMA_LENGTH(LENGTH) ((LENGTH == TIM_DMABurstLength_1Byte) || \ 
                                   (LENGTH == TIM_DMABurstLength_2Bytes) || \ 
                                   (LENGTH == TIM_DMABurstLength_3Bytes) || \ 
                                   (LENGTH == TIM_DMABurstLength_4Bytes) || \ 
                                   (LENGTH == TIM_DMABurstLength_5Bytes) || \ 
                                   (LENGTH == TIM_DMABurstLength_6Bytes) || \ 
                                   (LENGTH == TIM_DMABurstLength_7Bytes) || \ 
                                   (LENGTH == TIM_DMABurstLength_8Bytes) || \ 
                                   (LENGTH == TIM_DMABurstLength_9Bytes) || \ 
                                   (LENGTH == TIM_DMABurstLength_10Bytes) || \ 
                                   (LENGTH == TIM_DMABurstLength_11Bytes) || \ 
                                   (LENGTH == TIM_DMABurstLength_12Bytes) || \ 
                                   (LENGTH == TIM_DMABurstLength_13Bytes) || \ 
                                   (LENGTH == TIM_DMABurstLength_14Bytes) || \ 
                                   (LENGTH == TIM_DMABurstLength_15Bytes) || \ 
                                   (LENGTH == TIM_DMABurstLength_16Bytes) || \ 
                                   (LENGTH == TIM_DMABurstLength_17Bytes) || \ 
                                   (LENGTH == TIM_DMABurstLength_18Bytes)) 
                                                         
/* TIM DMA sources ----------------------------------------------------------*/ 
#define TIM_DMA_Update                    ((u16)0x0100) 
#define TIM_DMA_CC1                       ((u16)0x0200) 
#define TIM_DMA_CC2                       ((u16)0x0400) 
#define TIM_DMA_CC3                       ((u16)0x0800) 
#define TIM_DMA_CC4                       ((u16)0x1000) 
#define TIM_DMA_Trigger                   ((u16)0x4000) 
 
#define IS_TIM_DMA_SOURCE(SOURCE) (((SOURCE & (u16)0xA0FF) == 0x0000) && (SOURCE != 0x0000)) 
 
/* TIM External Trigger Prescaler -------------------------------------------*/ 
#define TIM_ExtTRGPSC_OFF                 ((u16)0x0000) 
#define TIM_ExtTRGPSC_DIV2                ((u16)0x1000)  
#define TIM_ExtTRGPSC_DIV4                ((u16)0x2000) 
#define TIM_ExtTRGPSC_DIV8                ((u16)0x3000) 
 
#define IS_TIM_EXT_PRESCALER(PRESCALER) ((PRESCALER == TIM_ExtTRGPSC_OFF) || \ 
                                         (PRESCALER == TIM_ExtTRGPSC_DIV2) || \ 
                                         (PRESCALER == TIM_ExtTRGPSC_DIV4) || \ 
                                         (PRESCALER == TIM_ExtTRGPSC_DIV8)) 
 
/* TIM Input Trigger Selection ---------------------------------------------*/ 
#define TIM_TS_ITR0                       ((u16)0x0000) 
#define TIM_TS_ITR1                       ((u16)0x0010) 
#define TIM_TS_ITR2                       ((u16)0x0020) 
#define TIM_TS_ITR3                       ((u16)0x0030) 
#define TIM_TS_TI1F_ED                    ((u16)0x0040) 
#define TIM_TS_TI1FP1                     ((u16)0x0050) 
#define TIM_TS_TI2FP2                     ((u16)0x0060) 
#define TIM_TS_ETRF                       ((u16)0x0070) 
 
#define IS_TIM_TRIGGER_SELECTION(SELECTION) ((SELECTION == TIM_TS_ITR0) || \ 
                                             (SELECTION == TIM_TS_ITR1) || \ 
                                             (SELECTION == TIM_TS_ITR2) || \ 
                                             (SELECTION == TIM_TS_ITR3) || \ 
                                             (SELECTION == TIM_TS_TI1F_ED) || \ 
                                             (SELECTION == TIM_TS_TI1FP1) || \ 
                                             (SELECTION == TIM_TS_TI2FP2) || \ 
                                             (SELECTION == TIM_TS_ETRF)) 
 
#define IS_TIM_INTERNAL_TRIGGER_SELECTION(SELECTION) ((SELECTION == TIM_TS_ITR0) || \ 
                                                      (SELECTION == TIM_TS_ITR1) || \ 
                                                      (SELECTION == TIM_TS_ITR2) || \ 
                                                      (SELECTION == TIM_TS_ITR3)) 
 
#define IS_TIM_TIX_TRIGGER_SELECTION(SELECTION) ((SELECTION == TIM_TS_TI1F_ED) || \ 
                                                 (SELECTION == TIM_TS_TI1FP1) || \ 
                                                 (SELECTION == TIM_TS_TI2FP2)) 
 
/* TIM External Trigger Polarity --------------------------------------------*/ 
#define TIM_ExtTRGPolarity_Inverted       ((u16)0x8000) 
#define TIM_ExtTRGPolarity_NonInverted    ((u16)0x0000) 
 
#define IS_TIM_EXT_POLARITY(POLARITY) ((POLARITY == TIM_ExtTRGPolarity_Inverted) || \ 
                                       (POLARITY == TIM_ExtTRGPolarity_NonInverted))  
 
/* TIM Prescaler Reload Mode ------------------------------------------------*/ 
#define TIM_PSCReloadMode_Update          ((u16)0x0000) 
#define TIM_PSCReloadMode_Immediate       ((u16)0x0001) 
 
#define IS_TIM_PRESCALER_RELOAD(RELOAD) ((RELOAD == TIM_PSCReloadMode_Update) || \ 
                                         (RELOAD == TIM_PSCReloadMode_Immediate)) 
 
/* TIM Forced Action --------------------------------------------------------*/ 
#define TIM_ForcedAction_Active           ((u16)0x0050) 
#define TIM_ForcedAction_InActive         ((u16)0x0040) 
 
#define IS_TIM_FORCED_ACTION(ACTION) ((ACTION == TIM_ForcedAction_Active) || \ 
                                      (ACTION == TIM_ForcedAction_InActive)) 
 
/* TIM Encoder Mode ---------------------------------------------------------*/  
#define TIM_EncoderMode_TI1               ((u16)0x0001) 
#define TIM_EncoderMode_TI2               ((u16)0x0002) 
#define TIM_EncoderMode_TI12              ((u16)0x0003) 
 
#define IS_TIM_ENCODER_MODE(MODE) ((MODE == TIM_EncoderMode_TI1) || \ 
                                   (MODE == TIM_EncoderMode_TI2) || \ 
                                   (MODE == TIM_EncoderMode_TI12)) 
 
/* TIM Event Source ---------------------------------------------------------*/ 
#define TIM_EventSource_Update            ((u16)0x0001) 
#define TIM_EventSource_CC1               ((u16)0x0002) 
#define TIM_EventSource_CC2               ((u16)0x0004) 
#define TIM_EventSource_CC3               ((u16)0x0008) 
#define TIM_EventSource_CC4               ((u16)0x0010) 
#define TIM_EventSource_Trigger           ((u16)0x0040) 
 
#define IS_TIM_EVENT_SOURCE(SOURCE) (((SOURCE & (u16)0xFFA0) == 0x0000) && (SOURCE != 0x0000)) 
                                      
 
/* TIM Update Source --------------------------------------------------------*/ 
#define TIM_UpdateSource_Global           ((u16)0x0000) 
#define TIM_UpdateSource_Regular          ((u16)0x0001) 
 
#define IS_TIM_UPDATE_SOURCE(SOURCE) ((SOURCE == TIM_UpdateSource_Global) || \ 
                                      (SOURCE == TIM_UpdateSource_Regular)) 
 
/* TIM Ouput Compare Preload State ------------------------------------------*/ 
#define TIM_OCPreload_Enable              ((u16)0x0008) 
#define TIM_OCPreload_Disable             ((u16)0x0000) 
 
#define IS_TIM_OCPRELOAD_STATE(STATE) ((STATE == TIM_OCPreload_Enable) || \ 
                                       (STATE == TIM_OCPreload_Disable)) 
 
/* TIM Ouput Compare Fast State ---------------------------------------------*/ 
#define TIM_OCFast_Enable                 ((u16)0x0004) 
#define TIM_OCFast_Disable                ((u16)0x0000) 
 
#define IS_TIM_OCFAST_STATE(STATE) ((STATE == TIM_OCFast_Enable) || \ 
                                    (STATE == TIM_OCFast_Disable)) 
                                     
/* TIM Ouput Compare Clear State ---------------------------------------------*/ 
#define TIM_OCClear_Enable                ((u16)0x0080) 
#define TIM_OCClear_Disable               ((u16)0x0000) 
 
#define IS_TIM_OCCLEAR_STATE(STATE) ((STATE == TIM_OCClear_Enable) || \ 
                                     (STATE == TIM_OCClear_Disable)) 
 
/* TIM Trigger Output Source ------------------------------------------------*/  
#define TIM_TRGOSource_Reset              ((u16)0x0000) 
#define TIM_TRGOSource_Enable             ((u16)0x0010) 
#define TIM_TRGOSource_Update             ((u16)0x0020) 
#define TIM_TRGOSource_OC1                ((u16)0x0030) 
#define TIM_TRGOSource_OC1Ref             ((u16)0x0040) 
#define TIM_TRGOSource_OC2Ref             ((u16)0x0050) 
#define TIM_TRGOSource_OC3Ref             ((u16)0x0060) 
#define TIM_TRGOSource_OC4Ref             ((u16)0x0070) 
 
#define IS_TIM_TRGO_SOURCE(SOURCE) ((SOURCE == TIM_TRGOSource_Reset) || \ 
                                    (SOURCE == TIM_TRGOSource_Enable) || \ 
                                    (SOURCE == TIM_TRGOSource_Update) || \ 
                                    (SOURCE == TIM_TRGOSource_OC1) || \ 
                                    (SOURCE == TIM_TRGOSource_OC1Ref) || \ 
                                    (SOURCE == TIM_TRGOSource_OC2Ref) || \ 
                                    (SOURCE == TIM_TRGOSource_OC3Ref) || \ 
                                    (SOURCE == TIM_TRGOSource_OC4Ref)) 
 
/* TIM Slave Mode -----------------------------------------------------------*/ 
#define TIM_SlaveMode_Reset               ((u16)0x0004) 
#define TIM_SlaveMode_Gated               ((u16)0x0005) 
#define TIM_SlaveMode_Trigger             ((u16)0x0006) 
#define TIM_SlaveMode_External1           ((u16)0x0007) 
 
 
#define IS_TIM_SLAVE_MODE(MODE) ((MODE == TIM_SlaveMode_Reset) || \ 
                                 (MODE == TIM_SlaveMode_Gated) || \ 
                                 (MODE == TIM_SlaveMode_Trigger) || \ 
                                 (MODE == TIM_SlaveMode_External1)) 
 
/* TIM TIx External Clock Source --------------------------------------------*/ 
#define TIM_TIxExternalCLK1Source_TI1     ((u16)0x0050) 
#define TIM_TIxExternalCLK1Source_TI2     ((u16)0x0060) 
#define TIM_TIxExternalCLK1Source_TI1ED   ((u16)0x0040) 
 
#define IS_TIM_TIXCLK_SOURCE(SOURCE) ((SOURCE == TIM_TIxExternalCLK1Source_TI1) || \ 
                                      (SOURCE == TIM_TIxExternalCLK1Source_TI2) || \ 
                                      (SOURCE == TIM_TIxExternalCLK1Source_TI1ED)) 
 
 
/* TIM Master Slave Mode ----------------------------------------------------*/ 
#define TIM_MasterSlaveMode_Enable        ((u16)0x0080) 
#define TIM_MasterSlaveMode_Disable       ((u16)0x0000) 
 
#define IS_TIM_MSM_STATE(STATE) ((STATE == TIM_MasterSlaveMode_Enable) || \ 
                                 (STATE == TIM_MasterSlaveMode_Disable)) 
 
/* TIM Flags ----------------------------------------------------------------*/ 
#define TIM_FLAG_Update                   ((u16)0x0001) 
#define TIM_FLAG_CC1                      ((u16)0x0002) 
#define TIM_FLAG_CC2                      ((u16)0x0004) 
#define TIM_FLAG_CC3                      ((u16)0x0008) 
#define TIM_FLAG_CC4                      ((u16)0x0010) 
#define TIM_FLAG_Trigger                  ((u16)0x0040) 
#define TIM_FLAG_CC1OF                    ((u16)0x0200) 
#define TIM_FLAG_CC2OF                    ((u16)0x0400) 
#define TIM_FLAG_CC3OF                    ((u16)0x0800) 
#define TIM_FLAG_CC4OF                    ((u16)0x1000) 
 
#define IS_TIM_GET_FLAG(FLAG) ((FLAG == TIM_FLAG_Update) || \ 
                               (FLAG == TIM_FLAG_CC1) || \ 
                               (FLAG == TIM_FLAG_CC2) || \ 
                               (FLAG == TIM_FLAG_CC3) || \ 
                               (FLAG == TIM_FLAG_CC4) || \ 
                               (FLAG == TIM_FLAG_Trigger) || \ 
                               (FLAG == TIM_FLAG_CC1OF) || \ 
                               (FLAG == TIM_FLAG_CC2OF) || \ 
                               (FLAG == TIM_FLAG_CC3OF) || \ 
                               (FLAG == TIM_FLAG_CC4OF)) 
 
#define IS_TIM_CLEAR_FLAG(FLAG) (((FLAG & (u16)0xE1A0) == 0x0000) && (FLAG != 0x0000))  
                                  
 
 
/* Exported macro ------------------------------------------------------------*/ 
/* Exported functions --------------------------------------------------------*/ 
void TIM_DeInit(TIM_TypeDef* TIMx); 
void TIM_TimeBaseInit(TIM_TypeDef* TIMx, TIM_TimeBaseInitTypeDef* TIM_TimeBaseInitStruct); 
void TIM_OCInit(TIM_TypeDef* TIMx, TIM_OCInitTypeDef* TIM_OCInitStruct); 
void TIM_ICInit(TIM_TypeDef* TIMx, TIM_ICInitTypeDef* TIM_ICInitStruct); 
void TIM_TimeBaseStructInit(TIM_TimeBaseInitTypeDef* TIM_TimeBaseInitStruct); 
void TIM_OCStructInit(TIM_OCInitTypeDef* TIM_OCInitStruct); 
void TIM_ICStructInit(TIM_ICInitTypeDef* TIM_ICInitStruct); 
void TIM_Cmd(TIM_TypeDef* TIMx, FunctionalState NewState); 
void TIM_ITConfig(TIM_TypeDef* TIMx, u16 TIM_IT, FunctionalState NewState); 
void TIM_DMAConfig(TIM_TypeDef* TIMx, u16 TIM_DMABase, u16 TIM_DMABurstLength); 
void TIM_DMACmd(TIM_TypeDef* TIMx, u16 TIM_DMASource, FunctionalState Newstate); 
void TIM_InternalClockConfig(TIM_TypeDef* TIMx); 
void TIM_ITRxExternalClockConfig(TIM_TypeDef* TIMx, u16 TIM_InputTriggerSource); 
void TIM_TIxExternalClockConfig(TIM_TypeDef* TIMx, u16 TIM_TIxExternalCLKSource,  
                                u16 TIM_ICPolarity, u8 ICFilter); 
void TIM_ETRClockMode1Config(TIM_TypeDef* TIMx, u16 TIM_ExtTRGPrescaler, u16 TIM_ExtTRGPolarity,  
                             u8 ExtTRGFilter); 
void TIM_ETRClockMode2Config(TIM_TypeDef* TIMx, u16 TIM_ExtTRGPrescaler, u16 TIM_ExtTRGPolarity,  
                             u8 ExtTRGFilter); 
void TIM_ETRConfig(TIM_TypeDef* TIMx, u16 TIM_ExtTRGPrescaler, u16 TIM_ExtTRGPolarity, 
                   u8 ExtTRGFilter);							 					    
void TIM_SelectInputTrigger(TIM_TypeDef* TIMx, u16 TIM_InputTriggerSource); 
void TIM_PrescalerConfig(TIM_TypeDef* TIMx, u16 Prescaler, u16 TIM_PSCReloadMode); 
void TIM_CounterModeConfig(TIM_TypeDef* TIMx, u16 TIM_CounterMode); 
void TIM_ForcedOC1Config(TIM_TypeDef* TIMx, u16 TIM_ForcedAction); 
void TIM_ForcedOC2Config(TIM_TypeDef* TIMx, u16 TIM_ForcedAction); 
void TIM_ForcedOC3Config(TIM_TypeDef* TIMx, u16 TIM_ForcedAction); 
void TIM_ForcedOC4Config(TIM_TypeDef* TIMx, u16 TIM_ForcedAction); 
void TIM_ARRPreloadConfig(TIM_TypeDef* TIMx, FunctionalState Newstate); 
void TIM_SelectCCDMA(TIM_TypeDef* TIMx, FunctionalState Newstate); 
void TIM_OC1PreloadConfig(TIM_TypeDef* TIMx, u16 TIM_OCPreload); 
void TIM_OC2PreloadConfig(TIM_TypeDef* TIMx, u16 TIM_OCPreload); 
void TIM_OC3PreloadConfig(TIM_TypeDef* TIMx, u16 TIM_OCPreload); 
void TIM_OC4PreloadConfig(TIM_TypeDef* TIMx, u16 TIM_OCPreload); 
void TIM_OC1FastConfig(TIM_TypeDef* TIMx, u16 TIM_OCFast); 
void TIM_OC2FastConfig(TIM_TypeDef* TIMx, u16 TIM_OCFast); 
void TIM_OC3FastConfig(TIM_TypeDef* TIMx, u16 TIM_OCFast); 
void TIM_OC4FastConfig(TIM_TypeDef* TIMx, u16 TIM_OCFast); 
void TIM_ClearOC1Ref(TIM_TypeDef* TIMx, u16 TIM_OCClear); 
void TIM_ClearOC2Ref(TIM_TypeDef* TIMx, u16 TIM_OCClear); 
void TIM_ClearOC3Ref(TIM_TypeDef* TIMx, u16 TIM_OCClear); 
void TIM_ClearOC4Ref(TIM_TypeDef* TIMx, u16 TIM_OCClear); 
void TIM_UpdateDisableConfig(TIM_TypeDef* TIMx, FunctionalState Newstate); 
void TIM_EncoderInterfaceConfig(TIM_TypeDef* TIMx, u16 TIM_EncoderMode,  
                                u16 TIM_IC1Polarity, u16 TIM_IC2Polarity); 
void TIM_GenerateEvent(TIM_TypeDef* TIMx, u16 TIM_EventSource); 
void TIM_OC1PolarityConfig(TIM_TypeDef* TIMx, u16 TIM_OCPolarity); 
void TIM_OC2PolarityConfig(TIM_TypeDef* TIMx, u16 TIM_OCPolarity); 
void TIM_OC3PolarityConfig(TIM_TypeDef* TIMx, u16 TIM_OCPolarity); 
void TIM_OC4PolarityConfig(TIM_TypeDef* TIMx, u16 TIM_OCPolarity);   
void TIM_UpdateRequestConfig(TIM_TypeDef* TIMx, u16 TIM_UpdateSource); 
void TIM_SelectHallSensor(TIM_TypeDef* TIMx, FunctionalState Newstate); 
void TIM_SelectOnePulseMode(TIM_TypeDef* TIMx, u16 TIM_OPMode); 
void TIM_SelectOutputTrigger(TIM_TypeDef* TIMx, u16 TIM_TRGOSource); 
void TIM_SelectSlaveMode(TIM_TypeDef* TIMx, u16 TIM_SlaveMode); 
void TIM_SelectMasterSlaveMode(TIM_TypeDef* TIMx, u16 TIM_MasterSlaveMode); 
void TIM_SetCounter(TIM_TypeDef* TIMx, u16 Counter); 
void TIM_SetAutoreload(TIM_TypeDef* TIMx, u16 Autoreload); 
void TIM_SetCompare1(TIM_TypeDef* TIMx, u16 Compare1); 
void TIM_SetCompare2(TIM_TypeDef* TIMx, u16 Compare2); 
void TIM_SetCompare3(TIM_TypeDef* TIMx, u16 Compare3); 
void TIM_SetCompare4(TIM_TypeDef* TIMx, u16 Compare4); 
void TIM_SetIC1Prescaler(TIM_TypeDef* TIMx, u16 TIM_IC1Prescaler); 
void TIM_SetIC2Prescaler(TIM_TypeDef* TIMx, u16 TIM_IC2Prescaler); 
void TIM_SetIC3Prescaler(TIM_TypeDef* TIMx, u16 TIM_IC3Prescaler); 
void TIM_SetIC4Prescaler(TIM_TypeDef* TIMx, u16 TIM_IC4Prescaler); 
void TIM_SetClockDivision(TIM_TypeDef* TIMx, u16 TIM_CKD); 
u16 TIM_GetCapture1(TIM_TypeDef* TIMx); 
u16 TIM_GetCapture2(TIM_TypeDef* TIMx); 
u16 TIM_GetCapture3(TIM_TypeDef* TIMx); 
u16 TIM_GetCapture4(TIM_TypeDef* TIMx); 
u16 TIM_GetCounter(TIM_TypeDef* TIMx); 
u16 TIM_GetPrescaler(TIM_TypeDef* TIMx); 
FlagStatus TIM_GetFlagStatus(TIM_TypeDef* TIMx, u16 TIM_FLAG);  
void TIM_ClearFlag(TIM_TypeDef* TIMx, u16 TIM_FLAG); 
ITStatus TIM_GetITStatus(TIM_TypeDef* TIMx, u16 TIM_IT); 
void TIM_ClearITPendingBit(TIM_TypeDef* TIMx, u16 TIM_IT); 
 
#endif /*__STM32F10x_TIM_H */ 
 
/******************* (C) COPYRIGHT 2007 STMicroelectronics *****END OF FILE****/