8

正如我在阅读 Linux Device Drivers 3rd Edition 中与 Linux 设备模型相关的章节后所了解的那样,当配置新设备时,内核(2.6)或多或少遵循以下顺序:

  1. 设备在驱动核心中注册(device_register(),其中包括设备初始化)
  2. 在设备模型中注册了一个 kobject
  3. 它在 sysfs 中创建一个条目并引发热插拔事件
  4. 检查总线和驱动程序以查看哪一个与设备匹配
  5. 探测
  6. 设备绑定到驱动

我的主要疑问是,在第 1 步中,何时device_register()调用以及应该在device结构中设置哪些字段?

它是由设备所连接的总线调用的吗?代码中有任何示例吗?

我有什么误解吗?:)

4

2 回答 2

3

PCI 热插拔代码将调用 pci_do_scan_bus() 来遍历所有插槽,看看我们是否找到了设备/网桥并将它们添加到我们的设备树中:

unsigned int __devinit pci_do_scan_bus(struct pci_bus *bus)   { 
    max = pci_scan_child_bus(bus) //scan bus for all slots and devices in them
    pci_bus_add_devices(bus);  //add what we find
...
}

struct device 中的字段实际上是在调用 pci_scan_child_bus() 时填充的。这是调用图(有点:)):

pci_scan_child_bus > pci_scan_slot(扫描总线上的插槽)> pci_scan_single_device > pci_device_add > device_initialize。

注意 device_initialize() 是 device_register() 的第一部分。您将看到在调用 device_initialize() 之后,struct device 的字段在 pci_device_add 中填充。您可以在内核源代码的 drivers/pci/probe.c 下找到它。struct pci_dev 也将被填充,稍后将由设备特定的驱动程序使用。

将 kobject 实际添加到设备层次结构中发生在 pci_bus_add_devices 中。这是调用图:

pci_bus_add_devices > pci_bus_add_device > device_add。

如您所见,此调用流程完成了 device_register() 函数的第二部分。

因此,简而言之,device_register() 包括:1. 初始化设备和 2. 添加设备。pci_device_add 执行第 1 步, pci_bus_add_device 执行第 2 步。

感兴趣的文件是:drivers/pci/{pci.c,bus.c,probe.c}

于 2010-06-04T20:11:26.900 回答
0

struct bus type中有一个指向函数 match的指针,它的工作是匹配与设备关联的驱动程序。因此,当设备与总线相关联时,一旦设备连接到总线,总线就有责任搜索设备。

如果不是这样,请纠正我。

于 2012-10-19T10:04:45.840 回答