实例解析:Linux操作系统的TCP/IP协议栈

日期: 2008-06-19 作者:佚名 来源:TechTarget中国

    分析tcp_v4_init,这个函数在net/ipv4/tcp_ipv4.c里面:


实例解析:Linux操作系统的TCP/IP协议栈


  tcp_inode当然就是一个inode节点了,而tcp_socket等于tcp_inode.u.socket_i,通过一个指针他们指向同一个内存。tcp_socket是用来通信使用的,可以叫TCP的controlsocket或者是communication
 
  socket,当TCP通信没有相应的socket的时候这个socket就充当了socket的角色。比如在一个关闭端口上收到SYN时发送RST,或者是在三次握手的时候发送SYN(还没有accept产生新的socket)
 
  值得注意的是ops->create函数的调用,我们前面见过对于AF_INET来说这个回调函数是net/ipv4/af_inet.c的inet_create函数,这个函数是用来创建一个socket的时候用的,由于函数比较长,这里先略过分析,这第一次的分析只是一个大致流程的熟悉而已。
 
  由于有socket创建和通信,所以这段代码是协议相关的,所以把这段代码从原来的tcp.c里面提取了出来
 
  下面是tcp_init函数,它在net/ipv4/tcp.c里面,大体上来说就是创建了几个hash表和bucket.这段代码创建了下面几个全局对象:


实例解析:Linux操作系统的TCP/IP协议栈



  其中ehash代表establishedhash,bhash代表bindhash,它们当然分别是所有的满足TCP_ESTABLISHED<=sk->state
 
  再下来就是icmp_init函数了,在net/ipv4/icmp.c里面,事实上,如果把tcp_v4_init里面的IPPROTO_TCP替换成IPPROTO_ICMP,基本都是一样的。剩下的proc_net_register函数前面已经讲过了,这里就不说了。
 
  到这里为止,Linux下面IP栈的开始的工作我们基本应该有了个了解,其中有几个关键的函数:
 
  dev_add_pack:注册一个链路层以上的处理函数,一般是用来使用新的网络层协议的,不过如果注册时重复也是可以的,这时候系统会设置一个copy位。如果是ETH_P_ALL则会接收所有的数据包。加入的元素保存在ptype_all链表和ptype_basehash链表中间。
 
  inet_add_protocol:注册一个建立在IP层以上的协议,例如TCP和UDP等
 
  proc_net_register(还有类似的proc_register):
 
  在/proc/net目录下面创建一个子目录项来使管理者能通过文件系统得到统计信息
 
  现在迷惑的地方还有很多,一个是结构体sk_buff的每个成员的意义,一个是结构体sock的意义,不过这两个问题应该在以后看多了就知道了。

我们一直都在努力坚持原创.......请不要一声不吭,就悄悄拿走。

我原创,你原创,我们的内容世界才会更加精彩!

【所有原创内容版权均属TechTarget,欢迎大家转发分享。但未经授权,严禁任何媒体(平面媒体、网络媒体、自媒体等)以及微信公众号复制、转载、摘编或以其他方式进行使用。】

微信公众号

TechTarget微信公众号二维码

TechTarget

官方微博

TechTarget中国官方微博二维码

TechTarget中国

电子邮件地址不会被公开。 必填项已用*标注

敬请读者发表评论,本站保留删除与本文无关和不雅评论的权力。

作者

佚名
佚名

相关推荐