C 从多个源文件构建内核模块,其中一个源文件与模块同名

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.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/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版本。我没有进一步调查…确保您的跨文件函数没有标记为静态。