应用层:

套接字将Unix一切都是内核的概念应用到网络连接中,内核跟用户空间套接字之间的接口实现在c的标准库中,使用了socketcall系统调用.
socketcall充当了一个多路分解器,将各种任务分配到不同的过程执行,比如打开一个套接字,绑定或发送数据.
对于程序使用的套接字来说,都对应一个socket结构和sock的实例,二者充当向下(内核)跟向上(用户)接口

socket定义:
  1. struct socket{
  2. socket_state state;//套接字连接状态
  3. unsigned long flags;
  4. const struct proto_ops *ops; //具体协议类型
  5. struct file *file; //指向一个伪文件的file实例,用于跟套接字通信(描述符)
  6. struct sock *sk;
  7. short type; //所用协议类型的数字标识符
  8. };
ops包含处理套接字的特定于协议函数
  1. struct proto_ops
  2. {
  3. int family;
  4. .....
  5. int (*bind)(.............);
  6. int (*connect)(...........);
  7. .......等等
  8. };
这里跟c标准库的对应函数同名,因为c库函数会通过syscall系统调用来调用上面的函数指针

套接字与文件
在连接建立后,用户进程使用普通的文件操作来访问套接字,每个套接字都分配了一个该类型的inode,inode又管理到另外一个普通文件相关的结构.用于操作文件的函数保存到一个单独的指针表中
  1. struct inode{
  2. .....
  3. struct file_operations *i_fop;
  4. ....
  5. }

因此,对套接字文件描述符的文件操作,可以透明的定向到网络子系统的代码,套接字使用的file_operations如下:
  1. struct file_operations socket_file_ops={
  2. .owner=THIS_MODULE,
  3. .poll=sock_poll
  4. .aio_read=sock_aio_read;
  5. .mmap
  6. .....
  7. };

前缀为sock_的函数都是简单的包装器函数,他们会调用sock_operations.比如sock_mmap所示
  1. static int sock_mmap(struct file*file,struct vm_area_struct *vma)
  2. {
  3. struct socket*sock=file->private_data; //socket指向 文件实例
  4. return sock->ops->ops->mmap(file,sock,vma);
  5. }

inode跟套接字的关联,是通过以下辅助结构完成的
  1. struct socket_alloc{
  2. struct socket socket;
  3. struct inode vfs_inode;
  4. }

内核提供了两个宏进行必要的指针运算,根据inode找到相关套接字实例(socket_i)或者反过来(sock_inode)
socketcall系统调用
文件功能中的读写操作可以通过虚拟文件系统相关调用进入内核,然后重定向到socket_file_ops的函数指针,除此之外,还要对套接字执行其他任务
Linux提供了socketcall系统调用,它实现在sys_socketcall中,17个套接字操作对应一个系统调用,由于所要处理的任务不同,参数列表有很大差别.
  1. sys_socketcall(int call,unsigned long _user*args)
  2. {
  3. switch(call)
  4.     { case sys_socket:
  5. err=sys_socket(a0,a1,a[2]);
  6. break;
  7.      case SYS_bind:
  8. err=sys_bind(a0,(struct sockaddr __user*)a1,a[2]);
  9. ........
  10.     }
  11. }









