我只是想理解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 interface
,Ethernet controller
,USB 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
。当然,这些检查是为了保护您,因此使用此选项是危险的。