用扬创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包,而且这个数据时错位的?
大体问题如上,如果哪位高手可指教,将感激不尽啊!
打赏帖 | |
---|---|
【S32K146】S32DS watchdog 配置使用被打赏20分 | |
【Zephyr】使用 IAR 调试 Zephyr 镜像被打赏20分 | |
【Zephyr】MCXN947 Zephyr 开发入门适配shell被打赏20分 | |
【我要开发板】6.联合MATLAB记录数据被打赏50分 | |
【瑞萨RA2E1开发板】:使用ADC功能实现位移传感器采集方案被打赏20分 | |
【nRF7002DK】基于sht30的温湿度计被打赏20分 | |
【nRF7002DK】日志打印被打赏20分 | |
【换取手持示波器】RGB屏幕移植ARM-2D库被打赏35分 | |
【分享开发笔记,赚取电动螺丝刀】分享一下如何解决瑞萨RA2E1使用printf编译报错问题被打赏27分 | |
rtthread硬件加密-5hash加密分析被打赏10分 |