如何注册Linux内核中的UDP端口并为此端口范围创建钩子

如何注册Linux内核中的UDP端口并为此端口范围创建钩子

问题描述:

我是Linux内核的新手。我正在编写内核模块,该模块处理多个UDP语音流。对于这个模块,我想在内核中注册多个不同语音流的UDP端口,以便其他UDP流量不能使用这些UDP端口。根据我的理解,创建套接字和绑定是一种方法。如何注册Linux内核中的UDP端口并为此端口范围创建钩子

我也想为这些UDP语音端口创建一个钩子函数,这样每当收到语音包时它都会调用我的钩子函数。

我有几个问题:

  • 有没有什么更好的办法在Linux内核中注册多个UDP端口,除了创建套接字并绑定?
  • 如何创建一个钩子函数,并为这些注册的多个UDP语音端口调用它?
+2

我必须问 - 你为什么要在内核中做这件事? –

+1

@ShacharShemesh:如果你没有问过,我会。看起来像我的XY问题。 – Olaf

+0

您应该针对特定问题提出具体问题。由于Stack Overflow隐藏了你的关闭原因:*“请修改问题以将其限制为具有足够细节的特定问题以确定一个合适的答案。避免一次询问多个不同的问题。请参阅如何寻求帮助以澄清此问题问题。“* – jww

简短的答案是这样的:如果你必须问,那么你不应该这样做。

这里的长版本:

TCP/IP编程其中API向用户空间使用它面向的领域之一。结果是,没有简单的方法从内核创建TCP/IP(包括UDP)套接字。

即使您管理它,也会发现您拥有的API不合适。当您使用它时,代码将尝试操作用户空间内存,用户空间通知等。

一位经验丰富的内核开发人员可能会将其拉下。然而,必须去Stack Overflow才能开始的人可能没有足够的经验。

这使我们回到原来的问题:为什么你想在内核编写这样的代码呢? IP语音是一个复杂的协议。在内核中调试代码比调试用户空间代码困难得多,更不用说出错时的错误恢复。

如果您正在编写绝对必须具有高性能和低延迟的代码,我建议您考虑将解决方案建立在纯粹的用户空间上(即根本没有内核)。

这样的解决方案是DPDK。它允许您将网络数据包直接接收到用户空间缓冲区中。不幸的是,这不是为初学者设计的解决方案。由于不涉及内核,接口必须专用于DPDK。这也意味着你必须编写自己的UDP堆栈来支持它。

DPDK不是一个简单的工具,但如果您必须拥有绝对最高的带宽和绝对最低的延迟时间,那么这是最好的解决方案。可能比在内核中编写整个VoIP栈更好。如果那不是你所需要的,那么就使用普通的套接字编程工具。