Linux内核代码60%都是驱动?驱动代码不会造成内核臃肿吗?

原创 嵌入式悦翔园 2023-07-11 11:40

关注星标公众号,第一时间获取信息

一、前言

今天逛知乎看到这么一个问题:为什么Linux内核代码60%都是驱动? 如果每支持新的设备就加入驱动,内核会不会变得越来越臃肿?

要先搞明白这个问题,我们首先要明确(区分)两个概念:内核代码内核,这是两个完全不一样的概念,我们通过 git clone 命令从网上拉取下来的代码叫做内核代码,如果增加新的设备内核代码确实会变得越来越臃肿,这点是肯定的,但是内核并不会变得臃肿,具体原因我们接下里会进行讨论。说了那么多内核代码,那内核是什么呢?为什么内核代码变多了内核却不会变大?

内核 是我们通过交叉编译之后真正烧录到板子里跑起来的代码,而交叉编译的时候,是有选择的进行编译,这里面有顶尖的大神们的智慧结晶,与你硬件相关的才编译,不相关的代码则不会被编译到内核里,所以不是说内核里提交了一个设备的驱动你的内核就会变大,这要看你的硬件有没有用到这个驱动。

二、Linux中避免内核臃肿的措施

我们上面知道了内核是经过我们交叉编译裁剪之后的代码,会有选择性的将对我们有用的代码编译进内核中,不需要的将被舍弃,这是Linux内核开发者智慧的结晶,也是保证内核不会变得臃肿的原因。那除了交叉编译之外还有没有其他的措施来保证内核不会变的越来越大呢?下面就给大家分享几个用来保证内核不臃肿的措施。

2.1 交叉编译及SDK包的裁剪

(这部分稍微有些啰嗦,主要为了让初学者更好的理解,老工程师可以直接跳过啦!)交叉编译是指在一种平台上编译生成在另一种不同平台上运行的可执行程序。在Linux中,常见的情况是在PC主机(Ubuntu系统)上编译生成适用于嵌入式设备或其他架构的目标程序。

通过上面的介绍我们已经知道了内核代码是会通过交叉编译来进行选择性的将对我们有用的代码编译进内核的,但是交叉编译到底是如何工作的呢?我们应该怎么去配置交叉编译以让我们的内核能过够在稳定运行的基础上尽量小巧呢?

做过嵌入式Linux的应该都清楚,我这里的介绍也主要针对嵌入式Linux来讲解,一般嵌入式Linux的交叉编译工具链都是由SDK包提供商(一般是芯片厂)提供,所以一般不需要我们进行编写和设计,只需要针对自己开发板的实际情况进行裁剪即可。

其实Linux代码到你烧录到板子中的内核代码是经过了下面的过程:

上面的图是我对于一套代码从Linux开源代码一步一步的被裁剪和适配后最终到达用户手中过程的理解,当然不同的厂商这个过程可能有所不同。

所以回到我们的问题,看完上面图片中的过程,你觉得Linux内核中提交了新设备的驱动代码会被烧录到最终烧录到板子中吗?

这里分几种情况来讨论:

  1. 如果这个新设备在该款芯片上完全不会用到,那么芯片厂提供的SDK包中就不会包含这个驱动;
  2. 如果这个新设备芯片是支持的,但是我这款开发板不支持,那么板厂就不会同步这个设备的驱动;
  3. 如果这个新设备在开发板上也是支持的,但是作为用户完全不会用到该设备,那么该设备的驱动也会被裁剪;

所以不是说Linux内核代码中新提交一个设备驱动,该设备驱动就会最终到开发板中,中间是会经过很多筛选的,只有真正对用户有用的代码才会被同步编译和烧录。

这里用户可能会有疑问,讲了半天代码包的裁剪,代码裁剪和交叉编译有什么关系呢?这里还要明确一点,代码的裁剪并不是你想象的直接把代码从代码包中删除了,更多时候是把代码从编译中删除掉,即该设备的驱动并不会被编译到内核中,但是源代码你还是可以看到的。

