我正在学习如何在Openwrt中开发一个内核模块。我做一个你好世界尝试。包目录树是:Openwrt内核模块
khelloworld/
Makefile
src/
khelloworld.c
Makefile
在openwrt生成文件源:
include $(TOPDIR)/rules.mk
include $(INCLUDE_DIR)/kernel.mk
PKG_NAME:=khelloworld
PKG_RELEASE:=1
PKG_VERSION:=1.0
include $(INCLUDE_DIR)/package.mk
define KernelPackage/khelloworld
SUBMENU:=HELLO WORLD MODULES
TITLE:=khelloworld
MAINTAINER:=Nobody
MENU:=1
FILES:=$(PKG_BUILD_DIR)/$(PKG_NAME).$(LINUX_KMOD_SUFFIX)
endef
EXTRA_KCONFIG:= \
CONFIG_HELLO_MOD=m
EXTRA_CFLAGS:= \
$(patsubst CONFIG_%, -DCONFIG_%=1, $(patsubst %=m,%,$(filter %=m,$(EXTRA_KCONFIG)))) \
$(patsubst CONFIG_%, -DCONFIG_%=1, $(patsubst %=y,%,$(filter %=y,$(EXTRA_KCONFIG)))) \
#MAKE_OPTS:= \
# EXTRA_CFLAGS="$(EXTRA_CFLAGS)" \
# $(EXTRA_KCONFIG)
define Build/Prepare
# Copy sources
mkdir -p $(PKG_BUILD_DIR)
cp -R ./src/* $(PKG_BUILD_DIR)/
endef
define Build/Compile
$(MAKE) -C "$(LINUX_DIR)" \
CROSS_COMPILE="$(TARGET_CROSS)" \
ARCH="$(LINUX_KARCH)" \
SUBDIRS="$(PKG_BUILD_DIR)" \
EXTRA_CFLAGS="$(EXTRA_CFLAGS)" \
$(EXTRA_KCONFIG) \
modules
endef
$(eval $(call KernelPackage,khelloworld))
源生成文件:
obj-m += khelloworld.o
all:
$(MAKE) -C "$(LINUX_DIR)" \
$(MAKE_OPTS) \
modules
与c的HelloWorld源:
#include <linux/module.h>
#include <linux/kernel.h>
int init_module(void) {
printk(KERN_INFO "Hello World KERNEL!!!\n");
return 0;
}
void cleanup_module(void) {
printk(KERN_INFO "Goodbye World KERNEL!!!\n");
}
该模块用这个命令编译好:让包/ khelloworld /编译
然后我用这个命令安装它在我的OpenWrt:
opkg install kmod-khelloworld-xxxxxx.ipk
,并没有错误完成安装。但问题dmesg
不显示init函数的预期消息。
但它显示此消息
[ 9493.863000] khelloworld: version magic '3.4.11-rt19 mod_unload modversions MIPS32_R1 32BIT ' should be '3.4.11-rt19 SMP preempt mod_unload MIPS32_R1 32BIT '
我认为insmod
丢失。所以我增加了以下安装宏Makefile文件只是"$(eval $(call KernelPackage,khelloworld))"
define Build/install
insmod $(PKG_BUILD_DIR)/khelloworld.ko
endef
之前,但没有解决不了的问题。 有没有人有关于这个问题的想法,以及我如何纠正它?
你错过了init和exit语句。你尝试过吗? – LethalProgrammer
@LethalProgrammer不能解决问题 –
您是否使用modprobe添加了加载模块? – LethalProgrammer