工程师笔记 | Lwip中和 IP分包相关的参数

STM32单片机 2020-10-27 00:00





前不久接到一个客户的问题。在H743上需要通过UDP发送大的数据包,涉及到IP分包的问题。他们在测试的过程中遇到了只要发送6KBUDP数据包就会出现hardfault的问题。拿到这个问题的时候,调试得到了和客户一样的现象:


程序进入hardfault,并且是由Lwip协议栈的 

ip_reass_free_complete_datagram函数触发。后经过一番调试,搞清楚了问题的原因,要说清楚,我们得先来看看Lwip中IP分包的实现。


IP分包


因为以太网对一次传输数据的最大长度规定为1500字节,所以如果UDP的数据包大于这个长度,就会在IP层进行分包后,再通过以太网传输。用户数据通过UDP发送,数据封装的过程如下图:



IP首部一般是20字节,UDP首部8字节,1500-20-8=1472,所以当发送的用户数据超过1472个字节后,IP层就会分包。分包和重组的工作都是在IP层自动完成,对于UDP层来说,不用关心这个过程。


IP分包

Lwip中IP数据重组的实现


Lwip中通过ip_reassdata数据结构来描述一份正在被重组的IP数据报,其中的p字段指向第一个数据分片。Lwip中可以同时处理多个IP数据报的重组,每个IP数据报对应一个ip_reassdata数据结构,并且通过结构中的next指针构成一个单向的链表。reassdatagrams,指向ip_reassdata结构组成的链表的开头。


当以太网底层驱动接收到数据后,将数据传递给Lwip协议栈,ip_input函数会根据当前是IPv4还是IPV6调用对应的处理函数。在ip4_input中,通过检查IP首部中的标志位和分片偏移量,来判断当前是否是一个IP分片包。如果是就调用ip4_reass进行重组。


在整个IP数据报重组完成之前,接收到的IP分片包都保存在buffer中,如果其中的某个分片丢失,则重组就无法完成,而这些不全的IP分包数据不能一直占着buffer,所以在Lwip中定义了ip_reassdata的生存时间,每1秒执行一次ip_reass_tmr函数,将生存时间减1,当减到0后就删除对应的ip_reassdata数据结构,以及其上挂的所有数据分片pbuf。


IP分包

Lwip中IP数据分片的实现


发送的过程比接收的过程相对简单,大致就是:UDP层将要发送的数据组装在一个pbuf中,然后调用ip_output发送数据,当然在这个过程中,协议栈会添加相应的IP首部数据。如果IP数据报的长度大于以太网的MTU时,Lwip协议栈的IP层就会进行分片,将数据报分成两个或者更多进行发送。IP分片的工作是在ip_frag函数中完成的。


代码的实现在这里就不详细展开介绍了。我们这里主要讲的是,我们在应用Lwip的时候,哪些配置参数是需要注意的。


Lwip的相关配置参数


opt.h里有所有的Lwip默认配置,另外lwipopts.h中是应用程序中对lwip协议栈的配置。协议栈首先会去检查lwipopts.h中的参数,没有定义的再去检查opt.h。所以lwipopts.h中的配置会覆盖opt.h中的配置。这里我们只看和IP分片重组相关的部分。


IP_REASSEMBLY和IP_FRAG:如果需要支持IP重组和分片功能,这两个宏一定要设置为1。


IP_REASS_MAXAGE:IP分片包的生存时间,超过这个时间还没有收到所有的IP分片,则重组失败,已经收到的IP分片也将从协议栈中删除。以秒为单位。


MEMP_NUM_REASSDATA:可以同时进行IP重组的IP数据报的个数。这个数值是指整个IP数据报的个数,不是指IP分片的个数。


IP_REASS_MAX_PBUFS:指在ip_reassdata链表中挂接的,等待重组的pbuf的总个数。


MEMP_NUM_FRAG_PBUF:可同时发送的IP分片个数。


MEM_SIZE : heap大小,发送的数据越大,这个size就需要越大。


PBUF_POOL_SIZE:pbuf pool中buffer的个数,跟接收数据的大小有关。


PBUF_POOL_BUFSIZE:pbuf pool中每个buffer的大小,跟接收数据的大小有关。


问题分析


我们再回到一开始遇到的问题。


