从几个源文件构build一个内核模块,其中一个与模块具有相同的名称

是否可以从几个源文件构build一个内核模块,其中一个与模块具有相同的名称。

例如:我想用下面的源文件构build“mymodule.ko”:
mymodule.c的
mymodule_func.c

这个makefile不起作用:

#Makefile obj-m += mymodule.o mymodule-objs := mymodule.o mymodule_func.o 

谢谢

Solutions Collecting From Web of "从几个源文件构build一个内核模块,其中一个与模块具有相同的名称"

我找到了一个解决方案,我把我的源文件放在一个子文件夹中:

Makefile文件
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 

你可以使用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

根据我的理解,不可能让模块名称和源名称相同。 将模块名称提供为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 

在内核make文件中修复的正确方法是:

 # obj-m+= module.o #append other source files except module.c which would be include by default module-objs+= src1.o src2.o 

另一个解决方案是创建符号链接到文件,说:

 mymodule.c: ln -sf mymodule.c _mymodule.c 

现在,使用_mymodule.o作为对象名称:

 mymodule-objs := _mymodule.o