本文主要是介绍网卡驱动设计--2440,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
注意学习软件的移植。。
从uboot中找出DM9000的参考代码;先参考其初始化代码,进行了如下步骤: 前两步需分析得出
1、由于DM9000是一个单独的芯片,所以要设置其片选
1.1设置数据位宽
1.2设置其工作时序(参考uboot--初始化CPU对应目录U-Boot\arch\arm\cpu\arm920t\s3c2440\lowlevel_init.s)
2、中断初始化(采用中断的方式使用DM9000)
2.1初始化中断引脚(触发中断方式,使能)
3、复位设备(参考uboot得出)
3.1实现向dm9000中读/写数据的函数(注意第一步设置的位宽为16bit);回忆第一节课DM9000读写的的方式
DM9000的两个操作接口:index接口(0x20000300),数据接口(0x20000304)
3.2实现复位函数内的操作(对比uboot)
4、寻找DM9000芯片(移植dm9000_probe(void));对比厂商ID(Vendor ID -- VID)、产品ID(Product ID -PID)
5、MAC初始化(移植)
6、填充MAC地址
6.1设置其物理地址(有偏移地址10H做起始地址)
6.2暂时用不到以 偏移地址 16H为开头的Multicast address register,暂时不用初始化
分析发送函数;参考函数(static int dm9000_send(struct eth_device *netdev, void *packet, int length)
)
1、禁止中断---设置IMR(偏移地址FFH)寄存器;禁止[5:0]位相对应的中断
2、设置发送长度---设置TXPLL\TXPLH(偏移地址FCH)
3、将数据搬移到DM9000的发送RAM中(准备数据)---设置MWCMD(偏移地址为F8H)
4、把数据放入发送缓冲寄存器---利用数据接口发送DM_DAT
5、发出发送命令---设置TCR(发送控制寄存器,偏移地址02H),第0位置1
6、等待传送完毕---提取TCR的第0位,因其表示发送数据完成之后自动清零
7、清除发送状态---设置(读或写都将该位清零)NSR的第5位wakest、第3位TX2END、 第2位TX2END;即向NSR寄存器写入0x2c.
8、恢复中断使能--- 只使能接收中断
分析接收函数;static int dm9000_rx(struct eth_device *netdev)
1、检测接收状态,判断产生接收中断,产生则代表接收到数据,未产生中断则返回---ISR(中断状态寄存器)的接收位第0位PR
2、清除接收位---向ISR第0位写1
3、空读(Dummy read)---MRCMDX
//先隔过对数据的检查,进行以下操作
4、读取数据包状态 /* A packet ready now & Get status/length */ ----MRCMD
4.1读取数据包的长度----LEN= DM_DAT
5、读取包的数据--与以太网的数据的最大长度( PKT_MAX_LEN 1522)作比较,不可超过,注意接收的数据宽度为16位
中断处理函数的实现(接收数据后触发中断)
1、保存环境
2 、调用接收函数
3、清除中断
3、恢复环境
这篇关于网卡驱动设计--2440的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!