是否可以从多个源文件构建内核模块,其中一个源文件与模块同名?
例如:
我想用以下源文件构建“mymodule.ko”:
mymodule.c的
mymodule_func.c
此makefile不起作用:
#Makefile
obj-m += mymodule.o
mymodule-objs := mymodule.o mymodule_func.o
感谢
答案 0 :(得分:16)
我找到了解决方案,我将源文件放在子文件夹中:
生成文件
SRC / mymodule.c的
SRC / mymodule_func.c
#Makefile
obj-m += mymodule.o
mymodule-objs := ./src/mymodule.o ./src/mymodule_func.o
all:
make -C $(KERNEL_PATH) M=$(PWD) modules
clean:
make -C $(KERNEL_PATH) M=$(PWD) clean
答案 1 :(得分:8)
在内核make文件中修复的正确方法如下:
#
obj-m+= my_module.o
#append other source files except my_module.c which would be include by default
my_module-objs+= src1.o src2.o
答案 2 :(得分:5)
根据我的理解,模块名称和源名称不可能相同。最好将模块名称提供为module.o
,并使用Makefile编译可加载的内核模块,如下所示,
Makefile
# If KERNELRELEASE is defined, we've been invoked from the
# kernel build system and can use its language.
ifneq ($(KERNELRELEASE),)
**obj-m := module.o
module-objs := mymodule.o mymodule_func.o**
# Otherwise we were called directly from the command
# line; invoke the kernel build system.
EXTRA_CFLAGS += -DDEBUG
else
KERNELDIR := /lib/modules/$(shell uname -r)/build
PWD := $(shell pwd)
default:
$(MAKE) -C $(KERNELDIR) M=$(PWD) modules
endif
clean:
$(MAKE) -C $(KERNELDIR) SUBDIRS=$(PWD) clean
答案 3 :(得分:3)
您可以使用TARGET
命名您的.ko文件,就像我在此示例中所做的那样:
TARGET = can
KDIR = /lib/modules/3.1.10-1.16-desktop/build
PWD := $(shell pwd)
obj-m += $(TARGET).o
can-objs := can_core.o can_open.o can_select.o can_sysctl.o can_write.o \
can_close.o can_ioctl.o can_read.o can_util.o \
can_debug.o can_error.o \
can_async.o can_sim.o
default:
make -C $(KDIR) M=$(PWD) modules
所以在构建之后,我结束了一堆目标文件和can.ko
答案 4 :(得分:1)
另一个解决方案是为文件创建符号链接,例如:
mymodule.c: ln -sf mymodule.c _mymodule.c
现在,使用_mymodule.o
作为对象名称:
mymodule-objs := _mymodule.o