Files
CH32V208WBU6/DRV/drv_tim.c
T
2023-06-20 23:41:10 +08:00

173 lines
5.3 KiB
C

/*
* dvr_tim.c
*
* Created on: Mar 31, 2023
* Author: gxms0
*/
#include "drv_tim.h"
#include "Global.h"
void tim_init(void)
{
TIM_PWM_Init();
}
void TIM_PWM_Init()
{
TIM_PWM_Timer2();
TIM_PWM_Timer3();
TIM_PWM_Timer4();
}
void TIM_PWM_Timer2()
{
GPIO_InitTypeDef GPIO_InitStructure={0};
TIM_OCInitTypeDef TIM_OCInitStructure={0};
TIM_TimeBaseInitTypeDef TIM_TimeBaseInitStructure={0};
RCC_APB2PeriphClockCmd( RCC_APB2Periph_GPIOA, ENABLE );
RCC_APB1PeriphClockCmd( RCC_APB1Periph_TIM2, ENABLE );
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0 | GPIO_Pin_1 | GPIO_Pin_2 | GPIO_Pin_3;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init( GPIOA, &GPIO_InitStructure );
TIM_TimeBaseInitStructure.TIM_Prescaler = SystemCoreClock/1000000 - 1;//1M
TIM_TimeBaseInitStructure.TIM_Period = 1000000 / TIM2_FRQ - 1;//50hz
TIM_TimeBaseInitStructure.TIM_ClockDivision = TIM_CKD_DIV1;
TIM_TimeBaseInitStructure.TIM_CounterMode = TIM_CounterMode_Up;
TIM_TimeBaseInit( TIM2, &TIM_TimeBaseInitStructure);
TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM1;
TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;
TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_High;
TIM_OCInitStructure.TIM_Pulse = PWM_CH3;
TIM_OC1Init( TIM2, &TIM_OCInitStructure );
TIM_OCInitStructure.TIM_Pulse = PWM_CH4;
TIM_OC2Init( TIM2, &TIM_OCInitStructure );
TIM_OCInitStructure.TIM_Pulse = PWM_CH5;
TIM_OC3Init( TIM2, &TIM_OCInitStructure );
TIM_OCInitStructure.TIM_Pulse = PWM_CH6;
TIM_OC4Init( TIM2, &TIM_OCInitStructure );
TIM_OC1PreloadConfig( TIM2, TIM_OCPreload_Enable );
TIM_OC2PreloadConfig( TIM2, TIM_OCPreload_Enable );
TIM_OC3PreloadConfig( TIM2, TIM_OCPreload_Enable );
TIM_OC4PreloadConfig( TIM2, TIM_OCPreload_Enable );
TIM_ARRPreloadConfig( TIM2, ENABLE );
TIM_CtrlPWMOutputs(TIM2, ENABLE );
TIM_Cmd( TIM2, ENABLE );
}
void TIM_PWM_Timer3()
{
GPIO_InitTypeDef GPIO_InitStructure={0};
TIM_OCInitTypeDef TIM_OCInitStructure={0};
TIM_TimeBaseInitTypeDef TIM_TimeBaseInitStructure={0};
RCC_APB2PeriphClockCmd( RCC_APB2Periph_GPIOC | RCC_APB2Periph_AFIO, ENABLE );
RCC_APB1PeriphClockCmd( RCC_APB1Periph_TIM3, ENABLE );
GPIO_PinRemapConfig(GPIO_FullRemap_TIM3,ENABLE);
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_6 | GPIO_Pin_7 | GPIO_Pin_8 | GPIO_Pin_9;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init( GPIOC, &GPIO_InitStructure );
TIM_TimeBaseInitStructure.TIM_Prescaler = SystemCoreClock/1000000 - 1;//1M
TIM_TimeBaseInitStructure.TIM_Period = 1000000 / TIM3_FRQ - 1;//1khz
TIM_TimeBaseInitStructure.TIM_ClockDivision = TIM_CKD_DIV1;
TIM_TimeBaseInitStructure.TIM_CounterMode = TIM_CounterMode_Up;
TIM_TimeBaseInit( TIM3, &TIM_TimeBaseInitStructure);
TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM1;
TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;
TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_High;
TIM_OCInitStructure.TIM_Pulse = MOT_CH1;
TIM_OC1Init( TIM3, &TIM_OCInitStructure );
TIM_OCInitStructure.TIM_Pulse = MOT_CH2;
TIM_OC2Init( TIM3, &TIM_OCInitStructure );
TIM_OCInitStructure.TIM_Pulse = MOT_CH3;
TIM_OC3Init( TIM3, &TIM_OCInitStructure );
TIM_OCInitStructure.TIM_Pulse = MOT_CH4;
TIM_OC4Init( TIM3, &TIM_OCInitStructure );
TIM_OC1PreloadConfig( TIM3, TIM_OCPreload_Enable );
TIM_OC2PreloadConfig( TIM3, TIM_OCPreload_Enable );
TIM_OC3PreloadConfig( TIM3, TIM_OCPreload_Enable );
TIM_OC4PreloadConfig( TIM3, TIM_OCPreload_Enable );
TIM_ARRPreloadConfig( TIM3, ENABLE );
TIM_CtrlPWMOutputs(TIM3, ENABLE );
TIM_Cmd( TIM3, ENABLE );
}
void TIM_PWM_Timer4()
{
GPIO_InitTypeDef GPIO_InitStructure={0};
TIM_OCInitTypeDef TIM_OCInitStructure={0};
TIM_TimeBaseInitTypeDef TIM_TimeBaseInitStructure={0};
RCC_APB2PeriphClockCmd( RCC_APB2Periph_GPIOB, ENABLE );
RCC_APB1PeriphClockCmd( RCC_APB1Periph_TIM4, ENABLE );
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8 | GPIO_Pin_9;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init( GPIOB, &GPIO_InitStructure );
TIM_TimeBaseInitStructure.TIM_Prescaler = SystemCoreClock/1000000 - 1;//1M
TIM_TimeBaseInitStructure.TIM_Period = 1000000 / TIM4_FRQ - 1;//50hz
TIM_TimeBaseInitStructure.TIM_ClockDivision = TIM_CKD_DIV1;
TIM_TimeBaseInitStructure.TIM_CounterMode = TIM_CounterMode_Up;
TIM_TimeBaseInit( TIM4, &TIM_TimeBaseInitStructure);
TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM1;
TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;
TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_High;
TIM_OCInitStructure.TIM_Pulse = PWM_CH1;
TIM_OC3Init( TIM4, &TIM_OCInitStructure );
TIM_OCInitStructure.TIM_Pulse = PWM_CH2;
TIM_OC4Init( TIM4, &TIM_OCInitStructure );
TIM_OC1PreloadConfig( TIM4, TIM_OCPreload_Enable );
TIM_OC2PreloadConfig( TIM4, TIM_OCPreload_Enable );
TIM_OC3PreloadConfig( TIM4, TIM_OCPreload_Enable );
TIM_OC4PreloadConfig( TIM4, TIM_OCPreload_Enable );
TIM_ARRPreloadConfig( TIM4, ENABLE );
TIM_CtrlPWMOutputs(TIM4, ENABLE );
TIM_Cmd( TIM4, ENABLE );
}