到目前为止,我有一个主要用 C 语言编写的大型系统,它一直在用户空间中运行。现在我需要将代码编译为内核模块。为此,afaik,我至少应该重写代码并将函数替换为malloc
, calloc
, free
,printf
与它们的内核等效项,因为这些只是用户空间函数。然而,问题是我没有系统中使用的一些定制库的源代码,这些库malloc
在它们的函数中调用等。所以,基本上,我可能需要重新实现整个库。
现在的问题是:如果我将自己的实现malloc
作为包装器编写,这将是一个非常肮脏的黑客攻击,kmalloc
如下所示:
void *malloc(size_t size) {
return kmalloc(size, GFP_USER);
}
然后将此实现链接到系统代码,这将消除模块错误中的所有未知符号。
实际上,我认为这将是一个常见问题,并且已经有人编写了这样的 kmalloc 包装器,但是我已经在谷歌上搜索了几天,没有发现任何有用的东西。
编辑:这样做的原因是我正在谈论的系统是在 VxWorks 实时操作系统上运行的实时应用程序,现在我们希望将其移植到 Linux RTAI 上使用,其中应用程序主要在内核空间中运行。但我想在用户空间也有可能实现实时,所以,我应该按照 Mike 的建议去做,将代码分成内核和用户空间部分,并通过共享内存在它们之间进行通信。