だから私は始まったばかりです。BSDルートキットの設計すぐに問題が発生したようです。
こんにちはc:
#include <sys/param.h>
#include <sys/module.h>
#include <sys/kernel.h>
#include <sys/systm.h>
static int
load(struct module *module, int cmd, void *arg) {
int error = 0;
switch (cmd) {
case MOD_LOAD:
uprintf("hello, world!\n");
break;
case MOD_UNLOAD:
uprintf("good-bye");
break;
default:
error = EOPNOTSUPP;
break;
}
return(error);
}
static moduledata_t hello_mod = {
"hello",
load,
NULL
};
DECLARE_MODULE(hello, hello_mod, SI_SUB_DRIVERS, SI_ORDER_MIDDLE);
次のMakefileを使ってコンパイルするとうまくいくようです。
ファイルの生成:
KMOD= hello
SRCS= hello.c
.include <bsd.kmod.mk>
しかし走るときsudo kldload ./hello.ko
モジュールがすでに次のことを行っていることを知らせます。
kldload: can't load ./hello.ko: module already loaded or in kernel
走るsudo kldstat -v | grep hello
何も見つかりませんでした。
最後のステップとして、以下を使用してモジュールを削除しようとしました。sudo kldunload hello
次の結果が表示されます。
kldunload: can't find file hello.ko
上記のコマンドを実行してみましたが、成功root
しませんでしたfreebsd
。
完全性のために、追加情報は次のとおりです。
ls-la:
total 224 drwxr-xr-x 2 freebsd freebsd 512 Dec 7 22:40 . drwxr-xr-x 4 freebsd freebsd 512 Dec 7 22:16 ..
-rw-r--r-- 1 freebsd freebsd 1386 Dec 7 22:40 .depend.hello.o
-rw-r--r-- 1 freebsd freebsd 50 Dec 7 22:07 Makefile
-rw-r--r-- 1 freebsd freebsd 0 Dec 7 22:40 export_syms
-rw-r--r-- 1 freebsd freebsd 488 Dec 7 22:08 hello.c
-rw-r--r-- 1 freebsd freebsd 3176 Dec 7 22:40 hello.kld
-rwxr-xr-x 1 freebsd freebsd 199904 Dec 7 22:40 hello.ko
-rw-r--r-- 1 freebsd freebsd 2864 Dec 7 22:40 hello.o lrwxr-xr-x 1 freebsd freebsd 26 Dec 7 22:40 machine -> /usr/src/sys/arm64/include
uname-Mrs。:
FreeBSD 12.0-RELEASE arm64
プラットフォーム
raspberry Pi 3B
私は同様の質問を見つけました。FreeBSDフォーラム昨年から始めましたが解決されませんでした。
何が起こっているのか、どうやって進むことができるのかご存知ですか?