我正在尝试启用从设备供应商处获得的内核模块以与 DKMS 配合使用。我可以成功构建模块并手动安装和启用它。但是当使用 DKMS 时,会出现一个对我没有任何帮助的错误:
$ sudo dkms build -m biokernbase -v 3.1.2.1
Kernel preparation unnecessary for this kernel. Skipping...
Building module:
cleaning build area....
make KERNELRELEASE=3.13.0-123-generic all KVERSION=3.13.0-123-generic DKMS=y
....
.ko failed for: 3.13.0-123-generic (x86_64)
Consult the make.log in the build directory
/var/lib/dkms/biokernbase/3.1.2.1/build/ for more information.
生成日志
DKMS make.log for biokernbase-3.1.2.1 for kernel 3.13.0-123-generic (x86_64)
Wed Dec 13 17:22:51 CET 2017
make -C /lib/modules/3.13.0-123-generic/build M=/var/lib/dkms/biokernbase/3.1.2.1/build modules
make[1]: Entering directory `/usr/src/linux-headers-3.13.0-123-generic'
CC [M] /var/lib/dkms/biokernbase/3.1.2.1/build/main.o
CC [M] /var/lib/dkms/biokernbase/3.1.2.1/build/event.o
CC [M] /var/lib/dkms/biokernbase/3.1.2.1/build/usbreader.o
CC [M] /var/lib/dkms/biokernbase/3.1.2.1/build/memory.o
CC [M] /var/lib/dkms/biokernbase/3.1.2.1/build/misc.o
CC [M] /var/lib/dkms/biokernbase/3.1.2.1/build/isa.o
LD [M] /var/lib/dkms/biokernbase/3.1.2.1/build/biokernbase.o
Building modules, stage 2.
MODPOST 1 modules
CC /var/lib/dkms/biokernbase/3.1.2.1/build/biokernbase.mod.o
LD [M] /var/lib/dkms/biokernbase/3.1.2.1/build/biokernbase.ko
make[1]: Leaving directory `/usr/src/linux-headers-3.13.0-123-generic'
dkms配置文件
PACKAGE_NAME="biokernbase"
PACKAGE_VERSION="3.1.2.1"
CLEAN="make clean DKMS=y"
MAKE[0]="make all KVERSION=$kernelver DKMS=y"
BUILT_MODULE_NAME[0]="biokernbase"
DEST_MODULE_LOCATION[0]="/kernel/drivers/misc"
AUTOINSTALL="yes"
Makefile
DRV_NAME := biokernbase
DRV_PATH := daqnavi
KVERSION := $(shell uname -r)
KDIR := /lib/modules/$(KVERSION)/build
BASE_DIR := /usr/lib/daqnavi
obj-m := $(DRV_NAME).o
$(DRV_NAME)-objs := main.o event.o usbreader.o memory.o misc.o isa.o
EXTRA_CFLAGS += -I$(BASE_DIR)/include -I$(BASE_DIR)/include/hw -I$(BASE_DIR)/include/linux
SYMBOL_PATH = $(BASE_DIR)/modules
all:
$(MAKE) -C $(KDIR) M=$(PWD) modules
clean:
$(MAKE) -C $(KDIR) M=$(PWD) clean
rm -f *.o *~ .depend .*.cmd *.ko *.mod.c .tmp_versions modules.order Module.symvers
更新 1:内核兼容性
我目前使用的是 Ubuntu 14.04.5 LTS,内核是 3.13.0-123-generic。
供应商的文档指出与 Ubuntu 12.04/14.04/15.10、内核版本 3.2/3.13/4.2 兼容。
当我手动将biokernbase.ko
dkms 构建的复制到时/lib/modules/3.13.0-123-generic/kernel/drivers/misc/
,内核模块似乎已成功加载:
$ sudo modprobe biokernbase; echo $?
0
非常感谢任何想法或提示。
答案1
从中删除手动复制的 biokernbase.ko /lib/modules/3.13.0-123-generic/kernel/drivers/misc/
。
像这样编辑dkms.conf
...(将原始文件保留为 .bak 文件)...
PACKAGE_NAME="biokernbase"
PACKAGE_VERSION="3.1.2.1"
CLEAN="make clean"
MAKE[0]="'make' all KVER=${kernelver}"
BUILT_MODULE_NAME[0]="biokernbase"
DEST_MODULE_LOCATION[0]="/updates/dkms"
AUTOINSTALL="yes"
再次执行sudo dkms build
并查看是否能解决问题。
答案2
我正在使用这个完全相同的模块(来自 Advantech)。我发现他们包含的 dkms.conf 有一些杂散的 \r 回车符,导致 dkms 脚本中的检查失败。尝试在 dkms.conf 上运行 dos2unix 或以其他方式确保没有不需要的空格字符。