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)
  •                           春天来了,我们中国的传统节日--春节到了,随着国家富强,人们民族文化自信心的增强,这个中国年过的还挺热闹,挺红火。一段山村过新年的快乐时光,即兴而发赋了两首新诗。《渔家乐·山村新春》白发垂髫同喜乐,新春佳节意情奢。烟花璀璨腾空起,山村美景醉心涯。晓雾轻笼林野静,晚云淡抹岫峰斜。自然恩赐千般好,福满人间岁月嘉
    广州铁金刚 2025-02-17 15:59 117浏览
  • 文心一言免费对于创业来说是一个很大的机遇,加油!虽然是一个很大的挑战,但是好处还是很大的。文心一言的免费开放为创业者提供了一个低成本甚至零成本使用先进人工智能技术的机会。在以往,创业者若想在项目中融入AI技术,往往需要支付高昂的研发或授权费用。而现在,他们可以直接利用文心一言的强大功能,如语言理解、生成能力、深度搜索等,来构建自己的产品或服务,从而显著降低创业成本。文心一言的全面免费开放为创业者提供了广阔的创新空间。创业者可以基于文心一言开发出各种创新的应用和服务,满足市场的多样化需求。例如,利
    curton 2025-02-14 13:37 327浏览
  • 近日,紫光展锐蜂窝物联网芯片V8850荣获国密一级认证,标志着展锐V8850在安全能力方面获得权威认可,位居行业领先水平。这是紫光展锐继短距物联网芯片V5663在2020获得ARM PSA Level 2认证,蜂窝物联网芯片V8811在2021年获得ARM PSA Level 1 认证后,第三次荣获安全行业权威认证。荣获国密一级安全认证,意味着紫光展锐V8850能支持智能支付、共享经济、定位追踪、安防监控、智能表计、工业DTU、公网对讲,以及车载通信终端设备上的国密升级改造,可为移动支付、短信
    紫光展锐 2025-02-14 19:26 80浏览
  • 导读:2025年1月6日,在 ChatGPT 诞生两周年之际,OpenAI 的核心人物 Sam Altman 回顾了一段波澜壮阔且充满挑战的历程。九年前,怀揣着对通用人工智能(AGI)的坚定信念,OpenAI 踏上征程。彼时,质疑声不绝于耳,多数人认为这毫无成功的可能。但他们未曾动摇,毅然投身这一充满未知的领域。直至 2022 年 ChatGPT 的推出,如同在科技领域投入巨石,引发轩然大波,开启了前所未有的发展态势。然而,荣耀背后是难以想象的艰难。围绕新技术构建公司,犹如在黑暗中摸索前行,每一
    用户1739588245528 2025-02-15 11:03 160浏览
  • 2025,新一轮汽车行业“战争”开始,但这一次不是过往的“价格战”,而是新一轮的“智驾战”。近期,比亚迪董事长兼总裁王传福在比亚迪智能化战略发布会上表示:“比亚迪将全系搭载“天神之眼”高阶智驾系统,其中首批21款车型将陆续上市,包括秦家族、元家族、宋家族、海豹家族等。”具体来看,20万元以上、15万元至20万元、10万元至15万元级别的车型将全系标配“天神之眼”。10万元以下的车型多数将搭载“天神之眼”,包括海鸥、海豹05DM-i和第二代秦PLUS DM-i。智驾不是什么新鲜技术,但是在比亚迪之
    刘旷 2025-02-18 10:19 58浏览
  • 概述        TC10 为OPEN Alliance 中的一个技术委员会小组,专注于研究基于车载以太网的休眠唤醒机制,旨在为汽车应用场景提供灵活的休眠唤醒解决方案。该小组提出的休眠唤醒规范(《TC10 Sleep/Wake-up Specification》,以下简称TC10规范)作为对IEEE 802.3系列规范的补充,详细定义了以太网PHY的休眠唤醒过程、新增服务原语和接口、时间参数、指令描述等内容。目前,TC10已经发布了适配10Ba
    经纬恒润 2025-02-18 14:30 79浏览
  •  探针台是半导体测试领域的重要设备,用于支撑和固定待测芯片,以便进行jing确的电气测试。在使用过程中,探针台可能会出现位置偏移,这时就需要进行复位操作。下面,我们将详细介绍探针台复位的zui简单三个步骤。  一、确定复位基准点复位操作的di一步是确定复位基准点。通常,探针台会配备有明确的复位标记或感应点。用户需要仔细查找并确认这些标记,确保复位操作的准确性。找到基准点后,将探针台移动到该位置附近,准备进行下一步操作。二、执行复位动作在确认基准点后,接下来需要执行复
    锦正茂科技 2025-02-15 09:36 97浏览
  •         电磁铁作为一种能够利用电流产生磁性的装置,在现代社会的生产和生活中发挥着越来越重要的作用。其应用范围广泛,不仅局限于工业制造领域,还深入到交通运输、医疗健康以及我们的日常生活之中。一、电磁铁在工业制造中的应用       在工业制造领域,电磁铁的应用可谓是举足轻重。它们被广泛应用于各种机械设备和生产线中,起着自动化控制、物料搬运等关键作用。例如,在重型机械中,电磁铁用于吸附和移动大型金属构件
    锦正茂科技 2025-02-18 10:05 57浏览
  • 随着国内市场的逐渐稳固,华为将目光投向了广阔的海外市场,开启了一段充满挑战与机遇的国际化征程。然而,华为在拓展海外市场时,遭遇了重重困难。文化差异带来的挑战不同国家和地区有着不同的文化背景、商业习惯和价值观,这使得华为在与当地客户、合作伙伴沟通和合作时面临诸多障碍。在欧洲,一些客户对产品的认证标准和售后服务有着非常严格的要求,并且注重商务活动中的礼仪和沟通方式。在机上欧洲通信市场竞争激烈,爱立信、诺基亚等本土企业在技术、品牌和市场份额上具有优势。而且欧洲各国的通信标准和监管政策不同,华为需要满足
    韭菜财经 2025-02-18 14:11 131浏览
  • 电磁铁通电时会产生磁场,磁力随电流增强而增强,表现出吸引铁磁性物质的特性。电磁铁是一种能够产生磁场的装置,其特性在于可以通过通电来控制磁场的产生和消失。那么,当电磁铁通电时,它具体会表现出哪些特性和现象呢?一、产生磁场通电是电磁铁产生磁场的关键。当电流通过电磁铁的线圈时,线圈周围就会产生磁场。这个磁场与电流的大小和方向密切相关,电流越大,产生的磁场也越强。同时,磁场的方向可以通过改变电流的方向来改变,这是电磁铁灵活性的重要体现。二、磁力变化随着电流的增强,电磁铁产生的磁力也会相应增强。这种磁力的
    锦正茂科技 2025-02-15 09:59 138浏览
  • 在设备间通信日益增长的需求中,对于十几米甚至更长距离的高速外设数据传输变得尤为重要。RS-232C接口,凭借其仅需简单的接收、发送及地线配置,以及成本效益高的双绞线连接,凭借其卓越性能,成为了连接通信接口芯片的关键纽带。为了在这种长距离高速通信场景下实现线路的可靠隔离,并有效抵御外部噪声对通信信号的干扰,虽然上一期介绍的晶体管类型输出系列光耦能够满足100kbps速率的隔离传输需求,但面对更高的速率稳定性和性能要求,业界更倾向于采用速率可达300Kbps的KL6N138和KL6N139达林顿高速
    晶台光耦 2025-02-14 13:40 68浏览
  • 清晨,闹钟准时响起,窗帘自动拉开,床灯随之亮起,音箱中则自动传出每日的早间新闻,从而唤醒熟睡中的你,而这只是智能家居中的冰山一角。作为人类群体追求更高生活品质的居住空间,智能家居正飞速普及至我们的日常生活之中,极大地提升了生活的便利性与舒适度。然而,随着单品智能向全屋智能的快速发展,不同智能家居设备的工作电压与通信频率等运行参数存在差异,它们共同运行在一个智能家居系统之中,其所产生的电气噪声与电磁干扰会互相影响,并形成潜在的安全隐患。例如,电气噪声可能导致线路过热,增加电气火灾的发生风险;电磁干
    华普微HOPERF 2025-02-18 10:48 51浏览
  • 《哪吒2》票房破百亿背后的科技密码:解码中国动画产业的技术跃迁与制造底气2024年夏季,国产动画电影《哪吒2》以雷霆之势席卷全球院线,不仅成为中国影史第二部票房突破百亿的现象级作品,更以多项技术突破刷新行业纪录。这些成就背后,不仅是中国动画工业的崛起,更是中国科技创新与高端制造业协同突破的缩影。作为深耕PCB行业多年的捷多邦小编,今天带您从技术视角,解读这场银幕奇迹背后的制造密码。一、从“数字造神”到“算力革命”:动画技术背后的硬核突破《哪吒2》的视觉革命始于AI工业化管道的深度应用。影片中大量
    捷多邦 2025-02-15 17:57 457浏览
  •  电磁铁的磁芯材质:软铁还是硬铁电磁铁的磁芯通常采用软铁材质,因其具有高磁导率和低矫顽力,使得电磁铁能够在通电时迅速产生强磁场,断电后磁场又能迅速消失。一、电磁铁与磁芯材质电磁铁是一种利用电流产生磁场的装置。其核心部件——磁芯,对电磁铁的性能有着至关重要的影响。在选择磁芯材质时,需要考虑多种因素,如磁导率、矫顽力、饱和磁化强度等。这些因素直接关系到电磁铁的工作效率、响应速度和能耗等方面。二、软铁与硬铁的特性软铁和硬铁是两种常见的磁性材料。软铁具有高磁导率和低矫顽力的特点,这意味着它容易
    锦正茂科技 2025-02-18 10:32 38浏览
  • 嘿,大家好!在高压电子世界里摸爬滚打的朋友们,你们有没有遇到过这样的难题?那就是,如何选择适合高压环境的光颉精密电阻? 这可不是一个简单的问题,毕竟在高压环境下,电阻不仅要顶得住电压的“压力”,还得保证精度和稳定性,这要求可真不低。想想看,如果选错了电阻,就像给跑车装了个自行车轮,那能行吗?肯定不行!轻则电路性能大打折扣,重则电阻直接“罢工”,甚至引发更严重的后果。所以说,在高压应用中,选择一款靠谱的光颉精密电阻,那可是至关重要的。别担心,今天咱们就来好好聊聊,如何选择适合高压环境的光
    贞光科技 2025-02-18 17:28 76浏览
我要评论
0
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