123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981 |
-
- typedef enum _ftm_chnl
- {
- kFTM_Chnl_0 = 0U,
- kFTM_Chnl_1,
- kFTM_Chnl_2,
- kFTM_Chnl_3,
- kFTM_Chnl_4,
- kFTM_Chnl_5,
- kFTM_Chnl_6,
- kFTM_Chnl_7
- } ftm_chnl_t;
- typedef enum _ftm_fault_input
- {
- kFTM_Fault_0 = 0U,
- kFTM_Fault_1,
- kFTM_Fault_2,
- kFTM_Fault_3
- } ftm_fault_input_t;
- typedef enum _ftm_pwm_mode
- {
- kFTM_EdgeAlignedPwm = 0U,
- kFTM_CenterAlignedPwm,
- kFTM_CombinedPwm
- } ftm_pwm_mode_t;
- typedef enum _ftm_pwm_level_select
- {
- kFTM_NoPwmSignal = 0U,
- kFTM_LowTrue,
- kFTM_HighTrue
- } ftm_pwm_level_select_t;
- typedef struct _ftm_chnl_pwm_signal_param
- {
- ftm_chnl_t chnlNumber;
- ftm_pwm_level_select_t level;
- uint8_t dutyCyclePercent;
- uint8_t firstEdgeDelayPercent;
- } ftm_chnl_pwm_signal_param_t;
- typedef enum _ftm_output_compare_mode
- {
- kFTM_NoOutputSignal = (1U << FTM_CnSC_MSA_SHIFT),
- kFTM_ToggleOnMatch = ((1U << FTM_CnSC_MSA_SHIFT) | (1U << FTM_CnSC_ELSA_SHIFT)),
- kFTM_ClearOnMatch = ((1U << FTM_CnSC_MSA_SHIFT) | (2U << FTM_CnSC_ELSA_SHIFT)),
- kFTM_SetOnMatch = ((1U << FTM_CnSC_MSA_SHIFT) | (3U << FTM_CnSC_ELSA_SHIFT))
- } ftm_output_compare_mode_t;
- typedef enum _ftm_input_capture_edge
- {
- kFTM_RisingEdge = (1U << FTM_CnSC_ELSA_SHIFT),
- kFTM_FallingEdge = (2U << FTM_CnSC_ELSA_SHIFT),
- kFTM_RiseAndFallEdge = (3U << FTM_CnSC_ELSA_SHIFT)
- } ftm_input_capture_edge_t;
- typedef enum _ftm_dual_edge_capture_mode
- {
- kFTM_OneShot = 0U,
- kFTM_Continuous = (1U << FTM_CnSC_MSA_SHIFT)
- } ftm_dual_edge_capture_mode_t;
- typedef struct _ftm_dual_edge_capture_param
- {
- ftm_dual_edge_capture_mode_t mode;
- ftm_input_capture_edge_t currChanEdgeMode;
- ftm_input_capture_edge_t nextChanEdgeMode;
- } ftm_dual_edge_capture_param_t;
- typedef enum _ftm_quad_decode_mode
- {
- kFTM_QuadPhaseEncode = 0U,
- kFTM_QuadCountAndDir
- } ftm_quad_decode_mode_t;
- typedef enum _ftm_phase_polarity
- {
- kFTM_QuadPhaseNormal = 0U,
- kFTM_QuadPhaseInvert
- } ftm_phase_polarity_t;
- typedef struct _ftm_phase_param
- {
- bool enablePhaseFilter;
- uint32_t phaseFilterVal;
- ftm_phase_polarity_t phasePolarity;
- } ftm_phase_params_t;
- typedef struct _ftm_fault_param
- {
- bool enableFaultInput;
- bool faultLevel;
- bool useFaultFilter;
- } ftm_fault_param_t;
- typedef enum _ftm_deadtime_prescale
- {
- kFTM_Deadtime_Prescale_1 = 1U,
- kFTM_Deadtime_Prescale_4,
- kFTM_Deadtime_Prescale_16
- } ftm_deadtime_prescale_t;
- typedef enum _ftm_clock_source
- {
- kFTM_SystemClock = 1U,
- kFTM_FixedClock,
- kFTM_ExternalClock
- } ftm_clock_source_t;
- typedef enum _ftm_clock_prescale
- {
- kFTM_Prescale_Divide_1 = 0U,
- kFTM_Prescale_Divide_2,
- kFTM_Prescale_Divide_4,
- kFTM_Prescale_Divide_8,
- kFTM_Prescale_Divide_16,
- kFTM_Prescale_Divide_32,
- kFTM_Prescale_Divide_64,
- kFTM_Prescale_Divide_128
- } ftm_clock_prescale_t;
- typedef enum _ftm_bdm_mode
- {
- kFTM_BdmMode_0 = 0U,
-
- kFTM_BdmMode_1,
-
- kFTM_BdmMode_2,
-
- kFTM_BdmMode_3
-
- } ftm_bdm_mode_t;
- typedef enum _ftm_fault_mode
- {
- kFTM_Fault_Disable = 0U,
- kFTM_Fault_EvenChnls,
- kFTM_Fault_AllChnlsMan,
- kFTM_Fault_AllChnlsAuto
- } ftm_fault_mode_t;
- typedef enum _ftm_external_trigger
- {
- kFTM_Chnl0Trigger = (1U << 4),
- kFTM_Chnl1Trigger = (1U << 5),
- kFTM_Chnl2Trigger = (1U << 0),
- kFTM_Chnl3Trigger = (1U << 1),
- kFTM_Chnl4Trigger = (1U << 2),
- kFTM_Chnl5Trigger = (1U << 3),
- kFTM_Chnl6Trigger =
- (1U << 8),
- kFTM_Chnl7Trigger =
- (1U << 9),
- kFTM_InitTrigger = (1U << 6),
- kFTM_ReloadInitTrigger = (1U << 7)
- } ftm_external_trigger_t;
- typedef enum _ftm_pwm_sync_method
- {
- kFTM_SoftwareTrigger = FTM_SYNC_SWSYNC_MASK,
- kFTM_HardwareTrigger_0 = FTM_SYNC_TRIG0_MASK,
- kFTM_HardwareTrigger_1 = FTM_SYNC_TRIG1_MASK,
- kFTM_HardwareTrigger_2 = FTM_SYNC_TRIG2_MASK
- } ftm_pwm_sync_method_t;
- typedef enum _ftm_reload_point
- {
- kFTM_Chnl0Match = (1U << 0),
- kFTM_Chnl1Match = (1U << 1),
- kFTM_Chnl2Match = (1U << 2),
- kFTM_Chnl3Match = (1U << 3),
- kFTM_Chnl4Match = (1U << 4),
- kFTM_Chnl5Match = (1U << 5),
- kFTM_Chnl6Match = (1U << 6),
- kFTM_Chnl7Match = (1U << 7),
- kFTM_CntMax = (1U << 8),
- kFTM_CntMin = (1U << 9),
- kFTM_HalfCycMatch = (1U << 10)
- } ftm_reload_point_t;
- typedef enum _ftm_interrupt_enable
- {
- kFTM_Chnl0InterruptEnable = (1U << 0),
- kFTM_Chnl1InterruptEnable = (1U << 1),
- kFTM_Chnl2InterruptEnable = (1U << 2),
- kFTM_Chnl3InterruptEnable = (1U << 3),
- kFTM_Chnl4InterruptEnable = (1U << 4),
- kFTM_Chnl5InterruptEnable = (1U << 5),
- kFTM_Chnl6InterruptEnable = (1U << 6),
- kFTM_Chnl7InterruptEnable = (1U << 7),
- kFTM_FaultInterruptEnable = (1U << 8),
- kFTM_TimeOverflowInterruptEnable = (1U << 9),
- kFTM_ReloadInterruptEnable = (1U << 10)
- } ftm_interrupt_enable_t;
- typedef enum _ftm_status_flags
- {
- kFTM_Chnl0Flag = (1U << 0),
- kFTM_Chnl1Flag = (1U << 1),
- kFTM_Chnl2Flag = (1U << 2),
- kFTM_Chnl3Flag = (1U << 3),
- kFTM_Chnl4Flag = (1U << 4),
- kFTM_Chnl5Flag = (1U << 5),
- kFTM_Chnl6Flag = (1U << 6),
- kFTM_Chnl7Flag = (1U << 7),
- kFTM_FaultFlag = (1U << 8),
- kFTM_TimeOverflowFlag = (1U << 9),
- kFTM_ChnlTriggerFlag = (1U << 10),
- kFTM_ReloadFlag = (1U << 11)
- } ftm_status_flags_t;
- enum _ftm_quad_decoder_flags
- {
- kFTM_QuadDecoderCountingIncreaseFlag = FTM_QDCTRL_QUADIR_MASK,
- kFTM_QuadDecoderCountingOverflowOnTopFlag = FTM_QDCTRL_TOFDIR_MASK,
- };
- typedef struct _ftm_config
- {
- ftm_clock_prescale_t prescale;
- ftm_bdm_mode_t bdmMode;
- uint32_t pwmSyncMode;
- uint32_t reloadPoints;
- ftm_fault_mode_t faultMode;
- uint8_t faultFilterValue;
- ftm_deadtime_prescale_t deadTimePrescale;
- uint32_t deadTimeValue;
- uint32_t extTriggers;
- uint8_t chnlInitState;
- uint8_t chnlPolarity;
- bool useGlobalTimeBase;
- } ftm_config_t;
- extern "C" {
- status_t FTM_Init(FTM_Type *base, const ftm_config_t *config);
- void FTM_Deinit(FTM_Type *base);
- void FTM_GetDefaultConfig(ftm_config_t *config);
- status_t FTM_SetupPwm(FTM_Type *base,
- const ftm_chnl_pwm_signal_param_t *chnlParams,
- uint8_t numOfChnls,
- ftm_pwm_mode_t mode,
- uint32_t pwmFreq_Hz,
- uint32_t srcClock_Hz);
- void FTM_UpdatePwmDutycycle(FTM_Type *base,
- ftm_chnl_t chnlNumber,
- ftm_pwm_mode_t currentPwmMode,
- uint8_t dutyCyclePercent);
- void FTM_UpdateChnlEdgeLevelSelect(FTM_Type *base, ftm_chnl_t chnlNumber, uint8_t level);
- void FTM_SetupInputCapture(FTM_Type *base,
- ftm_chnl_t chnlNumber,
- ftm_input_capture_edge_t captureMode,
- uint32_t filterValue);
- void FTM_SetupOutputCompare(FTM_Type *base,
- ftm_chnl_t chnlNumber,
- ftm_output_compare_mode_t compareMode,
- uint32_t compareValue);
- void FTM_SetupDualEdgeCapture(FTM_Type *base,
- ftm_chnl_t chnlPairNumber,
- const ftm_dual_edge_capture_param_t *edgeParam,
- uint32_t filterValue);
- void FTM_SetupFault(FTM_Type *base, ftm_fault_input_t faultNumber, const ftm_fault_param_t *faultParams);
- void FTM_EnableInterrupts(FTM_Type *base, uint32_t mask);
- void FTM_DisableInterrupts(FTM_Type *base, uint32_t mask);
- uint32_t FTM_GetEnabledInterrupts(FTM_Type *base);
- uint32_t FTM_GetStatusFlags(FTM_Type *base);
- void FTM_ClearStatusFlags(FTM_Type *base, uint32_t mask);
- static inline void FTM_SetTimerPeriod(FTM_Type *base, uint32_t ticks)
- {
- base->MOD = ticks;
- }
- static inline uint32_t FTM_GetCurrentTimerCount(FTM_Type *base)
- {
- return (uint32_t)((base->CNT & FTM_CNT_COUNT_MASK) >> FTM_CNT_COUNT_SHIFT);
- }
- static inline void FTM_StartTimer(FTM_Type *base, ftm_clock_source_t clockSource)
- {
- uint32_t reg = base->SC;
- reg &= ~(FTM_SC_CLKS_MASK);
- reg |= FTM_SC_CLKS(clockSource);
- base->SC = reg;
- }
- static inline void FTM_StopTimer(FTM_Type *base)
- {
-
- base->SC &= ~(FTM_SC_CLKS_MASK);
- }
- static inline void FTM_SetSoftwareCtrlEnable(FTM_Type *base, ftm_chnl_t chnlNumber, bool value)
- {
- if (value)
- {
- base->SWOCTRL |= (1U << chnlNumber);
- }
- else
- {
- base->SWOCTRL &= ~(1U << chnlNumber);
- }
- }
- static inline void FTM_SetSoftwareCtrlVal(FTM_Type *base, ftm_chnl_t chnlNumber, bool value)
- {
- if (value)
- {
- base->SWOCTRL |= (1U << (chnlNumber + FTM_SWOCTRL_CH0OCV_SHIFT));
- }
- else
- {
- base->SWOCTRL &= ~(1U << (chnlNumber + FTM_SWOCTRL_CH0OCV_SHIFT));
- }
- }
- static inline void FTM_SetGlobalTimeBaseOutputEnable(FTM_Type *base, bool enable)
- {
- if (enable)
- {
- base->CONF |= FTM_CONF_GTBEOUT_MASK;
- }
- else
- {
- base->CONF &= ~FTM_CONF_GTBEOUT_MASK;
- }
- }
- static inline void FTM_SetOutputMask(FTM_Type *base, ftm_chnl_t chnlNumber, bool mask)
- {
- if (mask)
- {
- base->OUTMASK |= (1U << chnlNumber);
- }
- else
- {
- base->OUTMASK &= ~(1U << chnlNumber);
- }
- }
- static inline void FTM_SetPwmOutputEnable(FTM_Type *base, ftm_chnl_t chnlNumber, bool value)
- {
- if (value)
- {
- base->SC |= (1U << (chnlNumber + FTM_SC_PWMEN0_SHIFT));
- }
- else
- {
- base->SC &= ~(1U << (chnlNumber + FTM_SC_PWMEN0_SHIFT));
- }
- }
- static inline void FTM_SetFaultControlEnable(FTM_Type *base, ftm_chnl_t chnlPairNumber, bool value)
- {
- if (value)
- {
- base->COMBINE |= (1U << (FTM_COMBINE_FAULTEN0_SHIFT + (FTM_COMBINE_COMBINE1_SHIFT * chnlPairNumber)));
- }
- else
- {
- base->COMBINE &= ~(1U << (FTM_COMBINE_FAULTEN0_SHIFT + (FTM_COMBINE_COMBINE1_SHIFT * chnlPairNumber)));
- }
- }
- static inline void FTM_SetDeadTimeEnable(FTM_Type *base, ftm_chnl_t chnlPairNumber, bool value)
- {
- if (value)
- {
- base->COMBINE |= (1U << (FTM_COMBINE_DTEN0_SHIFT + (FTM_COMBINE_COMBINE1_SHIFT * chnlPairNumber)));
- }
- else
- {
- base->COMBINE &= ~(1U << (FTM_COMBINE_DTEN0_SHIFT + (FTM_COMBINE_COMBINE1_SHIFT * chnlPairNumber)));
- }
- }
- static inline void FTM_SetComplementaryEnable(FTM_Type *base, ftm_chnl_t chnlPairNumber, bool value)
- {
- if (value)
- {
- base->COMBINE |= (1U << (FTM_COMBINE_COMP0_SHIFT + (FTM_COMBINE_COMBINE1_SHIFT * chnlPairNumber)));
- }
- else
- {
- base->COMBINE &= ~(1U << (FTM_COMBINE_COMP0_SHIFT + (FTM_COMBINE_COMBINE1_SHIFT * chnlPairNumber)));
- }
- }
- static inline void FTM_SetInvertEnable(FTM_Type *base, ftm_chnl_t chnlPairNumber, bool value)
- {
- if (value)
- {
- base->INVCTRL |= (1U << chnlPairNumber);
- }
- else
- {
- base->INVCTRL &= ~(1U << chnlPairNumber);
- }
- }
- void FTM_SetupQuadDecode(FTM_Type *base,
- const ftm_phase_params_t *phaseAParams,
- const ftm_phase_params_t *phaseBParams,
- ftm_quad_decode_mode_t quadMode);
- static inline uint32_t FTM_GetQuadDecoderFlags(FTM_Type *base)
- {
- return base->QDCTRL & (FTM_QDCTRL_QUADIR_MASK | FTM_QDCTRL_TOFDIR_MASK);
- }
- static inline void FTM_SetQuadDecoderModuloValue(FTM_Type *base, uint32_t startValue, uint32_t overValue)
- {
- base->CNTIN = startValue;
- base->MOD = overValue;
- }
- static inline uint32_t FTM_GetQuadDecoderCounterValue(FTM_Type *base)
- {
- return base->CNT;
- }
- static inline void FTM_ClearQuadDecoderCounterValue(FTM_Type *base)
- {
- base->CNT = base->CNTIN;
- }
- static inline void FTM_SetSoftwareTrigger(FTM_Type *base, bool enable)
- {
- if (enable)
- {
- base->SYNC |= FTM_SYNC_SWSYNC_MASK;
- }
- else
- {
- base->SYNC &= ~FTM_SYNC_SWSYNC_MASK;
- }
- }
- static inline void FTM_SetWriteProtection(FTM_Type *base, bool enable)
- {
-
- if (enable)
- {
- base->FMS |= FTM_FMS_WPEN_MASK;
- }
- else
- {
- base->MODE |= FTM_MODE_WPDIS_MASK;
- }
- }
- }
|