Linux内核之网络的更多相关文章

  1. Linux内核分析 - 网络[十四]:IP选项

    Linux内核分析 - 网络[十四]:IP选项 标签: linux内核网络structsocketdst 2012-04-25 17:14 5639人阅读 评论(1) 收藏 举报  分类: 内核协议栈 ...

  2. Linux内核中网络数据包的接收-第一部分 概念和框架

    与网络数据包的发送不同,网络收包是异步的的.由于你不确定谁会在什么时候突然发一个网络包给你.因此这个网络收包逻辑事实上包括两件事:1.数据包到来后的通知2.收到通知并从数据包中获取数据这两件事发生在协 ...

  3. Linux内核中网络数据包的接收-第二部分 select/poll/epoll

    和前面文章的第一部分一样,这些文字是为了帮别人或者自己理清思路的.而不是所谓的源代码分析.想分析源代码的,还是直接debug源代码最好,看不论什么文档以及书都是下策. 因此这类帮人理清思路的文章尽可能 ...

  4. Linux内核笔记--网络子系统初探

    内核版本:linux-2.6.11 本文对Linux网络子系统的收发包的流程进行一个大致梳理,以流水账的形式记录从应用层write一个socket开始到这些数据被应用层read出来的这个过程中linu ...

  5. LINUX内核参数网络相关

    有助于提高网络性能和吞吐量的参数 net.core.somaxconn = 128 已完成连接队列(completed connection queue) (1)三次握手已经完成,但还未被应用层接收( ...

  6. linux内核中网络文件系统的注册初始化

    针对内核3.9 系统开启时,会使用init/main.c,然后再里面调用kernel_init(),在里面会再调用do_basic_setup(),调用do_initcalls(),调用do_one_ ...

  7. linux内核之网络协议栈

    https://www.ibm.com/developerworks/cn/linux/l-ntflt/

  8. Linux内核分析 - 网络

    http://blog.csdn.net/column/details/network-kernel-yoyo.html

  9. Linux内核--网络栈实现分析(二)--数据包的传递过程(上)

    本文分析基于Linux Kernel 1.2.13 原创作品,转载请标明http://blog.csdn.net/yming0221/article/details/7492423 更多请看专栏,地址 ...

随机推荐

  1. 如何用纯 CSS 创作一个小球反弹的动画

    效果预览 在线演示 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/OwWROO 可交互视频 ...

  2. ccf 201712-3 Crontab(Python实现)

    一.原题 问题描述 试题编号: 201712-3 试题名称: Crontab 时间限制: 10.0s 内存限制: 256.0MB 问题描述: 样例输入 3 201711170032 201711222 ...

  3. 【php】 phpword下载文件问题

    这个问题是在 科锐国际 工作过程中发现的 word文档的名字(有汉字和空格)在windows系统上遍历是查不到文件的,但是在linux系统上市可以的压缩包里面的中文名word文档,如果出现汉字和空格, ...

  4. GoF23种设计模式之行为型模式之策略模式

    传送门 ☞ 轮子的专栏 ☞ 转载请注明 ☞ http://blog.csdn.net/leverage_1229 1概述           定义一系列算法,把它们一个个都封装起来,并且让它们可以相互 ...

  5. Flask初学者:Jinja2模板

    Python的Jinja2模板,其实就是在HTML文档中使用控制语句和表达语句替换HTML文档中的变量来控制HTML的显示格式,Python的Jinja2模板可以更加灵活和方便的控制HTML的显示,而 ...

  6. MIP启发式算法:Variable neighborhood search

    *本文主要记录和分享学习到的知识,算不上原创. *参考文章见链接. 本文主要讲述启发式算法中的变邻域搜索(Variable neighborhood search).变邻域搜索的特色在于邻域结构的可变 ...

  7. BZOJ 2687: 交与并

    答案存在于 1.两个互相包含的区间 2.两个互不包含的区间 决策单调性显然 但是这代码很精妙啊,并不知道这个为什么能这样写 #include<cstdio> #include<alg ...

  8. iOS 9下支持的键盘类型:

    http://blog.csdn.net/cloudox_/article/details/50532124

  9. web前端开发小结

    1.浏览器内核 IE-----Trident Edge-----EdgeHTML Firefox-----Gecko Safari-----Webkit Chrome-----Blink(Webkit ...

  10. python-高级编程-06-长连接&连接池

    我们都知道tcp是基于连接的协议,其实这个连接只是一个逻辑上面的概念,在ip层来看,tcp和udp仅仅是内容上稍有差别而已. tcp 的连接仅仅是连接两端对于四元组和sequence号的一种约定而已 ...