OpenEdv-开源电子网

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

为什么我有ucos的定时器中断函数会导致hardfault?不带ucos的中断函数是没有问题,一旦加入了ucos之后就会出现hardfault!

[复制链接]

10

主题

48

帖子

0

精华

初级会员

Rank: 2

积分
192
金钱
192
注册时间
2016-5-11
在线时间
16 小时
发表于 2016-11-20 13:38:53 | 显示全部楼层 |阅读模式
10金钱

最佳答案

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

现在找到的原因就是在ucos下的硬件定时器中断都会导致hardfault!想请原子哥给解释一下,我移植的原子的ucos系统,是不是系统的原因导致的呢?
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

10

主题

48

帖子

0

精华

初级会员

Rank: 2

积分
192
金钱
192
注册时间
2016-5-11
在线时间
16 小时
 楼主| 发表于 2016-11-20 13:38:54 | 显示全部楼层
现在找到的原因就是在ucos下的硬件定时器中断都会导致hardfault!想请原子哥给解释一下,我移植的原子的ucos系统,是不是系统的原因导致的呢?
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165226
金钱
165226
注册时间
2010-12-1
在线时间
2107 小时
发表于 2016-11-20 18:47:04 | 显示全部楼层
说明你的代码存在bug,至于具体原因,仿真看看是哪一步进入的hardfault。
回复

使用道具 举报

28

主题

288

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1212
金钱
1212
注册时间
2011-4-9
在线时间
97 小时
发表于 2016-11-21 13:25:47 | 显示全部楼层
跟踪一下啊
回复

使用道具 举报

10

主题

48

帖子

0

精华

初级会员

Rank: 2

积分
192
金钱
192
注册时间
2016-5-11
在线时间
16 小时
 楼主| 发表于 2016-11-28 09:24:39 | 显示全部楼层
正点原子 发表于 2016-11-20 18:47
说明你的代码存在bug,至于具体原因,仿真看看是哪一步进入的hardfault。

我单步调试找它进入hardfault的代码是在ucos系统切换的api函数里面。
回复

使用道具 举报

10

主题

48

帖子

0

精华

初级会员

Rank: 2

积分
192
金钱
192
注册时间
2016-5-11
在线时间
16 小时
 楼主| 发表于 2016-11-28 09:25:42 | 显示全部楼层

什么意思?单步调试吗?单步调试找到的进入hardfault的程序为ucos系统里面的函数。
回复

使用道具 举报

10

主题

48

帖子

0

精华

初级会员

Rank: 2

积分
192
金钱
192
注册时间
2016-5-11
在线时间
16 小时
 楼主| 发表于 2016-12-5 20:47:26 | 显示全部楼层
正点原子 发表于 2016-11-20 18:47
说明你的代码存在bug,至于具体原因,仿真看看是哪一步进入的hardfault。

void TIM3_IRQHandler(void)   //TIM3ÖD¶Ï
{
        float i;
//        float angle;//½óêÕμ½μÄêÇ»¡¶è£¬èç1ûêǽǶ裬»1μýøDD»»Ëã
        OSIntEnter();
        if (TIM_GetITStatus(TIM3, TIM_IT_Update) != RESET)  //¼ì2éTIM3¸üDÂÖD¶Ï·¢éúóë·ñ
                {
                                TIM_ClearITPendingBit(TIM3, TIM_IT_Update  );  //Çå3yTIMx¸üDÂÖD¶Ï±êÖ¾
                        if(canflag1==1)
                        {
                                Can_Send_Msg(0x321,"01234567",8);
                        }
                        if(canflag2==1)
                        {
                                Can_Send_Msg(0x322,"01234567",8);
                                i=sin(angle1*3.14/180.00);
                                deepth=(int)(longth*(i-sin(sen1*3.14/180.00)));
                        }
                }
                OSIntExit();
}

这是我的定时器中断服务函数的程序;就是通过can发送命令,然后can的中断函数得到角度值angle1.运行的过程中此中断函数就会导致程序运行出错,也没有访问越界什么的原因啊!
回复

使用道具 举报

10

主题

48

帖子

0

精华

初级会员

Rank: 2

积分
192
金钱
192
注册时间
2016-5-11
在线时间
16 小时
 楼主| 发表于 2016-12-5 20:49:41 | 显示全部楼层

void TIM3_IRQHandler(void)   //TIM3ÖD¶Ï
{
        float i;
//        float angle;//½óêÕμ½μÄêÇ»¡¶è£¬èç1ûêǽǶ裬»1μýøDD»»Ëã
        OSIntEnter();
        if (TIM_GetITStatus(TIM3, TIM_IT_Update) != RESET)  //¼ì2éTIM3¸üDÂÖD¶Ï·¢éúóë·ñ
                {
                                TIM_ClearITPendingBit(TIM3, TIM_IT_Update  );  //Çå3yTIMx¸üDÂÖD¶Ï±êÖ¾
                        if(canflag1==1)
                        {
                                Can_Send_Msg(0x321,"01234567",8);
                        }
                        if(canflag2==1)
                        {
                                Can_Send_Msg(0x322,"01234567",8);
                                i=sin(angle1*3.14/180.00);
                                deepth=(int)(longth*(i-sin(sen1*3.14/180.00)));
                        }
                }
                OSIntExit();
}

这是我的定时器中断服务函数的程序;就是通过can发送命令,然后can的中断函数得到角度值angle1.运行的过程中此中断函数就会导致程序运行出错,也没有访问越界什么的原因啊!
而且我也跟踪了,通过r6的地址得到hardfault之前的程序是OS_Start函数,真的不知道是什么原因了。大神能给个回复吗
回复