发送6KB的UDP数据,通过wireshark抓包可以看到,这6KB的数据被分成了5个IP分片发出来。但程序中只设置了4个ETH_RX_Buffer,每个buffer有1536个字节,虽然4个buffer加起来有6144字节,看起来刚好够我们发送的6KB。但我们要知道,STM32MAC层在接收数据的时候,一个以太网帧的数据可以放在多个ETH_RX_Buffer中,但一个ETH_RX_Buffer不能放多个帧的数据。


简单点说,就是MAC层即使只收到1个字节的数据,在当前的配置下,它也会占用掉一个1536字节的buffer。那现在PC端发来了5个IP分片,分别在5个以太网帧中,现在问题就很清楚了,因为我们只设置了4个ETH_RX_Buffer,所以轮到第5个以太网帧的数据过来的时候,ETH_RX_Buffer已经被占完了,没有空余的buffer来接收第5个以太网帧。


这里就不得不提到,


当前STM32Cube_FW_H7_V1.6.0的以太网底层驱动还有一个bug。在H7的驱动中,从底层驱动到lwip协议栈,使用了“零拷贝”的机制,也就是说,ETH_RX_Buffer的地址直接传递给lwip协议栈进行数据处理,不会再进行数据的拷贝。


但是,当前的驱动中,在low_level_input函数中,没有等lwip协议栈处理完ETH_RX_Buffer中的数据,接收 descriptor立刻就被还给ETH DMA了。这样当连续收到大量数据的时候,就会发生后面的数据把前面未处理完的数据覆盖掉的情况(ST官方已经在修改这个问题,在后续版本中会更新,当前可以通过增加ETH_RX_Buffer来解决这个问题)。



好,我们再回到前面的问题上,MAC接收到第5个以太网帧后,由于H7底层驱动的bug,就会将第一个ETH_RX_Buffer中的数据覆盖掉,这样导致lwip协议栈在处理时,因为收到了不完整,且被破坏的数据,出现了hardfault。如果将ETH_RX_DESC_CNT和对应ETH_RX_Buffer个数增加,就可以解决这个问题。当然MPU配置中,Descriptor对应的region范围也要调整大小,这里就不详说。



这个问题,如果继续增加发送的数据大小,就会发现还会遇到其他问题。


随着数据增大,IP分片也增多,


这样在ip_reassdata中挂接的pbuf也增多,


所以还需要关注IP_REASS_MAX_PBUFS的大小,相应进行调整。


而在发送大的数据出现IP分片的时候,


就需要关注MEMP_NUM_FRAG_PBUF,


MEM_SIZE以及发送descriptor的个数了。







