Построение модуля ядра из нескольких исходных файлов, одно из которых имеет то же имя, что и модуль
Можно ли собрать модуль ядра из нескольких исходных файлов, один из которых имеет то же имя, что и модуль?
Например: я хочу собрать "mymodule.ko" со следующими исходными файлами:
mymodule.c
mymodule_func.c
Этот make файл не работает:
#Makefile
obj-m += mymodule.o
mymodule-objs := mymodule.o mymodule_func.o
Спасибо
Ответы
Ответ 1
Я нашел решение, я поместил исходный файл в подпапку:
Makefile
ЦСИ /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
Ответ 2
Правильный способ исправления в файле 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
Ответ 3
В соответствии с моим пониманием невозможно, чтобы имя модуля и имя источника были одинаковыми. Было бы лучше указать имя модуля как 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
Ответ 4
Вы можете использовать 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
Ответ 5
Другим решением является создание символической ссылки на файл, например:
mymodule.c: ln -sf mymodule.c _mymodule.c
Теперь используйте _mymodule.o
в качестве имени объекта:
mymodule-objs := _mymodule.o