OpenEdv-开源电子网

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

stm32H7 以太网收到固定长度字节后,无法继续收数据问题

[复制链接]

48

主题

135

帖子

0

精华

高级会员

Rank: 4

积分
561
金钱
561
注册时间
2017-8-29
在线时间
89 小时
发表于 2021-4-15 10:23:41 | 显示全部楼层 |阅读模式
1金钱
STM32H7,仿照原子阿波罗以太示例移植代码。 移植后,单片机搭建Server端,PC客户端建立连接。可正常收发。
后续测试稳定性:
1、间隔2s发送长度18bytes的指令,当发送到162帧时,单片机不再回复; (18 * 162 = 2916)
2、间隔2s发送长度12bytes的指令,当发送到242帧时,单片机不再回复; (12 * 242 = 2904)

Debug调试,发现162帧或242帧后,再发送指令,代码无法运行至recv回调函数。 只有断开连接再重新连接后方可继续正常收发。

发现2916bytes和2904bytes非常接近,是否是ethernetif.c配置时有什么缓存的长度限制了?或者没及时释放?


请求给位大佬能够指点一二。谢谢!!!!

最佳答案

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

问题已经解决。 猜测可能原因是:某些缓存没有被释放。 解决方式: 在接收回调函数中,原先处理方式: struct pbuf *q = NULL; unsigned long copylen = 0; unsigned long copyedsize = 0; char *recvBuf = NULL; /* 申请大小TCP_SERVER_RX_BUFSIZE 缓存 */ recvBuf = (char *)mem_malloc(TCP_SERVER_RX_BUFSIZE); if (recvBuf != NULL) { for (q = p; q != NULL; q ...
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

48

主题

135

帖子

0

精华

高级会员

Rank: 4

积分
561
金钱
561
注册时间
2017-8-29
在线时间
89 小时
 楼主| 发表于 2021-4-15 10:23:42 | 显示全部楼层
问题已经解决。

猜测可能原因是:某些缓存没有被释放。

解决方式:
在接收回调函数中,原先处理方式:
        struct pbuf *q = NULL;
        unsigned long copylen = 0;
        unsigned long copyedsize = 0;
                char *recvBuf = NULL;
                /* 申请大小TCP_SERVER_RX_BUFSIZE 缓存 */
                recvBuf = (char *)mem_malloc(TCP_SERVER_RX_BUFSIZE);
                if (recvBuf != NULL)
                {
                for (q = p; q != NULL; q = q->next)
                {
                    copylen = MIN(q->len, (TCP_SERVER_RX_BUFSIZE - copyedsize));
                    MEMCPY((recvBuf + copyedsize), q->payload , copylen);
                    copyedsize += copylen;
                    if (copyedsize >= TCP_SERVER_RX_BUFSIZE)
                    {
                        break;
                    }
                }
                       
                        /* free pbuf */
                        pbuf_free(p);
/* update recv window */
                        tcp_recved(tpcb, p->tot_len);

                        /* 数据处理 */
                        es->pfHandleRecvData((UBYTE*)recvBuf, copyedsize, es);

                        /* 释放缓存 */
                        mem_free(recvBuf);
                }

现在的处理方式:
将   tcp_recved(tpcb, p->tot_len);  放到 pbuf_free(p);   前面。

解决了该问题。




                       
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-2-28 03:33

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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