STM32单片机 ST MCU (产品+工具+资料+技术+市场+活动)x 您的关注x您的支持 = STM32 单片机蝴蝶乐园
评论 (0)
  • 近年来,随着半导体产业的快速发展和技术的不断迭代,物联网设备种类繁多(如智能家居、工业传感器),对算力、功耗、实时性要求差异大,单一架构无法满足所有需求。因此米尔推出MYD-YT113i开发板(基于全志T113-i)来应对这一市场需求。米尔基于全志T113-i核心板及开发板part 01  T113-i芯片及OpenAMP简介T113-i芯片简介T113-i由两颗ARM A7 、一颗C906(RISC-V)和一颗DSP(HIFI 4)组成。C906(RISC-V核)特性:主频
    米尔电子嵌入式 2025-03-21 16:28 40浏览
  •       知识产权保护对工程师的双向影响      正向的激励,保护了工程师的创新成果与权益,给企业带来了知识产权方面的收益,企业的创新和发明大都是工程师的劳动成果,他们的职务发明应当受到奖励和保护,是企业发展的重要源泉。专利同时也成了工程师职称评定的指标之一,专利体现了工程师的创新能力,在求职、竞聘技术岗位或参与重大项目时,专利证书能显著增强个人竞争力。专利将工程师的创意转化为受法律保护的“无形资产”,避免技术成果被他人抄袭或无偿使
    广州铁金刚 2025-03-25 11:48 91浏览
  • 精益管理的理念和思维是源于日本的丰田模式,虽然精益管理有很多有效而丰有智慧的思想和方法,但在欧美企业要应用精益也并不容易,始终东西方的文化、人民习性都会存在着一点差异。不过,客观来说,精益管理是其优缺点的,以下,优思学院[1]综合吉朱·安东尼(Jiju Antony)教授《中小企业精益六西格玛》一书中的研究略作说明。精益的优点以下是精益生产系统的一些优点(Schonberger,2008):1)积极的劳动力效应。精益战略往往基于员工的主动性,那些从事实际工作的员工才是改善工作的最具创造力的人员。
    优思学院 2025-03-21 15:09 31浏览
  • 在智能终端设备快速普及的当下,语音交互已成为提升用户体验的关键功能。广州唯创电子推出的WT3000T8语音合成芯片,凭借其卓越的语音处理能力、灵活的控制模式及超低功耗设计,成为工业控制、商业终端、公共服务等领域的理想选择。本文将从技术特性、场景适配及成本优势三方面,解析其如何助力行业智能化转型。一、核心技术优势:精准、稳定、易集成1. 高品质语音输出,适配复杂环境音频性能:支持8kbps~320kbps宽范围比特率,兼容MP3/WAV格式,音质清晰自然,无机械感。大容量存储:内置Flash最大支
    广州唯创电子 2025-03-24 09:08 163浏览
  • 文/郭楚妤编辑/cc孙聪颖‍在人工智能与实体经济深度融合的时代浪潮中,究竟何种 AI 产品,方能切实契合用户对美好未来的向往与期待?3 月 20 日,备受全球瞩目的中国家电及消费电子博览会(AWE2025)于上海新国际博览中心盛大开幕。展会首日,长虹重磅推出首款治愈系 AI TV、客餐厅 PRO 共享空调,以及面向低空经济领域的通信模组等一系列创新产品。这一举动充分展现了长虹在家电领域全面推进 AI 化的坚定决心,以及为低空经济等新兴产业提供有力科技支撑的硬核实力 。“首发” 新品,领航用户价值
    华尔街科技眼 2025-03-21 21:13 54浏览
  • 无论你是刚步入职场的新人,还是已经有几年经验的职场老手,培养领导力都是职业发展中一个至关重要的环节。拥有良好的领导能力不仅能让你从人群中脱颖而出,也能让你在团队中成为一个值得信赖、富有影响力的核心成员。什么是领导力?领导力并不仅仅意味着“当老板”或者“发号施令”。它更多地是一种能够影响他人、激发团队潜能,并带领大家实现目标的能力。一位优秀的领导者需要具备清晰的沟通能力、解决问题的能力,以及对人心的深刻理解。他们知道如何激励人心,如何在压力下保持冷静,并能在关键时刻做出正确的决策。如何培养领导力?
    优思学院 2025-03-23 12:24 77浏览
  • 在科技飞速发展的今天,视频监控领域对于高清、稳定、多功能解码芯片的需求与日俱增。现在,一款具有划时代意义的解码芯片——XS9922B 震撼登场,它将为车载监控、倒车影像等应用场景带来全新的变革体验。多协议支持,高清标清一网打尽,XS9922B 作为一款 4 通道模拟复合视频解码芯片,拥有强大的协议兼容性。它不仅支持 HDCCTV 高清协议,让你轻松捕捉高清画面的每一个细节,还兼容 CVBS 标清协议,满足不同设备和场景的多样化需求。无论是 720P/1080P 的高清制式,还是 960H/D1
    芯片徐15652902508 2025-03-21 13:58 32浏览
  • 文/Leon编辑/cc孙聪颖‍去年,百度公关部副总裁璩静的争议言论闹得沸沸扬扬,最终以道歉离职收场。时隔一年,百度的高管又出事了。近日,“百度副总裁谢广军女儿开盒孕妇”事件登上热搜,持续发酵,引起网友对百度数据安全性的怀疑。3月19日晚间,百度正式发布声明,表示坚决谴责窃取和公开他人隐私的网络暴力行为,同时强调,百度内部实施匿名化、假名化处理,经查验,泄露数据并非来自百度,而是海外的社工库,“当事人承认家长给她数据库”为不实信息,针对相关谣言百度已经向公安机关报案。然而,并非所有网友都对这份声明
    华尔街科技眼 2025-03-21 21:21 98浏览
  • 在人工智能与物联网技术蓬勃发展的今天,语音交互已成为智能设备的重要功能。广州唯创电子推出的WT3000T8语音合成芯片凭借其高性能、低功耗和灵活的控制方式,广泛应用于智能家居、工业设备、公共服务终端等领域。本文将从功能特点、调用方法及实际应用场景入手,深入解析这款芯片的核心技术。一、WT3000T8芯片的核心功能WT3000T8是一款基于UART通信的语音合成芯片,支持中文、英文及多语种混合文本的实时合成。其核心优势包括:高兼容性:支持GB2312/GBK/BIG5/UNICODE编码,适应不同
    广州唯创电子 2025-03-24 08:42 152浏览
  • 在智慧城市领域中,当一个智慧路灯项目因信号盲区而被迫增设数百个网关时,当一个传感器网络因入网设备数量爆增而导致系统通信失效时,当一个智慧交通系统因基站故障而导致交通瘫痪时,星型网络拓扑与蜂窝网络拓扑在构建广覆盖与高节点数物联网网络时的局限性便愈发凸显,行业内亟需一种更高效、可靠与稳定的组网技术以满足构建智慧城市海量IoT网络节点的需求。星型网络的无线信号覆盖范围高度依赖网关的部署密度,同时单一网关的承载设备数量有限,难以支撑海量IoT网络节点的城市物联系统;而蜂窝网络的无线信号覆盖范围同样高度依
    华普微HOPERF 2025-03-24 17:00 143浏览
  • 今年全国两会期间,“体重管理”和“育儿”整体配套政策引发了持久广泛关注。从“吃”到“养”,都围绕着国人最为关心的话题:健康。大家常说“病从口入”,在吃这件事上,过去大家可能更多是为了填饱肚子,如今,消费者从挑选食材到厨电都贯彻着健康的宗旨,吃得少了更要吃得好了。这也意味着在新消费趋势下,谁能抓住众人的心头好,就能带起众人的购买欲望,才能在新一轮竞争中脱颖而出。作为家电行业的风向标,在2025年中国家电及消费电子博览会(AWE)上,这两个话题也被媒体和公众频繁提及。深耕中国厨房三十余年的苏泊尔再次
    华尔街科技眼 2025-03-22 11:42 64浏览
  • 核心板简介创龙科技 SOM-TL3562 是一款基于瑞芯微 RK3562J/RK3562 处理器设计的四核 ARM C ortex-A53 + 单核 ARM Cortex-M0 全国产工业核心板,主频高达 2.0GHz。核心板 CPU、R OM、RAM、电源、晶振等所有元器件均采用国产工业级方案,国产化率 100%。核心板通过 LCC 邮票孔 + LGA 封装连接方式引出 MAC、GMAC、PCIe 2.1、USB3.0、 CAN、UART、SPI、MIPI CSI、MIPI
    Tronlong 2025-03-24 09:59 157浏览
  • 人形机器人产业节奏预估:2024年原型机元年,2025年小规模量产元年。当宇树科技H1人形机器人以灵动的手部动作在春晚舞台上演创意融合舞蹈《秧Bot》,舞出"中国智造"时,电视机前十几亿观众第一次深刻意识到:那个需要仰望波士顿动力的时代正在落幕。*图源:宇树科技短短数周后,宇树G1机器人又用一段丝滑的街舞在网络收割亿级播放量,钢铁之躯跳出赛博朋克的浪漫。2月11日,宇树科技在其京东官方旗舰店上架了两款人形机器人产品,型号分别为Unitree H1和G1。2月12日,9.9万元的G1人形机器人首批
    艾迈斯欧司朗 2025-03-22 21:05 119浏览
  • 很多时候我们会以价值来衡量一个人或一件事,也很容易以成败来论定其价值;所谓胜者为王败者为寇,同样的一个人,在成功时是一种评价,如若失败,所得到的又是另一种评断。古训有云:「不以成败论英雄」,成败得失只是一时的胜负,决定胜败的因素很多,无论人、事、时、地、物,都能影响最后的结果,然而结果却不一定是真正最终的价值论断。好比历史上名垂千古的楚汉之争,刘邦最终得胜,开国立业成为汉高祖,然而,刘邦的为人处事、风格操守或是韬略能力,真的就强于项羽吗?其实,刘邦若无萧何、韩信等人鼎力相辅,若非民心一面倒向刘邦
    优思学院 2025-03-21 12:08 36浏览
我要评论
0
10
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