当前位置: 首页 > article >正文

从Ping命令到网卡:用Wireshark抓包深度解析LwIP 2.1.0的数据发送链路

从Ping命令到网卡用Wireshark抓包深度解析LwIP 2.1.0的数据发送链路当你在嵌入式设备上执行ping 192.168.1.1时ICMP报文究竟经历了怎样的奇幻旅程本文将带你用Wireshark抓包工具逆向拆解LwIP协议栈的数据发送链路通过可视化抓包源码对照的双重视角揭示从应用层到物理层的完整封装过程。不同于传统由内向外的代码分析我们将采用网络工程师的视角从抓包结果反向追踪协议栈行为这种独特的调试方法能帮助开发者快速定位网络层异常。1. 实验环境搭建与抓包准备在开始解剖数据包之前我们需要构建一个可观测的调试环境。推荐使用以下组合硬件平台STM32F407 Discovery开发板内置ETH接口或QEMU虚拟设备协议栈LwIP 2.1.0配置LWIP_RAW1启用RAW API抓包工具Wireshark 3.6需开启Promiscuous模式测试用例修改自contrib-2.1.0/apps/ping/ping.c的自定义Ping程序关键配置要点/* ping.c 线程函数示例 */ void ping_thread(void *arg) { int s lwip_socket(AF_INET, SOCK_RAW, IP_PROTO_ICMP); struct timeval timeout { 2, 0 }; // 2秒超时 lwip_setsockopt(s, SOL_SOCKET, SO_RCVTIMEO, timeout, sizeof(timeout)); while(1) { ping_send(s, dest_addr); // 发送ICMP Echo ping_recv(s); // 接收ICMP Reply sys_msleep(1000); // 1秒间隔 } }注意确保主机与设备通过交换机直连避免路由器过滤ICMP报文。若使用虚拟环境需配置QEMU的-net tap模式。2. Wireshark捕获的ICMP报文解析启动Ping程序后Wireshark将捕获到类似如下的数据帧Frame 1: 98 bytes on wire (784 bits) Ethernet II Destination: 00:80:e1:12:34:56 (Broadcast) Source: 00:22:33:44:55:66 Internet Protocol Version 4 Source: 192.168.1.100 Destination: 192.168.1.1 Internet Control Message Protocol Type: 8 (Echo (ping) request) Code: 0 Checksum: 0x1234 [correct] Identifier: 0x0001 Sequence Number: 1 Data: abcdefghijklmnopqrstuvwabcdefghi这个标准ICMP报文背后隐藏着LwIP协议栈的五层封装过程应用层ping_send()构造ICMP Echo头部传输层RAW Socket处理协议类型(IP_PROTO_ICMP)网络层ip4_output_if()添加IP头部链路层etharp_output()处理ARP和以太网帧物理层low_level_output()写入网卡缓冲区3. 逆向追踪协议栈调用链3.1 从抓包结果定位源码位置通过Wireshark的Follow UDP Stream功能可以观察到每个ICMP报文都对应着协议栈中的关键函数调用。例如IP头部TTL255→ 在ip4_output_if()中设置的默认值无IP分片标志→pbuf结构体的tot_len字段小于MTU以太网广播地址→etharp_output()在ARP缓存未命中时的行为关键数据结构对照/* 对应Wireshark中的IP头部 */ struct ip_hdr { u16_t _v_hl_tos; // 版本头部长度TOS u16_t _len; // 总长度 u16_t _id; // 标识符 u16_t _offset; // 分片偏移 u8_t _ttl; // 生存时间 u8_t _proto; // 协议类型 u16_t _chksum; // 校验和 ip4_addr_p_t src, dest; // 源/目的IP };3.2 关键函数调用路径根据抓包特征逆向推导出的调用序列ping_send()→lwip_sendto()netconn_send()→lwip_netconn_do_send()raw_sendto()→raw_sendto_if_src()ip4_output_if()→etharp_output()low_level_output()→ DMA传输提示在调试时可以在low_level_output()中添加打印语句实时观察网卡驱动是否被正确调用。4. 协议栈分层封装实战分析4.1 应用层ICMP报文构造ping_send()中的核心操作iecho (struct icmp_echo_hdr *)mem_malloc(ping_size); iecho-type ICMP_ECHO; // 类型8 iecho-code 0; // 代码0 iecho-chksum 0; // 暂存校验和 iecho-id ping_id; // 进程标识符 iecho-seqno htons(seqno); // 序列号此时Wireshark可见特征数据部分包含时间戳和填充字符校验和字段为全零尚未计算4.2 网络层IP封装过程ip4_output_if()执行的头部填充逻辑字段名设置方式抓包示例值版本/头部长度IP_HLEN / 44 4TOS取自RAW PCB的tos字段0x00总长度pbuf-tot_len0x0054 (84字节)TTL默认值2550xFF协议类型来自socket创建时的参数0x01 (ICMP)4.3 链路层ARP与帧封装当目标MAC地址未知时etharp_output()的行为发送ARP请求广播缓存当前数据包etharp_queue()收到ARP响应后继续发送这个过程中Wireshark会先捕获到ARP who-has 192.168.1.1 tell 192.168.1.100 ARP reply 192.168.1.1 is-at 00:80:e1:12:34:565. 网卡驱动层的关键实现在ethernetif.c中必须正确实现的三个核心函数初始化函数void low_level_init(struct netif *netif) { netif-hwaddr_len ETHARP_HWADDR_LEN; netif-mtu 1500; netif-flags NETIF_FLAG_BROADCAST | NETIF_FLAG_ETHARP; // 硬件初始化代码... }发送函数err_t low_level_output(struct netif *netif, struct pbuf *p) { uint8_t *buffer (uint8_t *)p-payload; uint32_t length p-tot_len; // 启动DMA传输 HAL_ETH_TransmitFrame(ð_handle, length); return ERR_OK; }接收函数用于Ping回复struct pbuf *low_level_input(struct netif *netif) { struct pbuf *p pbuf_alloc(PBUF_RAW, len, PBUF_POOL); HAL_ETH_ReadData(ð_handle, (uint8_t *)p-payload, len); return p; }6. 典型问题排查指南根据Wireshark抓包结果快速诊断现象可能原因调试建议无任何数据包网卡未初始化检查low_level_init()调用链只有ARP请求无ICMPIP层发送失败断点调试ip4_output_if()ICMP报文校验和错误内存越界或DMA传输损坏启用PBUF_DEBUG进行校验收到回复但应用层未捕获Socket配置错误验证SO_RCVTIMEO超时设置在STM32平台上我曾遇到DMA传输长度未对齐导致报文截断的问题。通过以下修改修复// 在low_level_output()中添加4字节对齐处理 uint32_t aligned_len (length 3) ~0x03; HAL_ETH_TransmitFrame(ð_handle, aligned_len);这种结合抓包与源码的调试方法能显著提高嵌入式网络问题的定位效率。当你下次看到Wireshark中红色的Malformed Packet提示时不妨沿着本文的调用链逐层检查往往能在协议栈的某个分层边界找到答案。

相关文章:

从Ping命令到网卡:用Wireshark抓包深度解析LwIP 2.1.0的数据发送链路

从Ping命令到网卡:用Wireshark抓包深度解析LwIP 2.1.0的数据发送链路 当你在嵌入式设备上执行ping 192.168.1.1时,ICMP报文究竟经历了怎样的奇幻旅程?本文将带你用Wireshark抓包工具逆向拆解LwIP协议栈的数据发送链路,通过可视化抓…...

【病变检测】基于CNN实现视网膜影像检测糖尿病视网膜病变附Matlab代码

✅作者简介:热爱科研的Matlab仿真开发者,擅长毕业设计辅导、数学建模、数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。🍎 往期回顾关注个人主页:Matlab科研工作室👇 关注我领取海量matlab电子书和…...

【数据库系统】数据库系统概论——第十一章 并发控制

第十一章 并发控制 文章目录 第十一章 并发控制 前言 11.1并发控制概述 11.2封锁 11.3封锁协议 11.4活锁和死锁 11.4.1活锁 11.4.2死锁 11.5并发调度的可串行性 11.5.1可串行化调度 11.5.2冲突可串行化调度 11.6两段锁协议 11.7封锁的粒度 11.7.1多粒度封锁 11.7.2意向锁 11.8其…...

保姆级教程:用记事本写个.cmd脚本,一键解决Unity Hub安装包验证失败

一键解决Unity Hub安装包验证失败的终极脚本方案 每次打开Unity Hub都要手动设置代理?安装包验证失败的问题反复出现?今天教你用记事本写个.cmd脚本,彻底告别重复劳动。这个方案尤其适合那些不熟悉命令行操作,但又希望一劳永逸解…...

Android开发实战:利用BluetoothDevice精准获取蓝牙设备地址

1. 蓝牙设备地址的基础认知 在开始动手写代码之前,我们先要搞清楚蓝牙设备地址到底是什么。简单来说,蓝牙设备地址就像是每个蓝牙设备的身份证号码,全球唯一且不会重复。它由6个字节组成,通常表示为12个十六进制数字,中…...

内存条趋势

截至2026年4月10日,一根16GB DDR4内存条的市场价格,取决于你通过什么渠道购买: 现货市场(如华强北、电商零售):价格在 689元 至 759元 之间-2-4-10。 合约市场(品牌新机采购价)&…...

科哥版fft npainting lama图像修复:5分钟快速部署,小白也能轻松去除水印

科哥版fft npainting lama图像修复:5分钟快速部署,小白也能轻松去除水印 1. 引言:为什么选择这款图像修复工具 在日常工作和生活中,我们经常遇到需要处理图片的情况:去除水印、删除不需要的物体、修复老照片瑕疵等。…...

给你的Windows来一次“数字瘦身“:告别卡顿与干扰,重获流畅体验

给你的Windows来一次"数字瘦身":告别卡顿与干扰,重获流畅体验 【免费下载链接】Win11Debloat A simple, lightweight PowerShell script that allows you to remove pre-installed apps, disable telemetry, as well as perform various other…...

Lychee Rerank MM免配置教程:绕过HuggingFace下载直启Qwen2.5-VL重排序服务

Lychee Rerank MM免配置教程:绕过HuggingFace下载直启Qwen2.5-VL重排序服务 1. 引言:为什么需要免配置方案 如果你曾经尝试部署多模态AI模型,一定遇到过这样的烦恼:从HuggingFace下载几个GB的模型文件,网络不稳定导致…...

【Loom响应式重构黄金窗口期】:JDK21 LTS已发布,你的Java 8/17项目还剩9个月兼容缓冲期!

第一章:Loom响应式重构黄金窗口期全景洞察Java Loom 项目自JDK 21正式转为生产就绪以来,其虚拟线程(Virtual Threads)与结构化并发(Structured Concurrency)能力正深刻重塑高并发服务的架构范式。当前正处于…...

1000+ 道 Java面试题及答案整理(牛客网最新版)

作为 Java 程序员,选择学习什么样的技术?什么技术该不该学?去招聘网站上搜一搜、看看岗位要求就十分清楚了,自己具备的技术和能力,直接影响到你工作选择范围和能不能面试成功。 如果想进大厂,那就需要在 Ja…...

5个Python生物信息学实战技巧:从数据处理到机器学习完整指南

5个Python生物信息学实战技巧:从数据处理到机器学习完整指南 【免费下载链接】Bioinformatics-with-Python-Cookbook-Second-Edition 项目地址: https://gitcode.com/gh_mirrors/bi/Bioinformatics-with-Python-Cookbook-Second-Edition Python生物信息学是…...

面试必问:JDK 8有哪些新特性?这一篇彻底讲清楚

如果你也有这些困惑,那这篇文章就是为你准备的。 我用了一整天时间,把Java从1996年诞生到今天的发展历程彻底梳理了一遍。看完这篇,你不仅知道每个版本有哪些重要特性,还能明白"为什么企业都用JDK 8"、"新项目该选…...

FreeRTOS任务优先级设置不当导致系统卡死的排查与修复

1. FreeRTOS任务优先级设置不当的典型表现 在STM32F1系列单片机开发中,使用FreeRTOS时如果任务优先级设置不当,系统往往会表现出一些典型症状。最常见的就是系统运行一段时间后突然卡死,所有任务停止响应,连最基本的LED闪烁或串口…...

终极Obsidian样式定制指南:5分钟打造个性化知识管理界面

终极Obsidian样式定制指南:5分钟打造个性化知识管理界面 【免费下载链接】obsidian-style-settings A dynamic user interface for adjusting theme, plugin, and snippet CSS variables within Obsidian 项目地址: https://gitcode.com/gh_mirrors/ob/obsidian-s…...

医学信息学实战:队列研究设计与数据分析的关键要点

1. 队列研究的基本概念与核心价值 第一次接触队列研究时,我也被那些专业术语绕得头晕。直到参与了一个真实的糖尿病并发症研究项目,才真正理解这种方法的精妙之处。简单来说,队列研究就像给人群拍连续剧——把研究对象按是否接触某种因素&…...

SteamCleaner:一键释放60GB硬盘空间的专业游戏缓存清理工具

SteamCleaner:一键释放60GB硬盘空间的专业游戏缓存清理工具 【免费下载链接】SteamCleaner :us: A PC utility for restoring disk space from various game clients like Origin, Steam, Uplay, Battle.net, GoG and Nexon :us: 项目地址: https://gitcode.com/g…...

FastVideo 未来展望:下一代视频生成技术路线图分析

FastVideo 未来展望:下一代视频生成技术路线图分析 【免费下载链接】FastVideo A unified inference and post-training framework for accelerated video generation. 项目地址: https://gitcode.com/gh_mirrors/fa/FastVideo FastVideo 作为统一的视频生成…...

Rusted PackFile Manager:从零开始打造你的Total War模组

Rusted PackFile Manager:从零开始打造你的Total War模组 【免费下载链接】rpfm Rusted PackFile Manager (RPFM) is a... reimplementation in Rust and Qt5 of PackFile Manager (PFM), one of the best modding tools for Total War Games. 项目地址: https://…...

Janus-Pro-7B快速入门:10分钟完成GitHub镜像拉取与本地部署

Janus-Pro-7B快速入门:10分钟完成GitHub镜像拉取与本地部署 你是不是也对那些动辄几十上百G的大模型望而却步,觉得部署起来太麻烦?今天咱们就来聊聊Janus-Pro-7B,一个在GitHub上挺火的开源模型,我会带你用最简单的方式…...

StructBERT语义相似度分析:Docker一键部署方案,解决PyTorch兼容性问题

StructBERT语义相似度分析:Docker一键部署方案,解决PyTorch兼容性问题 1. 为什么需要这个解决方案 在自然语言处理领域,语义相似度计算是一个基础但至关重要的任务。无论是智能客服、内容推荐还是文本查重,都需要准确判断两段文…...

5步掌握Android设备远程控制:py-scrcpy-client实战指南

5步掌握Android设备远程控制:py-scrcpy-client实战指南 【免费下载链接】py-scrcpy-client 项目地址: https://gitcode.com/gh_mirrors/py/py-scrcpy-client 想要在电脑上实时查看和控制Android设备吗?py-scrcpy-client为你提供了完美的解决方案…...

带式输送机传动滚筒的设计

目 录 摘要 ………………………………………………………………………………(Ⅰ) Abstract……………………………………………………………………………(Ⅱ) 第一章 绪论………………………………………………………………………(01) 1.1概述……………………………………………...

OpenCode快速上手:3步配置本地AI编程环境,告别复杂安装

OpenCode快速上手:3步配置本地AI编程环境,告别复杂安装 1. 引言:为什么选择OpenCode? 在AI编程助手领域,OpenCode以其独特的终端优先设计和隐私安全特性脱颖而出。作为一个2024年开源的Go语言框架,它能够…...

3分钟快速优化Windows性能:Mem Reduct系统优化工具终极指南

3分钟快速优化Windows性能:Mem Reduct系统优化工具终极指南 【免费下载链接】memreduct Lightweight real-time memory management application to monitor and clean system memory on your computer. 项目地址: https://gitcode.com/gh_mirrors/me/memreduct …...

蓝桥杯单片机各模块化代码

138译码器相关,基础模块的必要工具//HC138端口选择 //通过前三位按位与,其他位数按位或的原理 //省去了部分HC138选端口的代码 //最好分开写 void InitHC138(unsigned char n) {switch(n){case 4:P2P2&0x1f; P2P2|0x80; …...

亲测有效!Xinference-v1.17.1部署避坑指南与性能调优

亲测有效!Xinference-v1.17.1部署避坑指南与性能调优 1. 引言 最近在项目里折腾AI模型服务,从零开始部署开源大模型,踩了不少坑。试过几个平台,要么配置复杂,要么性能拉胯,直到遇到了Xinference-v1.17.1。…...

PCB 相关知识

一.PCB线宽单位换算:100mil 2.54mm 。二.在1盎司的铜厚上过1A电流需要,1mm(40mil)的线宽。三:不要并排打孔,需要错位打孔:防止回流平面被割裂,绕线辐射。且增加走线空间。四.1:mark…...

猫抓Cat-Catch:如何轻松实现网页视频资源嗅探与一键下载

猫抓Cat-Catch:如何轻松实现网页视频资源嗅探与一键下载 【免费下载链接】cat-catch 猫抓 浏览器资源嗅探扩展 / cat-catch Browser Resource Sniffing Extension 项目地址: https://gitcode.com/GitHub_Trending/ca/cat-catch 还在为无法下载网页视频而烦恼…...

天地图(T=img_w/c)和谷歌地图(lyrs=s/m)的URL参数到底怎么用?一篇讲清所有地图瓦片服务调用细节

天地图与谷歌地图URL参数全解析:从瓦片调用到坐标系实战 当你需要在项目中集成地图服务时,是否曾被各种URL参数搞得一头雾水?Timg_w和Timg_c有什么区别?lyrss和lyrsm又代表什么?本文将彻底拆解两大主流地图服务的URL设…...