/** ****************************************************************************** * @file stm8s_tim1.h * @author MCD Application Team * @version V2.3.0 * @date 16-June-2017 * @brief This file contains all functions prototype and macros for the TIM1 peripheral. ****************************************************************************** * @attention * *

© COPYRIGHT 2014 STMicroelectronics

* * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License"); * You may not use this file except in compliance with the License. * You may obtain a copy of the License at: * * http://www.st.com/software_license_agreement_liberty_v2 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * ****************************************************************************** */ /* Define to prevent recursive inclusion -------------------------------------*/ #ifndef __STM8S_TIM1_H #define __STM8S_TIM1_H /* Includes ------------------------------------------------------------------*/ #include "stm8s.h" /** @addtogroup STM8S_StdPeriph_Driver * @{ */ /** @addtogroup TIM1_Exported_Types * @{ */ /** TIM1 Output Compare and PWM modes */ typedef enum { TIM1_OCMODE_TIMING = ((uint8_t)0x00), TIM1_OCMODE_ACTIVE = ((uint8_t)0x10), TIM1_OCMODE_INACTIVE = ((uint8_t)0x20), TIM1_OCMODE_TOGGLE = ((uint8_t)0x30), TIM1_OCMODE_PWM1 = ((uint8_t)0x60), TIM1_OCMODE_PWM2 = ((uint8_t)0x70) }TIM1_OCMode_TypeDef; #define IS_TIM1_OC_MODE_OK(MODE) (((MODE) == TIM1_OCMODE_TIMING) || \ ((MODE) == TIM1_OCMODE_ACTIVE) || \ ((MODE) == TIM1_OCMODE_INACTIVE) || \ ((MODE) == TIM1_OCMODE_TOGGLE)|| \ ((MODE) == TIM1_OCMODE_PWM1) || \ ((MODE) == TIM1_OCMODE_PWM2)) #define IS_TIM1_OCM_OK(MODE)(((MODE) == TIM1_OCMODE_TIMING) || \ ((MODE) == TIM1_OCMODE_ACTIVE) || \ ((MODE) == TIM1_OCMODE_INACTIVE) || \ ((MODE) == TIM1_OCMODE_TOGGLE)|| \ ((MODE) == TIM1_OCMODE_PWM1) || \ ((MODE) == TIM1_OCMODE_PWM2) || \ ((MODE) == (uint8_t)TIM1_FORCEDACTION_ACTIVE) || \ ((MODE) == (uint8_t)TIM1_FORCEDACTION_INACTIVE)) /** TIM1 One Pulse Mode */ typedef enum { TIM1_OPMODE_SINGLE = ((uint8_t)0x01), TIM1_OPMODE_REPETITIVE = ((uint8_t)0x00) }TIM1_OPMode_TypeDef; #define IS_TIM1_OPM_MODE_OK(MODE) (((MODE) == TIM1_OPMODE_SINGLE) || \ ((MODE) == TIM1_OPMODE_REPETITIVE)) /** TIM1 Channel */ typedef enum { TIM1_CHANNEL_1 = ((uint8_t)0x00), TIM1_CHANNEL_2 = ((uint8_t)0x01), TIM1_CHANNEL_3 = ((uint8_t)0x02), TIM1_CHANNEL_4 = ((uint8_t)0x03) }TIM1_Channel_TypeDef; #define IS_TIM1_CHANNEL_OK(CHANNEL) (((CHANNEL) == TIM1_CHANNEL_1) || \ ((CHANNEL) == TIM1_CHANNEL_2) || \ ((CHANNEL) == TIM1_CHANNEL_3) || \ ((CHANNEL) == TIM1_CHANNEL_4)) #define IS_TIM1_PWMI_CHANNEL_OK(CHANNEL) (((CHANNEL) == TIM1_CHANNEL_1) || \ ((CHANNEL) == TIM1_CHANNEL_2)) #define IS_TIM1_COMPLEMENTARY_CHANNEL_OK(CHANNEL) (((CHANNEL) == TIM1_CHANNEL_1) || \ ((CHANNEL) == TIM1_CHANNEL_2) || \ ((CHANNEL) == TIM1_CHANNEL_3)) /** TIM1 Counter Mode */ typedef enum { TIM1_COUNTERMODE_UP = ((uint8_t)0x00), TIM1_COUNTERMODE_DOWN = ((uint8_t)0x10), TIM1_COUNTERMODE_CENTERALIGNED1 = ((uint8_t)0x20), TIM1_COUNTERMODE_CENTERALIGNED2 = ((uint8_t)0x40), TIM1_COUNTERMODE_CENTERALIGNED3 = ((uint8_t)0x60) }TIM1_CounterMode_TypeDef; #define IS_TIM1_COUNTER_MODE_OK(MODE) (((MODE) == TIM1_COUNTERMODE_UP) || \ ((MODE) == TIM1_COUNTERMODE_DOWN) || \ ((MODE) == TIM1_COUNTERMODE_CENTERALIGNED1) || \ ((MODE) == TIM1_COUNTERMODE_CENTERALIGNED2) || \ ((MODE) == TIM1_COUNTERMODE_CENTERALIGNED3)) /** TIM1 Output Compare Polarity */ typedef enum { TIM1_OCPOLARITY_HIGH = ((uint8_t)0x00), TIM1_OCPOLARITY_LOW = ((uint8_t)0x22) }TIM1_OCPolarity_TypeDef; #define IS_TIM1_OC_POLARITY_OK(POLARITY) (((POLARITY) == TIM1_OCPOLARITY_HIGH) || \ ((POLARITY) == TIM1_OCPOLARITY_LOW)) /** TIM1 Output Compare N Polarity */ typedef enum { TIM1_OCNPOLARITY_HIGH = ((uint8_t)0x00), TIM1_OCNPOLARITY_LOW = ((uint8_t)0x88) }TIM1_OCNPolarity_TypeDef; #define IS_TIM1_OCN_POLARITY_OK(POLARITY) (((POLARITY) == TIM1_OCNPOLARITY_HIGH) || \ ((POLARITY) == TIM1_OCNPOLARITY_LOW)) /** TIM1 Output Compare states */ typedef enum { TIM1_OUTPUTSTATE_DISABLE = ((uint8_t)0x00), TIM1_OUTPUTSTATE_ENABLE = ((uint8_t)0x11) }TIM1_OutputState_TypeDef; #define IS_TIM1_OUTPUT_STATE_OK(STATE) (((STATE) == TIM1_OUTPUTSTATE_DISABLE) || \ ((STATE) == TIM1_OUTPUTSTATE_ENABLE)) /** TIM1 Output Compare N States */ typedef enum { TIM1_OUTPUTNSTATE_DISABLE = ((uint8_t)0x00), TIM1_OUTPUTNSTATE_ENABLE = ((uint8_t)0x44) } TIM1_OutputNState_TypeDef; #define IS_TIM1_OUTPUTN_STATE_OK(STATE) (((STATE) == TIM1_OUTPUTNSTATE_DISABLE) ||\ ((STATE) == TIM1_OUTPUTNSTATE_ENABLE)) /** TIM1 Break Input enable/disable */ typedef enum { TIM1_BREAK_ENABLE = ((uint8_t)0x10), TIM1_BREAK_DISABLE = ((uint8_t)0x00) }TIM1_BreakState_TypeDef; #define IS_TIM1_BREAK_STATE_OK(STATE) (((STATE) == TIM1_BREAK_ENABLE) || \ ((STATE) == TIM1_BREAK_DISABLE)) /** TIM1 Break Polarity */ typedef enum { TIM1_BREAKPOLARITY_LOW = ((uint8_t)0x00), TIM1_BREAKPOLARITY_HIGH = ((uint8_t)0x20) }TIM1_BreakPolarity_TypeDef; #define IS_TIM1_BREAK_POLARITY_OK(POLARITY) (((POLARITY) == TIM1_BREAKPOLARITY_LOW) || \ ((POLARITY) == TIM1_BREAKPOLARITY_HIGH)) /** TIM1 AOE Bit Set/Reset */ typedef enum { TIM1_AUTOMATICOUTPUT_ENABLE = ((uint8_t)0x40), TIM1_AUTOMATICOUTPUT_DISABLE = ((uint8_t)0x00) }TIM1_AutomaticOutput_TypeDef; #define IS_TIM1_AUTOMATIC_OUTPUT_STATE_OK(STATE) (((STATE) == TIM1_AUTOMATICOUTPUT_ENABLE) || \ ((STATE) == TIM1_AUTOMATICOUTPUT_DISABLE)) /** TIM1 Lock levels */ typedef enum { TIM1_LOCKLEVEL_OFF = ((uint8_t)0x00), TIM1_LOCKLEVEL_1 = ((uint8_t)0x01), TIM1_LOCKLEVEL_2 = ((uint8_t)0x02), TIM1_LOCKLEVEL_3 = ((uint8_t)0x03) }TIM1_LockLevel_TypeDef; #define IS_TIM1_LOCK_LEVEL_OK(LEVEL) (((LEVEL) == TIM1_LOCKLEVEL_OFF) || \ ((LEVEL) == TIM1_LOCKLEVEL_1) || \ ((LEVEL) == TIM1_LOCKLEVEL_2) || \ ((LEVEL) == TIM1_LOCKLEVEL_3)) /** TIM1 OSSI: Off-State Selection for Idle mode states */ typedef enum { TIM1_OSSISTATE_ENABLE = ((uint8_t)0x04), TIM1_OSSISTATE_DISABLE = ((uint8_t)0x00) }TIM1_OSSIState_TypeDef; #define IS_TIM1_OSSI_STATE_OK(STATE) (((STATE) == TIM1_OSSISTATE_ENABLE) || \ ((STATE) == TIM1_OSSISTATE_DISABLE)) /** TIM1 Output Compare Idle State */ typedef enum { TIM1_OCIDLESTATE_SET = ((uint8_t)0x55), TIM1_OCIDLESTATE_RESET = ((uint8_t)0x00) }TIM1_OCIdleState_TypeDef; #define IS_TIM1_OCIDLE_STATE_OK(STATE) (((STATE) == TIM1_OCIDLESTATE_SET) || \ ((STATE) == TIM1_OCIDLESTATE_RESET)) /** TIM1 Output Compare N Idle State */ typedef enum { TIM1_OCNIDLESTATE_SET = ((uint8_t)0x2A), TIM1_OCNIDLESTATE_RESET = ((uint8_t)0x00) }TIM1_OCNIdleState_TypeDef; #define IS_TIM1_OCNIDLE_STATE_OK(STATE) (((STATE) == TIM1_OCNIDLESTATE_SET) || \ ((STATE) == TIM1_OCNIDLESTATE_RESET)) /** TIM1 Input Capture Polarity */ typedef enum { TIM1_ICPOLARITY_RISING = ((uint8_t)0x00), TIM1_ICPOLARITY_FALLING = ((uint8_t)0x01) }TIM1_ICPolarity_TypeDef; #define IS_TIM1_IC_POLARITY_OK(POLARITY) (((POLARITY) == TIM1_ICPOLARITY_RISING) || \ ((POLARITY) == TIM1_ICPOLARITY_FALLING)) /** TIM1 Input Capture Selection */ typedef enum { TIM1_ICSELECTION_DIRECTTI = ((uint8_t)0x01), TIM1_ICSELECTION_INDIRECTTI = ((uint8_t)0x02), TIM1_ICSELECTION_TRGI = ((uint8_t)0x03) }TIM1_ICSelection_TypeDef; #define IS_TIM1_IC_SELECTION_OK(SELECTION) (((SELECTION) == TIM1_ICSELECTION_DIRECTTI) || \ ((SELECTION) == TIM1_ICSELECTION_INDIRECTTI) || \ ((SELECTION) == TIM1_ICSELECTION_TRGI)) /** TIM1 Input Capture Prescaler */ typedef enum { TIM1_ICPSC_DIV1 = ((uint8_t)0x00), TIM1_ICPSC_DIV2 = ((uint8_t)0x04), TIM1_ICPSC_DIV4 = ((uint8_t)0x08), TIM1_ICPSC_DIV8 = ((uint8_t)0x0C) }TIM1_ICPSC_TypeDef; #define IS_TIM1_IC_PRESCALER_OK(PRESCALER) (((PRESCALER) == TIM1_ICPSC_DIV1) || \ ((PRESCALER) == TIM1_ICPSC_DIV2) || \ ((PRESCALER) == TIM1_ICPSC_DIV4) || \ ((PRESCALER) == TIM1_ICPSC_DIV8)) /** TIM1 Input Capture Filer Value */ #define IS_TIM1_IC_FILTER_OK(ICFILTER) ((ICFILTER) <= 0x0F) /** TIM1 External Trigger Filer Value */ #define IS_TIM1_EXT_TRG_FILTER_OK(FILTER) ((FILTER) <= 0x0F) /** TIM1 interrupt sources */ typedef enum { TIM1_IT_UPDATE = ((uint8_t)0x01), TIM1_IT_CC1 = ((uint8_t)0x02), TIM1_IT_CC2 = ((uint8_t)0x04), TIM1_IT_CC3 = ((uint8_t)0x08), TIM1_IT_CC4 = ((uint8_t)0x10), TIM1_IT_COM = ((uint8_t)0x20), TIM1_IT_TRIGGER = ((uint8_t)0x40), TIM1_IT_BREAK = ((uint8_t)0x80) }TIM1_IT_TypeDef; #define IS_TIM1_IT_OK(IT) ((IT) != 0x00) #define IS_TIM1_GET_IT_OK(IT) (((IT) == TIM1_IT_UPDATE) || \ ((IT) == TIM1_IT_CC1) || \ ((IT) == TIM1_IT_CC2) || \ ((IT) == TIM1_IT_CC3) || \ ((IT) == TIM1_IT_CC4) || \ ((IT) == TIM1_IT_COM) || \ ((IT) == TIM1_IT_TRIGGER) || \ ((IT) == TIM1_IT_BREAK)) /** TIM1 External Trigger Prescaler */ typedef enum { TIM1_EXTTRGPSC_OFF = ((uint8_t)0x00), TIM1_EXTTRGPSC_DIV2 = ((uint8_t)0x10), TIM1_EXTTRGPSC_DIV4 = ((uint8_t)0x20), TIM1_EXTTRGPSC_DIV8 = ((uint8_t)0x30) }TIM1_ExtTRGPSC_TypeDef; #define IS_TIM1_EXT_PRESCALER_OK(PRESCALER) (((PRESCALER) == TIM1_EXTTRGPSC_OFF) || \ ((PRESCALER) == TIM1_EXTTRGPSC_DIV2) || \ ((PRESCALER) == TIM1_EXTTRGPSC_DIV4) || \ ((PRESCALER) == TIM1_EXTTRGPSC_DIV8)) /** TIM1 Internal Trigger Selection */ typedef enum { TIM1_TS_TIM6 = ((uint8_t)0x00), /*!< TRIG Input source = TIM6 TRIG Output */ TIM1_TS_TIM5 = ((uint8_t)0x30), /*!< TRIG Input source = TIM5 TRIG Output */ TIM1_TS_TI1F_ED = ((uint8_t)0x40), TIM1_TS_TI1FP1 = ((uint8_t)0x50), TIM1_TS_TI2FP2 = ((uint8_t)0x60), TIM1_TS_ETRF = ((uint8_t)0x70) }TIM1_TS_TypeDef; #define IS_TIM1_TRIGGER_SELECTION_OK(SELECTION) (((SELECTION) == TIM1_TS_TI1F_ED) || \ ((SELECTION) == TIM1_TS_TI1FP1) || \ ((SELECTION) == TIM1_TS_TI2FP2) || \ ((SELECTION) == TIM1_TS_ETRF) || \ ((SELECTION) == TIM1_TS_TIM5) || \ ((SELECTION) == TIM1_TS_TIM6)) #define IS_TIM1_TIX_TRIGGER_SELECTION_OK(SELECTION) (((SELECTION) == TIM1_TS_TI1F_ED) || \ ((SELECTION) == TIM1_TS_TI1FP1) || \ ((SELECTION) == TIM1_TS_TI2FP2)) /** TIM1 TIx External Clock Source */ typedef enum { TIM1_TIXEXTERNALCLK1SOURCE_TI1ED = ((uint8_t)0x40), TIM1_TIXEXTERNALCLK1SOURCE_TI1 = ((uint8_t)0x50), TIM1_TIXEXTERNALCLK1SOURCE_TI2 = ((uint8_t)0x60) }TIM1_TIxExternalCLK1Source_TypeDef; #define IS_TIM1_TIXCLK_SOURCE_OK(SOURCE) (((SOURCE) == TIM1_TIXEXTERNALCLK1SOURCE_TI1ED) || \ ((SOURCE) == TIM1_TIXEXTERNALCLK1SOURCE_TI2) || \ ((SOURCE) == TIM1_TIXEXTERNALCLK1SOURCE_TI1)) /** TIM1 External Trigger Polarity */ typedef enum { TIM1_EXTTRGPOLARITY_INVERTED = ((uint8_t)0x80), TIM1_EXTTRGPOLARITY_NONINVERTED = ((uint8_t)0x00) }TIM1_ExtTRGPolarity_TypeDef; #define IS_TIM1_EXT_POLARITY_OK(POLARITY) (((POLARITY) == TIM1_EXTTRGPOLARITY_INVERTED) || \ ((POLARITY) == TIM1_EXTTRGPOLARITY_NONINVERTED)) /** TIM1 Prescaler Reload Mode */ typedef enum { TIM1_PSCRELOADMODE_UPDATE = ((uint8_t)0x00), TIM1_PSCRELOADMODE_IMMEDIATE = ((uint8_t)0x01) }TIM1_PSCReloadMode_TypeDef; #define IS_TIM1_PRESCALER_RELOAD_OK(RELOAD) (((RELOAD) == TIM1_PSCRELOADMODE_UPDATE) || \ ((RELOAD) == TIM1_PSCRELOADMODE_IMMEDIATE)) /** TIM1 Encoder Mode */ typedef enum { TIM1_ENCODERMODE_TI1 = ((uint8_t)0x01), TIM1_ENCODERMODE_TI2 = ((uint8_t)0x02), TIM1_ENCODERMODE_TI12 = ((uint8_t)0x03) }TIM1_EncoderMode_TypeDef; #define IS_TIM1_ENCODER_MODE_OK(MODE) (((MODE) == TIM1_ENCODERMODE_TI1) || \ ((MODE) == TIM1_ENCODERMODE_TI2) || \ ((MODE) == TIM1_ENCODERMODE_TI12)) /** TIM1 Event Source */ typedef enum { TIM1_EVENTSOURCE_UPDATE = ((uint8_t)0x01), TIM1_EVENTSOURCE_CC1 = ((uint8_t)0x02), TIM1_EVENTSOURCE_CC2 = ((uint8_t)0x04), TIM1_EVENTSOURCE_CC3 = ((uint8_t)0x08), TIM1_EVENTSOURCE_CC4 = ((uint8_t)0x10), TIM1_EVENTSOURCE_COM = ((uint8_t)0x20), TIM1_EVENTSOURCE_TRIGGER = ((uint8_t)0x40), TIM1_EVENTSOURCE_BREAK = ((uint8_t)0x80) }TIM1_EventSource_TypeDef; #define IS_TIM1_EVENT_SOURCE_OK(SOURCE) ((SOURCE) != 0x00) /** TIM1 Update Source */ typedef enum { TIM1_UPDATESOURCE_GLOBAL = ((uint8_t)0x00), TIM1_UPDATESOURCE_REGULAR = ((uint8_t)0x01) }TIM1_UpdateSource_TypeDef; #define IS_TIM1_UPDATE_SOURCE_OK(SOURCE) (((SOURCE) == TIM1_UPDATESOURCE_GLOBAL) || \ ((SOURCE) == TIM1_UPDATESOURCE_REGULAR)) /** TIM1 Trigger Output Source */ typedef enum { TIM1_TRGOSOURCE_RESET = ((uint8_t)0x00), TIM1_TRGOSOURCE_ENABLE = ((uint8_t)0x10), TIM1_TRGOSOURCE_UPDATE = ((uint8_t)0x20), TIM1_TRGOSource_OC1 = ((uint8_t)0x30), TIM1_TRGOSOURCE_OC1REF = ((uint8_t)0x40), TIM1_TRGOSOURCE_OC2REF = ((uint8_t)0x50), TIM1_TRGOSOURCE_OC3REF = ((uint8_t)0x60) }TIM1_TRGOSource_TypeDef; #define IS_TIM1_TRGO_SOURCE_OK(SOURCE) (((SOURCE) == TIM1_TRGOSOURCE_RESET) || \ ((SOURCE) == TIM1_TRGOSOURCE_ENABLE) || \ ((SOURCE) == TIM1_TRGOSOURCE_UPDATE) || \ ((SOURCE) == TIM1_TRGOSource_OC1) || \ ((SOURCE) == TIM1_TRGOSOURCE_OC1REF) || \ ((SOURCE) == TIM1_TRGOSOURCE_OC2REF) || \ ((SOURCE) == TIM1_TRGOSOURCE_OC3REF)) /** TIM1 Slave Mode */ typedef enum { TIM1_SLAVEMODE_RESET = ((uint8_t)0x04), TIM1_SLAVEMODE_GATED = ((uint8_t)0x05), TIM1_SLAVEMODE_TRIGGER = ((uint8_t)0x06), TIM1_SLAVEMODE_EXTERNAL1 = ((uint8_t)0x07) }TIM1_SlaveMode_TypeDef; #define IS_TIM1_SLAVE_MODE_OK(MODE) (((MODE) == TIM1_SLAVEMODE_RESET) || \ ((MODE) == TIM1_SLAVEMODE_GATED) || \ ((MODE) == TIM1_SLAVEMODE_TRIGGER) || \ ((MODE) == TIM1_SLAVEMODE_EXTERNAL1)) /** TIM1 Flags */ typedef enum { TIM1_FLAG_UPDATE = ((uint16_t)0x0001), TIM1_FLAG_CC1 = ((uint16_t)0x0002), TIM1_FLAG_CC2 = ((uint16_t)0x0004), TIM1_FLAG_CC3 = ((uint16_t)0x0008), TIM1_FLAG_CC4 = ((uint16_t)0x0010), TIM1_FLAG_COM = ((uint16_t)0x0020), TIM1_FLAG_TRIGGER = ((uint16_t)0x0040), TIM1_FLAG_BREAK = ((uint16_t)0x0080), TIM1_FLAG_CC1OF = ((uint16_t)0x0200), TIM1_FLAG_CC2OF = ((uint16_t)0x0400), TIM1_FLAG_CC3OF = ((uint16_t)0x0800), TIM1_FLAG_CC4OF = ((uint16_t)0x1000) }TIM1_FLAG_TypeDef; #define IS_TIM1_GET_FLAG_OK(FLAG) (((FLAG) == TIM1_FLAG_UPDATE) || \ ((FLAG) == TIM1_FLAG_CC1) || \ ((FLAG) == TIM1_FLAG_CC2) || \ ((FLAG) == TIM1_FLAG_CC3) || \ ((FLAG) == TIM1_FLAG_CC4) || \ ((FLAG) == TIM1_FLAG_COM) || \ ((FLAG) == TIM1_FLAG_TRIGGER) || \ ((FLAG) == TIM1_FLAG_BREAK) || \ ((FLAG) == TIM1_FLAG_CC1OF) || \ ((FLAG) == TIM1_FLAG_CC2OF) || \ ((FLAG) == TIM1_FLAG_CC3OF) || \ ((FLAG) == TIM1_FLAG_CC4OF)) #define IS_TIM1_CLEAR_FLAG_OK(FLAG) ((((uint16_t)(FLAG) & (uint16_t)0xE100) == 0x0000) && ((FLAG) != 0x0000)) /** TIM1 Forced Action */ typedef enum { TIM1_FORCEDACTION_ACTIVE = ((uint8_t)0x50), TIM1_FORCEDACTION_INACTIVE = ((uint8_t)0x40) }TIM1_ForcedAction_TypeDef; #define IS_TIM1_FORCED_ACTION_OK(ACTION) (((ACTION) == TIM1_FORCEDACTION_ACTIVE) || \ ((ACTION) == TIM1_FORCEDACTION_INACTIVE)) /** * @} */ /* Exported macro ------------------------------------------------------------*/ /* Exported functions --------------------------------------------------------*/ /** @addtogroup TIM1_Exported_Functions * @{ */ void TIM1_DeInit(void); void TIM1_TimeBaseInit(uint16_t TIM1_Prescaler, TIM1_CounterMode_TypeDef TIM1_CounterMode, uint16_t TIM1_Period, uint8_t TIM1_RepetitionCounter); void TIM1_OC1Init(TIM1_OCMode_TypeDef TIM1_OCMode, TIM1_OutputState_TypeDef TIM1_OutputState, TIM1_OutputNState_TypeDef TIM1_OutputNState, uint16_t TIM1_Pulse, TIM1_OCPolarity_TypeDef TIM1_OCPolarity, TIM1_OCNPolarity_TypeDef TIM1_OCNPolarity, TIM1_OCIdleState_TypeDef TIM1_OCIdleState, TIM1_OCNIdleState_TypeDef TIM1_OCNIdleState); void TIM1_OC2Init(TIM1_OCMode_TypeDef TIM1_OCMode, TIM1_OutputState_TypeDef TIM1_OutputState, TIM1_OutputNState_TypeDef TIM1_OutputNState, uint16_t TIM1_Pulse, TIM1_OCPolarity_TypeDef TIM1_OCPolarity, TIM1_OCNPolarity_TypeDef TIM1_OCNPolarity, TIM1_OCIdleState_TypeDef TIM1_OCIdleState, TIM1_OCNIdleState_TypeDef TIM1_OCNIdleState); void TIM1_OC3Init(TIM1_OCMode_TypeDef TIM1_OCMode, TIM1_OutputState_TypeDef TIM1_OutputState, TIM1_OutputNState_TypeDef TIM1_OutputNState, uint16_t TIM1_Pulse, TIM1_OCPolarity_TypeDef TIM1_OCPolarity, TIM1_OCNPolarity_TypeDef TIM1_OCNPolarity, TIM1_OCIdleState_TypeDef TIM1_OCIdleState, TIM1_OCNIdleState_TypeDef TIM1_OCNIdleState); void TIM1_OC4Init(TIM1_OCMode_TypeDef TIM1_OCMode, TIM1_OutputState_TypeDef TIM1_OutputState, uint16_t TIM1_Pulse, TIM1_OCPolarity_TypeDef TIM1_OCPolarity, TIM1_OCIdleState_TypeDef TIM1_OCIdleState); void TIM1_BDTRConfig(TIM1_OSSIState_TypeDef TIM1_OSSIState, TIM1_LockLevel_TypeDef TIM1_LockLevel, uint8_t TIM1_DeadTime, TIM1_BreakState_TypeDef TIM1_Break, TIM1_BreakPolarity_TypeDef TIM1_BreakPolarity, TIM1_AutomaticOutput_TypeDef TIM1_AutomaticOutput); void TIM1_ICInit(TIM1_Channel_TypeDef TIM1_Channel, TIM1_ICPolarity_TypeDef TIM1_ICPolarity, TIM1_ICSelection_TypeDef TIM1_ICSelection, TIM1_ICPSC_TypeDef TIM1_ICPrescaler, uint8_t TIM1_ICFilter); void TIM1_PWMIConfig(TIM1_Channel_TypeDef TIM1_Channel, TIM1_ICPolarity_TypeDef TIM1_ICPolarity, TIM1_ICSelection_TypeDef TIM1_ICSelection, TIM1_ICPSC_TypeDef TIM1_ICPrescaler, uint8_t TIM1_ICFilter); void TIM1_Cmd(FunctionalState NewState); void TIM1_CtrlPWMOutputs(FunctionalState NewState); void TIM1_ITConfig(TIM1_IT_TypeDef TIM1_IT, FunctionalState NewState); void TIM1_InternalClockConfig(void); void TIM1_ETRClockMode1Config(TIM1_ExtTRGPSC_TypeDef TIM1_ExtTRGPrescaler, TIM1_ExtTRGPolarity_TypeDef TIM1_ExtTRGPolarity, uint8_t ExtTRGFilter); void TIM1_ETRClockMode2Config(TIM1_ExtTRGPSC_TypeDef TIM1_ExtTRGPrescaler, TIM1_ExtTRGPolarity_TypeDef TIM1_ExtTRGPolarity, uint8_t ExtTRGFilter); void TIM1_ETRConfig(TIM1_ExtTRGPSC_TypeDef TIM1_ExtTRGPrescaler, TIM1_ExtTRGPolarity_TypeDef TIM1_ExtTRGPolarity, uint8_t ExtTRGFilter); void TIM1_TIxExternalClockConfig(TIM1_TIxExternalCLK1Source_TypeDef TIM1_TIxExternalCLKSource, TIM1_ICPolarity_TypeDef TIM1_ICPolarity, uint8_t ICFilter); void TIM1_SelectInputTrigger(TIM1_TS_TypeDef TIM1_InputTriggerSource); void TIM1_UpdateDisableConfig(FunctionalState NewState); void TIM1_UpdateRequestConfig(TIM1_UpdateSource_TypeDef TIM1_UpdateSource); void TIM1_SelectHallSensor(FunctionalState NewState); void TIM1_SelectOnePulseMode(TIM1_OPMode_TypeDef TIM1_OPMode); void TIM1_SelectOutputTrigger(TIM1_TRGOSource_TypeDef TIM1_TRGOSource); void TIM1_SelectSlaveMode(TIM1_SlaveMode_TypeDef TIM1_SlaveMode); void TIM1_SelectMasterSlaveMode(FunctionalState NewState); void TIM1_EncoderInterfaceConfig(TIM1_EncoderMode_TypeDef TIM1_EncoderMode, TIM1_ICPolarity_TypeDef TIM1_IC1Polarity, TIM1_ICPolarity_TypeDef TIM1_IC2Polarity); void TIM1_PrescalerConfig(uint16_t Prescaler, TIM1_PSCReloadMode_TypeDef TIM1_PSCReloadMode); void TIM1_CounterModeConfig(TIM1_CounterMode_TypeDef TIM1_CounterMode); void TIM1_ForcedOC1Config(TIM1_ForcedAction_TypeDef TIM1_ForcedAction); void TIM1_ForcedOC2Config(TIM1_ForcedAction_TypeDef TIM1_ForcedAction); void TIM1_ForcedOC3Config(TIM1_ForcedAction_TypeDef TIM1_ForcedAction); void TIM1_ForcedOC4Config(TIM1_ForcedAction_TypeDef TIM1_ForcedAction); void TIM1_ARRPreloadConfig(FunctionalState NewState); void TIM1_SelectCOM(FunctionalState NewState); void TIM1_CCPreloadControl(FunctionalState NewState); void TIM1_OC1PreloadConfig(FunctionalState NewState); void TIM1_OC2PreloadConfig(FunctionalState NewState); void TIM1_OC3PreloadConfig(FunctionalState NewState); void TIM1_OC4PreloadConfig(FunctionalState NewState); void TIM1_OC1FastConfig(FunctionalState NewState); void TIM1_OC2FastConfig(FunctionalState NewState); void TIM1_OC3FastConfig(FunctionalState NewState); void TIM1_OC4FastConfig(FunctionalState NewState); void TIM1_GenerateEvent(TIM1_EventSource_TypeDef TIM1_EventSource); void TIM1_OC1PolarityConfig(TIM1_OCPolarity_TypeDef TIM1_OCPolarity); void TIM1_OC1NPolarityConfig(TIM1_OCNPolarity_TypeDef TIM1_OCNPolarity); void TIM1_OC2PolarityConfig(TIM1_OCPolarity_TypeDef TIM1_OCPolarity); void TIM1_OC2NPolarityConfig(TIM1_OCNPolarity_TypeDef TIM1_OCNPolarity); void TIM1_OC3PolarityConfig(TIM1_OCPolarity_TypeDef TIM1_OCPolarity); void TIM1_OC3NPolarityConfig(TIM1_OCNPolarity_TypeDef TIM1_OCNPolarity); void TIM1_OC4PolarityConfig(TIM1_OCPolarity_TypeDef TIM1_OCPolarity); void TIM1_CCxCmd(TIM1_Channel_TypeDef TIM1_Channel, FunctionalState NewState); void TIM1_CCxNCmd(TIM1_Channel_TypeDef TIM1_Channel, FunctionalState NewState); void TIM1_SelectOCxM(TIM1_Channel_TypeDef TIM1_Channel, TIM1_OCMode_TypeDef TIM1_OCMode); void TIM1_SetCounter(uint16_t Counter); void TIM1_SetAutoreload(uint16_t Autoreload); void TIM1_SetCompare1(uint16_t Compare1); void TIM1_SetCompare2(uint16_t Compare2); void TIM1_SetCompare3(uint16_t Compare3); void TIM1_SetCompare4(uint16_t Compare4); void TIM1_SetIC1Prescaler(TIM1_ICPSC_TypeDef TIM1_IC1Prescaler); void TIM1_SetIC2Prescaler(TIM1_ICPSC_TypeDef TIM1_IC2Prescaler); void TIM1_SetIC3Prescaler(TIM1_ICPSC_TypeDef TIM1_IC3Prescaler); void TIM1_SetIC4Prescaler(TIM1_ICPSC_TypeDef TIM1_IC4Prescaler); uint16_t TIM1_GetCapture1(void); uint16_t TIM1_GetCapture2(void); uint16_t TIM1_GetCapture3(void); uint16_t TIM1_GetCapture4(void); uint16_t TIM1_GetCounter(void); uint16_t TIM1_GetPrescaler(void); FlagStatus TIM1_GetFlagStatus(TIM1_FLAG_TypeDef TIM1_FLAG); void TIM1_ClearFlag(TIM1_FLAG_TypeDef TIM1_FLAG); ITStatus TIM1_GetITStatus(TIM1_IT_TypeDef TIM1_IT); void TIM1_ClearITPendingBit(TIM1_IT_TypeDef TIM1_IT); /** * @} */ #endif /* __STM8S_TIM1_H */ /** * @} */ /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/