加入收藏 | 设为首页 | 会员中心 | 我要投稿 PHP编程网 - 黄冈站长网 (http://www.0713zz.com/)- 数据应用、建站、人体识别、智能机器人、语音技术!
当前位置: 首页 > 服务器 > 搭建环境 > Linux > 正文

Linux内核分析 - 网络[八]:IP协议

发布时间:2016-10-16 06:06:01 所属栏目:Linux 来源:站长网
导读:副标题#e# 内核版本:2.6.34 这篇是关于IP层协议接收报文时的处理,重点说明了路由表的查找,以及IP分片重组。 ip_rcv 进入IP层报文接收函数 丢弃掉不是发往本机的报文,skb-pkt_type在网卡接收报文处理以太网头时会根据dst mac设置, 协议栈的书会讲不是发

首先分配空间,真正分配空间的是 inet_frag_alloc中的q = kzalloc(f->qsize, GFP_ATOMIC);其中f->qsize = sizeof(struct ipq),也就是说分配了ipq 大小空间,但返回的却是struct inet_frag_queue q结构,原因在于inet_frag_queue是ipq的首个属性,它们两者的联系如下图 。

Linux内核分析 - 网络[八]:IP协议

static struct inet_frag_queue *inet_frag_create(struct netns_frags *nf,     
  struct inet_frags *f, void *arg)     
{     
 struct inet_frag_queue *q;     
         
 q = inet_frag_alloc(nf, f, arg);     
 if (q == NULL)     
  return NULL;     
         
 return inet_frag_intern(nf, q, f, arg);     
}

在分配并初始化空间后,由inet_frag_intern完成插入动作,首先还是根据(标识,源IP,目的IP,协议号)先成hash 值,这里的qp_in即之前的q。

hash = f->hashfn(qp_in);

然后新创建的队列qp(即上面的qp_in)插入到hash表 (即ip4_frags->hash)和net->ipv4.frags中,并增加队列qp的引用计数,net中的队列nqueues统计数。至此,IP分片的创 建过程完成。

atomic_inc(&qp->refcnt);     
hlist_add_head(&qp->list, &f->hash[hash]);     
list_add_tail(&qp->lru_list, &nf->lru_list);     
nf->nqueues++;

ip_frag_queue实现将IP分片加入队列中

(编辑:PHP编程网 - 黄冈站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读