1

驱动程序的静态加载存在一些问题,导致混乱。为了静态加载驱动程序,我遵循了两种方法 Process 1) 和 Process 2)。早些时候我遵循:

流程一:步骤如下:

  1. 我构建了名为 demochardrv.ko 的 char 驱动程序。
  2. 我将驱动程序复制到 /lib/modules/2.6.34.12/kernel/drivers/char/ 中。
  3. 我在 /etc/modules 中输入了它。
  4. 重启。

但是这 4 个步骤之前没有工作,我没有在 lsmod 中看到我的驱动程序。

因此,除了上述步骤之外,我还采用了另一种方式: 过程 2:步骤如下:

  1. 我在文件“/lib/modules/2.6.34.12/build/drivers/char/Kconfig”中添加了驱动程序详细信息: config DEMOCHARDRV tristate“TEST DEMO DRIVER' default n help TEST STATIC INSTALL DRIVER

  2. 我在“/lib/modules/2.6.34.12/build/drivers/char/Makefile”中添加了驱动程序详细信息:obj-$(CONFIG_DEMOCHARDRV) += demochardrv.o

  3. 复制 /lib/modules/2.6.34.12/build/drivers/char/ 中的驱动程序文件。

  4. 编辑 .config 文件并添加 CONFIG_DEMOCHARDRV=y。
  5. 触发 make menuconfig 并选择(使用 * / M)我的驱动程序。
  6. 制作、制作模块、制作 modules_install 和制作安装。
  7. 重启

现在,即使我没有在 menuconfig 中选择它,驱动程序也会在启动时加载。

为了解决流程 2 中的问题,我删除了 /etc/modules 中的条目。但是现在驱动程序根本没有加载。因此,我删除了 Process 2 步骤并再次遵循 Process 1 步骤,驱动程序现在正在启动时加载。现在流程 1 正在工作。但是流程 2 并不是单独工作的,它需要流程 1 的额外步骤。

所以我很困惑哪个过程是正确的。任何人都可以提供一些输入吗?

4

1 回答 1

1

当您“静态”加载 Linux 驱动程序时,您无法编译模块,您必须将其直接构建到内核二进制文件中。因此,您根本不应该将其视为模块,并将其配置为“*”(内置),或者根本不包含它。

根据内核 makefile doc,第二个过程应该是要走的路。但是,您应该放弃制作模块的想法,因为模块总是动态加载的。

于 2012-07-06T08:03:18.957 回答