搜索
bottom↓
回复: 7

UCOS运行一段时间后卡死了

[复制链接]

出55入4汤圆

发表于 2022-5-13 11:27:48 | 显示全部楼层 |阅读模式
100汤圆
本帖最后由 ChenXC1121 于 2022-5-13 11:43 编辑

UCOS II运行一段时间(有时运行一整天都没事,有时半个小时就出现)后卡死了,仿真发现停在OSIntExit中,然后单步继续执行,发现代码会去到f_lseek函数中的最后一句“LEAVE_FF(fs, res);”,之后退出来执行接下去的语句,就永远卡死在OSIntExit函数中,不知道是什么原因造成,是我的f_lseek函数有问题吗,哪位大神有遇到过的,请帮忙分析下,谢谢!

代码里面经常要通过f_lseek函数去定位到文件的某个位置,然后写入数据,而且目前代码里面经常是如下的操作:定位后600的位置,写入数据---->定位到100的位置,写入数据---->定位后700的位置,写入数据---->定位到200的位置,写入数据---->.........   大概依此规律循环下去,不知道这样往文件里面写数据会不会有问题?

阿莫论坛20周年了!感谢大家的支持与爱护!!

月入3000的是反美的。收入3万是亲美的。收入30万是移民美国的。收入300万是取得绿卡后回国,教唆那些3000来反美的!

出0入4汤圆

发表于 2022-5-14 13:23:21 | 显示全部楼层
文件系统操作时,要加锁Mutex。
我看你这个是不是申请后,有点没有释放掉。建议看下是不是锁资源没了

出0入42汤圆

发表于 2022-5-14 14:46:30 | 显示全部楼层
如果能打断点,可以看看tick中断还能不能进。
如果不能进,很可能是OS_ENTER_CRITICAL 和OS_EXIT_CRITICAL没有成对调用

出55入4汤圆

 楼主| 发表于 2022-5-14 15:08:09 | 显示全部楼层
wshtyr 发表于 2022-5-14 14:46
如果能打断点,可以看看tick中断还能不能进。
如果不能进,很可能是OS_ENTER_CRITICAL 和OS_EXIT_CRITICAL ...
(引用自3楼)



大神您好  请问有没有可能是系统进入f_lseek函数里面后导致堆栈溢出了,我看f_lseek函数里面的定义的局部变量不少。      这种会不会是第一次进入就死掉啦,还是有可能跑一段时间后才死掉。

出100入312汤圆

发表于 2022-5-14 16:05:48 来自手机 | 显示全部楼层
查查有没有内存泄露或不足,该加锁未加锁之类

出0入14汤圆

发表于 2022-5-15 13:16:50 | 显示全部楼层
创建任务时,栈开大点看

出55入4汤圆

 楼主| 发表于 2022-5-16 09:07:05 | 显示全部楼层
lordor 发表于 2022-5-15 13:16
创建任务时,栈开大点看
(引用自6楼)


大神您好  我那个栈一开大  KEIL编译就出错  请问改哪里可以把栈再改大些

出0入4汤圆

发表于 2022-5-16 12:51:03 | 显示全部楼层
lordor 发表于 2022-5-15 13:16
创建任务时,栈开大点看
(引用自6楼)

哈哈哈,这问题非远程Debug下, 悬丝诊脉就是靠经验猜
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-4-26 14:02

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

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