如何理解modinfo输出?

如何理解modinfo输出?

我只是想理解modinfo描述内核模块的输出。例如,在 module 的情况下i915,输出如下所示:

$ modinfo i915
filename:       /lib/modules/4.2.0-1-amd64/kernel/drivers/gpu/drm/i915/i915.ko
license:        GPL and additional rights
description:    Intel Graphics
author:         Intel Corporation
[...]
firmware:       i915/skl_dmc_ver1.bin
alias:          pci:v00008086d00005A84sv*sd*bc03sc*i*
[...]
depends:        drm_kms_helper,drm,video,button,i2c-algo-bit
intree:         Y
vermagic:       4.2.0-1-amd64 SMP mod_unload modversions
parm:           modeset:Use kernel modesetting [KMS] (0=DRM_I915_KMS from .config, 1=on, -1=force vga console preference [default]) (int)
[...]

我能够理解一些字段,但我不知道以下内容的含义:

  • firmware
  • alias
  • intree
  • vermagic

有谁知道如何解释它们?

答案1

固件:

firmware:       i915/skl_dmc_ver1.bin

许多设备需要两件事才能正常运行。一个驱动程序和一个固件。驱动程序从位于 的文件系统请求固件/lib/firmware。这是硬件所需的特殊文件,它不是二进制文件。然后,驱动程序执行所需操作,将固件加载到设备中。固件对设备内部的硬件进行编程。


别名:

alias:          pci:v00008086d00005A84sv*sd*bc03sc*i*

这可以在字符后面的部分中拆分:

  • v00008086:v代表供应商 ID,它标识硬件制造商。该列表由PCI 特别兴趣小组。你的号码0x8086代表“英特尔公司”。
  • d00005A84:d代表设备ID,由制造商选择。此 ID 通常与供应商 ID 配对,为硬件设备生成唯一的 32 位标识符。没有官方列表,我也无法找到英特尔设备 ID 列表来查找该号码。
  • sv*sd*: 这子系统供应商版本子系统设备版本用于进一步识别设备(*表示它将匹配任何内容)
  • bc03: 这基类。它定义了它是什么类型的设备;IDE interfaceEthernet controllerUSB Controller, ...bc03代表Display controller。您可能会从 的输出中注意到它们lspci,因为lspci将数字映射到设备类。
  • sc*: A子类到基类。
  • i*: 界面

内树:

intree:         Y

所有内核模块都以out-of-tree.一旦模块被接受包含,它就成为一个in-tree模块。没有该标志(设置为 )的模块N可以污染内核


维尔马吉克:

vermagic:       4.2.0-1-amd64 SMP mod_unload modversions

加载模块时,vermagic将检查值中的字符串是否匹配。如果它们不匹配,您将收到错误并且内核拒绝加载模块。您可以通过使用--force的标志来克服这个问题modprobe。当然,这些检查是为了保护您,因此使用此选项是危险的。

相关内容