- 1、本文档共24页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
TCP/IP 协议栈初始化流程
启动以后
先从 init/main.c 的 start_kernel 函数说起。
在这个函数里面调用 kernel_thread 启动了 init 进程,这个进程对应的函数是同一个文件里面的
init 函数,在 init 函数里面调用了一个
叫 do_basic_setup 的在同一个文件里面的函数,这个函数调用了 net/socket.c 里面的 sock_init 函数,
这个函数就是 TCP/IP 协议栈,也包括 ipx 等的入口。
首先 sock_init 函数里面有很多 ifdef 这样的东东,我觉得对于一个普通的主机来说,这些都不会
配置的,它们包括:
SLAB_SKB,CONFIG_WAN_ROUTER,CONFIG_FIREWALL,CONFIG_RTNETLINK,CONFIG_NETLINK_DEV
去掉了这些编译选项以后就剩下这样的代码:
for (i = 0; i NPROTO; i++)
net_families[i] = NULL;
sk_init();
proto_init();
其中 net_families 在 include/linux/net.h 里面定义,是这样的:
struct net_proto_family
{
int family;
int (*create)(struct socket *sock, int protocol);
/* These are counters for the number of different methods of
each we support */
short authentication;
short encryption;
short encrypt_net;
};
其中有用的只有前两项,那个 create 的 callback 函数是每个协议,例如 AF_INET 等初始化上层协
议如 TCP/ICMP 协议需要的,以后还会遇到的,这里先放着把
sk_init 函数在 net/core/sock.c 里面,没什么说的..
struct sock *sk_alloc(int family, int priority, int zero_it)
{
struct sock *sk = kmem_cache_alloc(sk_cachep, priority);
if(sk) {
if (zero_it)
memset(sk, 0, sizeof(struct sock));
sk-family = family;
}
return sk;
}
proto_init 函数在同一个文件里面:
void __init proto_init(void)
{
extern struct net_proto protocols[];
struct net_proto *pro;
pro = protocols;
while (pro-name != NULL)
{
(*pro-init_func)(pro);
pro++;
}
}
struct net_proto 在 include/linux/net.h 里面是这样的:
struct net_proto
{
const char *name; /* Protocol name */
void (*init_func)(struct net_proto *); /* Bootstrap */
};
这个 protocols 的数组是在 net/protocols.c 里面定义的,包含了一堆的协议初始化结构体,其中
我只注意两个:AF_INET 和 AF_PACKET
它们的初始化函数分别是 inet_proto_init 和 packet_proto_init
协议初始化-1
下面来看看 IPv4 协议和 PACKET 协议的初始化过程。
首先看 PACKET 协议,首先我们假定 PACKET 协议是编译在核心里面的,而不是一个 MODULE,这样得
到 packet_proto_init 函数在 net/packet/af_packet.c 里面是这样的:
void __init packet_proto_init(struct net_proto *pro)
{
sock_register(packet_family_ops);
register_netdevice_notifier(packet_netdev_notifier);
}
其中 sock_register 函数在 net/socket.c 里面,就是简单的设置前面说的 net_families 数组中间
对应的值:
int sock_register(struct net_proto_family
文档评论(0)