是否有任何有效的方法(可能通过滥用gcc预处理器?)来获取一组剥离的内核源代码,其中根据.config不需要的所有代码都被省略了?
最佳答案
很好地解决了一些问题.

首先,可以通过获取使用的编译器命令

make KBUILD_VERBOSE=1 | tee build.log
grep '^  gcc' build.log

现在,我只选择一个gcc命令行进行进一步的操作.例如kernel / kmod.c的构建,它看起来像:

gcc 

我现在删除选项-c,-o …并添加-E,从而禁用编译并将预处理器输出写入屏幕.此外,我添加-fdirectives-only以防止宏扩展,-undef删除GNU定义的宏定义.内核makefile已添加-nostdinc以删除标准c头.

现在包含仍包含在内,因此扩展了预处理器输出.因此我通过grep管道输入文件删除它们:grep -v’#include’kernel / kmod.c.现在只剩下一个include:makefile的命令行包含autoconf.h.这很棒,因为它实际上定义了#ifdef CONFIG _…使用的宏来选择活动的内核代码.

唯一剩下的就是通过grep -v’^#’过滤掉预处理器注释和autoconf.h中剩余的#defines.

整个管道看起来像:

grep -v '#include' kernel/kmod.c | gcc -E -fdirectives-only -undef 

结果是kernel / kmod.c的过滤版本,其中包含实际构建到kmod.o中的代码.

问题仍然存在:如何为整个源代码树做到这一点?是否存在实际构建但从未在链接中使用和剥离的文件?

dawei

【声明】:淮南站长网内容转载自互联网,其相关言论仅代表作者个人观点绝非权威,不代表本站立场。如您发现内容存在版权问题,请提交相关链接至邮箱:bqsm@foxmail.com,我们将及时予以处理。