cpu
[TOC] drivers/base/cpu.c CPU设备管理(CPU Device Management) CPU热插拔的核心实现drivers/base/cpu.c 是Linux内核设备模型中的一个基础文件,其核心职责是将系统中的各个CPU(中央处理器)抽象为标准的设备,并通过sysfs文件系统进行管理。该文件最主要的功能是为Linux内核提供CPU热插拔(CPU Hotplug)机制的通用框架,允许在系统运行时动态地使CPU核心上线(online)或离线(offline)。 历史与背景这项技术是为了解决什么特定问题而诞生的?CPU热插拔机制的出现主要是为了满足日益复杂的系统需求: RAS(可靠性、可用性、可服务性):在高端服务器和NUMA(非统一内存访问)硬件中,系统需要能够在不宕机的情况下,物理上移除发生故障的CPU节点,或添加新的计算资源。 电源管理:在负载较低时,可以将闲置的CPU核心完全离线,从而彻底切断其电源,实现比普通待机模式更深层次的节能。 资源灵活性与虚拟化:在虚拟化环境中,可以根据虚拟机的负载动态增加或减少vCPU(虚拟CPU)的数...
dd
[TOC] drivers/base/dd.c 驱动延迟探测(Driver Deferred Probing) 管理设备依赖和初始化顺序drivers/base/dd.c 是Linux内核驱动核心(Driver Core)的一个关键文件,它实现并管理着**驱动延迟探测(Deferred Probing)**机制。这个机制是现代Linux内核设备模型正常运转的基石,其核心功能是解决设备驱动初始化过程中的依赖顺序问题。当一个设备的驱动在尝试“探测”(probe,即初始化)时,如果它所依赖的其他资源(如时钟、电源、GPIO等)尚未准备就绪,该机制允许该驱动的探测操作被安全地推迟,并在稍后合适的时机自动重试。 历史与背景这项技术是为了解决什么特定问题而诞生的?这项技术是为了解决在复杂的片上系统(SoC)中普遍存在的设备依赖和初始化顺序问题而诞生的。 复杂的硬件依赖:现代硬件中,一个设备(如一个I2C音频解码器)的正常工作通常依赖于多个其他硬件模块。例如,它需要一个时钟控制器为其提供时钟信号,需要一个电源管理芯片(PMIC)为其提供稳定的电压,还可能需要一个GPIO控...
devres
[TOC] lib/devres.cdevm_ioremap_resource: 安全、自动管理的IO内存映射此函数是Linux内核中用于设备驱动程序开发的一个至关重要的辅助函数。它的核心作用是将一个从设备树(Device Tree)或平台数据中获取的、描述硬件寄存器物理地址的资源(struct resource), 安全地映射到内核可以访问的虚拟地址空间, 并且这个过程是完全由设备资源管理(devm)框架自动管理的。 该函数将一个典型的三步操作封装成了一个单一的、原子的API调用: 验证与请求: 它首先检查传入的资源是否是一个有效的内存区域(IORESOURCE_MEM)。然后, 它调用devm_request_mem_region向内核的资源仲裁系统”宣告”:”本驱动将要使用这段物理内存”。这可以防止两个不同的驱动程序意外地同时操作同一块硬件寄存器区域, 从而避免冲突。 内存映射: 在成功”占有”该物理内存区域后, 它调用底层的__devm_ioremap函数, 将这段物理地址映射为内核虚拟地址。这个返回的虚拟地址(类型为void __iomem *)就是驱...
devtmpfs
[TOC] drivers/base/devtmpfs.chandle_create 创建一个设备节点(device node)123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141// 在内核空间创建一个目录。// name: 要创建的目录的路径字符串。// mode: 目录的访问权限模式 (例如 0755)。static int dev_mkdir(const char *name, umo...
faux
[TOC] drivers/base/faux.c 虚拟设备总线(Faux Bus) 简化虚拟设备驱动的创建历史与背景这项技术是为了解决什么特定问题而诞生的?drivers/base/faux.c 文件所实现的 “Faux Bus”(虚拟总线)是一项较新的内核技术,在 Linux 6.14 内核中被合并。它的诞生主要是为了解决一个长期存在的内核开发“滥用”问题:将平台总线(Platform Bus)用于不属于平台设备(Platform Device)的场景。 内核维护者 Greg Kroah-Hartman 指出,多年来,许多开发者为了利用设备模型的便利性(如自动的驱动-设备绑定、probe/remove回调机制),会将一些纯粹的虚拟设备或简单的逻辑设备注册为“平台设备”。 这种做法在功能上可行,但从设计哲学上看是不正确的,因为平台设备本意是指那些在SoC(片上系统)上,无法通过正常总线(如PCI, USB)枚举发现的、有固定内存地址或硬件资源的设备。将纯虚拟设备(例如一个用于测试的dummy regulator)注册为平台设备,是一种概念上的滥用,...
sys_call_table
Linux内核ARM架构下sys_call_table的自动化生成机制剖析1. 引言在Linux操作系统内核中,系统调用(System Call)构成了用户空间与内核空间交互的基础接口。为了高效地将用户空间传递的系统调用号(System Call Number, SCN)映射至内核中相应的服务例程,内核在内部维护了一个核心数据结构——系统调用表。对于ARM架构,此表定义为sys_call_table,其本质是一个函数指针数组。 维护这样一个包含数百个条目,且需兼容多种应用程序二进制接口(Application Binary Interface, ABI)的数组,是一项复杂且易错的任务。任何手动的编辑都可能引入调用号与函数指针不匹配、ABI兼容性层实现错误或表大小同步失败等严重问题。为规避此类风险,Linux内核采用了一套高度自动化的代码生成机制。本文旨在以严谨的技术视角,对ARM架构下sys_call_table从源定义文件到最终二进制镜像中符号的全过程,进行深入、详尽的剖析。 2. sys_call_table 自动化生成流程sys_call_table的构建并非在C代码层面进...
base
[TOC] drivers/basedrivers/base 是Linux内核源代码中的一个核心目录,它并非一项独立的技术,而是内核设备模型(Linux Device Model)的基础实现。这个模型是一个统一的、抽象的框架,用于管理系统中的所有设备、驱动程序以及它们之间的关系。理解drivers/base就是理解现代Linux内核如何看待和管理硬件。 历史与背景这项技术是为了解决什么特定问题而诞生的? 在Linux内核2.5版本之前,内核中没有一个统一的结构来表示设备和驱动程序。驱动程序的编写和管理方式较为混乱,存在诸多问题: 电源管理困难:没有统一的设备层级结构,很难以正确的顺序对设备进行挂起(suspend)或恢复(resume)操作。例如,USB主控制器必须在USB设备之前被挂起。 代码冗余:每个子系统(如PCI, USB)都需要自己实现一套管理设备和驱动的机制,导致了大量的重复代码,尤其是在对象生命周期管理(如引用计数)和列表管理方面。 系统信息不透明:缺乏一种简洁、一致的方式从用户空间查看系统中所有设备的拓扑结构和状态。当时的 /proc 文件系统虽...
firmware
[TOC] drivers/base/firmware 固件加载器核心(Firmware Loader Core) 内核与用户空间固件交互的桥梁历史与背景这项技术是为了解决什么特定问题而诞生的?drivers/base/firmware 目录中的代码实现了Linux内核的固件加载器(Firmware Loader)框架。这项技术的诞生是为了解决现代硬件驱动程序面临的几个核心问题: 许可(Licensing)问题:许多硬件设备(如Wi-Fi、GPU、网络适配器)需要运行一段专有的、非开源的“固件”代码才能正常工作。根据GPLv2许可证,这些二进制“固件块”(blobs)不能直接编译进开源的Linux内核镜像中。固件加载器提供了一种机制,将这些非开源固件与开源的驱动程序分离开来。 灵活性和可更新性:将固件硬编码到驱动程序中是一种非常僵硬的设计。当固件需要更新以修复bug或添加新功能时,用户将不得不重新编译并安装整个内核。固件加载器允许固件作为普通文件存放在文件系统中(通常在 /lib/firmware),使得更新固件就像替换一个文件一样简单,无需触及内核本身。 ...
platform
[TOC] drivers/base/platform.c 平台设备模型(Platform Device Model) 描述SoC内部设备历史与背景这项技术是为了解决什么特定问题而诞生的?drivers/base/platform.c 文件实现了Linux内核中的“平台设备模型”(Platform Device Model)。这项技术是为了解决嵌入式系统(特别是基于ARM等SoC的设备)中如何描述和管理那些不通过标准总线(如PCI, USB, I2C, SPI)枚举,而是直接由系统集成商(SoC厂商)通过内存映射地址或其他固定方式连接到CPU总线上的设备的问题。 在没有平台设备模型之前,这些SoC内部的设备(如GPIO控制器、UART控制器、时钟控制器、中断控制器、DMA控制器等)的驱动程序通常是零散地被编写的,并且管理方式非常底层和不统一。开发者需要手动解析设备树(Device Tree)或其他平台数据,获取设备的基地址、长度、中断号等信息,然后手动映射内存、申请中断,并将这些信息传递给驱动。这种方式存在以下问题: 代码冗余:每种类型的设备驱动都需要重复实...
syscore
[toc] drivers/base/syscore.c 系统核心操作(System Core Operations) 管理核心系统组件的休眠与关闭历史与背景这项技术是为了解决什么特定问题而诞生的?drivers/base/syscore.c 文件实现了内核的“系统核心操作”(System Core Operations)框架。这项技术的诞生是为了解决一个非常底层且关键的问题:在系统范围的电源状态转换(如休眠、恢复、关闭)期间,如何以正确的顺序管理那些比普通设备更基础、更核心的系统组件。 常规的设备驱动程序通过其 .suspend 和 .resume 回调函数参与电源管理。然而,系统中存在一些组件,它们: 不是标准的“设备”:它们可能没有 struct device 实例,因此无法使用标准的设备电源管理(Device PM)框架。 具有严格的顺序依赖:它们的休眠和唤醒操作必须在所有普通设备之前或之后执行。 最典型的例子就是中断控制器(如ARM GIC)。在系统休眠时,必须在所有使用中断的设备都已经被挂起之后,才能挂起中断控制器本身。反之,在系统唤醒时,必须...








