Chinaunix首页 | 论坛 | 博客
  • 博客访问: 328340
  • 博文数量: 95
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 157
  • 用 户 组: 普通用户
  • 注册时间: 2014-03-26 20:03
文章分类

全部博文(95)

文章存档

2017年(15)

2015年(17)

2014年(63)

分类: 嵌入式

2014-11-26 20:53:26

核心板: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 有何不同。参考
阅读(1622) | 评论(0) | 转发(0) |
0

上一篇:YAFFS2移植到linux3.6.7

下一篇:linux mmap 详解

给主人留下些什么吧!~~