免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 4085 | 回复: 19
打印 上一主题 下一主题

[网络子系统] 关于linux内核处理分片的疑问[已解决] [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-01-12 13:14 |只看该作者 |倒序浏览
本帖最后由 whnewbie 于 2013-01-19 22:44 编辑

对于从外面进来的发往本机的分片报文,为什么要处理两次分片?

一是在prerouting那里,在这里就会收集分片

另一个在ip_local_deliver里。

int ip_local_deliver(struct sk_buff *skb)
{
        /*
         *        Reassemble IP fragments.
         */

        if (ip_hdr(skb)->frag_off & htons(IP_MF | IP_OFFSET)) {
                if (ip_defrag(skb, IP_DEFRAG_LOCAL_DELIVER))
                        return 0;
        }

        return NF_HOOK(PF_INET, NF_INET_LOCAL_IN, skb, skb->dev, NULL,
                       ip_local_deliver_finish);
}


发往本机的报文,首先也在prerouting那里处理过了啊,为什么在local_deliver还要再次处理一遍?

论坛徽章:
0
2 [报告]
发表于 2013-01-15 13:08 |只看该作者
prerouting时,还不确定数据包是往哪发送的,不可能有组包的地方吧。

论坛徽章:
4
酉鸡
日期:2014-03-21 23:19:50狮子座
日期:2014-08-01 22:11:40酉鸡
日期:2015-01-10 21:31:442015年辞旧岁徽章
日期:2015-03-03 16:54:15
3 [报告]
发表于 2013-01-15 15:02 |只看该作者
我也觉得奇怪.prerouting那次的重组代码在哪里?

论坛徽章:
0
4 [报告]
发表于 2013-01-15 20:23 |只看该作者
确定。你去看kernel代码就知道了

prerouting那里有处理分片的啊


2.6.18   ipv4: ip_conntrack_standalone.c line476
satic struct nf_hook_ops ip_conntrack_ops[] = {
        {
                .hook                = ip_conntrack_defrag,
                .owner                = THIS_MODULE,
                .pf                = PF_INET,
                .hooknum        = NF_IP_PRE_ROUTING,
                .priority        = NF_IP_PRI_CONNTRACK_DEFRAG,
        },



2.6.30

static struct nf_hook_ops ipv4_defrag_ops[] = {
        {
                .hook                = ipv4_conntrack_defrag,
                .owner                = THIS_MODULE,
                .pf                = PF_INET,
                .hooknum        = NF_INET_PRE_ROUTING,
                .priority        = NF_IP_PRI_CONNTRACK_DEFRAG,
        },
        {
                .hook           = ipv4_conntrack_defrag,
                .owner          = THIS_MODULE,
                .pf             = PF_INET,
                .hooknum        = NF_INET_LOCAL_OUT,
                .priority       = NF_IP_PRI_CONNTRACK_DEFRAG,
        },
};

论坛徽章:
0
5 [报告]
发表于 2013-01-15 23:05 |只看该作者
  prerouting的分片是链接跟踪那些需要

  local_in的分片重组,可能是
  1、netfilter模块不支持,那prerouting那里就没有分片重组了
  2、可能是需要处理本机发往本机的数据包
                                       

论坛徽章:
0
6 [报告]
发表于 2013-01-16 08:39 |只看该作者
本帖最后由 whnewbie 于 2013-01-16 09:07 编辑

回复 5# luoyan_xy


   考虑有conntrack模块的情况下,发往本机的报文那岂不是意味着分片报文会重组两次?

论坛徽章:
4
酉鸡
日期:2014-03-21 23:19:50狮子座
日期:2014-08-01 22:11:40酉鸡
日期:2015-01-10 21:31:442015年辞旧岁徽章
日期:2015-03-03 16:54:15
7 [报告]
发表于 2013-01-16 08:44 |只看该作者
  1. int ip_forward(struct sk_buff *skb)
  2. {
  3.         struct iphdr *iph;        /* Our header */
  4.         struct rtable *rt;        /* Route we use */
  5.         struct ip_options *opt        = &(IPCB(skb)->opt);

  6.         if (skb_warn_if_lro(skb))
  7.                 goto drop;

  8.         if (!xfrm4_policy_check(NULL, XFRM_POLICY_FWD, skb))
  9.                 goto drop;

  10.         if (IPCB(skb)->opt.router_alert && ip_call_ra_chain(skb))<---------这个地方也重组分片, 知道是为啥么?
复制代码

论坛徽章:
0
8 [报告]
发表于 2013-01-16 21:58 |只看该作者
IP数据包如果分片的话,只有到达目的主机后,目的主机的IP层会在传送给传输层之前将接收到的所有分片
组装成一个完整的IP数据包。至于楼主贴出的钩子操作只是netfilter相关的操作,不属于协议栈本身的处理

论坛徽章:
0
9 [报告]
发表于 2013-01-17 10:33 |只看该作者
楼上的答复我明白。现在我开启了netfilter了的...defrag两次?

论坛徽章:
0
10 [报告]
发表于 2013-01-17 13:47 |只看该作者
今天看完了代码,算是明白了

conntrack收集完之后,设置了iph->frag_off = 0;所以,再次进入到Local_deliver的时候就不会再次收集分片了
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP