cs8900网卡驱动简要解析(2)

cs8900_probe函数本身并不难,但是你必须清楚probe函数的重要职能。因为你很有可能要为属于你的设备编写一个probe函数。

先来看一行最易懂的代码:             printk(VERSION_STRING"/n"); 显然,内核启动时显示的相关信息就是这句话打印出来的。

net_device中的dev_addr就是网卡的MAC地址,你应该提供:

#if defined(CONFIG_ARCH_SMDK2410)  dev->dev_addr[0] = 0x00;  dev->dev_addr[1] = 0x00;  dev->dev_addr[2] = 0x3e;  dev->dev_addr[3] = 0x26;  dev->dev_addr[4] = 0x0a;  dev->dev_addr[5] = 0x00; #endif

使用类似的代码,为我们的网络芯片提供  dev->if_port   = IF_PORT_10BASET; (支持的多种接口)  dev->priv      = (void *) &priv; (设备私有数据结构)

哦,还要多说一句,IF_PORT_10BASET在include/linux/netdevice.h中定义,你通过这个枚举类型,可以了解更多的接口信息:

enum {         IF_PORT_UNKNOWN = 0,         IF_PORT_10BASE2,         IF_PORT_10BASET,         IF_PORT_AUI,         IF_PORT_100BASET,         IF_PORT_100BASETX,         IF_PORT_100BASEFX };

下面的代码对于移植是非常关键的。vSMDK2410_ETH_IO是网卡的虚拟地址,IRQ_EINT9是硬件中断。这两个值和另外一个地址(网卡的物理地址)必须在头文件中定义,而且要正确的定义。

#if defined(CONFIG_ARCH_SMDK2410)     dev->base_addr = vSMDK2410_ETH_IO + 0x300;     dev->irq = IRQ_EINT9; #endif /* #if defined(CONFIG_ARCH_SMDK2410) */

接下来分配I/O端口资源。使用的函数是check_mem_region和request_mem_region。LDD中的理论结合这里的实践,相信你很快就掌握驱动编程中的这个API了。

下面的代码实现了硬件的读写。使用的函数是cs8900_read和cs8900_write。虽然只需很短的篇幅就可以解释这对读写函数,但是为了不分散你对cs8900_probe函数的注意力,我还是留到下一节中说,不要着急:) 哦,差点忘了,这里使用了内核的自旋锁(spin_lock_init),不过关于自旋锁的机制已经超出本文的范围了。你现在只需要知道自旋锁用于并发控制,以及如何动态初始化自旋锁就可以了。如果你还想继续了解,请自行学习与自旋锁相关的API,它们是:

spinlock_t spin; //定义自旋锁 spin_lock(lock); //获得自旋锁 spin_trylock(lock); //尝试获得自旋锁 spin_unlock(lock); //释放自旋锁

一句话总结:cs8900_probe函数继续为设备进行初始化,并申请各种资源。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值