深入探究Linux内核启动过程分析 (linux内核启动分析)

Linux作为一款开源操作系统,得到了广泛的应用和支持。其内核启动过程是操作系统运行的基础,理解和掌握该过程对于深入理解Linux系统的运作有着重要意义。本文将对Linux内核启动过程进行分析和探究。

Linux内核启动过程

内核启动过程是指从计算机开机开始,经过一系列的证硫、硬件初始化和准备工作,最终加载Linux内核,并将控制权交给内核的过程。根据启动过程的不同阶段,可以将其分为BIOS、Boot loader、kernel三个阶段。

1. BIOS阶段

BIOS(Basic Input/Output System)是一种系统固件,它是计算机硬件的低级接口程序。当计算机开机时,BIOS会首先运行并检查计算机硬件的各项情况,包括CPU、RAM、硬盘、鼠标、键盘等。检查完成后,BIOS会按照预定的顺序(通常是从硬盘、CD-ROM、USB等设备中)查找引导扇区(boot sector),并加载该扇区的代码到内存中,将控制权交给引导扇区。

2. Boot loader阶段

引导扇区包含Boot loader程序的代码。Boot loader程序的主要功能是加载Linux内核并准备好内核运行环境。在此阶段,Boot loader程序通常需要完成以下几个主要任务:

(1)检测和初始化硬件环境,如硬盘、内存、网络接口等。

(2)读取并加载内核到内存中。由于内核具有非常庞大的体积,因此需要分成若干个部分(如vmlinuz、initrd等)进行加载。

(3)设置内核启动参数。内核启动参数通常包括rootfs根文件系统、init进程、内存分配方式、启动模式等,这些参数都会影响内核的初始化和运行。

(4)跳转到内核入口。Boot loader程序将控制权交给内核入口,内核开始执行。

3. Kernel阶段

Linux内核启动后,会根据启动参数对系统进行初始化和配置。具体包括以下几个步骤:

(1)初始化内核数据结构。内核需要建立一系列的数据结构,如进程管理结构、文件系统结构等。

(2)初始化CPU。内核需要对CPU进行初始化工作,如配置页表、初始化中断向量表等。

(3)初始化内存管理。内核需要初始化内存管理结构,包括虚拟内存映射、内存碎片管理、页面交换等。

(4)启动init进程。init进程是Linux系统中的用户空间进程,它负责完成系统的初始化和启动,并成为系统进程管理和调度的起点。

(5)加载并初始化驱动程序。Linux内核支持多种硬件设备和接口,不同设备需要不同的驱动程序。内核会自动扫描并加载硬件驱动程序,并完成驱动程序的初始化。

Linux内核启动过程是一个从硬件机器直到Linux系统运转的复杂过程,启动过程需要经过多个阶段,其中包含了从硬件检测到驱动程序的加载,再到用户空间初始化进程的启动等一系列的工作。在操作系统运行过程中,了解内核启动过程能够为我们分析和解决多种运行问题提供重要线索,从而更好地理解Linux系统的运转机理,更加玩熟练地应用和调试该操作系统的运作。

相关问题拓展阅读:

ARM linux内核启动时几个关键地址

1.内核启动地址

ZTEXTADDR

解压代码运行的开始地址。没有物理地址和虚拟地址之分,因为此时MMU处于关闭轮渗状态。这个地址不一定时RAM的地址,可以是支持读写寻址的flash等存储中介。

Start address of decompressor. here’s no point in talking about virtual or physical addresses here, since the MMU will be off at the time when you call the decompressor code. You normally call the kernel at this address to start it booting. This doesn’t have to be located in RAM, it can be in flash or other read-only or read-write addressable medium.

在arch/arm/搭指boot/compressed/Makefile中说的很明确

#

# We now have a PIC decompressor implementation. Decompressors running

# from RAM should not define ZTEXTADDR. Decompressors running directly

# from ROM or Flash must define ZTEXTADDR (preferably via the config)

# FIXME: Previous assignment to ztextaddr-y is lost here. See SHARK

ifeq ($(CONFIG_ZBOOT_ROM),y)

ZTEXTADDR := $(CONFIG_ZBOOT_ROM_TEXT)

ZBSSADDR := $(CONFIG_ZBOOT_ROM_BSS)

else

ZTEXTADDR :=

ZBSSADDR := ALIGN(8)

endif

ZRELADDR

内核启动在RAM中的地址。压缩的内核映像被解压到这个地址,然后执行。

This is the address where the decompressed kernel will be written, and eventually executed. The following constraint must be valid:

__virt_to_phys(TEXTADDR) == ZRELADDR

The initial part of the kernel is carefully coded to be position independent.

一般定义在项目目录下,比如:

arch/arm/mach-at91/Makefile.boot: zreladdr-y+= 0x

arch/arm/mach-at91/Makefile.boot: zreladdr-y+= 0x

arch/arm/mach-cns3/Makefile.boot: zreladdr-y+= 0x

arch/arm/mach-davinci/Makefile.boot: zreladdr-y+= 0xc

arch/arm/mach-davinci/Makefile.boot: zreladdr-y+= 0x

arch/arm/mach-dove/Makefile.boot: zreladdr-y+= 0x

arch/arm/mach-ebsa110/Makefile.boot: zreladdr-y+= 0x

arch/arm/mach-exynos/Makefile.boot: zreladdr-y+= 0x

arch/腊枝脊arm/mach-footbridge/Makefile.boot: zreladdr-y+= 0x

arch/arm/mach-gemini/Makefile.boot: zreladdr-y+= 0x

arch/arm/mach-gemini/Makefile.boot: zreladdr-y+= 0x

arch/arm/mach-integrator/Makefile.boot: zreladdr-y+= 0x

arch/arm/mach-iop13xx/Makefile.boot: zreladdr-y += 0x

在arch/arm/boot/Makefile中被赋值:

ZRELADDR := $(zreladdr-y)

PARAMS_PHYS := $(params_phys-y)

INITRD_PHYS := $(initrd_phys-y)

… …

ifneq ($(LOADADDR),)

UIMAGE_LOADADDR=$(LOADADDR)

else

ifeq ($(CONFIG_ZBOOT_ROM),y)

UIMAGE_LOADADDR=$(CONFIG_ZBOOT_ROM_TEXT)

求助各位大侠linux内核启动遇到的问题

打开终端,输入rpm -qa|grep kernel,执行,会显示陵肆纤你安装的内核 然后 sudo yum remove XXXX(我用是fedora,ubuntu用的好像不是yum) XXXX表示你安装尺仿的的旧雹坦版本,就可以卸载旧内核

linux内核启动分析的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于linux内核启动分析,深入探究Linux内核启动过程分析,ARM linux内核启动时几个关键地址,求助各位大侠linux内核启动遇到的问题的信息别忘了在本站进行查找喔。


数据运维技术 » 深入探究Linux内核启动过程分析 (linux内核启动分析)