当“wlan0”不是出现在/dev 中的设备时,Linux 如何找到/配置它?

Rib*_*ibo 2 wifi configuration device-tree

(在 raspberry pi zero w,内核 4.14y 上)似乎无线适配器芯片不是 /dev fs 中的设备,而是 'ifconfig' 知道的东西的名称。我知道这是 Berkley Sockets 的人工制品。

它是硬件,我认为它必须在设备树中提及——以导致加载某些驱动程序,但它不能在 /dev (devfs) 中创建条目。

Sockets 在哪里/如何找到这个不是设备的设备?

tel*_*coM 7

在 Linux 中,网络接口根本没有设备节点/dev

如果您需要可用网络接口的列表,例如在脚本中,请查看/sys/class/net/目录;你会看到每个界面有一个符号链接。将列出每个加载了驱动程序的网络接口。

以编程方式,您可以使用if_nameindex()系统调用:在 Stack Overflow 上查看此答案。

另外,请注意这/dev设备文件系统

设备树具有特定的不同的含义:它是一个系统的硬件组成的机器可读的描述。它用于没有即插即用硬件总线或无法自动发现硬件的系统。例如,像 Raspberry Pi 这样的 ARM SoC 上的 Linux 使用设备树。

RasPi 的启动顺序非常有趣:请参阅 RasPi.SE 上的这个问题。

简而言之,在启动时,在/boot/start.elf文件的控制下,GPU/boot/*.dtb在主 ARM CPU 启动之前加载适当的和 /boot/overlay/*.dtbo 文件。该*.dtb文件是二进制格式的编译后的设备树。它描述了可以在每个特定 RasPi 模型上找到的硬件,并从设备树源文件 (.dts`)生成,该文件只是以特定方式格式化的文本。

内核的设备树实时映像可以在: /sys/firmware/devicetree/base Per Ciro Santilli中看到,它可以通过以下方式以 .dts 格式显示:

sudo apt-get install device-tree-compiler
dtc -I fs -O dts /sys/firmware/devicetree/base
Run Code Online (Sandbox Code Playgroud)

您可以在此处找到设备树文件格式的规范。该规范旨在独立于操作系统。您可能还需要设备树参考作为对某些细节的澄清。

所以,你原来的问题的答案是这样的:

  • Berkeley Sockets API 从内核获取网络接口
  • 内核从设备树文件中获取必要的硬件信息
  • 设备树文件由 GPU/boot/start.elf根据配置加载/boot/config.txt
  • 设备树文件最初是根据每个 RasPi 模型的硬件规格创建的,并编译为适当的二进制格式。

设备树扫描代码主要关注为每个硬件找到一个有效的驱动程序。它不会太在意每个设备的用途:那是驱动程序的工作。

驱动程序使用适当的*_register_driver()内核函数来记录它自己的存在,使用设备树信息的适当部分来查找实际硬件,然后使用其他函数将该硬件注册为受其控制。一旦驱动程序初始化了硬件,它就会使用内核的register_netdev()函数将自己注册为一个新的网络接口,除其他外,这将使 Sockets API(它只是内核的另一个接口,而不是一个独立的实体)知道网络接口存在。

驱动程序也可能为其他事情注册自己:它会列出一些ethtool它支持的链接状态监控、流量统计和其他低级功能的操作,无线网卡的驱动程序也会register_wiphy()用来声明自己为具有特定 Wi-Fi 功能的无线网络接口。

Linux TCP/IP 堆栈有许多接口:Berkeley Sockets API 是应用程序程序员最熟悉的一面。netdev API 本质上是同一个硬币的另一个面向驱动程序的一面。