网卡驱动程序主要是实现了结构体struct net_device *ndev 中的一些方法,和中断处理函数:
ndev->open = &dm9000_open;
ndev->hard_start_xmit = &dm9000_start_xmit;
ndev->tx_timeout = &dm9000_timeout;
ndev->watchdog_timeo = msecs_to_jiffies(watchdog);
ndev->stop = &dm9000_stop;
ndev->set_multicast_list = &dm9000_hash_table;/////p531
ndev->ethtool_ops = &dm9000_ethtool_ops;
ndev->do_ioctl = &dm9000_ioctl;
ndev->poll_controller = &dm9000_poll_controller;
db->mii.mdio_read = dm9000_phy_read;
db->mii.mdio_write = dm9000_phy_write;
中断处理函数:static irqreturn_t dm9000_interrupt(int irq, void *dev_id)
其中最重要的是:dm9000_start_xmit和中断处理函数dm9000_interrupt。
dm9000_start_xmit:
初始化数据包的传输. 完整的报文(协议头和所有)包含在一个 socket 缓存区( sk_buff ) 结构.
整个网络系统的数据传输最终都是通过调用该函数来实现的。该函数把数据包写入网卡的SRAM中,并发出数据传输请求。
dm9000_interrupt:
在一个数据包发送完,一个数据包接收到,网络链路状态改变,触发中断,调用该中断处理函数。
在非中断模式下,被函数dm9000_poll_controller调用。
如果是接收到数据包触发了中断,则该中断函数调用函数dm9000_rx(dev);接收数据包,并调用函数netif_rx(skb);
将该数据包递交给上层。
int (*open)(struct net_device *dev): 打开接口. 任何时候 ifconfig 激活它, 接口被打开. open 方法应当注册它需要的任何系统资源( I/O 口, IRQ, DMA, 等等), 打开硬件, 进行任何别的你的设备要求的设置. void (*tx_timeout)(struct net_device *dev): 数据传输超时调用该方法,处理并恢复报文发送。 i这个超时时间由成员nt watchdog_timeo;来保存。 int (*stop)(struct net_device *dev): 停止接口. 接口停止当它被关闭. 这个函数应当恢复在打开时进行的操作. void (*set_multicast_list)(struct net_device *dev): 当设备的组播列表改变和当标志改变时调用的方法
ethtool_ops:
ethtool 是一个实用工具, 设计来给系统管理员以大量的控制网络接口的操作. 用 ethtool, 可能来控制各种接口参数, 包括速度, 介质类型, 双工模式, DMA 环设置, 硬件校验和, LAN 唤醒操作, 等等,
它的核心是一个 ethtool_ops 类型的结构, 里面包含一个全部 24 个不同方法来支持 ethtool. 大部分这些方法是相对直接地;
int (*do_ioctl)(struct net_device *dev, struct ifreq *ifr, int cmd):
处理特定于接口的 ioctl 命令. 相应的 net_device 结构中的成员可留为 NULL, 如果接口不需要任何特定于接口的命令.
int (*mdio_read) (struct net_device *dev, int phy_id, int location);
void (*mdio_write) (struct net_device *dev, int phy_id, int location, int val);
媒介独立接口(或 MII) 是一个 IEEE 802.3 标准, 描述以太网收发器如何与网络控制器接口;
这两个函数就是对媒介独立接口的寄存器进行操作的方法。