2.2 设备树

设备树的由来想必大家应该都有所耳闻:

ARM社区一贯充斥的大量垃圾代码导致Linus盛怒,因此社区在2011年到2012年进行了大量的工作。ARM Linux开始围绕Device Tree展开,Device Tree有自己的独立的语法,它的源文件为.dts,编译后得到.dtb,Bootloader在引导Linux内核的时候会将.dtb地址告知内核。之后内核会展开Device Tree并创建和注册相关的设备,因此arch/arm/mach-xxx和arch/arm/plat-xxx中大量的用于注册platform、I2C、SPI板级信息的代码被删除,而驱动也以新的方式和.dts中定义的设备结点进行匹配。

在设备树出现之前,内核代码中包含了大量与硬件设备相关的配置信息和初始化操作。随着硬件数量和多样性的增加,内核代码变得越来越复杂,难以管理和维护。设备树将硬件描述从内核代码中分离出来,使得内核代码更加清晰简洁,并且与具体硬件解耦。

使用设备树可以在运行时动态地配置硬件设备,而无需修改内核源代码。这点对于代码的调试非常方便,我们自需要重新编译设备树文件放到开发板中即可,而不用重新烧录整个内核。设备树中的硬件描述信息可以根据实际硬件配置进行自由组合和调整,从而达到更好的兼容性和灵活性。

2.3 模块化

Linux内核采用的是模块化设计,通过将功能划分为独立的模块,可以提高代码的可复用性和灵活性。内核模块是一段可以被动态加载到内核中并扩展其功能的代码。它相对独立于内核的其他部分,在需要时可以加载或卸载。

除了动态的加载将通用的功能封装成独立的模块,可以被多个子系统或驱动程序共享和复用,避免了重复编写相同的代码,提高了开发效率。如果看过I2C驱动的话大家应该清楚I2C驱动分为设备驱动和核心驱动,Linux内核已经将I2C驱动的公用代码封装到核心代码中了,其实I2C设备驱动代码只需要简单的调用I2C核心驱动中的接口即可,而不用从0开始完成一个I2C的驱动代码,这样代码的复用率会变高,内核驱动的代码量和代码复杂度也会变小。

2.4 硬件抽象层

硬件抽象层(Hardware Abstraction Layer,HAL)是一种软件层,用于将底层硬件设备的详细实现细节与上层应用程序隔离开来,提供一组统一的接口和功能,以简化对硬件的访问和操作。

硬件抽象层起到了在不同硬件平台之间建立标准化接口的作用,使得应用程序可以以相似的方式进行硬件访问和控制,而无需关心具体硬件的细节。通过使用硬件抽象层,开发人员可以更加方便地编写跨平台或可移植的应用程序,而不需要针对每个具体硬件设备进行独立的编程。

总的来说硬件抽象层提供了一种中间层的软件抽象,将底层硬件设备的具体实现细节与上层应用程序解耦,为开发人员提供简化的硬件访问接口和功能,以提高应用程序的可移植性和跨平台性。

三、嵌入式Linux的裁剪

其实本文默认说的Linux内核都是说的嵌入式Linux,因为对于像Ubuntu这种系统我也不太清楚。对于嵌入式Linux的裁剪我们上面已经介绍了整个代码包的流程,想必大家已经明白了我们烧录进去的内核是已经通过交叉编译精简过的,所以理论上来说烧录进去的已经是最精简的了。

其实内核裁剪不是我们想象的那么简单,只有道行深的工程师才敢进行内核的裁剪。Linux内核裁剪我也没有做过,所以这部分我留给大佬来补充吧!

四、总结

所以回归最开始的问题,Linux内核代码60%都是驱动?驱动代码不会造成内核臃肿吗?我认为答案是不会,如果你认为会变得越来越臃,可以一起交流一下哦!

推荐阅读



01

加入嵌入式交流群


02

嵌入式资源获取


03

STM32中断优先级详解


04

STM32下载程序新思路--使用串口下载程序


