加入收藏 | 设为首页 | 会员中心 | 我要投稿 宁德站长网 (https://www.0593zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 服务器 > 搭建环境 > Linux > 正文

linux – 如何防止内核将数据包传递到网络层?

发布时间:2021-01-13 08:27:42 所属栏目:Linux 来源:网络整理
导读:网卡接收的帧将由驱动程序处理,然后由Linux内核传递给协议栈的上层. 有没有一种简单的方法可以防止内核将数据包传递到网络层?这样我就可以从数据链路层接收帧并自己处理所有数据包(也许应用程序层程序会被重写)? 我认为重新编译内核是必要的,如果这是通

网卡接收的帧将由驱动程序处理,然后由Linux内核传递给协议栈的上层.

有没有一种简单的方法可以防止内核将数据包传递到网络层?这样我就可以从数据链路层接收帧并自己处理所有数据包(也许应用程序层程序会被重写)?

我认为重新编译内核是必要的,如果这是通过修改softirq中的代码或netif_rx或每个cpu的列表队列中的函数来完成的?

事实上,有些同学和我正在尝试在用户空间中实现TCP / IP协议栈的简化版本以进行练习,我们刚刚开始.我正在阅读一些书籍,如UNP,APUE2,TC??P / IP插图v1,v2,Linux网络架构,linux源代码等.我还有其他一些问题,我是否需要发布另一个问题?

最佳答案 如果你只想自己处理数据包,你可以使用内核模块netfilter并实现一些钩子.您可以轻松找到一些代码示例.

在不同的钩子中,您可以选择处理数据包并将其返回给内核或丢弃它.这只是一个改变的返回代码.

给出一些代码和解释主题的文章:http://www.linuxjournal.com/article/7184

这个解决方案可行,并且不太难实现,但不确定这是解决问题的自然方法.

(编辑:宁德站长网)

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

    热点阅读