由于有socket创建和通信,所以这段代码是协议相关的,所以把这段代码从原来的tcp.c里面提取了出来

下面是tcp_init函数,它在net/ipv4/tcp.c里面,大体上来说就是创建了几个hash表和bucket.这段代码创建了下面几个全局对象:

全局对象

全局对象

其中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下面TCP IP协议栈当中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的意义,不过这两个问题应该在以后看多了就知道了。


相关内容