用扬创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包,而且这个数据时错位的?
大体问题如上,如果哪位高手可指教,将感激不尽啊!
打赏帖 | |
---|---|
分享一种检测按键状态的方法被打赏20分 | |
周末总结一下,STM32C0系列的开发经验被打赏50分 | |
【换取手持数字示波器】MicrochipMPLABHarmony框架下定时器配置被打赏20分 | |
【换取手持数字示波器】MicrochipMPLABHarmony框架下PWM配置被打赏20分 | |
【Cortex-M】Systick Timer使用被打赏10分 | |
分享汽车防盗系统的组成与分类(一)被打赏5分 | |
VOFA+波形显示+JYD-31蓝牙发送和解析不定长数据被打赏10分 | |
【换取手持数字示波器】-STM32F4PWM控制LED灯管亮度被打赏22分 | |
【换取手持数字示波器】STM32F4驱动RPR-0521RS照度、接近一体型传感器被打赏23分 | |
宏定义和const关键字定义被打赏5分 |