OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 3706|回复: 2

请问各位为什么我的定时器捕获时候总是溢出?

[复制链接]

4

主题

7

帖子

0

精华

初级会员

Rank: 2

积分
51
金钱
51
注册时间
2015-3-1
在线时间
4 小时
发表于 2015-3-1 20:36:12 | 显示全部楼层 |阅读模式
5金钱
程序如下,用TIM3控制PB5作为输出引脚连接到TIM5的通道1(PA0)上进行捕获。
TIM3和输出引脚的初始化函数:
void tim3_init(void)
{
        GPIO_InitTypeDef GPIO_InitStructure;        
        TIM_TimeBaseInitTypeDef TIM_TimeBaseStruct;
        NVIC_InitTypeDef NVIC_InitStructure;
        RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM3,ENABLE);
        
        GPIO_InitStructure.GPIO_Pin=GPIO_Pin_5;
        GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz;
        GPIO_InitStructure.GPIO_Mode=GPIO_Mode_Out_PP;
        GPIO_Init(GPIOB,&GPIO_InitStructure);
        
        NVIC_InitStructure.NVIC_IRQChannel = TIM3_IRQn; 
        NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0; 
        NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1; 
        NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; 
        NVIC_Init(&NVIC_InitStructure);
        
        TIM_ClearITPendingBit(TIM3,TIM_IT_Update);

        TIM_TimeBaseStruct.TIM_Period=20
        TIM_TimeBaseStruct.TIM_Prescaler=29
        TIM_TimeBaseStruct.TIM_ClockDivision=0;
        TIM_TimeBaseStruct.TIM_CounterMode=TIM_CounterMode_Up;

        TIM_TimeBaseInit(TIM3,&TIM_TimeBaseStruct);

        TIM_ITConfig(TIM3,TIM_IT_Update,ENABLE);
        TIM_Cmd(TIM3,ENABLE);         
        }

TIM3 的中断函数:
void TIM3_IRQHandler(void)
{
        static u8 i;
        TIM_ClearITPendingBit(TIM3,TIM_IT_Update);

        if(i==0)
        {
                GPIO_SetBits(GPIOB,GPIO_Pin_5);
                i=1;
        }
        else if(i==1)
        {
                GPIO_ResetBits(GPIOB,GPIO_Pin_5);
                i=0;
        }
}


TIM5及输入引脚的初始化函数:
void init_input(void)
{
        GPIO_InitTypeDef GPIO_InitStructure;
        NVIC_InitTypeDef NVIC_InitStructure;
        TIM_TimeBaseInitTypeDef TIM_TimeBaseStruct;
        TIM_ICInitTypeDef TIM_ICInitStructure;


        RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);
        RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO,ENABLE);
        RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM5,ENABLE);

        GPIO_InitStructure.GPIO_Mode=GPIO_Mode_IN_FLOATING;

        GPIO_InitStructure.GPIO_Pin=GPIO_Pin_0;
        GPIO_Init(GPIOA,&GPIO_InitStructure)
        

        NVIC_InitStructure.NVIC_IRQChannel=TIM5_IRQn;
        NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=0
        NVIC_InitStructure.NVIC_IRQChannelSubPriority=0
        NVIC_InitStructure.NVIC_IRQChannelCmd=ENABLE;
        NVIC_Init(&NVIC_InitStructure);
        
        TIM_ClearITPendingBit(TIM5,TIM_IT_Update);
        
        TIM_TimeBaseStruct.TIM_Period=0xFFFF;
        TIM_TimeBaseStruct.TIM_Prescaler=29;
        TIM_TimeBaseStruct.TIM_ClockDivision=TIM_CKD_DIV1;
        TIM_TimeBaseStruct.TIM_CounterMode=TIM_CounterMode_Up;
        TIM_TimeBaseInit(TIM5,&TIM_TimeBaseStruct);
        

        TIM_ICInitStructure.TIM_Channel=TIM_Channel_1
        TIM_ICInitStructure.TIM_ICFilter=0
        TIM_ICInitStructure.TIM_ICPolarity=TIM_ICPolarity_Rising
        TIM_ICInitStructure.TIM_ICPrescaler=TIM_ICPSC_DIV1
        TIM_ICInitStructure.TIM_ICSelection=TIM_ICSelection_DirectTI;
        TIM_ICInit(TIM5,&TIM_ICInitStructure);
        
        TIM_ITConfig(TIM5,TIM_IT_Update|TIM_IT_CC1,ENABLE);
        TIM_Cmd(TIM5,ENABLE);

        printf("input ");
}


TIM5的中断函数
void TIM5_IRQHandler(void)
{
        static u8 flag;
        static u16 channel1_up,channel1_fall;

        if(TIM_GetITStatus(TIM5,TIM_IT_Update)==SET)
        {
                TIM_SetCounter(TIM5,0);
                printf("update ");
                TIM_ClearITPendingBit(TIM5,TIM_IT_Update);
        }

        else if(TIM_GetITStatus(TIM5,TIM_IT_CC1)==SET)
        {
                        if(flag==0)
                        {                                
                                channel1_up=TIM_GetCapture1(TIM5);
                                TIM_OC1PolarityConfig(TIM5,TIM_ICPolarity_Falling);
                                flag++;
                                printf("channel1_up %d ",channel1_up);
                        }
                        else if(flag==1)
                        {
                                channel1_fall=TIM_GetCapture1(TIM5);
                                TIM_OC1PolarityConfig(TIM5,TIM_ICPolarity_Rising);
                                input_tim_count[capture_i]=channel1_fall-channel1_up;
                                capture_i++;
                                flag--;
                                printf("channel1_fall %d ",channel1_fall);
                        }
                       TIM_ClearITPendingBit(TIM5,TIM_IT_CC1);
                }        
}


通过串口输出的时候一直就是update,我想不明白为什么会溢出

最佳答案

查看完整内容[请看2#楼]

printf占很多时间的,如果你的定时器速度比较快,就可能溢出。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2015-3-1 20:36:13 | 显示全部楼层
printf占很多时间的,如果你的定时器速度比较快,就可能溢出。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

4

主题

7

帖子

0

精华

初级会员

Rank: 2

积分
51
金钱
51
注册时间
2015-3-1
在线时间
4 小时
 楼主| 发表于 2015-3-2 09:11:39 | 显示全部楼层
回复【2楼】正点原子:
---------------------------------
谢谢原子哥,我把分频调大了之后就不会溢出了,就是捕获到的时间总是大一些。估计也是因为printf太占时间的原因。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-25 14:34

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表