OpenEdv-开源电子网

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

一个很SB的定时器问题!被他搞得受不了了,好心人,高手来看看,给点思路吧。

[复制链接]

14

主题

75

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
248
金钱
248
注册时间
2011-10-16
在线时间
31 小时
发表于 2012-2-10 10:26:53 | 显示全部楼层 |阅读模式

是这样的: 我的主程序初始化 串口3,定时器2和定时器3, 当我添加完定时器2初始化代码后 ,下载进去发现不工作了,一开始 我只用到串口3和定时器3 都还是工作的好好的,现在考虑
到项目实际情况,还要增加一个定时器,如是我就把定时器3的拷贝一下,在改成2,我想这样应该没问题,但是改完后下载进去就是不工作,如是我就这样:把定时器2的初始化函数注释掉,再
下载进去观察,注释掉后又能工作了,这样确定下来了是初始化定时器2的时候带来的问题,于是我就再把初始化定时器2的程序 一小部分,一小部分的注释,希望一步步缩小范围来找到出错的地方
,最后查到了下面的这个情况,如果我把 下面红色部分注释掉,原来的定时器3和串口3都还能工作,一旦不注释掉,就导致我的整个程序都不工作了

我看来看去 ,下面这5行红色的代码绝对没有问题啊 我以人头担保,但是这5句一上来就弄得我的整个程序不工作,去掉又正常 ,被他搞得受不了了。
// NVIC_InitStructure.NVIC_IRQChannel = TIM2_IRQn;  //TIM2中断
// NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 1;
// NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;  //从优先级3级
// NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; //IRQ通道被使能
// NVIC_Init(&NVIC_InitStructure);
void NVIC_Configuration(void)
{
 NVIC_InitTypeDef NVIC_InitStructure;

  NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2); //设置优先级分组:先占优先级0位,从优先级4位

 #ifdef  VECT_TAB_RAM      
  NVIC_SetVectorTable(NVIC_VectTab_RAM, 0x0);   //向量表位于RAM
 #else 
   NVIC_SetVectorTable(NVIC_VectTab_FLASH, 0x0);   //向量表位于FLASH
 #endif

 NVIC_InitStructure.NVIC_IRQChannel = USART3_IRQn;  //USART3中断
 NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=0;
 NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;  //
 NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;   //IRQ通道使能
 NVIC_Init(&NVIC_InitStructure); //根据NVIC_InitStruct中指定的参数初始化外设NVIC寄存器USART1

 NVIC_InitStructure.NVIC_IRQChannel = TIM3_IRQn;  //TIM3中断
 NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 2;
 NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;  //从优先级3级
 NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; //IRQ通道被使能
 NVIC_Init(&NVIC_InitStructure);  //根据NVIC_InitStruct中指定的参数初始化外设NVIC寄存器
 
 
 
// NVIC_InitStructure.NVIC_IRQChannel = TIM2_IRQn;  //TIM3中断
// NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 1;
// NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;  //从优先级3级
// NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; //IRQ通道被使能
// NVIC_Init(&NVIC_InitStructure);

}

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

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165371
金钱
165371
注册时间
2010-12-1
在线时间
2110 小时
发表于 2012-2-10 12:34:17 | 显示全部楼层
回复【楼主位】okyihu:
---------------------------------
没有中断服务函数?
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

14

主题

75

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
248
金钱
248
注册时间
2011-10-16
在线时间
31 小时
 楼主| 发表于 2012-2-11 20:49:00 | 显示全部楼层
回复【2楼】正点原子:
---------------------------------
有中断服务函数 ;中断服务函数里就就是发送一个数据帧到USART3去,
有时候我发现他进入中断以后,就一直停在里面不出来,有时候就是整个程序不工作,

还有 我在用你光盘里的程序的时候 发现个问题 就是在串口中断程序里 不能调用
delay_us()这个函数,只要在中断服务程序里 调用了这个函数,程序就会出现莫名其妙的原因
去掉以后就正常 ,不知你的程序是不是有BUG?
回复 支持 反对

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165371
金钱
165371
注册时间
2010-12-1
在线时间
2110 小时
发表于 2012-2-11 21:56:43 | 显示全部楼层
你是不是用了ucos啊??
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

14

主题

75

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
248
金钱
248
注册时间
2011-10-16
在线时间
31 小时
 楼主| 发表于 2012-2-12 22:29:18 | 显示全部楼层
---------------------------------
回复【4楼】正点原子:
你是不是用了ucos啊??
---------------------------------
没有用到UCOS ,今天把顶层的程序都去掉了,只留下操作片内资源的程序,发现控制硬件资源的程序没问题,可以工作,
然后又一步步把顶层实现HDLC协议的一些文件及函数陆续添加进来,搞完后 还是和原来一样 有莫名奇妙的问题,把我郁闷
的啊 !!!我后面添加进来的程序根本都没去操作这些片内资源,为什么一加进来的出错呢 ,搞不懂了 ,
我也没别的办法了 打算把整个程序重新写,把模块化程度加大,减少函数,文件之间的牵扯,最大限度的不使用全局变量,不去追求那些巧妙的实现方法,用最笨的办法,  

最后想问一下,你那些光盘里的代码,出错的几率应该很小吧,因为底层的操作单片机的程序,都是从你给我的那些例程改过来的,我害怕程序规模大了 ,要是问题还是出在这些底层代码上,会把我整死的,
回复 支持 反对

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165371
金钱
165371
注册时间
2010-12-1
在线时间
2110 小时
发表于 2012-2-13 00:26:52 | 显示全部楼层
底层要看你用在什么地方了,有些是没有严格测试的,也没有做容错处理,如果自己做产品,得做一些改进的.
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

14

主题

75

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
248
金钱
248
注册时间
2011-10-16
在线时间
31 小时
 楼主| 发表于 2012-2-13 09:16:54 | 显示全部楼层
回复【6楼】正点原子:

---------------------------------
原子哥,问题我已经查找出来了 ,在定时器库的时基初始化函数里,他设置UG位产生更新时间,然后CR1里没有设置URS位 所以,一初始化,就会产生一个
触发一个定时器中断,就开始调用定时器里发送数据帧的函数,但是我的本意不是这样,刚把URS设置后就正常了,谢谢你支持
回复 支持 反对

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165371
金钱
165371
注册时间
2010-12-1
在线时间
2110 小时
发表于 2012-2-13 10:07:16 | 显示全部楼层
哦,又学习了...
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-2-24 21:47

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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