YouSuanZhi/Core/Src/TIM.c

183 lines
4.9 KiB
C
Raw Permalink Normal View History

2025-12-30 07:21:11 +00:00
#include "stdbool.h"
#include "stm32f10x.h"
#include "cmsis_os.h"
2026-03-17 02:35:31 +00:00
2025-12-30 07:21:11 +00:00
/******************************** <20><><EFBFBD><EFBFBD>˵<EFBFBD><CBB5> *************************************
2026-03-17 02:35:31 +00:00
* TIM5->CH3 <EFBFBD><EFBFBD><EFBFBD><EFBFBD>
2025-12-30 07:21:11 +00:00
*******************************************************************************/
2026-03-17 02:35:31 +00:00
void TIM5_CH3_CTRL(uint16_t ARRValue, uint16_t CCRValue )
2025-12-30 07:21:11 +00:00
{
2026-03-17 02:35:31 +00:00
TIM5->ARR = ARRValue; // <09><><EFBFBD><EFBFBD>Ԥװ<D4A4><D7B0>
TIM5->CCR3 = CCRValue; // <09><><EFBFBD>÷<EFBFBD>תֵ
2025-12-30 07:21:11 +00:00
}
/******************************** <20><><EFBFBD><EFBFBD>˵<EFBFBD><CBB5> *************************************
2026-03-17 02:35:31 +00:00
* TIM5->CH3 PWM<EFBFBD><EFBFBD><EFBFBD><EFBFBD>
2025-12-30 07:21:11 +00:00
*******************************************************************************/
2026-03-17 02:35:31 +00:00
void TIM5_CH3_CMD( _Bool CMD )
2025-12-30 07:21:11 +00:00
{
if( CMD )
{
2026-03-17 02:35:31 +00:00
SET_BIT( TIM5->CR1,TIM_CR1_CEN );
SET_BIT( TIM5->CCER,TIM_CCER_CC3E );
2025-12-30 07:21:11 +00:00
}
else
{
2026-03-17 02:35:31 +00:00
CLEAR_BIT( TIM5->CCER,TIM_CCER_CC3E );
CLEAR_BIT( TIM5->CR1,TIM_CR1_CEN );
}
}
/******************************** <20><><EFBFBD><EFBFBD>˵<EFBFBD><CBB5> *************************************
* DIR
*******************************************************************************/
/******************************** <20><><EFBFBD><EFBFBD>˵<EFBFBD><CBB5> *************************************
*
*******************************************************************************/
void TIM5_IECMD( _Bool CMD )
{
if( CMD )
{
SET_BIT(TIM5->DIER, TIM_DIER_CC3IE); // ʹ<><CAB9><EFBFBD>ж<EFBFBD>
CLEAR_BIT( TIM5->SR, TIM_SR_UIF | TIM_SR_CC3IF ); // <09><><EFBFBD><EFBFBD><EFBFBD>жϱ<D0B6><CFB1><EFBFBD>
}
else
{
CLEAR_BIT(TIM5->DIER,TIM_DIER_CC3IE); // ʧ<><CAA7><EFBFBD>ж<EFBFBD>
CLEAR_BIT( TIM5->SR, TIM_SR_UIF | TIM_SR_CC3IF ); // <09><><EFBFBD><EFBFBD><EFBFBD>жϱ<D0B6><CFB1><EFBFBD>
}
}
/******************************** <20><><EFBFBD><EFBFBD>˵<EFBFBD><CBB5> *************************************
* TIM3->CH1 <EFBFBD><EFBFBD><EFBFBD><EFBFBD>
*******************************************************************************/
void TIM3_CH1_CTRL(uint16_t ARRValue, uint16_t CCRValue )
{
TIM3->ARR = ARRValue; // <09><><EFBFBD><EFBFBD>Ԥװ<D4A4><D7B0>
TIM3->CCR1 = CCRValue; // <09><><EFBFBD>÷<EFBFBD>תֵ
}
/******************************** <20><><EFBFBD><EFBFBD>˵<EFBFBD><CBB5> *************************************
* TIM3->CH1 PWM<EFBFBD><EFBFBD><EFBFBD><EFBFBD>
*******************************************************************************/
void TIM3_CH1_CMD( _Bool CMD )
{
if( CMD )
{
SET_BIT( TIM3->CR1,TIM_CR1_CEN );
SET_BIT( TIM3->CCER,TIM_CCER_CC1E );
}
else
{
CLEAR_BIT( TIM3->CCER,TIM_CCER_CC1E );
CLEAR_BIT( TIM3->CR1, TIM_CR1_CEN );
2025-12-30 07:21:11 +00:00
}
}
/******************************** <20><><EFBFBD><EFBFBD>˵<EFBFBD><CBB5> *************************************
* DIR
*******************************************************************************/
//void TIM4_CH1_DIR( _Bool CMD )
//{
// if( CMD )
// {
// GPIO_SetBits( GPIOD, GPIO_ODR_ODR13 );
// }
// else
// {
// GPIO_ResetBits( GPIOD, GPIO_ODR_ODR13 );
// }
//}
/******************************** <20><><EFBFBD><EFBFBD>˵<EFBFBD><CBB5> *************************************
*
*******************************************************************************/
2026-03-17 02:35:31 +00:00
void TIM3_IECMD( _Bool CMD )
2025-12-30 07:21:11 +00:00
{
if( CMD )
{
2026-03-17 02:35:31 +00:00
SET_BIT(TIM3->DIER, TIM_DIER_CC1IE); // ʹ<><CAB9><EFBFBD>ж<EFBFBD>
CLEAR_BIT( TIM3->SR, TIM_SR_UIF | TIM_SR_CC1IF ); // <09><><EFBFBD><EFBFBD><EFBFBD>жϱ<D0B6><CFB1><EFBFBD>
2025-12-30 07:21:11 +00:00
}
else
{
2026-03-17 02:35:31 +00:00
CLEAR_BIT(TIM3->DIER,TIM_DIER_CC1IE); // ʧ<><CAA7><EFBFBD>ж<EFBFBD>
CLEAR_BIT( TIM3->SR, TIM_SR_UIF | TIM_SR_CC1IF ); // <09><><EFBFBD><EFBFBD><EFBFBD>жϱ<D0B6><CFB1><EFBFBD>
2025-12-30 07:21:11 +00:00
}
}
/******************************** <20><><EFBFBD><EFBFBD>˵<EFBFBD><CBB5> *************************************
2026-03-17 02:35:31 +00:00
* TIM2->CH2 <EFBFBD><EFBFBD><EFBFBD><EFBFBD>
2025-12-30 07:21:11 +00:00
*******************************************************************************/
2026-03-17 02:35:31 +00:00
void TIM2_CH2_CTRL(uint16_t ARRValue, uint16_t CCRValue )
2025-12-30 07:21:11 +00:00
{
2026-03-17 02:35:31 +00:00
TIM2->ARR = ARRValue; // <09><><EFBFBD><EFBFBD>Ԥװ<D4A4><D7B0>
TIM2->CCR2 = CCRValue; // <09><><EFBFBD>÷<EFBFBD>תֵ
2025-12-30 07:21:11 +00:00
}
/******************************** <20><><EFBFBD><EFBFBD>˵<EFBFBD><CBB5> *************************************
2026-03-17 02:35:31 +00:00
* TIM2->CH2 PWM<EFBFBD><EFBFBD><EFBFBD><EFBFBD>
2025-12-30 07:21:11 +00:00
*******************************************************************************/
2026-03-17 02:35:31 +00:00
void TIM2_CH2_CMD( _Bool CMD )
2025-12-30 07:21:11 +00:00
{
if( CMD )
{
2026-03-17 02:35:31 +00:00
SET_BIT( TIM2->CR1,TIM_CR1_CEN );
SET_BIT( TIM2->CCER,TIM_CCER_CC2E );
2025-12-30 07:21:11 +00:00
}
else
{
2026-03-17 02:35:31 +00:00
CLEAR_BIT( TIM2->CCER,TIM_CCER_CC2E );
CLEAR_BIT( TIM2->CR1, TIM_CR1_CEN );
2025-12-30 07:21:11 +00:00
}
}
/******************************** <20><><EFBFBD><EFBFBD>˵<EFBFBD><CBB5> *************************************
* DIR
*******************************************************************************/
//void TIM4_CH1_DIR( _Bool CMD )
//{
// if( CMD )
// {
// GPIO_SetBits( GPIOD, GPIO_ODR_ODR13 );
// }
// else
// {
// GPIO_ResetBits( GPIOD, GPIO_ODR_ODR13 );
// }
//}
/******************************** <20><><EFBFBD><EFBFBD>˵<EFBFBD><CBB5> *************************************
*
*******************************************************************************/
2026-03-17 02:35:31 +00:00
void TIM2_IECMD( _Bool CMD )
2025-12-30 07:21:11 +00:00
{
if( CMD )
{
2026-03-17 02:35:31 +00:00
SET_BIT(TIM2->DIER, TIM_DIER_CC2IE); // ʹ<><CAB9><EFBFBD>ж<EFBFBD>
CLEAR_BIT( TIM2->SR, TIM_SR_UIF | TIM_SR_CC2IF ); // <09><><EFBFBD><EFBFBD><EFBFBD>жϱ<D0B6><CFB1><EFBFBD>
2025-12-30 07:21:11 +00:00
}
else
{
2026-03-17 02:35:31 +00:00
CLEAR_BIT(TIM2->DIER,TIM_DIER_CC2IE); // ʧ<><CAA7><EFBFBD>ж<EFBFBD>
CLEAR_BIT( TIM2->SR, TIM_SR_UIF | TIM_SR_CC2IF ); // <09><><EFBFBD><EFBFBD><EFBFBD>жϱ<D0B6><CFB1><EFBFBD>
2025-12-30 07:21:11 +00:00
}
}