关于定时器的使用

yuzhibing   2009-7-8 20:32 楼主
应版主的要求,修改下标题便于其他人搜索
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

我让定时器只干这个:启动定时器,在定时器溢出中断的时候点闪一个灯~~~

如果用内部时钟驱动定时器的话,在定时器启动时会进更新中断。

我琢磨了十来天了,后来也得到我的浙大高才研究生同事兼资深STM32用户的帮助和指导,做了好多试验,确实有这一现象,向香主请教啊~~~

如果大家感兴趣,也可以自己写几行代码测试一下~~~

回复评论 (47)

发一个最简单的程序上来

                                 只包含这个定时器和闪灯的操作,我测试一下。
点赞  2009-7-8 20:51

非常谢谢香主~~~

这是最少的代码,其他的我试验的代码就没写上来。 

  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); 
              
  }
  
}
点赞  2009-7-8 21:03

如果不用内部时钟驱动定时器,则不一定存在这一现象~~~

                                  
点赞  2009-7-8 21:05

你最好把所有代码贴出来

                                 尤其是时钟和NVIC的配置。
点赞  2009-7-8 21:15

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);
  
}
点赞  2009-7-8 21:18

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);
}
点赞  2009-7-8 21:18

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);
}
点赞  2009-7-8 21:19

谢谢,这几天有空儿试试看

                                  
点赞  2009-7-8 21:28

恩,好的,再次感谢香主

                                  
点赞  2009-7-8 21:31

我这里没有重现这个现象啊

按照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
点赞  2009-7-9 15:20

附件中有错,相应部分更正为:


TIM_UpdateDisableConfig(TIM4,ENABLE);//等同于我的MySetBitUdis(TIM4);
TIM_TimeBaseInit(TIM4, &TIM_TimeBaseStructure); 
TIM_UpdateDisableConfig(TIM4,DISABLE); //
点赞  2009-7-9 20:43

疑问3的工程文件

                                  
点赞  2009-7-9 20:44

请把你的回复贴到这里比较好,这样便于讨论参考

                                 另外,为了防止病毒,我不敢开你的Word文件。
点赞  2009-7-9 20:57

附件没有病毒

                                  
点赞  2009-7-9 21:33

~~~~~~~~~~~

                                  
点赞  2009-7-9 21:34

谢谢,明天再研究一下吧

                                 不好意思,我不是说你的文件有病毒,我是怕有病毒,呵呵~~~~
点赞  2009-7-9 21:58

~~~~~~

                                  
点赞  2009-7-11 23:54

~~~~~~

                                  
点赞  2009-7-13 21:28

不好意思,还没有腾出空来

                                 有个问题,既然给你的代码没有问题,为什么你非要使用有问题的方式操作呢?
点赞  2009-7-13 21:38
123下一页
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 京公网安备 11010802033920号
    写回复