OpenEdv-开源电子网

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

Debug中断为500ms,一直在中断里面不出去

[复制链接]

24

主题

257

帖子

0

精华

高级会员

Rank: 4

积分
771
金钱
771
注册时间
2017-2-19
在线时间
133 小时
发表于 2017-9-9 09:33:06 | 显示全部楼层 |阅读模式
1金钱
Debug时候一直在中断里面循环不出去是咋回事,中断时间为500ms,实际硬件测试led等闪烁时间正常。

void TIM5_Int_Init(u16 arr,u16 psc)
{
    TIM_TimeBaseInitTypeDef  TIM_TimeBaseStructure;
        NVIC_InitTypeDef NVIC_InitStructure;

        RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM5, ENABLE); //时钟使能
        
        //定时器TIM3初始化
        TIM_TimeBaseStructure.TIM_Period = arr; //设置在下一个更新事件装入活动的自动重装载寄存器周期的值        
        TIM_TimeBaseStructure.TIM_Prescaler =psc; //设置用来作为TIMx时钟频率除数的预分频值
        TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1; //设置时钟分割:TDTS = Tck_tim
        TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;  //TIM向上计数模式
        TIM_TimeBaseInit(TIM5, &TIM_TimeBaseStructure); //根据指定的参数初始化TIMx的时间基数单位

        TIM_ITConfig(TIM5,TIM_IT_Update,ENABLE ); //使能指定的TIM2中断,允许更新中断

        //中断优先级NVIC设置
        NVIC_InitStructure.NVIC_IRQChannel = TIM5_IRQn;  //TIM2中断
        NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;  //先占优先级0级
        NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3;  //从优先级3级
        NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; //IRQ通道被使能
        NVIC_Init(&NVIC_InitStructure);  //初始化NVIC寄存器


        TIM_Cmd(TIM5, ENABLE);  //使能TIMx                                         
}
//定时器2中断服务程序
void TIM5_IRQHandler(void)   //TIM3中断
{
        if (TIM_GetITStatus(TIM5, TIM_IT_Update) != RESET)  //检查TIM3更新中断发生与否
                {
                        TIM_ClearITPendingBit(TIM5, TIM_IT_Update  );  //清除TIMx更新中断标志
                        ADC_Scan();
                        PWM_Scan();
                        ADC_OUT_Scan();
                        RUNA=~RUNA;
                        
                }
}


这个是代码,大家帮忙看下

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

9

主题

101

帖子

0

精华

高级会员

Rank: 4

积分
532
金钱
532
注册时间
2017-3-5
在线时间
74 小时
发表于 2017-9-9 09:45:30 | 显示全部楼层
不出去的原因有可能是你的ADC函数,PWM函数等出现死循环,你单步调试看看是不是卡在这几个函数了。
回复

使用道具 举报

24

主题

257

帖子

0

精华

高级会员

Rank: 4

积分
771
金钱
771
注册时间
2017-2-19
在线时间
133 小时
 楼主| 发表于 2017-9-9 10:27:41 | 显示全部楼层
openedvxiaowang 发表于 2017-9-9 09:45
不出去的原因有可能是你的ADC函数,PWM函数等出现死循环,你单步调试看看是不是卡在这几个函数了。

没有卡在死循环,我找到原因了。 CNT的技术频率不对了。不知道为什么,还有这里如何修改呢!!!
12.png

13.png

14.png

看这里,我只执行了一条指令 ,但是CNT计数器跑了 590个技术,明显的CNT的频率偏高了,所以总是频繁进入定时器中断,而不去中循环。



回复

使用道具 举报

24

主题

257

帖子

0

精华

高级会员

Rank: 4

积分
771
金钱
771
注册时间
2017-2-19
在线时间
133 小时
 楼主| 发表于 2017-9-9 10:32:35 | 显示全部楼层
但是这个通过什么区调整CNT的计数频率呢?
回复

使用道具 举报

9

主题

101

帖子

0

精华

高级会员

Rank: 4

积分
532
金钱
532
注册时间
2017-3-5
在线时间
74 小时
发表于 2017-9-9 13:41:03 | 显示全部楼层
刘东君 发表于 2017-9-9 10:32
但是这个通过什么区调整CNT的计数频率呢?

你应该对定时计数器没有完全理解,回去看看手册或者随便找个例程,很容易理解的
回复

使用道具 举报

24

主题

257

帖子

0

精华

高级会员

Rank: 4

积分
771
金钱
771
注册时间
2017-2-19
在线时间
133 小时
 楼主| 发表于 2017-9-9 13:50:26 | 显示全部楼层
openedvxiaowang 发表于 2017-9-9 13:41
你应该对定时计数器没有完全理解,回去看看手册或者随便找个例程,很容易理解的

这个是软件设置的问题。。。。和我的程序没关系。。。。我直接用原子的代码也是这个样子的Debug现象
回复

使用道具 举报

13

主题

85

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1897
金钱
1897
注册时间
2016-8-20
在线时间
238 小时
发表于 2017-9-9 13:53:13 | 显示全部楼层
晶振频率你选的多大的啊,默认频率高了的话也会出现这种情况哦,选8M
回复

使用道具 举报

24

主题

257

帖子

0

精华

高级会员

Rank: 4

积分
771
金钱
771
注册时间
2017-2-19
在线时间
133 小时
 楼主| 发表于 2017-9-9 16:21:17 | 显示全部楼层
ChaserMCU 发表于 2017-9-9 13:53
晶振频率你选的多大的啊,默认频率高了的话也会出现这种情况哦,选8M

是8M的!
回复

使用道具 举报

1

主题

101

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
254
金钱
254
注册时间
2017-5-10
在线时间
55 小时
发表于 2017-9-11 10:41:13 来自手机 | 显示全部楼层
应该先把中断里的其他程序注释掉然后看看有没有问题再说……
回复

使用道具 举报

24

主题

257

帖子

0

精华

高级会员

Rank: 4

积分
771
金钱
771
注册时间
2017-2-19
在线时间
133 小时
 楼主| 发表于 2017-9-11 11:06:56 | 显示全部楼层
cromarti 发表于 2017-9-11 10:41
应该先把中断里的其他程序注释掉然后看看有没有问题再说……

用的这个程序也是一样的。。。原子的中断例子 LED=!LED也是一样。。。。
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-19 00:11

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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