想象一个项目,它需要构建两个linux内核模块,具有以下源树布局:
modules/
|--common/
| `--common_data.c
|--mod1/
| `--mod1_main.c
`--mod2/
`--mod2_main.c
common_data.o目标文件需要包含在两个模块中。所以这个项目的Kbuild文件看起来像这样:
obj-m := mod1.o mod2.o
mod1-y := mod1/mod1_main.o common/common_data.o
mod2-y := mod2/mod2_main.o common/common_data.o
如果common_data.c文件中没有导出符号(即EXPORT_SYMBOL),则构建正常。但是,如果有一些导出的符号(例如some_func
),那么MODPOST将产生如下警告:
WARNING: mod2: 'some_func' exported twice. Previous export was in mod1.ko
这是因为两个模块共享单个Module.symvers文件。可以在mod1 /和mod2 /目录中创建两个单独的Kbuild文件以避免此警告,因为这将有两个单独的Module.symvers文件。但这会导致另一个问题 - commond_data.o对象将被构建两次 - 第一次编译mod1.ko时第二次编译mod2.ko。
使用单个Kbuild文件时是否有任何方法可以抑制此警告;或者在使用两个单独的Kbuild文件时阻止第二次重建common_data.o文件?
答案 0 :(得分:0)
在对Kbuild系统进行一些修补之后,我最终得出的结论是,处理这种情况的最简单方法是从外部makefile中的make
输出中过滤出警告消息:
$(MAKE) -C $(KDIR) M=$$PWD 2>&1 \
| grep -v '^WARNING:.*exported twice\. Previous export was in'
或者没有牺牲STDERR并将其压入STDOUT,但需要bash
:
bash -c "$(MAKE) -C $(KDIR) M=$$PWD 2> >( grep -v '^WARNING:.*exported twice\. Previous export was in' )"