搜索
bottom↓
回复: 20

LWIP网络PCB死循环

[复制链接]

出0入0汤圆

发表于 2013-9-29 13:12:17 | 显示全部楼层 |阅读模式
tcp_active_pcbs , 队列中的元素的next  指向自己  , 导致死循环 。
  
大家有没有碰到过 。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x

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

一只鸟敢站在脆弱的枝条上歇脚,它依仗的不是枝条不会断,而是自己有翅膀,会飞。

出0入0汤圆

发表于 2013-9-29 13:48:06 | 显示全部楼层
这问题我半年前也发现了...

出0入0汤圆

 楼主| 发表于 2013-9-29 13:49:43 | 显示全部楼层
kayatsl 发表于 2013-9-29 13:48
这问题我半年前也发现了...

亲,  有点眉目没 ?

出0入0汤圆

发表于 2013-9-29 14:03:49 | 显示全部楼层
inurl 发表于 2013-9-29 13:49
亲,  有点眉目没 ?

当时项目赶, 没仔细查是哪里写成一样的, tcppcb太多地方会用到了

直接就写了个函数查询指针有没有指向自己的, 一段时间跑一次, 指向自己就重启


在我这里通常只有狂轰滥炸才会出现这现象,平常应用没有出现过这问题, 所以基本稳定运行... 很极端才会出现这个导致重启, 基本不影响不稳定性

出0入0汤圆

发表于 2013-9-29 14:28:04 | 显示全部楼层
我也遇到过,为什么会这样当时好像没找到原因。  怎么搞定的也忘记了......   

出100入101汤圆

发表于 2013-9-29 14:57:31 | 显示全部楼层
关注   

出0入0汤圆

发表于 2013-9-29 15:21:22 | 显示全部楼层
会不会是多释放了一次

出100入101汤圆

发表于 2013-9-29 15:29:35 | 显示全部楼层
kayatsl 发表于 2013-9-29 14:03
当时项目赶, 没仔细查是哪里写成一样的, tcppcb太多地方会用到了

直接就写了个函数查询指针有没有指向自 ...

有没有用操作系统?

出0入0汤圆

 楼主| 发表于 2013-9-29 17:33:02 | 显示全部楼层
root 发表于 2013-9-29 15:21
会不会是多释放了一次

都是调的内部API

出0入0汤圆

 楼主| 发表于 2013-9-29 18:10:59 | 显示全部楼层
root 发表于 2013-9-29 15:21
会不会是多释放了一次

大神, 感觉像是少释放了一次 !

出0入0汤圆

发表于 2013-9-29 18:23:49 | 显示全部楼层
fengyunyu 发表于 2013-9-29 15:29
有没有用操作系统?

freertos..................

出0入0汤圆

 楼主| 发表于 2013-9-29 18:25:31 | 显示全部楼层
  初步找到了问题 , 在tcp_alloc()的时候, 分配到了一个存在于当前tcp_active_pcbs链表的空间。 应该是tcp_close还没来得急完成的时候, tcp_alloc来到了。应该是个bug。

出0入0汤圆

 楼主| 发表于 2013-9-29 18:25:52 | 显示全部楼层
kayatsl 发表于 2013-9-29 18:23
freertos..................

初步找到了问题 , 在tcp_alloc()的时候, 分配到了一个存在于当前tcp_active_pcbs链表的空间。 应该是tcp_close还没来得急完成的时候, tcp_alloc来到了。应该是个bug。

出0入0汤圆

发表于 2013-9-29 18:41:04 | 显示全部楼层
恭喜问题找到了

出0入0汤圆

 楼主| 发表于 2013-9-30 10:11:40 | 显示全部楼层
root 发表于 2013-9-29 18:41
恭喜问题找到了

还需要研究啊

出0入0汤圆

 楼主| 发表于 2013-10-9 10:25:42 | 显示全部楼层
UPUPUPUPUPUPUPUP

出0入0汤圆

发表于 2013-10-9 12:41:57 | 显示全部楼层
关注一下这个问题

出0入0汤圆

发表于 2013-10-11 17:53:03 | 显示全部楼层
http://www.amobbs.com/forum.php? ... p;extra=#pid7033392

记一次lwip中 遇到 pcb == pcb->next 的pcb死循环debug过程

出100入101汤圆

发表于 2014-4-30 15:04:53 | 显示全部楼层
本帖最后由 fengyunyu 于 2014-4-30 15:09 编辑
kayatsl 发表于 2013-9-29 14:03
当时项目赶, 没仔细查是哪里写成一样的, tcppcb太多地方会用到了

直接就写了个函数查询指针有没有指向自 ...


没有再出问题了么?

出0入0汤圆

发表于 2014-4-30 15:37:15 | 显示全部楼层
fengyunyu 发表于 2014-4-30 15:04
没有再出问题了么?

看系统的log, 这半年貌似没再出现了..

出0入0汤圆

发表于 2014-6-24 16:16:50 | 显示全部楼层
inurl 发表于 2013-9-29 18:25
初步找到了问题 , 在tcp_alloc()的时候, 分配到了一个存在于当前tcp_active_pcbs链表的空间。 应该是tc ...

亲,我现在就碰到这个问题了,把服务器关闭了,客户端一直不断的尝试连接,没连接成功就置标志位,然后tcp_close,然后重新连接,
会调用tcp_alloc,就这样一直跑十分钟左右就死机了, 然后就pcb == pcb->next,楼主这个问题解决了吗?困扰一两天了,还找不出头绪,
我的是裸跑的,如果是个BUG解决不了 想用RTT系统的 不知道会不会一样有问题
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-5-20 03:23

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

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