[国嵌攻略][136][DM9000网卡驱动深度分析]

网卡初始化

1.分配描述结构,alloc_etherdev

2.获取平台资源,platform_get_resource

2.1.在s3c_dm9k_resource中有相关的资源

2.2.add地址由CS4和ADD2决定,是20000000

2.3.dat地址由CS4和ADD2决定,是20000004

2.4.中断资源是EINT7

3.虚拟地址映射,ioremap

4.读取芯片类型

5.设置操作函数集

6.读取MAC地址

7.注册网卡驱动,register_netdev

8.启动发送队列,netif_start_queue

网卡打开操作

在使用ifconfig eth 192.168.1.100配置网卡IP,或者使用ifconfig eth up打开网卡时会调用网卡驱动操作集合里的open函数。在open函数中做网卡硬件初始化化相关工作。

1.注册网卡中断处理函数,request_irq

2.初始化相关寄存器

3.使能发送和接收中断,来开启DM9000

网卡发送过程

1.通知协议栈暂停向驱动传送数据,netif_stop_queue

2.写入发送数据长度

3.写入发送数据

4.通知协议栈开始向驱动传输数据,netif_wake_queue

5.释放skb,dev_kfree_skb

网卡接收过程

接收在中断中完成,使用dm9000_rx函数处理

1.空读数据

2.读取接收状态

3.读取状态和长度

4.分配skb,使用dev_alloc_skb函数。分配长度是读取长度时获取的长度加4。4表示空读一个字节,状态一个字节,长度2个字节,剩下的部分才是真正读到的数据。

5.向后移动skb的data指针2个字节,使IP包满足4字节对齐。因为以太网包中的源地址6个字节,目的地址6个字节,类型2个字节,在头部移动2个字节,使IP包从16字节开始4字节对齐开始存放。使用skb_reserve(skb, 2)函数。

6.向前移动skb的tail指针4个字节,减去4个字节的CFS检验码,剩下的才是有效数据。使用skb_put(skb, RxLen - 4)。

7.读取数据到skb包中,注意读取时还是包含了4字节的CFS校验码。

8.提交数据到协议栈,使用netif_rx(skb)。

时间: 2024-07-28 22:22:42

[国嵌攻略][136][DM9000网卡驱动深度分析]的相关文章

[国嵌攻略][137][DM9000网卡驱动编程]

DM9000数据发送 DM9000数据发送函数是在/drivers/net/dm9000.c中的dm9000_start_xmit函数 static int dm9000_start_xmit(struct sk_buff *skb, struct net_device *dev){ //发送数据长度 board_info_t *db = netdev_priv(dev); iow(db, DM9000_TXPLL, (skb->len)>>0); iow(db, DM9000_TXPL

[国嵌攻略][158][SPI裸机驱动设计]

SPI控制器工作流程 SPI控制器提供2个SPI接口.每个SPI接口有两个通道,分别为TX通道和RX通道.CPU要写数据到FIFO中,先写数据到SPI_TX_DATA寄存器中,这样此寄存器中的内容就会自动移动到发送FIFO中:同理,如果CPU要从接收FIFO中读取数据,就访问寄存器SPI_RX_DATA,紧接着接收FIFO的数据就会自动移动到SPI_RX_DATA寄存器中. OK6410 SPI裸机程序分析 //SPI初始化 u8 SPI_Init(){ //SPI复位 CH_CFG0 |= B

[国嵌攻略][133][网卡驱动架构分析]

Linux网络子系统 1.系统调用接口:提供系统调用 2.协议无关接口:统一网络协议给系统调用接口使用 3.网络协议栈  :实现网络协议 4.设备无关接口:统一设备驱动程序给网络协议使用 5.设备驱动程序:实现网卡驱动 Linux驱动在内核中都有一个结构来描述,首先找到设备描述结构,然后找到设备如何注册和初始化. 网卡描述结构 在Linux内核中,每个网卡都由一个net_device结构来描述,其中一些重要成员: char name[IFNAMSIZ]   设备名,如:eth%d unsigne

[国嵌攻略][155][I2C用户态驱动设计]

用户态驱动模型 用户态驱动模型首先是一个应用程序,其次是在这个用户程序中通过内核调用来驱动设备. IIC通用驱动代码 IIC通用驱动程序的代码在/drivers/i2c/i2c-dev.c中.一次读操作或者一次写操作就是一条消息. EEPROM用户态驱动 IIC通用设备对应/dev/i2c-0设备文件. 1.打开通用设备驱动 2.构造写数据到eeprom的消息 3.使用ioctl写入数据 4.构造从eeprom读数据的消息 5.使用ioctl读出数据 6.关闭设备 配置IIC驱动 make me

[国嵌攻略][117][LED驱动程序设计]

LED程序设计 1.编写内核模块 2.搭建字符驱动框架 3.实现设备方法 头文件 <linux/io.h> writel() leddev.h //设备命令 #define LED_MAGIC 'L' //LED幻数 #define LED_ON _IO(LED_MAGIC, 0) //打开LED #define LED_OFF _IO(LED_MAGIC, 1) //关闭LED leddev.c /***********************************************

[国嵌攻略][164][USB驱动程序设计]

USB驱动模型 1.USB host controller driver(主控器驱动):为USB主控制器提供驱动程序 2.USB core(USB核心):连接USB主控制器驱动和USB设备驱动 3.USB client driver:为USB外部设备提供驱动程序 USB设备模型 device(设备)->config(配置)->interface(接口)->endpoint(端点),构成了USB设备的四个层次.一个usb driver(驱动)对应的是一个interface(接口).一个接口

[国嵌攻略][061][2440LCD驱动设计]

LCD初始化 1.引脚初始化 2.时序初始化 VBPD(vertical back porch):表示在一帧图像开始时,垂直同步信号以后的无效的行数 VFBD(vertical front porch):表示在一帧图像结束后,垂直同步信号以前的无效的行数 VSPW(vertical sync pulse width):表示垂直同步脉冲的宽度,用行数计算 HBPD(horizontal back porch):表示从水平同步信号开始到一行的有效数据开始之间的VCLK的个数 HFPD(horizon

[国嵌攻略][131][串口驱动分析-接收]

tty数据接收流程 //tty子系统 1.tty_fops中的tty_read响应系统调用 2.tty_read调用tty_ldisc_N_TTY中的n_tty_read n_tty_read 1.设置app的状态 2.如果没有数据可读,让阻塞生效 3.如果有数据可读,从read_buf中读走数据 什么时候串口驱动会把数据送到n_tty_read的read_buf中 当串口接收到数据时会产生接收中断,然后中断处理程序会把数据送到read_buf中. 串口驱动如何收到数据 串口中断处理程序s3c2

[国嵌攻略][151][nandflash驱动程序设计]

初始化 打开/drivers/mtd/nand/s3c2410.c找到nand flash驱动程序代码,找到模块初始化函数s3c_nand_init,找到platform_driver中的probe函数. 1.使能时钟 2.进行物理地址到虚拟地址转换 3.硬件纠错初始化 4.搜索nand flash 5.注册分区信息 nand flash读操作 nand flash读写函数位于通用驱动/drivers/mtd/nand/nand_base.c.nand flash的读函数位于nand_read的