核心板:tq2416-corec,操作系统 linux-3.1
两片dm9000cep,分别简称片1和片2,片1接线按照天嵌提供原理图接线,片2中,中断接EINT13,片选接CSn1,。
驱动中添加片2硬件资源,其基地址要加8与s3c2440加4不同,时因为:S3c2440总线总是字节对齐,而2416不管时8bit还是16bit都是从地址0开始,同时设置bank1控制寄存器SMBCR1位宽为16bit。
开始调试的时候,+8一直读取不到正确的芯片ID,读取的数据时0x2b2a2928即寄存器的地址,说明片选信号没起作用,CMD一直选择的读取地址。后来改成+4能正确读取芯片ID,但是却ping不同主机。
解决办法:还要在dm9000驱动程序中设置SMBCR1的位宽为16位。但是对2416总线寻址还是不明白??和2440 有何不同。参考
阅读(1691) | 评论(0) | 转发(0) |