用扬创UTU24440-V4.5的核心板,自己做的底板,数据线通过16245驱动后进入DM9000,用读信号(IOR)控制16245的数据方向,写信号、中断IRQ、ADDR2等都是直接从ARM2440接到DM9000的,数据线和信号线走线有点长,有15cm的样子,DM9000的电路和网络变压器都是按开发板设计的。 用扬创的Uboot、内核镜像和文件系统,在开发板上网络是好的,但是在我的底板上就出现PING一会还通,过了一会又不通的情况,最后在内核驱动里加入了打印信息分析,发现DM9000驱动里面的发送函数一直在工作,死循环,怪的是每次发的数据都是一样的,发送的堆栈也取不完,奇怪!!最后用示波器看IRQ_LAN信号,发现正常时几秒才有一个中断,但是发送函数一直工作时IRQ_LAN信号就一直有信号,造成ARM内核一直往外发数据,这个数据有时抓包工具抓不到,有时抓到也是乱的,但是分析抓包数据可以看出抓到的数据也对,就是DM9000的ARP包,只是排序错了,就是数据平移了。
软件没有问题,在以前自己做的一个底板上面试就没有问题,在开发板的底板上夜没有问题。
我分析应该是硬件方面出了问题,但我不知道是哪个地方,DM9000片子我也换过了、网络变压器我也换过、49.9欧姆电阻也换过、无源晶体我也换过有源晶振试过,但始终找不到问题,不知道为什么DM9000的中断引脚会输出很多有效电平,促使ARM内核一直发ARP包,而且这个数据时错位的?
大体问题如上,如果哪位高手可指教,将感激不尽啊!
打赏帖 | |
---|---|
rtthread硬件加密--2crc加密分析被打赏10分 | |
【分享开发笔记,赚取电动螺丝刀】mcxa156使用低功耗定时器适配硬件RTC框架被打赏26分 | |
【STM32F769】AI之与本地deepseek对接被打赏50分 | |
Buck电路工作在CCM模式下电感电流的计算公式是什么?被打赏5分 | |
buck电路工作原理被打赏5分 | |
基于MSPM0L1306的MODBUS-RTU协议通讯实验被打赏100分 | |
我想要一部加热台+多合一调试工具被打赏18分 | |
每周了解几个硬件知识+485硬件知识分享被打赏10分 | |
【换取手持示波器】TouchGFX应用移植自定义屏幕被打赏34分 | |
【换取手持数字示波器】树莓派PICO调试器官方固件本地化部署实践被打赏24分 |