是否可以从多个源文件构建内核模块,其中一个与模块同名?
例如:我想用以下源文件构建“mymodule.ko”:
mymodule.c
mymodule_func.c
这个makefile不起作用:
#Makefile
obj-m += mymodule.o
mymodule-objs := mymodule.o mymodule_func.o
谢谢
是否可以从多个源文件构建内核模块,其中一个与模块同名?
例如:我想用以下源文件构建“mymodule.ko”:
mymodule.c
mymodule_func.c
这个makefile不起作用:
#Makefile
obj-m += mymodule.o
mymodule-objs := mymodule.o mymodule_func.o
谢谢
我找到了解决方案,我将源文件放在了一个子文件夹中:
生成文件
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
修复内核 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
据我了解,模块名称和源名称不可能相同。最好提供模块名称module.o
并使用 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
您可以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
另一种解决方案是为文件创建符号链接,例如:
mymodule.c: ln -sf mymodule.c _mymodule.c
现在,_mymodule.o
用作对象名称:
mymodule-objs := _mymodule.o
如果有人在使用Xilinx SoC和petalinux时偶然发现了这个问题,请注意生成的 .bb (bitbake) 文件。除了在 Makefile 中指定目标文件:
modulename-objs+= src1.o src2.o
所有文件(包括头文件)都必须列在 modulename.bb 文件的SRC_URI
变量中。