OpenEdv-开源电子网

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

uCOS程序,连续运行了三天,就一直停在了空闲任务,什么原因

[复制链接]

28

主题

100

帖子

0

精华

初级会员

Rank: 2

积分
147
金钱
147
注册时间
2017-4-28
在线时间
44 小时
发表于 2020-4-20 18:10:59 | 显示全部楼层 |阅读模式
50金钱
uCOSII 是运行在LPC3250 上的,在做稳定性测试的时候,连续运行了3~4天,就会卡到空闲任务里面,出不来。
通过在DEBUG模式下查看tcb任务块,已经优先级就绪表。发现任务块中有任务,也是在就绪状态,但是优先级就绪表里没有优先级,
显示0;造成这种原因有什么啊,从哪里分析一下,求大神给个思路或解决办法。。

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

使用道具 举报

31

主题

2183

帖子

0

精华

资深版主

Rank: 8Rank: 8

积分
14286
金钱
14286
注册时间
2018-8-3
在线时间
1147 小时
发表于 2020-4-20 18:56:05 | 显示全部楼层
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165309
金钱
165309
注册时间
2010-12-1
在线时间
2108 小时
发表于 2020-4-21 00:58:06 | 显示全部楼层
简化代码试试,或者加入一些printf辅助分析
回复

使用道具 举报

2

主题

391

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1957
金钱
1957
注册时间
2014-8-8
在线时间
307 小时
发表于 2020-4-24 09:54:08 | 显示全部楼层
查下临界保护代码是否生效,大部分原因是临界代码没生效导致的有就绪的无法运行
回复

使用道具 举报

28

主题

100

帖子

0

精华

初级会员

Rank: 2

积分
147
金钱
147
注册时间
2017-4-28
在线时间
44 小时
 楼主| 发表于 2020-5-12 16:46:28 | 显示全部楼层
这几天又找了找原因。发现时ucos的时钟节拍所在的timer0中断,不能进了。但是查看timer0的寄存器配置,也是正常的。同时其他中断也可以进。pc指针也是没有乱。内存越界的话也不好找、只能一遍遍的读代码。真奇怪!
回复

使用道具 举报

28

主题

100

帖子

0

精华

初级会员

Rank: 2

积分
147
金钱
147
注册时间
2017-4-28
在线时间
44 小时
 楼主| 发表于 2020-5-12 16:47:18 | 显示全部楼层
365mcu 发表于 2020-4-24 09:54
查下临界保护代码是否生效,大部分原因是临界代码没生效导致的有就绪的无法运行

我看了一下一切正常,是时钟节拍所在的timer0中断响应了
回复

使用道具 举报

28

主题

100

帖子

0

精华

初级会员

Rank: 2

积分
147
金钱
147
注册时间
2017-4-28
在线时间
44 小时
 楼主| 发表于 2020-5-12 16:48:36 | 显示全部楼层
正点原子 发表于 2020-4-21 00:58
简化代码试试,或者加入一些printf辅助分析

这是个很大的系统。我接手以前就有这个问题。简化代码。那就太难了
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165309
金钱
165309
注册时间
2010-12-1
在线时间
2108 小时
发表于 2020-5-13 01:20:48 | 显示全部楼层
白菜菜 发表于 2020-5-12 16:48
这是个很大的系统。我接手以前就有这个问题。简化代码。那就太难了

屏蔽掉一些代码即可,并不要删除代码。比如屏蔽掉一些任务
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

28

主题

100

帖子

0

精华

初级会员

Rank: 2

积分
147
金钱
147
注册时间
2017-4-28
在线时间
44 小时
 楼主| 发表于 2020-5-13 17:46:31 | 显示全部楼层
白菜菜 发表于 2020-5-12 16:47
我看了一下一切正常,是时钟节拍所在的timer0中断响应了

怎么查看是否生效?查看中断有没有关掉吗
回复

使用道具 举报

28

主题

100

帖子

0

精华

初级会员

Rank: 2

积分
147
金钱
147
注册时间
2017-4-28
在线时间
44 小时
 楼主| 发表于 2020-5-13 17:47:31 | 显示全部楼层
今天又复现了这个现象。发现中断嵌套达到了34个。实际npx lpc3250 默认设置是9个。该大了一些。不知道是不是这个原因。重新测试当中。
回复

使用道具 举报

0

主题

18

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
207
金钱
207
注册时间
2015-10-16
在线时间
71 小时
发表于 2020-9-4 12:11:40 | 显示全部楼层
白菜菜 发表于 2020-5-13 17:47
今天又复现了这个现象。发现中断嵌套达到了34个。实际npx lpc3250 默认设置是9个。该大了一些。不知道是不 ...

你的ucos用的是哪个版本的?
回复

使用道具 举报

28

主题

100

帖子

0

精华

初级会员

Rank: 2

积分
147
金钱
147
注册时间
2017-4-28
在线时间
44 小时
 楼主| 发表于 2020-9-22 16:31:44 | 显示全部楼层
xue2003265029 发表于 2020-9-4 12:11
你的ucos用的是哪个版本的?

ucosii
回复

使用道具 举报

0

主题

18

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
207
金钱
207
注册时间
2015-10-16
在线时间
71 小时
发表于 2020-9-23 16:47:24 | 显示全部楼层
不知道是不是V2.86版的。
https://www.amobbs.com/thread-5635959-1-1.html
回复

使用道具 举报

0

主题

1

帖子

0

精华

新手上路

积分
44
金钱
44
注册时间
2021-3-16
在线时间
29 小时
发表于 2021-7-17 11:19:30 | 显示全部楼层
楼主找到原因没有
回复

使用道具 举报

28

主题

100

帖子

0

精华

初级会员

Rank: 2

积分
147
金钱
147
注册时间
2017-4-28
在线时间
44 小时
 楼主| 发表于 2021-11-9 13:26:12 | 显示全部楼层
lcf52520 发表于 2021-7-17 11:19
楼主找到原因没有

貌似没有解决。复现比较麻烦。
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2024-11-22 16:57

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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