OpenEdv-开源电子网

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

UCOSIII+LWIP工程,NETCONN方式下运行出现hardfault

[复制链接]

20

主题

134

帖子

0

精华

高级会员

Rank: 4

积分
550
金钱
550
注册时间
2016-7-26
在线时间
90 小时
发表于 2018-8-14 10:44:33 | 显示全部楼层 |阅读模式
50金钱
PHY采用LAN8720,工程使用的是UCOSIII+LWIP,使用的NETCONN的方式进行TCP连接。
程序运行一会儿就会进入hardfault,定位发生位置在tcpip_thread或者tcp_tmr函数中。
后来又发现是因为公司电脑加密,导致tcp无法穿过防火墙的情况下才会出现,在不加密的电脑上可以连接成功能正常运行。
而且有的时候程序在debug状态下会跳到mian重新开始执行,这个问题也感到很困惑。


经测试只要不加入tcp的任务程序能稳定的执行,加入之后就完蛋;
实在搞不定,头都快大了,求大神给指点迷津

最佳答案

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

反复尝试各种修改,发现在tcp_client_thread任务中不能加ostimedly函数,之前担心此任务会一直占用资源,所以加了延时,注释掉之后程序又能跑了,搞不懂啊
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

20

主题

134

帖子

0

精华

高级会员

Rank: 4

积分
550
金钱
550
注册时间
2016-7-26
在线时间
90 小时
 楼主| 发表于 2018-8-14 10:44:34 | 显示全部楼层
反复尝试各种修改,发现在tcp_client_thread任务中不能加ostimedly函数,之前担心此任务会一直占用资源,所以加了延时,注释掉之后程序又能跑了,搞不懂啊
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165352
金钱
165352
注册时间
2010-12-1
在线时间
2108 小时
发表于 2018-8-15 01:34:26 | 显示全部楼层
帮顶
回复

使用道具 举报

9

主题

796

帖子

1

精华

金牌会员

Rank: 6Rank: 6

积分
2038
金钱
2038
注册时间
2017-8-2
在线时间
522 小时
发表于 2018-8-15 08:35:39 | 显示全部楼层
回到main  说明你开了看门狗呗;
tcp里面有错误  导致跳入了hard faulthandler
猪猪熊呢?
回复

使用道具 举报

20

主题

134

帖子

0

精华

高级会员

Rank: 4

积分
550
金钱
550
注册时间
2016-7-26
在线时间
90 小时
 楼主| 发表于 2018-8-15 11:28:53 | 显示全部楼层
323232 发表于 2018-8-15 08:35
回到main  说明你开了看门狗呗;
tcp里面有错误  导致跳入了hard faulthandler

1、确实没有使用看门狗;
2、lwip里面错误不好定位实在是。
回复

使用道具 举报

1

主题

87

帖子

0

精华

初级会员

Rank: 2

积分
162
金钱
162
注册时间
2018-11-7
在线时间
16 小时
发表于 2018-11-11 19:23:54 | 显示全部楼层
帮顶  
回复

使用道具 举报

1

主题

87

帖子

0

精华

初级会员

Rank: 2

积分
162
金钱
162
注册时间
2018-11-7
在线时间
16 小时
发表于 2018-11-14 00:11:11 | 显示全部楼层
为什么任务udp_thread和tcp_client_thread的创建要放在start_task之前创建?
回复

使用道具 举报

1

主题

87

帖子

0

精华

初级会员

Rank: 2

积分
162
金钱
162
注册时间
2018-11-7
在线时间
16 小时
发表于 2018-11-14 00:14:37 | 显示全部楼层
任务udp_thread和tcp_client_thread没用延时函数,那么任务之间是如何调度的呢?
回复

使用道具 举报

5

主题

26

帖子

0

精华

初级会员

Rank: 2

积分
78
金钱
78
注册时间
2014-8-20
在线时间
6 小时
发表于 2018-11-15 19:20:06 | 显示全部楼层
UCOSIII的邮箱、信号量函数操作和UCOSII完全不同,也就是sys_arch中的驱动写法不同,造成比如说邮箱创建失败却调用了等奇葩的问题,在调试时也经常进入hardfault,最后没调通换回了UCOSII,建议着重Debug看看是不是到了sys_arch里的某个函数掉进了Hardfault
我只想往前走,不停地往前走
回复

使用道具 举报

8

主题

32

帖子

0

精华

初级会员

Rank: 2

积分
116
金钱
116
注册时间
2015-7-21
在线时间
18 小时
发表于 2020-8-24 15:59:00 | 显示全部楼层
飀人士 发表于 2018-11-14 00:14
任务udp_thread和tcp_client_thread没用延时函数,那么任务之间是如何调度的呢?

有几个函数是阻塞的,所有没有延时的话,也有任务调度点
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2024-11-24 14:59

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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