C 从多个源文件构建内核模块,其中一个源文件与模块同名
是否可以从多个源文件构建一个内核模块,其中一个源文件与该模块具有相同的名称 例如: 我想用以下源文件构建“mymodule.ko”:C 从多个源文件构建内核模块,其中一个源文件与模块同名,c,linux,makefile,linux-kernel,C,Linux,Makefile,Linux Kernel,是否可以从多个源文件构建一个内核模块,其中一个源文件与该模块具有相同的名称 例如: 我想用以下源文件构建“mymodule.ko”: mymodule.c mymodule_func.c 此生成文件不工作: #Makefile obj-m += mymodule.o mymodule-objs := mymodule.o mymodule_func.o 谢谢您可以使用TARGET来命名您的.ko文件,就像我在本例中所做的那样: TARGET = can KDIR = /lib/modules
mymodule.c
mymodule_func.c 此生成文件不工作:
#Makefile
obj-m += mymodule.o
mymodule-objs := mymodule.o mymodule_func.o
谢谢您可以使用
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
我找到了一个解决方案,我将源文件放在一个子文件夹中: 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
另一种解决方案是创建指向该文件的符号链接,例如:
mymodule.c: ln -sf mymodule.c _mymodule.c
现在,使用\u mymodule.o
作为对象名称:
mymodule-objs := _mymodule.o
在内核生成文件中修复的正确方法如下:
#
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
如果我在can objs中添加一个can.o对象,我会得到make[2]:Circular can.o,谢谢你的回答。我发现它是这里最有用的方法。这种方法对我不起作用,可能取决于kernel/kbuild版本。我没有进一步调查…确保您的跨文件函数没有标记为静态。