| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 嵌入式 -> usb_tuning工具的调试总结 -> 正文阅读 |
|
[嵌入式]usb_tuning工具的调试总结 |
????????此工具是原本是uart接口,后为了省内存改为usb。tuning工具是python写的图形化窗口交互工具,用来给用户获取修改isp和3a参数,交互方式有敲命令、拖动滑条和点击标签。 在调试过程中下位机arm程序出现的几个问题1.程序运行中出现异常 ? ? ? ? 一开始用trace32追踪,只能查出程序是在dev->send指针处出现预取指中止,发现send函数指针的值被改成0xcdcdcdcd,至此只能判断是内存覆盖。于是在send变量的内存处设置内存写断点,后来在usb驱动里面某处停下来了,这是一句函数调用,用来往pdata指向的内存写入上位机发送过来的数据,这样就知道send指针的值是在这里被改写的,pdata指向的地址经过了send内存,send的内容被覆盖。这些工作还只是弄清了现象的直接原因。必须查到根本原因才能解掉这个bug。 ? ? ? ? pdata指向一个堆空间,用以把上位机发送的数据存储在堆里。于是我把pdata的值print出来,转而把send的值也print出来,最后发现随着pdata的递增,指向的地址越来越靠近send的内存地址。真相渐渐清晰了,send变量也被分配在堆里,而pdata也指向堆。分析代码后发现send是一个device结构体的成员,而所有的device结构体都用链表的形式用calloc函数存储在了堆里。而我们的堆空间极其有限只有4096个字节。 ? ? ? ? 最后改用数组存储usb数据了,问题得以解决。 2.程序跑飞,停不下来 ? ? ? ? 这是继第一个bug解掉之后的第二个问题。上位机发送isp filter read命令后,得不到下位机的反馈,当我想break时,发现程序停不下来,显然已经跑飞了。 ? ? ? ? 然后我通过print log缩小问题出现的范围,最后发现在读isp寄存器的时候跑飞了,用jtag的dump功能查看内存发现也查看不了,然后确定是isp模块没有工作,读寄存器导致跑飞。 3.上位机偶尔收不到下位机的数据 ? ? ? ? 这个情况是偶尔的,最后发现是arm没有接收完上位机的完整一条命令(分多次中断接收),我就开始usb write了,没有做好错误处理。 总结? ? ? ? 调试是程序员很重要的一部分内容,要善于运用多种调试工具和手段,区分不同调试工具和手段的局限性,从而选择最合理的。在调试中,程序员的思维也很重要,严防掉进不重要的细节陷阱,关注最重要的地方。仅仅凭经验调试是走不远的,思路也很重要。 ? ? ? ?? |
|
嵌入式 最新文章 |
基于高精度单片机开发红外测温仪方案 |
89C51单片机与DAC0832 |
基于51单片机宠物自动投料喂食器控制系统仿 |
《痞子衡嵌入式半月刊》 第 68 期 |
多思计组实验实验七 简单模型机实验 |
CSC7720 |
启明智显分享| ESP32学习笔记参考--PWM(脉冲 |
STM32初探 |
STM32 总结 |
【STM32】CubeMX例程四---定时器中断(附工 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/25 20:25:47- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |