关于6410板文件的dm9000的平台设备
来源:互联网 发布:企业在淘宝开店费用 编辑:程序博客网 时间:2024/06/01 18:59
#define CONFIG_DM9000_BASE 0x20000300
#define DM9000_IO 0x20000000
#define DM9000_DATA 0x20000004
这几个数值代表的地址是从哪里得到的,我翻了MINI2440的原理图和S3C2440的芯片手册没看懂从哪里找网卡的地址,请老师指导一下
tiny6410/mini6410开发板上DM9000与S3C6410的连接关系入手。下面是两者之间的连接示意图:
DM9000的访问地址主要是由CMD和CS#这两个端口的连接方式来确定的,CS#是DM9000的片选引脚,CMD引脚在芯片手册中描述如下:
CMD pin :
Command Type
When high, the access of this command cycle is DATA port
When low, the access of this command cycle is INDEX port
DM9000的CS#接的是S3C6410静态内存区(物理地址为0x10000000~0x3fffffff)的Bank1片选nCS1引脚(对应起始物理地址为0x18000000),CMD引脚则接的是S3C6410地址总线的Xm0ADDR2位。因此可以确定,DM9000的INDEX端口地址是0x18000000(Xm0ADDR2=0),DATA端口的地址是0x18000004(Xm0ADDR2=1)。
注意: 由上面的分析可以知道,DM9000的寻址仅仅取决于其CMD和CS#两个引脚的接法。也就是说,即使读者要将访问地址改为“0x18000000 + 0x300”(事实上在友善之臂提供的uboot以及其他一些资料中就是用的这个地址),同样能够正常的访问到网卡的INDEX端口。
提示: 确定了DM9000的INDEX和DATA端口地址,我们就有了访问网卡的途径。读网卡寄存器的方法是:先向INDEX端口写入寄存器的地址,再从DATA端口读出该寄存器的值。写寄存器的方法与之对应:先向INDEX端口写入寄存器的地址,再向DATA端口写入值。通过I/O端口读写网卡寄存器的方法在驱动中由ior()、iow()这来两个函数实现。
首先,让我们打开arch/arm/mach-s3c64xx目录下的mach-mini6410.c,找出DM9000平台驱动对应的平台设备及资源。下面列出了平台设备资源的情况:
#define S3C64XX_PA_DM9000 (0x18000000)
#define S3C64XX_SZ_DM9000 SZ_1M
#define S3C64XX_VA_DM9000 S3C_ADDR(0x03b00300)
static struct resource dm9000_resources[] = {
[0] = {
.start = S3C64XX_PA_DM9000,
.end = S3C64XX_PA_DM9000 + 3,
.flags = IORESOURCE_MEM,
},
[1] = {
.start = S3C64XX_PA_DM9000 + 4,
.end = S3C64XX_PA_DM9000 + S3C64XX_SZ_DM9000 - 1,
.flags = IORESOURCE_MEM,
},
[2] = {
.start = IRQ_EINT(7),
.end = IRQ_EINT(7),
.flags = IORESOURCE_IRQ | IRQF_TRIGGER_HIGH,
},
};
这里定义了三个平台资源,下标为0和1的资源(后面简称为资源0、资源1…)是IO内存资源,其中资源0的start成员代表的地址S3C64XX_PA_DM9000,也就是0x18000000,是访问DM9000的INDEX端口的地址,而资源1的start成员代表的地址S3C64XX_PA_DM9000+4,也就是0x18000004,则是访问DM9000的DATA端口的地址。DM9000的INDEX端口和DATA端口分别用来写命令和读写数据,要理解为什么能通过这两个地址访问对应的端口,需从
http://blog.csdn.net/gooogleman/article/details/7533348
- 关于6410板文件的dm9000的平台设备
- 关于DM9000 的讨论
- Redboot 的DM9000 网卡驱动在 MINI2440平台的移植
- 关于字符设备文件和块设备文件的区别
- Linux3.6.7在OK6410平台的移植(七)DM9000
- 关于DM9000在ARM总线上的地址
- 关于nios的DM9000驱动中的中断嵌套问题
- OK6410开发板上的DM9000网卡
- dm9000源码的分析
- MINI2440的DM9000配置
- DM9000的驱动问题
- DM9000的寄存器介绍
- DM9000的移植(S3C2440)
- dm9000的移植
- 转载 DM9000的调试
- DM9000的DM9161的比较
- 关于文件流设备操作函数的几点注意
- DM9000网卡驱动的移植
- 黑马程序员--IO流部分总结
- 员工的4个动力需求
- 网络字节序
- Android入门 — 模拟器的创建和运行
- 2012 5.4青年节--上海出差
- 关于6410板文件的dm9000的平台设备
- mmsplayer for wince,windows demo已经发布
- 随机MAC地址生成
- Marquee标签的使用
- 图片缓存思路
- JAVA日期操作
- 学习common lisp 笔记二
- poj2960【Nim博弈,SG】
- 游戏编程基础(二)GDI透明半透明效果