免费注册 查看新帖 |

Chinaunix

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

关于neifilter开发的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-11-26 20:20 |只看该作者 |倒序浏览
我注册了一个NF_IP_PRE_ROUTING hook函数,用来查看收到的所有数据包。我现在要对一些特定的数据包返回NF_STOLEN,延迟一段时间再将这些包重新注入内核,我之前想直接调用ip_rcv_finish(skb)函数,但是会出现段错误,接着就死机。

不知道这种方法错在哪里,或者正确的做法应该是怎样的?烦请高手指点下,谢了

论坛徽章:
0
2 [报告]
发表于 2008-11-26 21:14 |只看该作者
顶!
搭车问一下,NF_STOLEN的作用是什么呢?一直不是很明白。。。

论坛徽章:
3
金牛座
日期:2014-06-14 22:04:062015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:45
3 [报告]
发表于 2008-11-26 21:18 |只看该作者
原帖由 new_learner 于 2008-11-26 21:14 发表
顶!
搭车问一下,NF_STOLEN的作用是什么呢?一直不是很明白。。。


NF_STOLEN内核把这个包没收了,有点类似于NF_DROP,但又有所不同:
DROP就是丢弃,释放所有相关资源,就好象没有收到这个报文。STOLEN则表示hook函数接管了这个报文的处理,netfilter将放弃对这个报文的任何处理,但资源是不释放的。

论坛徽章:
36
IT运维版块每日发帖之星
日期:2016-04-10 06:20:00IT运维版块每日发帖之星
日期:2016-04-16 06:20:0015-16赛季CBA联赛之广东
日期:2016-04-16 19:59:32IT运维版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-19 06:20:00每日论坛发贴之星
日期:2016-04-19 06:20:00IT运维版块每日发帖之星
日期:2016-04-25 06:20:00IT运维版块每日发帖之星
日期:2016-05-06 06:20:00IT运维版块每日发帖之星
日期:2016-05-08 06:20:00IT运维版块每日发帖之星
日期:2016-05-13 06:20:00IT运维版块每日发帖之星
日期:2016-05-28 06:20:00每日论坛发贴之星
日期:2016-05-28 06:20:00
4 [报告]
发表于 2008-11-26 21:29 |只看该作者
STOLEN是告诉内核,这个包我这里接收了,你就不用操心这个包去哪里了。

论坛徽章:
36
IT运维版块每日发帖之星
日期:2016-04-10 06:20:00IT运维版块每日发帖之星
日期:2016-04-16 06:20:0015-16赛季CBA联赛之广东
日期:2016-04-16 19:59:32IT运维版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-19 06:20:00每日论坛发贴之星
日期:2016-04-19 06:20:00IT运维版块每日发帖之星
日期:2016-04-25 06:20:00IT运维版块每日发帖之星
日期:2016-05-06 06:20:00IT运维版块每日发帖之星
日期:2016-05-08 06:20:00IT运维版块每日发帖之星
日期:2016-05-13 06:20:00IT运维版块每日发帖之星
日期:2016-05-28 06:20:00每日论坛发贴之星
日期:2016-05-28 06:20:00
5 [报告]
发表于 2008-11-26 21:29 |只看该作者
LZ所谓“延迟一段”是什么意思,莫非是要丢到应用空间处理,再送回来吗?

论坛徽章:
0
6 [报告]
发表于 2008-11-26 21:32 |只看该作者
原帖由 Godbach 于 2008-11-26 21:29 发表
LZ所谓“延迟一段”是什么意思,莫非是要丢到应用空间处理,再送回来吗?


不是的,是在以后收到一些别的数据包以后再将之前的数据包重新注入内核

论坛徽章:
36
IT运维版块每日发帖之星
日期:2016-04-10 06:20:00IT运维版块每日发帖之星
日期:2016-04-16 06:20:0015-16赛季CBA联赛之广东
日期:2016-04-16 19:59:32IT运维版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-19 06:20:00每日论坛发贴之星
日期:2016-04-19 06:20:00IT运维版块每日发帖之星
日期:2016-04-25 06:20:00IT运维版块每日发帖之星
日期:2016-05-06 06:20:00IT运维版块每日发帖之星
日期:2016-05-08 06:20:00IT运维版块每日发帖之星
日期:2016-05-13 06:20:00IT运维版块每日发帖之星
日期:2016-05-28 06:20:00每日论坛发贴之星
日期:2016-05-28 06:20:00
7 [报告]
发表于 2008-11-26 21:33 |只看该作者
像LZ这样的应用,完全可以自己在PRE_ROUTING处注册自己的hook函数,对于符合你要的packet进行处理。

论坛徽章:
0
8 [报告]
发表于 2008-11-26 21:38 |只看该作者
原帖由 Godbach 于 2008-11-26 21:33 发表
像LZ这样的应用,完全可以自己在PRE_ROUTING处注册自己的hook函数,对于符合你要的packet进行处理。


我是注册了一个PRE_ROUTING hook函数,对收到的满足条件的数据包返回NF_STOLEN之前,保存skb,然后我想在将来收到另外一些数据的包的时候,将之前保存的skb重新交给内核,不知道应该如何实现

论坛徽章:
36
IT运维版块每日发帖之星
日期:2016-04-10 06:20:00IT运维版块每日发帖之星
日期:2016-04-16 06:20:0015-16赛季CBA联赛之广东
日期:2016-04-16 19:59:32IT运维版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-19 06:20:00每日论坛发贴之星
日期:2016-04-19 06:20:00IT运维版块每日发帖之星
日期:2016-04-25 06:20:00IT运维版块每日发帖之星
日期:2016-05-06 06:20:00IT运维版块每日发帖之星
日期:2016-05-08 06:20:00IT运维版块每日发帖之星
日期:2016-05-13 06:20:00IT运维版块每日发帖之星
日期:2016-05-28 06:20:00每日论坛发贴之星
日期:2016-05-28 06:20:00
9 [报告]
发表于 2008-11-26 22:17 |只看该作者
原帖由 sleepaholic 于 2008-11-26 21:38 发表


我是注册了一个PRE_ROUTING hook函数,对收到的满足条件的数据包返回NF_STOLEN之前,保存skb,然后我想在将来收到另外一些数据的包的时候,将之前保存的skb重新交给内核,不知道应该如何实现


不知道你当前的设备是用作主机还是用作路由设备。

如果你保存了之前的数据包,收到了另外数据包时再交给内核,那你像让内核如何处理这个包呢?

论坛徽章:
0
10 [报告]
发表于 2008-11-26 22:33 |只看该作者
原帖由 Godbach 于 2008-11-26 22:17 发表


不知道你当前的设备是用作主机还是用作路由设备。

如果你保存了之前的数据包,收到了另外数据包时再交给内核,那你像让内核如何处理这个包呢?


是作路由设备用。

恩,是的,我想在内核里面完成对包的处理
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP