用扬创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包,而且这个数据时错位的?
大体问题如上,如果哪位高手可指教,将感激不尽啊!
有奖活动 | |
---|---|
【EEPW电子工程师创研计划】技术变现通道已开启~ | |
发原创文章 【每月瓜分千元赏金 凭实力攒钱买好礼~】 | |
【EEPW在线】E起听工程师的声音! | |
“我踩过的那些坑”主题活动——第001期 | |
高校联络员开始招募啦!有惊喜!! | |
【工程师专属福利】每天30秒,积分轻松拿!EEPW宠粉打卡计划启动! | |
送您一块开发板,2025年“我要开发板活动”又开始了! | |
打赏了!打赏了!打赏了! |
打赏帖 | |
---|---|
【我踩过的那些坑】calloc和malloc错误使用导致跑飞问题排查被打赏50分 | |
多组DCTODC电源方案被打赏50分 | |
【我踩过的那些坑】STM32cubeMX软件的使用过程中的“坑”被打赏50分 | |
新手必看!C语言精华知识:表驱动法被打赏50分 | |
【我踩过的那些坑】杜绑线问题被打赏50分 | |
【我踩过的那些坑】STM32的硬件通讯调试过程的“坑”被打赏50分 | |
【我踩过的那些坑】晶振使用的问题被打赏100分 | |
【我踩过的那些坑】电感选型错误导致的处理器连接不上被打赏50分 | |
【我踩过的那些坑】工作那些年踩过的记忆深刻的坑被打赏10分 | |
【我踩过的那些坑】DRC使用位置错误导致的问题被打赏100分 |