linux网络体系架构
原创kylin_zeng:http://blog.csdn.net/kylin_fire_zeng 本文参考国嵌视频教程,再此感谢国嵌教育。
一、协议栈层次对比:
1)网络接口层把数据链路层和物理层合并在了一起,提供访问物理设备的驱动程序,对应的网络协议主要是以太网协议。
2)网络层协议管理离散的计算机间的数据传输,如IP协议为用户和远程计算机提供了信息包的传输方法,确保信息包能正确地到达目的机器。重要的网络层协议包括ARP(地址解析协议)、ICMP(Internet控制消息协议)和IP协议(网际协议)等
3)传输层的功能包括:格式化信息流、提供可靠传输。传输层包括TCP(Transmission Control Protocol,传输控制协议)和UDP(User Datagram Protocol,用户数据报协议),它们是传输层中最主要的协议
4)应用层位于协议栈的顶端,它的主要任务是服务于应用,如利用FTP(文件传输协议)传输一个文件。常见的应用层协议有:HTTP,FTP,Telnet等。应用层是Linux网络设定很关键的一层,Linux服务器的配置文档主要针对应用层中的协议
二、linux网络子系统
1)
2)Linux 网络子系统的顶部是系统调用接口层。它为用户空间的应用程序提供了一种访问内核网络子系
统的方法。位于其下面的是一个协议无关层,它提供了一种通用方法来使用传输层协议。然后是具体
协议的实现,在Linux 中包括内嵌的协议TCP、UDP,当然还有IP。然后是设备无关层,它提供了
协议与设备驱动通信的通用接口,最下面是设备驱动程序。
3)系统调用接口:为应用程序提供访问内核网络子系统的方法:Socket系统调用。
4)协议无关接口:实现一组通用函数来访问各种不同的协议:通过socket实现。Linux 中的socket 使用
struct sock来描述,这个结构包含了特定socket 所需要的所有状态信息,还包括
socket 所使用的特定协议和在socket 上可以执行的一些操作
5)网络协议层用于实现各种具体的网络协议,如:TCP、UDP 等
6)设备无关接口:设备无关接口将协议与各种网络设备驱动连接在一起。
这一层提供一组通用函数供底层网络设备驱动程序使用,让它们可以对高层协议栈进行操作。首先,设备驱
动程序可能会通过调用register_netdevice 或unregister_netdevice 在内核中进行注册或注销。调
用者首先填写net_device 结构,然后传递这个结构进行注册。内核调用它的init 函数(如果定义了这种函
数),然后执行一组健全性检查,并将新设备添加到设备列表中(内核中的活动设备链表)
要从协议层向设备发送数据,需要使用dev_queue_xmit函数,这个函数对数据进行排
队,并交由底层设备驱动程序进行最终传输报文的接收通常是使用netif_rx执行的。当底层设备驱动
程序接收到一个报文(包含在所分配的sk_buff 中)时,就会通过调用netif_rx 将数据上传至设备
无关层,然后,这个函数通过netif_rx_schedule 将sk_buff 在上层协议队列中进行排队,供以后进行处理。
7)驱动程序:网络体系结构的最底部是负责管理物理网络设备的设备驱动程序层
****************************************************************************************************************************************
二、网络驱动程序设计:
每个网络接口都由一个net_device结构来描述,该结构可使用如下内核函数动态分配:
1、struct net_device *alloc_netdev(int sizeof_priv, const char *mask, void (*setup)(struct net_device *))
sizeof_priv 私有数据区大小;mask:设备名;setup 初始化函数
2、struct net_device *alloc_etherdev(int sizeof_priv)
struct net_device
{
char name[IFNAMSIZ] ;// 设备名,如:eth%d //%d表示由内核自动获取。
vunsigned long state ;// 设备状态
vunsigned long base_addr ;// I/O 基地址
vunsigned int irq ;// 中断号
...
}
3、net_device初始化:int (*init)(struct net_device *dev)
初始化函数。该函数在register_netdev时被调用来完成对net_device 结构的初始化
net_device和字符驱动一样, 网络设备也要声明能操作它的函数。有些操作可以保留为NULL, 有的可以通过ether_setup 来使用默认设置。网络
接口的设备方法可分为两组:基本的和可选的,基本方法包括那些使用接口所必需的;可选的方法实现更多高级的功能。
4、基本方法:
int (*open)(struct net_device *dev) //打开接口。ifconfig 激活时,接口将被打开。
int (*stop)(struct net_device *dev) //停止接口。该什么时候调用呢?
int (*hard_start_xmit) (struct sk_buff *skb, struct net_device *dev) //数据发送函数。
5、可选操作:
int (*do_ioctl)(struct net_device *dev, struct ifreq *ifr, int cmd) //处理特定于接口的ioctl 命令
int (*set_mac_address)(struct net_device *dev, void *addr) //改变Mac地址的函数,需要硬件支持该功能
6、设备注册:
网络接口驱动的注册方式与字符驱动不同之处在于它没有主次设备号,并使用如下函数注册。
int register_netdev(struct net_device *dev)
7、sk_buff 存放网络包:
Linux内核中的每个网络数据包都由一个套接字缓冲区结构struct sk_buff 描述,即一个
sk_buff结构就是一个包,指向sk_buff的指针通常被称做skb。
struct sk_buff
{
struct device *dev; //处理该包的设备
__u32 saddr; //IP源地址
__u32 daddr; //IP目的地址
__u32 raddr; //IP路由器地址
unsigned char *head; //分配空间的开始
unsigned char *data; //有效数据的开始
unsigned char *tail; //有效数据的结束
unsigned char *end; //分配空间的结束
unsigned long len; //有效数据的长度
};
8、skb操作函数:
操作sk_buff的内核函数如下: struct sk_buff *alloc_skb(unsigned int len, int priority)
分配一个sk_buff 结构,供协议栈代码使用 struct sk_buff *dev_alloc_skb(unsigned int len)分配一个sk_buff 结构,供驱动代码使用
unsigned char *skb_push(struct sk_buff *skb, int len) //向后移动skb的tail指针,并返回tail移动之前的值。 这样才能再填入后面的值
unsigned char *skb_put(struct sk_buff *skb, int len) //向前移动skb的head指针,并返回head移动之后的值 这样才不会覆盖后面的值
kfree_skb(struct sk_buff *skb) //释放一个sk_buff 结构,供协议栈代码使用
dev_kfree_skb(struct sk_buff *skb) //释放一个sk_buff 结构,供驱动代码使用
9、设备打开:
Open 请求任何它需要的系统资源并且启动
接口:
注册中断,DMA等
设置寄存器,启动设备
启动发送队列
例如:
int net_open(struct net_device *dev)
{
/*申请中断*/
request_irq(dev->irq, &net_interrupt, SA_SHIRQ,
“dm9000”, dev);
/* 设置寄存器,启动设备*/
...... ...... ...... ......
/*启动发送队列*/
netif_start_queue(dev);
}
10、数据发送:
当核心需要发送一个数据包时,它调用hard_start_transmit函数,该函数将最终调用到net_device结构中的hard_start_xmit函数指针。
11、数据接收
网络接口驱动可以实现两种方式的报文接收: 中断和查询,Linux中驱动多采用中断方式
接收流程:
1、分配Skb:
skb = dev_alloc_skb(pkt->datalen + 2)
2、从硬件中读取数据到Skb
3、调用netif_rx将数据交给协议栈
netif_rx(skb)
12、中断处理:
网络接口通常支持3种类型的中断: 新报文到达中断、报文发送完成中断和出错中断。中
断处理程序可通过查看网卡中的中断状态寄存器,来分辨出中断类型。
linux网络体系架构的更多相关文章
- Linux网络驱动架构
网络设备介绍 网络设备是计算机体系结构中必不可少的一部分,处理器如果想与外界通信,通常都会选择网络设备作为通信接口.众所周知,在 OSI(Open Systems Interconnection,开放 ...
- Linux网络编程学习(一) ----- 概论和Linux模型(第一章第二章)
1.什么是计算机网络,通信方式是什么? 计算机网络就是通过通信线路相互连接的计算机的集合,主要通过双绞线.同轴电缆.电话线或者光缆等有形传输介质通信,还有就是通过激光.微波.卫星等实现无线通信 2.W ...
- 【转】XenServer体系架构解析
XenServer是一套已在云计算环境中经过验证的企业级开放式服务器虚拟化解决方案,可以将静态.复杂的IT环境转变为更加动态.易于管理的虚拟数据中心,从而大大降低数据中心成本.同时,它可以提供先进的管 ...
- Linux网络编程&内核学习
c语言: 基础篇 1.<写给大家看的C语言书(第2版)> 原书名: Absolute Beginner's Guide to C (2nd Edition) 原出版社: Sams 作者: ...
- ocp11g培训内部教材_052课堂笔记(042)_体系架构
OCP 052 课堂笔记 目录 第一部分: Oracle体系架构... 4 第一章:实例与数据库... 4 1.Oracle 网络架构及应用环境... 4 2.Oracle 体系结构... 4 3. ...
- [转]OpenContrail 体系架构文档
OpenContrail 体系架构文档 英文原文:http://opencontrail.org/opencontrail-architecture-documentation/ 翻译者:@KkBLu ...
- 精通android体系架构、mvc、常见的设计模式、控制反转(ioc)
1.请看某个著名的it公司一则招聘信息的其中一条要求:“熟悉android系统架构及相关技术,1年以上实际android平台开发经验:”,里面非常明确的说道要求熟练android系统架构,这从某种程度 ...
- 【转帖】Linux 内核系统架构
Linux 内核系统架构 描述Linux内核的文章已经有上亿字了 但是对于初学者,还是应该多学习多看,毕竟上亿字不能一下子就明白的. 即使看了所有的Linux 内核文章,估计也还不是很明白,这时候 ...
- Android四层体系架构
Application应用层 应用是用Java语言编写的运行在虚拟机上的程序,即图中最上层的蓝色部分.手机的上层应用其实,Google最开始时就在Android系统中捆绑了一些核心应用比如e-mail ...
随机推荐
- html 5 废弃的标签和属性
第一类:表现性元素 basefont big center font s strike tt u 建议用语义正确的元素代替他们,并使用CSS来确保渲染后的效果 第二类:框架类元素 因框架有很多可用性及 ...
- Xcode之外的文档浏览工具--Dash (在iOS代码库中浏览本帖)
链接地址:http://www.cocoachina.com/bbs/read.php?tid=273479 Xcode之外的文档浏览工具--Dash (在iOS代码库中浏览本帖) ...
- BZOJ 1800: [Ahoi2009]fly 飞行棋( 枚举 )
O(N2)算出有x条直径然后答案就是x(x-1)/2...这个数据范围是闹哪样! ----------------------------------------------------------- ...
- UrlEncode编码/UrlDecode解码
public class encode { public static void main(String[] args) throws UnsupportedEncodingException ...
- myEclipse快捷键及其常用设置
快捷键: 查找替换:ctrl + f 复制行: ctrl + alt + down 删除行: ctrl + d 插入行: shift + enter, ctrl + shift ...
- apt-get 命令详解(中文),以及实例
apt-get 命令详解(中文),以及实例 一,什么的是apt-get 高级包装工具(英语:Advanced Packaging Tools,简称:APT)是Debian及其衍生发行版(如:ubunt ...
- JS实现常用的分享到按钮
我们阅读博客的时候经常会用到这样功能,当然有时候也会想把自己的网站上也加入类似的分享功能,各大厂商已经给出了相应的API,点击一个按钮即可弹出窗口进入分享,我们事先可以设置一些参数,一般常用的就是 网 ...
- Android 一个改进的okHttp封装库
一.概述 之前写了篇Android OkHttp完全解析 是时候来了解OkHttp了,其实主要是作为okhttp的普及文章,当然里面也简单封装了工具类,没想到关注和使用的人还挺多的,由于这股热情,该工 ...
- 腾讯QQ是用什么语言开发的(转)
腾讯QQ的部分COM组件用的VC6,用exescope看其中几个dll的依赖,依赖于MFC42.dll,MSVCRT.dll,MSVCP60.dll都说明是VC6写的. 还有一部分用的VS2005,包 ...
- Nginx 开启 debug 日志的办法
译序:一般来讲,Nginx 的错误日志级别是 error,作为 Nginx 用户来讲,你设置成 info 就足够用了. 但有时有些难以挖掘的 bug,需要看到更详细的 debug 级别 ...