カーネルモジュールをロードできません。

カーネルモジュールをロードできません。

だから私は始まったばかりです。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フォーラム昨年から始めましたが解決されませんでした。

何が起こっているのか、どうやって進むことができるのかご存知ですか?

ベストアンサー1

おすすめ記事