想用定时器1产生一路pwm,都是没有问题的,但是开启更新中断后就没有输出了,开启比较中断也是不行,没有输出,难道在PWM输出模式下面不能产生更新中断?非要在比较输出模式下才行?
[mw_shl_code=c,true]/*******************************************************************************
* Function Name : Tim1_Init(uint16_t Arr, uint16_t Psc)
* Description : ???????¨?±?÷1??????????±???4?·PWM
* Input : -
* -
* -
* Output : ×°????999??·?????71,?¨?±?÷1us??????????
* Return : ????TIM1
*******************************************************************************/
void Tim1_Init(uint16_t Arr, uint16_t Psc)
{
GPIO_InitTypeDef GPIO_InitStructure; //IO??????
TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure; //TIM1?±?ù??????
NVIC_InitTypeDef NVIC_InitStructure;
TIM_OCInitTypeDef TIM_OCInitStructure; //????
RCC_APB2PeriphClockCmd(RCC_APB2Periph_TIM1, ENABLE); //????TIM1?±??
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_AFIO, ENABLE); //????GPIOA??AFIO?±??
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8; //PA8
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(GPIOA, &GPIO_InitStructure);
// GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9; //PA9
// GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
// GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
// GPIO_Init(GPIOA, &GPIO_InitStructure);
// GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10; //PA10
// GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
// GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
// GPIO_Init(GPIOA, &GPIO_InitStructure);
//
// GPIO_InitStructure.GPIO_Pin = GPIO_Pin_11; //PA11
// GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
// GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
// GPIO_Init(GPIOA, &GPIO_InitStructure);
TIM_TimeBaseStructure.TIM_Period = Arr; //×°????
TIM_TimeBaseStructure.TIM_Prescaler = Psc; //·?????
TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1; //
TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up; //?ò??????????
TIM_TimeBaseInit(TIM1, &TIM_TimeBaseStructure);
TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM1; //PWM2????
TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable; //????????
TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_Low; //?????????????§
TIM_OC1Init(TIM1, &TIM_OCInitStructure);
// TIM_OC2Init(TIM1, &TIM_OCInitStructure);
// TIM_OC3Init(TIM1, &TIM_OCInitStructure);
// TIM_OC4Init(TIM1, &TIM_OCInitStructure);
// TIM_ARRPreloadConfig(TIM1, ENABLE);
// NVIC_InitStructure.NVIC_IRQChannel = TIM1_UP_IRQn; //TIM1????
// NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 3; //????3
// NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3; //?ì??3
// NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
// NVIC_Init(&NVIC_InitStructure);
// TIM_ITConfig(TIM1, TIM_IT_Update, ENABLE);
TIM_CtrlPWMOutputs(TIM1, ENABLE);
TIM_Cmd(TIM1, ENABLE); //????TIM1
}
//T1更新中断
/*******************************************************************************
* Function Name : TIM1_CC_IRQHandler
* Description : ???1????
* Input : - None
* -
* -
* Output : None
* Return : None
*******************************************************************************/
void TIM1_UP_IRQHandler(void)
{
if (TIM_GetITStatus(TIM1, TIM_IT_Update) == SET)
{
TIM_ClearITPendingBit(TIM1, TIM_IT_Update);
}
}[/mw_shl_code]
|