应版主的要求,修改下标题便于其他人搜索
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
我让定时器只干这个:启动定时器,在定时器溢出中断的时候点闪一个灯~~~
如果用内部时钟驱动定时器的话,在定时器启动时会进更新中断。
我琢磨了十来天了,后来也得到我的浙大高才研究生同事兼资深STM32用户的帮助和指导,做了好多试验,确实有这一现象,向香主请教啊~~~
如果大家感兴趣,也可以自己写几行代码测试一下~~~
发一个最简单的程序上来
只包含这个定时器和闪灯的操作,我测试一下。
非常谢谢香主~~~
这是最少的代码,其他的我试验的代码就没写上来。
TIM_TimeBaseStructure.TIM_Period = 10000;
TIM_TimeBaseStructure.TIM_Prescaler = 35999;
TIM_TimeBaseStructure.TIM_ClockDivision = 0;
TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;
// MySetBitUdis(TIM4);
TIM_TimeBaseInit(TIM4, &TIM_TimeBaseStructure);
// MyResetBitUdis(TIM4);
TIM_ClearFlag(TIM4, TIM_FLAG_Update);
TIM_ITConfig(TIM4, TIM_IT_Update , ENABLE);
TIM_Cmd(TIM4, ENABLE);
-------------------------------------------------------------------
u8 i=0;
u8 j=0;
void TIM4_IRQHandler(void)
{
i++;
if (TIM_GetITStatus(TIM4, TIM_IT_Update) != RESET)
{
j++;
GPIO_SetBits(GPIOC, GPIO_Pin_7);
// delay();
// GPIO_ResetBits(GPIOC, GPIO_Pin_7);
}
}
如果不用内部时钟驱动定时器,则不一定存在这一现象~~~
你最好把所有代码贴出来
尤其是时钟和NVIC的配置。
NVIC
void NVIC_Configuration(void)
{
NVIC_InitTypeDef NVIC_InitStructure;
#ifdef VECT_TAB_RAM
/* Set the Vector Table base location at 0x20000000 */
NVIC_SetVectorTable(NVIC_VectTab_RAM, 0x0);
#else /* VECT_TAB_FLASH */
/* Set the Vector Table base location at 0x08000000 */
NVIC_SetVectorTable(NVIC_VectTab_FLASH, 0x0);
#endif
NVIC_InitStructure.NVIC_IRQChannel = TIM4_IRQChannel;
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1;
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
NVIC_Init(&NVIC_InitStructure);
}
RCC
void RCC_Configuration(void)
{
/* RCC system reset(for debug purpose) */
RCC_DeInit();
/* Enable HSE */
RCC_HSEConfig(RCC_HSE_ON);
/* Wait till HSE is ready */
HSEStartUpStatus = RCC_WaitForHSEStartUp();
if(HSEStartUpStatus == SUCCESS)
{
/* Enable Prefetch Buffer */
FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);
/* Flash 2 wait state */
FLASH_SetLatency(FLASH_Latency_2);
/* HCLK = SYSCLK */
RCC_HCLKConfig(RCC_SYSCLK_Div1);
/* PCLK2 = HCLK */
RCC_PCLK2Config(RCC_HCLK_Div1);
/* PCLK1 = HCLK/2 */
RCC_PCLK1Config(RCC_HCLK_Div2);
/* PLLCLK = 8MHz * 9 = 72 MHz */
RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9);
/* Enable PLL */
RCC_PLLCmd(ENABLE);
/* Wait till PLL is ready */
while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET)
{
}
/* Select PLL as system clock source */
RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);
/* Wait till PLL is used as system clock source */
while(RCC_GetSYSCLKSource() != 0x08)
{
}
}
/* TIM4 clock enable */
RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM4, ENABLE);
/* GPIO clock enable */
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC | RCC_APB2Periph_GPIOD |
RCC_APB2Periph_AFIO, ENABLE);
}
GPIO,万利199的板子,IAR4.42版本
void GPIO_Configuration(void)
{
GPIO_InitTypeDef GPIO_InitStructure;
GPIO_PinRemapConfig(GPIO_Remap_TIM4, ENABLE);
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_12;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
GPIO_Init(GPIOD, &GPIO_InitStructure);
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_4|GPIO_Pin_5|GPIO_Pin_6|GPIO_Pin_7;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
GPIO_Init(GPIOC, &GPIO_InitStructure);
// GPIO_SetBits(GPIOC, GPIO_Pin_6);
GPIO_SetBits(GPIOC, GPIO_Pin_5);
GPIO_SetBits(GPIOC, GPIO_Pin_4);
}
我这里没有重现这个现象啊
按照lz所说,用HSI驱动。即使使用HSI,还有两条路供应时钟:
1. HSI direct:就是HSI(8M)直接作为sysclk
2. HSI indirect:使用HSI/2(4M),通过PLL,产生sysclk
以上两种方法,TIM4都工作正常,跑了一段时间,才点灯。没有说一启动TIM4就进入更新中断。
整个项目在附件中,lz可以参考一下。
Fwlib2.0.3的库,IAR4.42,跑在万利199板子上。
P.S,打开以下相应宏定义,来选择以上两种时钟方案
//#define HSI_DIRECT
#define HSI_INDIRECT
打开项目时,请自己指定第三方驱动的路径。
相关链接:
https://bbs.eeworld.com.cn/upfiles/img/20097/200979151635997.zip
附件中有错,相应部分更正为:
TIM_UpdateDisableConfig(TIM4,ENABLE);//等同于我的MySetBitUdis(TIM4);
TIM_TimeBaseInit(TIM4, &TIM_TimeBaseStructure);
TIM_UpdateDisableConfig(TIM4,DISABLE); //
请把你的回复贴到这里比较好,这样便于讨论参考
另外,为了防止病毒,我不敢开你的Word文件。
谢谢,明天再研究一下吧
不好意思,我不是说你的文件有病毒,我是怕有病毒,呵呵~~~~
不好意思,还没有腾出空来
有个问题,既然给你的代码没有问题,为什么你非要使用有问题的方式操作呢?