双核Linux内核的引导

简介: 双核Linux内核的引导

最后再整一篇多核的引导,称热打铁

Linux内核的引导

引导Linux系统的过程包括很多阶段,这里将以引导ARM Linux为例来进行讲解(见图3.11)。

一般的SoC内嵌入了bootrom,上电时bootrom运行

对于CPU0而言,bootrom会去引导bootloader,而其他CPU则判断自己是不是CPU0,不是就进入WFI的状态等待CPU0来唤醒它。

CPU0引导bootloader,bootloader引导Linux内核,在内核启动阶段,CPU0会发中断唤醒CPU1,之后CPU0和CPU1都投入运行。

CPU0导致用户空间的init程序被调用,init程序再派生其他进程,派生出来的进程再派生其他进程。

CPU0和CPU1共担这些负载,进行负载均衡。(这里的运行策略可能不是这么简单,除非核的配置是一样的,一般都不是。)

bootrom是各个SoC厂家根据自身情况编写的,目前的SoC一般都具有从SD、eMMC、NAND、USB等介质启动的能力,这证明这些bootrom内部的代码具备读SD、NAND等能力。(读取这些介质上的文件到RAM去运行)

嵌入式Linux领域最著名的bootloader是U-Boot,其代码仓库位于http://git.denx.de/u-boot.git/

早前,bootloader需要将启动信息以ATAG的形式封装,并且把ATAG的地址填充在r2寄存器中,机型号填充在r1寄存器中,详见内核文档Documentation/arm/booting。

在ARM Linux支持设备树(Device Tree)后,bootloader则需要把dtb的地址放入r2寄存器中。(所以现在不用那个tag符号表了)

当然,ARM Linux也支持直接把dtb和zImage绑定在一起的模式 (内核ARM_APPENDED_DTB选项“Use appended device tree blob to zImage”),这样 r2寄存器就不再需要填充dtb地址了

类似zImage的内核镜像实际上是由没有压缩的解压算法被压缩的内核组成,所以在bootloader跳入zImage以后,它自身的解压缩逻辑就把内核的镜像解压缩出来了。

关于内核启动,与我们关系比较大的部分是每个平台的设备回调函数设备属性信息,它们通常包装在DT_MACHINE_START和MACHINE_END之间,包含reserve()、map_io()、init_machine()、init_late()、smp等回调函数或者属性。

这些回调函数会在内核启动过程中被调用。后续章节会进一步介绍。

用户空间的init程序常用的有busybox init、SysVinit、systemd等,它们的职责类似,把整个系统启动,最后形成一个进程树,比如Ubuntu上运行的pstree:

init─┬─NetworkManager─┬─dhclient
   │              └─2*[{NetworkManager}]
   ├─VBoxSVC─┬─VirtualBox───29*[{VirtualBox}]
   │       └─11*[{VBoxSVC}]
   ├─VBoxXPCOMIPCD
   ├─accounts-daemon───{accounts-daemon}
   ├─acpid
   ├─apache2───5*[apache2]
   ├─at-spi-bus-laun───2*[{at-spi-bus-laun}]
   ├─atd
   ├─avahi-daemon───avahi-daemon
   ├─bluetoothd
   ├─cgrulesengd
   ├─colord───2*[{colord}]
   ├─console-kit-dae───64*[{console-kit-dae}]
   ├─cpufreqd───{cpufreqd}
   ├─cron
   ├─cupsd
   ├─2*[dbus-daemon]
   ├─dbus-launch
   ├─dconf-service───2*[{dconf-service}]
   ├─dnsmasq

这一顿操作,结合前面在bootloader方面从粗到细,从浅到深到浅写了很多。

真的让人对这个bootloader这个部分,起码说宏观上的理解,应该算是比较清晰了。

参考资料:

《Linux设备驱动开发详解》

目录
相关文章
|
20天前
|
Linux C语言
Linux内核队列queue.h
Linux内核队列queue.h
|
21天前
|
存储 Linux
linux查看系统版本、内核信息、操作系统类型版本
linux查看系统版本、内核信息、操作系统类型版本
56 9
|
29天前
|
Ubuntu Linux
linux查看系统版本及内核信息
在Linux中检查系统版本和内核信息,可使用`uname -r`查看内核版本,`uname -a`获取详细信息,或者查看`/proc/version`。要了解发行版版本,尝试`lsb_release -a`(如果安装了)或查阅`/etc/os-release`。Red Hat家族用`/etc/redhat-release`,Debian和Ubuntu系用`/etc/issue`及相关文件。不同发行版可能需不同命令。
32 3
|
1天前
|
弹性计算 网络协议 Shell
自动优化Linux 内核参数
【4月更文挑战第29天】
5 1
|
2天前
|
弹性计算 网络协议 Linux
自动优化 Linux 内核参数
【4月更文挑战第28天】
8 0
|
13天前
|
算法 Linux 调度
深入理解Linux内核的进程调度机制
【4月更文挑战第17天】在多任务操作系统中,进程调度是核心功能之一,它决定了处理机资源的分配。本文旨在剖析Linux操作系统内核的进程调度机制,详细讨论其调度策略、调度算法及实现原理,并探讨了其对系统性能的影响。通过分析CFS(完全公平调度器)和实时调度策略,揭示了Linux如何在保证响应速度与公平性之间取得平衡。文章还将评估最新的调度技术趋势,如容器化和云计算环境下的调度优化。
|
18天前
|
算法 Linux 调度
深度解析:Linux内核的进程调度机制
【4月更文挑战第12天】 在多任务操作系统如Linux中,进程调度机制是系统的核心组成部分之一,它决定了处理器资源如何分配给多个竞争的进程。本文深入探讨了Linux内核中的进程调度策略和相关算法,包括其设计哲学、实现原理及对系统性能的影响。通过分析进程调度器的工作原理,我们能够理解操作系统如何平衡效率、公平性和响应性,进而优化系统表现和用户体验。
|
25天前
|
负载均衡 算法 Linux
深度解析:Linux内核调度器的演变与优化策略
【4月更文挑战第5天】 在本文中,我们将深入探讨Linux操作系统的核心组成部分——内核调度器。文章将首先回顾Linux内核调度器的发展历程,从早期的简单轮转调度(Round Robin)到现代的完全公平调度器(Completely Fair Scheduler, CFS)。接着,分析当前CFS面临的挑战以及社区提出的各种优化方案,最后提出未来可能的发展趋势和研究方向。通过本文,读者将对Linux调度器的原理、实现及其优化有一个全面的认识。
|
25天前
|
Ubuntu Linux
Linux查看内核版本
在Linux系统中查看内核版本有多种方法:1) 使用`uname -r`命令直接显示版本号;2) 通过`cat /proc/version`查看内核详细信息;3) 利用`dmesg | grep Linux`显示内核版本行;4) 如果支持,使用`lsb_release -a`查看发行版及内核版本。
36 6
|
28天前
|
Linux 内存技术
Linux内核读取spi-nor flash sn
Linux内核读取spi-nor flash sn
20 1