2024年4月7日发(作者:)

嵌入式 Linux 启动时间优化

1 简介

本章包含的话题有启动时间的测量、分析、人因工程(human factors)、初始化技术和优化

技巧等。

产品花在启动方面的时间直接影响终端用户对该产品的第一印象。

一个消费电子设备不管如何引人注目或者设计得怎么好,设备从关机状态到可交互的使用状

态所需的时间对于获得正面的用户体验尤为关键。案例 #1 就是在关机状态从头启动一个设

备的例子。

启动一个设备涉及到许多步骤和一系列的事件。为了使用前后一致的术语,消费电子 Linux

论坛(CE Linux Forum)的启动时间优化工作组起草了一个术语词汇表,该表包括了相关术

语在该领域内通用的定义。该词汇表如下:

启动时间相关的词汇表

2 技术/项目主页

下面主要介绍与减少 Linux 启动时间有关的各种技术。

有一部分描述了 上可以下载的本地补丁,而其余部分则介绍了在其他地方维护

的项目或者补丁。

2.1 测量启动时间

Printk Times – 用于显示每个 printk 的执行时间

内核函数跟踪(Ftrace) – 用于报告内核中每个函数的调用时间

Linux 跟踪工具箱(LTT) – 用于报告确切的内核和进程事件的时间数据

Oprofile(译注:最新替代品是 perf) – 通用的 Linux 分析器(Profile)

Bootchart – 用于 Linux 启动过程的性能分析和数据展示。收集启动过程中的用户空间部

分的资源使用情况和进程信息,然后渲染成 PNG、SVG 或者 EPS 格式的图表。

Bootprobe – 一组用于分析系统启动过程的 System Tap 脚本

当然,别忘了 cat /proc/uptime (译注:统计系统已经运行的时间)

grabserial – Tim Bird (译注:CE Linux Forum 主席)写的一个非常赞的工具用于记录控制

台输出并打上时间戳

进程跟踪 – 同样是 Tim Bird 写的一个简单补丁,用于记录 exec、fork 和 exit 系统调用。

ptx_ts – Pengutronix 的时间戳记录器(TimeStamper):一个简单的过滤器,可前置时间戳

到标准输出(STDOUT)上,有点像 grabserial 但是不限于串口。

Initcall(内核初始化函数)调试 – 一个用于显示 initcalls 所花时间的内核命令行选项

也可以看下: Kernel 检测工具,里头列举了一些已知的内核检测工具,这些对于测量内核启

动时间来说可能会有帮助。

2.2 减少启动时间的技术和技巧

2.2.1 引导程序(Bootloader)加速

就地执行(XIP)内核 – 允许内核在 ROM 或者 FLASH 上就地执行(XIP)

在启动时通过 DMA 拷贝内核镜像

使用 DMA 从闪存(Flash)拷贝内核镜像文件到内存中

采用未压缩的内核 – 一个未压缩的内核或许可以更快启动

快速内核解压

2.2.2 内核加速

关闭控制台 – 避免启动过程中的控制台输出开销(译注:尤其是串口控制台,会严重拖慢

系统启动,甚至带来各种实时问题)

关闭调试接口 和 printk – 避免调试接口和printk带来的开销,缺点是将丢失大量(对于

调试可能有用)的信息

不同步 RTC – 避免在启动时延迟用 RTC 时钟边沿同步系统时间(可能带来时钟漂移)

更短的 IDE 延迟时间 – 减少 IDE 启动延迟的持续时间(有效但是可能危险)

硬编码内核模块信息 – 通过硬编码用于加载重定位信息的内容来减少加载模块的开销

不侦测 IDE – 强制内核使用 ide=noprobe 命令行选项,从而绕过 IDE 侦测

预设 LPJ – 允许使用一个预设的 loops_per_jiffy(同样可以通过内核命令行选项设置)

异步函数调用 – 允许侦测(Probe)函数或者其他函数并行处理,从而让耗时的启动活动