嵌入式悦翔园 专注于嵌入式技术,包括但不限于STM32、Arduino、51单片机、物联网、Linux等编程学习笔记,同时包含大量的学习资源。欢迎关注,一同交流学习,共同进步!
评论 (0)
  • 1. 在Ubuntu官网下载Ubuntu server  20.04版本https://releases.ubuntu.com/20.04.6/2. 在vmware下安装Ubuntu3. 改Ubuntu静态IP$ sudo vi /etc/netplan/00-installer-config.yaml# This is the network config written by 'subiquity'network:  renderer: networkd&nbs
    二月半 2025-04-17 16:27 118浏览
  •   无人机电磁兼容模拟训练系统软件:全方位剖析   一、系统概述   北京华盛恒辉无人机电磁兼容模拟训练系统软件,专为满足无人机于复杂电磁环境下的运行需求而打造,是一款专业训练工具。其核心功能是模拟无人机在电磁干扰(EMI)与电磁敏感度(EMS)环境里的运行状况,助力用户评估无人机电磁兼容性能,增强其在复杂电磁场景中的适应水平。   应用案例   目前,已有多个无人机电磁兼容模拟训练系统在实际应用中取得了显著成效。例如,北京华盛恒辉和北京五木恒润无人机电磁兼容模拟训练系统。这些成功案例为
    华盛恒辉l58ll334744 2025-04-17 14:52 52浏览
  •   无人机蜂群电磁作战仿真系统软件,是专门用于模拟、验证无人机蜂群在电磁作战环境中协同、干扰、通信以及对抗等能力的工具。下面从功能需求、技术架构、典型功能模块、发展趋势及应用场景等方面展开介绍:   应用案例   目前,已有多个无人机蜂群电磁作战仿真系统在实际应用中取得了显著成效。例如,北京华盛恒辉和北京五木恒润无人机蜂群电磁作战仿真系统。这些成功案例为无人机蜂群电磁作战仿真系统的推广和应用提供了有力支持。   功能需求   电磁环境建模:模拟构建复杂多样的电磁环境,涵盖各类电磁干扰源与
    华盛恒辉l58ll334744 2025-04-17 16:49 111浏览
  • 现阶段,Zigbee、Z-Wave、Thread、Wi-Fi与蓝牙等多种通信协议在智能家居行业中已得到广泛应用,但协议间互不兼容的通信问题仍在凸显。由于各协议自成体系、彼此割据,智能家居市场被迫催生出大量桥接器、集线器及兼容性软件以在不同生态的设备间构建通信桥梁,而这种现象不仅增加了智能家居厂商的研发成本与时间投入,还严重削减了终端用户的使用体验。为应对智能家居的生态割裂现象,家居厂商需为不同通信协议重复开发适配方案,而消费者则需面对设备入网流程繁琐、跨品牌功能阉割及兼容隐患等现实困境。在此背景
    华普微HOPERF 2025-04-17 17:53 91浏览
  • 一、行业背景与需求智能门锁作为智能家居的核心入口,正从单一安防工具向多场景交互终端演进。随着消费者对便捷性、安全性需求的提升,行业竞争已从基础功能转向成本优化与智能化整合。传统门锁后板方案依赖多颗独立芯片(如MCU、电机驱动、通信模块、语音模块等),导致硬件复杂、功耗高、开发周期长,且成本压力显著。如何通过高集成度方案降低成本、提升功能扩展性,成为厂商破局关键。WTVXXX-32N语音芯片通过“单芯片多任务”设计,将语音播报、电机驱动、通信协议解析、传感器检测等功能整合于一体,为智能门锁后板提供
    广州唯创电子 2025-04-18 09:04 161浏览
  •   无人机蜂群电磁作战仿真系统全解析   一、系统概述   无人机蜂群电磁作战仿真系统是专业的仿真平台,用于模拟无人机蜂群在复杂电磁环境中的作战行为与性能。它构建虚拟电磁环境,模拟无人机蜂群执行任务时可能遇到的电磁干扰与攻击,评估作战效能和抗干扰能力,为其设计、优化及实战应用提供科学依据。   应用案例   目前,已有多个无人机蜂群电磁作战仿真系统在实际应用中取得了显著成效。例如,北京华盛恒辉和北京五木恒润无人机蜂群电磁作战仿真系统。这些成功案例为无人机蜂群电磁作战仿真系统的推广和应用提
    华盛恒辉l58ll334744 2025-04-17 16:29 121浏览
  •   无人机电磁环境效应仿真系统:深度剖析   一、系统概述   无人机电磁环境效应仿真系统,专为无人机在复杂电磁环境下的性能评估及抗干扰能力训练打造。借助高精度仿真技术,它模拟无人机在各类电磁干扰场景中的运行状态,为研发、测试与训练工作提供有力支撑。   应用案例   目前,已有多个无人机电磁环境效应仿真系统在实际应用中取得了显著成效。例如,北京华盛恒辉和北京五木恒润无人机电磁环境效应仿真系统。这些成功案例为无人机电磁环境效应仿真系统的推广和应用提供了有力支持。   二、系统功能  
    华盛恒辉l58ll334744 2025-04-17 15:51 118浏览
  • 近日,全球6G技术与产业生态大会(简称“全球6G技术大会”)在南京召开。紫光展锐应邀出席“空天地一体化与数字低空”平行论坛,并从6G通信、感知、定位等多方面分享了紫光展锐在6G前沿科技领域的创新理念及在空天地一体化技术方面的研发探索情况。全球6G技术大会是6G领域覆盖广泛、内容全面的国际会议。今年大会以“共筑创新 同享未来”为主题,聚焦6G愿景与关键技术、安全可信、绿色可持续发展等前沿主题,汇聚国内外24家企业、百余名国际知名高校与科研代表共同商讨如何推动全行业6G标准共识形成。6G迈入关键期,
    紫光展锐 2025-04-17 18:55 181浏览
  • 一、行业背景与需求随着智能化技术的快速发展和用户对便捷性需求的提升,电动车行业正经历从传统机械控制向智能交互的转型。传统电动车依赖物理钥匙、遥控器和独立防盗装置,存在操作繁琐、功能单一、交互性差等问题。用户期待通过手机等智能终端实现远程控制、实时数据监控及个性化交互体验。为此,将蓝牙语音芯片集成至电动车中控系统,成为推动智能化升级的关键技术路径。二、方案概述本方案通过在电动车中控系统中集成WT2605C蓝牙语音芯片,构建一套低成本、高兼容性的智能交互平台,实现以下核心功能:手机互联控制:支持蓝牙
    广州唯创电子 2025-04-18 08:33 161浏览
  • 置信区间反映的是“样本均值”这个统计量的不确定性,因此使用的是标准误(standard error),而不是直接用样本标准差(standard deviation)。标准误体现的是均值的波动程度,而样本标准差体现的是个体数据的波动程度,两者并非一回事,就如下图所显示的一样。下面优思学院会一步一步解释清楚:一、标准差和标准误,究竟差在哪?很多同学对“标准差”和“标准误”这两个概念傻傻分不清楚,但其实差别明显:标准差(Standard Deviation,σ或s):是衡量单个数据点相对于平均值波动的
    优思学院 2025-04-17 13:59 29浏览
  •   北京华盛恒辉无人机电磁兼容模拟训练系统软件是专门用于模拟与分析无人机在复杂电磁环境中电磁兼容性(EMC)表现的软件工具。借助仿真技术,它能帮助用户评估无人机在电磁干扰下的性能,优化电磁兼容设计,保障无人机在复杂电磁环境中稳定运行。   应用案例   目前,已有多个无人机电磁兼容模拟训练系统在实际应用中取得了显著成效。例如,北京华盛恒辉和北京五木恒润无人机电磁兼容模拟训练系统。这些成功案例为无人机电磁兼容模拟训练系统的推广和应用提供了有力支持。   系统功能   电磁环境建模:支持三维
    华盛恒辉l58ll334744 2025-04-17 15:10 82浏览
我要评论
0
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