这些小活动你都参加了吗?快来围观一下吧!>>
电子产品世界 » 论坛首页 » 嵌入式开发 » MCU » 关于DM9000的一个难搞问题

共2条 1/1 1 跳转至

关于DM9000的一个难搞问题

助工
2011-09-15 11:34:19     打赏
用扬创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包,而且这个数据时错位的?

    大体问题如上,如果哪位高手可指教,将感激不尽啊!



关键词: 关于     DM9000     一个     难搞     问题    

助工
2011-09-15 13:37:26     打赏
2楼
ARM内核一直发ARP包 是ARM内协议栈本身在寻找主机或网关,而数据包中,数据错位,通常是数据包发送时,未发完前一数据包就又开始新数据包发送。
数据包错位的问题我已解决,但方法并不是最好。 因为我是在测试时,发现长时间大流量测试才可能出现错位,所以错位机率很小,这样的话,我只需定期检测发送FIFO的写入和读出之间,是否能达到要求(除掉FIFO翻转后的地址),如果一直不达到,则说明FIFO中有错位,导致一些数据长时间停在那里,故而此时可以复位dm9000(不关闭dm9k电源,复位很快),这样可解决该问题。

共2条 1/1 1 跳转至

回复

匿名不能发帖!请先 [ 登陆 注册 ]