使用道具 举报

10

主题

48

帖子

0

精华

初级会员

Rank: 2

积分
192
金钱
192
注册时间
2016-5-11
在线时间
16 小时
 楼主| 发表于 2016-12-5 20:50:10 | 显示全部楼层
正点原子 发表于 2016-11-20 18:47
说明你的代码存在bug,至于具体原因,仿真看看是哪一步进入的hardfault。

而且我也跟踪了,通过r6的地址得到hardfault之前的程序是OS_Start函数,真的不知道是什么原因了。大神能给个回复吗
回复

使用道具 举报

28

主题

288

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1212
金钱
1212
注册时间
2011-4-9
在线时间
97 小时
发表于 2016-12-6 08:54:22 | 显示全部楼层
airuoshahen 发表于 2016-12-5 20:50
而且我也跟踪了,通过r6的地址得到hardfault之前的程序是OS_Start函数,真的不知道是什么原因了。大神能 ...

好好查查哪里溢出了,硬件错误一搬都是内存错误造成。
回复

使用道具 举报

4

主题

290

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1130
金钱
1130
注册时间
2015-8-4
在线时间
107 小时
发表于 2016-12-6 09:42:29 | 显示全部楼层
不要在中断里面直接调用CAN的发送函数,置标志位或发送OS事件,到任务里面去发送。
活到老,学到老。
回复

使用道具 举报

10

主题

48

帖子

0

精华

初级会员

Rank: 2

积分
192
金钱
192
注册时间
2016-5-11
在线时间
16 小时
 楼主| 发表于 2016-12-8 08:54:37 | 显示全部楼层
kingnike 发表于 2016-12-6 09:42
不要在中断里面直接调用CAN的发送函数,置标志位或发送OS事件,到任务里面去发送。

为什么啊?在中断里面发送不行吗?
回复

使用道具 举报

4

主题

290

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1130
金钱
1130
注册时间
2015-8-4
在线时间
107 小时
发表于 2016-12-8 09:00:21 | 显示全部楼层
airuoshahen 发表于 2016-12-8 08:54
为什么啊?在中断里面发送不行吗?

中断里面尽量少做事,你可以把发送函数屏蔽了再看看还有没有报错。
活到老,学到老。
回复

使用道具 举报

10

主题

48

帖子

0

精华

初级会员

Rank: 2

积分
192
金钱
192
注册时间
2016-5-11
在线时间
16 小时
 楼主| 发表于 2016-12-8 09:04:04 | 显示全部楼层
kingnike 发表于 2016-12-8 09:00
中断里面尽量少做事,你可以把发送函数屏蔽了再看看还有没有报错。

是,中断里面少做事,但我这个中断里面就一个can的发送函数,还多吗?如果我不在这里发送的话,我就不能保证时间的精确性了吧?
回复

使用道具 举报

4

主题

290

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1130
金钱
1130
注册时间
2015-8-4
在线时间
107 小时
发表于 2016-12-8 10:24:36 | 显示全部楼层
airuoshahen 发表于 2016-12-8 09:04
是,中断里面少做事,但我这个中断里面就一个can的发送函数,还多吗?如果我不在这里发送的话,我就不能 ...

这个就不清楚了,你先排除问题出在哪里吧。找到进HARD FAULT的原因。
活到老,学到老。
回复

使用道具 举报

4

主题

290

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1130
金钱
1130
注册时间
2015-8-4
在线时间
107 小时
发表于 2016-12-8 10:24:51 | 显示全部楼层
airuoshahen 发表于 2016-12-8 09:04
是,中断里面少做事,但我这个中断里面就一个can的发送函数,还多吗?如果我不在这里发送的话,我就不能 ...

这个就不清楚了,你先排除问题出在哪里吧。找到进HARD FAULT的原因。
活到老,学到老。
回复

使用道具 举报

4

主题

290

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1130
金钱
1130
注册时间
2015-8-4
在线时间
107 小时
发表于 2016-12-8 10:24:51 | 显示全部楼层
airuoshahen 发表于 2016-12-8 09:04
是,中断里面少做事,但我这个中断里面就一个can的发送函数,还多吗?如果我不在这里发送的话,我就不能 ...

这个就不清楚了,你先排除问题出在哪里吧。找到进HARD FAULT的原因。
活到老,学到老。
回复

使用道具 举报

4

主题

290

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1130
金钱
1130
注册时间
2015-8-4
在线时间
107 小时
发表于 2016-12-8 10:24:52 | 显示全部楼层
airuoshahen 发表于 2016-12-8 09:04
是,中断里面少做事,但我这个中断里面就一个can的发送函数,还多吗?如果我不在这里发送的话,我就不能 ...

这个就不清楚了,你先排除问题出在哪里吧。找到进HARD FAULT的原因。
活到老,学到老。
回复

使用道具 举报

4

主题

290

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1130
金钱
1130
注册时间
2015-8-4
在线时间
107 小时
发表于 2016-12-8 10:24:52 | 显示全部楼层
airuoshahen 发表于 2016-12-8 09:04
是,中断里面少做事,但我这个中断里面就一个can的发送函数,还多吗?如果我不在这里发送的话,我就不能 ...

这个就不清楚了,你先排除问题出在哪里吧。找到进HARD FAULT的原因。
活到老,学到老。
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2024-11-1 22:26

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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