资料介绍
现象
51交换机中移入ERPS功能后,通过ping设备抓包发现设备的mac地址的后两位并不是设备的原先的地址,原先的mac地址为 fc:19:d0:01:02:03,但是设备arp应答的地址却是
fc:19:d0:01:05:07,设备arp应答的地址时通过uip_ethaddr该全局变量获取的。故pc发送icmp的目的mac地址
fc:19:d0:01:05:07,不为设备的mac地址,设备无法命中对应的ACL规则,导致ping设备不通.
初步怀疑是新增ERPS代码导致
故通过添加调试打印的方式进行跟踪查看该全局变量uip_ethaddr的mac地址是何时被修改的,从设备初始化开始加,最后发现在main函数中的while循环中,当第一个10ms定时器出发后,进入Drv_Port_IsolateApply()该函数的调用后uip_ethaddr该内容的后面两个字节就被修改了。当时感觉很不可思议,怎么无缘无故就发生变化了呢。
则通过注释ERPS的新增代码发现,当注释到uip_ERPS_PduHandle函数时发现能够正常ping通设备。并且经过测试发现当将某个全局变量改大或者改小的话,问题也不会出。这就更加感觉离谱了,然后就怀疑是存储变量的xdata区域是否有界限限定,但是咨询后发现xdata区域大小是48K,所以并没有超出范围。
借助MAP文件分析
通过咨询得到可以通过Keil编译生成的MAP文件进行查看uip_ethaddr该变量前后是否出现相关其他变量,是否出现内存越界问题。借助MAP文件,经过测试发现当问题出现时总是发生在指针地址为02007FF6H地方,并且是从02007FFAH的位置开始踩内存,踩内存的大小为6个字节。
根据这一现象,则怀疑是否我们原先代码就是存在这样的问题的,然后从库上下载代码,并且通过调整几个变量的大小,使得 uip_ethaddr的位置刚好落在02007FF6H处。最后验证发现确实是同样存在问题的,uip_ethaddr的内存的最后两个字节被修改为05,07。然后再次调整,将某个全局变量落在该指针处,通过将该指针的内容打印方式进行确认是否是在该问题02007FFAH的往后6个字节被踩掉了。结果验证确实如此,该全局数组的数据从指针地址02007FFAH开始的往后6个字节被修改了。
故猜想是否只要有内存落在该地址区间,这片内存就会被改变,根据该猜想进行验证,通过查找文档发现,可以直接指定某个变量在某个地址区间,Keil C可以让你指定变量的存储地址例如 你想定义一个整型变量 并把它初始化为0x4050 用C是不能够把变量指定在某个地址的 另外你也不能指定位变量的地址 但是 对于不需要初始化的变量 你可以使用关键字_at_来指定地址,故根据文档设置全局变量如下: uint8 xdata ucString2[64] _at_ 0x7FF6; 并且通过调试手段将该内存的内容给打印出来。经过测试发现,正如我们猜想的,还是在同一个位置地址02007FFAH处被踩了6 个字节。根据上述现象,我们就想采取使用占用地址的方式来规避该问题。
- 嵌入式 Linux 中的内存管理
- arm嵌入式系统基础总结教程
- ARM嵌入式系统BSP的程序设计总结
- Python在嵌入式项目中的辅助开发总结
- 嵌入式知识点总结
- 基于Python的实时嵌入式软件测试脚本总结
- 嵌入式系统与嵌入式PLC
- 嵌入式系统论文总结
- 嵌入式设备固件的安全分析和测评技术 8次下载
- 单片机与嵌入式的详细资料总结免费下载 32次下载
- 嵌入式Linux设备驱动程序开发基础知识总结免费下载 13次下载
- 嵌入式装置内存泄漏检测系统设计 3次下载
- TI的嵌入式分析技术使设备更加智能 9次下载
- 基于嵌入式Linux LCD设备驱动分析 14次下载
- 嵌入式设备故障检测和诊断系统设计
- 嵌入式fpga是什么意思 992次阅读
- 什么是嵌入式系统?嵌入式系统的具体应用 2096次阅读
- 嵌入式设备系统日志记录方法 4993次阅读
- 嵌入式开发是否应该使用动态内存分配 1515次阅读
- 嵌入式C语言知识点总结 2575次阅读
- 嵌入式系统节省内存的解决方法 3128次阅读
- 嵌入式系统内存管理机制详解 4430次阅读
- 嵌入式系统开发学习心得体会_经验总结 3w次阅读
- 嵌入式行业发展状况_嵌入式行业人才需求_嵌入式系统就业前景分析 2.3w次阅读
- 全面的嵌入式基础知识总结 8561次阅读
- 嵌入式开发就业前景分析_嵌入式领域的职业发展方向 1.8w次阅读
- 嵌入式输入设备设计 1232次阅读
- 嵌入式输入设备设计应用 478次阅读
- 必读:嵌入式系统基础及知识及接口技术总结 2062次阅读
- 一种嵌入式系统的内存分配方案 2220次阅读
下载排行
本周
- 1感应笔电路图
- 0.06 MB | 7次下载 | 免费
- 2美的电磁炉维修手册大全
- 1.56 MB | 5次下载 | 5 积分
- 3Cortex-M3/M4F指令集技术用户手册
- 2.28MB | 3次下载 | 免费
- 4SMD LED选型手册 贴片灯珠
- 5.47 MB | 3次下载 | 免费
- 5基于PLC的拉丝机张力控制系统研究
- 0.14 MB | 2次下载 | 5 积分
- 6LZC3106G高性能谐振控制器中文手册
- 1.29 MB | 1次下载 | 1 积分
- 7JL2233B集成电平转换功能的LDO中文手册
- 0.50 MB | 1次下载 | 免费
- 8加密芯片的一种破解方法和对应加密方案改进设计
- 0.29 MB | 1次下载 | 免费
本月
- 1使用单片机实现七人表决器的程序和仿真资料免费下载
- 2.96 MB | 44次下载 | 免费
- 2UC3842/3/4/5电源管理芯片中文手册
- 1.75 MB | 19次下载 | 免费
- 3华瑞昇CR216芯片数字万用表规格书附原理图及校正流程方法
- 0.74 MB | 14次下载 | 3 积分
- 4DMT0660数字万用表产品说明书
- 0.70 MB | 13次下载 | 免费
- 53314A函数发生器维修手册
- 16.30 MB | 13次下载 | 免费
- 6TPS54202H降压转换器评估模块用户指南
- 1.02MB | 8次下载 | 免费
- 7STM32F101x8/STM32F101xB手册
- 1.69 MB | 8次下载 | 1 积分
- 8感应笔电路图
- 0.06 MB | 7次下载 | 免费
总榜
- 1matlab软件下载入口
- 未知 | 935119次下载 | 10 积分
- 2开源硬件-PMP21529.1-4 开关降压/升压双向直流/直流转换器 PCB layout 设计
- 1.48MB | 420062次下载 | 10 积分
- 3Altium DXP2002下载入口
- 未知 | 233084次下载 | 10 积分
- 4电路仿真软件multisim 10.0免费下载
- 340992 | 191367次下载 | 10 积分
- 5十天学会AVR单片机与C语言视频教程 下载
- 158M | 183335次下载 | 10 积分
- 6labview8.5下载
- 未知 | 81581次下载 | 10 积分
- 7Keil工具MDK-Arm免费下载
- 0.02 MB | 73807次下载 | 10 积分
- 8LabVIEW 8.6下载
- 未知 | 65987次下载 | 10 积分
评论
查看更多