首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

linux内核的启动流程

Linux内核的启动流程是一个复杂的过程,涉及多个步骤,从硬件初始化到系统服务的启动。以下是Linux内核启动的主要步骤:

Linux内核的启动流程

  • BIOS/UEFI初始化:计算机开机时首先执行BIOS或UEFI的初始化,负责检测硬件并加载引导加载程序。
  • 引导加载程序(Bootloader)加载:如GRUB、LILO等,读取配置文件并加载Linux内核。
  • 内核加载和初始化:引导加载程序将内核加载到内存中,传递控制权给内核,内核开始初始化硬件设备、文件系统等。
  • 用户空间初始化:内核完成初始化后,启动init进程,进一步初始化用户空间的各种服务和程序。
  • 用户空间启动:最终,用户可以登录系统并开始使用各种应用程序和服务。

每个步骤的详细说明

  • BIOS/UEFI初始化:这一步是计算机启动的第一步,BIOS或UEFI固件负责检测硬件并加载引导加载程序。这个过程通常在几秒钟内完成,为后续的启动流程奠定基础。
  • 引导加载程序(Bootloader)加载:引导加载程序位于启动设备上,如硬盘或USB驱动器。它的主要任务是加载内核映像到内存中,并设置启动参数,然后跳转到内核的入口点。这个过程确保了操作系统的正确引导。
  • 内核加载和初始化:内核加载完成后,首先进行硬件初始化和配置,包括CPU寄存器、内存控制器、中断控制器等。然后,内核会解析硬件设备树,挂载根文件系统,并启动系统服务和守护进程。这个过程是系统启动的关键,确保了操作系统的稳定运行。
  • 用户空间初始化:内核完成初始化后,会启动init进程,这是系统中第一个用户空间进程。init进程负责启动其他用户空间进程,如系统管理工具、用户登录服务等。这一步完成后,系统准备接受用户登录。
  • 用户空间启动:用户登录后,系统进入正常运行状态,用户可以开始使用各种应用程序和服务。

通过上述步骤,Linux内核完成了从启动到运行的全过程。这个过程不仅展示了Linux内核的强大功能,也体现了操作系统设计的精妙之处。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

linux内核启动流程(文章最后流程图)

大家好,又见面了,我是你们的朋友全栈君。 原文:linux内核启动流程 本文以Linux3.14版本源码为例分析其启动流程。各版本启动代码略有不同,但核心流程与思想万变不离其宗。...内核映像被加载到内存并获得控制权之后,内核启动流程开始。通常,内核映像以压缩形式存储,并不是一个可以执行的内核。因此,内核阶段的首要工作是自解压内核映像。...通过linux/arch/arm/boot/compressed目录下的Makefile寻找到vmlinux文件的链接脚本(vmlinux.lds),从中查找系统启动入口函数。...函数启动用户进程 部分书籍介绍的内核启动流程基于经典的2.6版本,kernel_init函数还会调用init_post函数专门负责_init进程的启动,现版本已经被整合到了一起。...当内核被引导并进行初始化后,内核启动了自己的第一个用户空间应用程序_init,这是调用的第一个使用标准C库编译的程序,其进程编号时钟为1.

1.7K40

linux内核启动流程分析 - efistub的入口函数

最近打算写一个系列文章,主要讲linux内核的启动流程。 网上类似标题的文章很多,但大都是从start_kernel讲起,我觉得这是远远不够的。...linux内核的启动流程涉及的东西非常多,而且偏硬件,比较难理解,写这个系列其实还是挺有难度的,我会尽量讲的透彻一点,尽量不敷衍每个细节。 好,那今天我们就从如何找到efi stub的入口函数讲起。...该方式为我们研究内核启动降低了不少难度,我们不用再去看类似于grub等boot loader的代码了,从开机到启动完毕的所有流程代码,在内核里都可以找到,完美。...这两个部分都可以认为是内核启动流程的部分,并不是真正的内核逻辑,真正内核逻辑被压缩到了compressed部分里的piggy.S文件里。...或者说,在 uefi 平台上,以 efi stub形式启动内核时,开机后内核执行的第一个方法就是该方法。 以这里为起点,我们就可以开始探索linux内核的完整启动流程了。

3.6K30
  • linux内核启动流程分析 - startup_64

    由之前的文章 linux内核启动流程分析 - efi_stub_entry 可知,rsi中存放的是boot_params的地址,而BP_kernel_alignment又是boot_params中的kernel_alignment...这里再提下343行中的1f,它是GNU Assembler中的一种语法,表示的是汇编语言的local label,1f表示向下找第一个名为1的label,还有其他写法比如1b,表示向上找第一个名为1的label...init_size值是大于bzImage文件的大小的,因为bzImage是一个压缩过的内核,如果我们想要执行到真正的内核,还要在内存中对bzImage解压缩,init_size指定的多余的空间就是为了解压缩用的...当我们要把bzImage移动到init_size的结尾部分时,其实只要移动bzImage里的compressed部分就好,因为这里有我们真正需要解压缩的内核及其相关代码。...的结尾时,它的起始地址。

    2.5K20

    linux内核启动流程分析 - efi_main

    上一篇文章 linux内核启动流程分析 - efi_stub_entry 中,为了叙述方便,我们只是粗略的讲了下efi_main函数,这里我们再具体看下。 ?...有关boot_params的创建及其hdr的初始化,我们在 linux内核启动流程分析 - efi_pe_entry 中有讲到,这里就不再赘述。 继续看该函数的其余部分。 ?...而710行中的image_offset是kernel在内存的起始地址到compressed部分起始地址(startup_32的地址)的偏移量,这个在 linux内核启动流程分析 - efi_pe_entry...linux内核构建结束后,最终生成的文件是 arch/x86/boot/bzImage,这其实是个压缩过的内核,在kernel启动过程中,还要在内存中对内核进行解压,进而得到真正的内核。...综上可知,712行中的buffer_end表示的是kernel在启动过程中,需要使用的内存的结束地址。 714到717行是一些条件判断,在这些条件下,需要拷贝内存中的内核到合适的位置上。

    3.7K30

    linux内核启动流程分析 - efi_pe_entry

    接上一篇文章 linux内核启动流程分析 - efistub的入口函数,我们继续看efi_pe_entry这个函数。 ?...handle指向的是运行时的kernel,sys_table_arg指向的是uefi的system table(有了system table,就可以使用uefi的各种服务,比如输入输出、boot service...接下来该函数验证了system table中的signature是否等于uefi specification中定义的signature,以此来判断该次启动是否用的是uefi方式。...boot_params又被称为zeropage,该结构体用来存放各种启动参数,供后续启动kernel使用,其具体结构如下: ?...所以最开始我认为efi_pe_entry中使用的是startup_32的绝对地址,即上面输出的0,这种想法是错误的,其实它是根据当前rip中的地址,以及startup_32到下一条指令的偏移量,计算出真正的运行时中的

    2.8K30

    linux内核启动流程分析 - efi_stub_entry

    接上一篇文章 linux内核启动流程分析 - efi_pe_entry,我们继续看efi_stub_entry函数。 ? 该函数比较特殊,是用汇编写的,下面我们来逐行分析下。...有了这种约定之后,大家就可以各自写各自的逻辑,且在最终链接到一起时,还是可以正常执行的。...但如果我们要直接写汇编代码,这些就是要了解清楚的。 那对于x64的linux内核来说,calling convention具体是怎么约定的呢?...第五行代码将startup_64函数的编译时地址,加到了rax寄存器里,也就是加到了startup_32函数运行时的地址上,这样rax里存放的地址,就是运行时的startup_64函数的地址了。...看上面选中的行,确实是0x200。 我们再来看下efi_stub_entry中使用到startup_64的那行代码的反汇编: ?

    2.5K20

    Linux 的启动流程

    今天,我想接着往下写,探讨操作系统接管硬件以后发生的事情,也就是操作系统的启动流程。 ? 这个部分比较有意思。...第一步、加载内核 操作系统接管硬件以后,首先读入 /boot 目录下的内核文件。 ?...内核文件加载以后,就开始运行第一个程序 /sbin/init,它的作用是初始化系统环境。...它们在Windows叫做"服务"(service),在Linux就叫做"守护进程"(daemon)。 init进程的一大任务,就是去运行这些开机启动的程序。...但是,不同的场合需要启动不同的程序,比如用作服务器时,需要启动Apache,用作桌面就不需要。Linux允许为不同的场合,分配不同的开机启动程序,这就叫做"运行级别"(runlevel)。

    3.3K50

    Linux 的启动流程

    那篇文章不涉及操作系统,只与主板的板载程序有关。今天,分享一篇Linux系统启动的文,主要探讨操作系统接管硬件以后发生的事情,也就是操作系统的启动流程。 ? 这个部分比较有意思。...第一步、加载内核 操作系统接管硬件以后,首先读入 /boot 目录下的内核文件 ?...内核文件加载以后,就开始运行第一个程序 /sbin/init,它的作用是初始化系统环境。...它们在Windows叫做"服务"(service),在Linux就叫做守护进程(daemon)。 init进程的一大任务,就是去运行这些开机启动的程序。...但是,不同的场合需要启动不同的程序,比如用作服务器时,需要启动Apache,用作桌面就不需要。Linux允许为不同的场合,分配不同的开机启动程序,这就叫做运行级别(runlevel)。

    2K30

    Linux 的启动流程

    本篇的重点是讲解设备和驱动的启动流程,设备和驱动的流程是整个内核启动的核心,也是工作中最常面对的问题。出于知识点的系统性考虑,在进入主题之前我们先看下整个 Linux 在 ARM 中的启动流程如何。...Uboot 的启动流程 ARM Linux 的启动流程大致为:Uboot → Kernel → Root filesystem。Uboot 在上电的时候就拿到 CPU 的控制权,实现了硬件的初始化。...初始化 RAM 因为内核要在 RAM 中运行,所以在调用内核之前必须初始化和设置 RAM,为调用内核做好准备。 初始化串口 内核在启动过程中可以将信息通过串口输出,这样就可以清楚的知道内核启动信息。...设置内核启动参数 内核在启动过程中会根据该启动参数进行相应的初始化工作。...Linux 内核的启动流程(设备和驱动的加载) 关于 Uboot 的启动本课程不做详细介绍,因为本课程的主要内容是内核。在讲述内核启动之前让我们先了解下内核的组成结构: ?

    2.8K42

    linux启动流程

    每次打开 Linux PC 时,它都会经历一系列阶段,然后最终显示提示输入用户名或密码的登录屏幕。每个 Linux 发行版在典型的启动过程中都会经历 4 个不同的阶段。...) 加载引导加载程序 (GRUB2) 内核初始化 启动systemd,所有进程的父进程 1....当 Linux 系统启动时,BIOS(基本输入输出系统)启动并执行开机自检(POST)。这是执行大量诊断检查的完整性检查。...GRUB 的主要目标是将 Linux 内核加载到主内存中。 3. 内核初始化 内核是任何 Linux 系统的核心。它将 PC 的硬件与底层进程连接起来。内核控制 Linux 系统上的所有进程。...启动 Systemd 内核最终加载了Systemd,它是旧SysVinit的替代品。Systemd是所有 Linux 进程的母体,并管理文件系统的挂载、启动和停止服务等等。

    12.1K10

    【Linux】启动流程

    Linux操作系统的启动过程是一个复杂而精密的流程,涉及到多个阶段和组件。本文将对Linux启动流程进行深入探讨,并对比不同发行版之间的一些差异。...传递控制权: 最后,Grub将控制权传递给Linux内核。 Syslinux的启动流程 Syslinux是另一个轻量级的引导加载程序,适用于一些嵌入式系统和Live CD。...Syslinux的启动流程相对简单: 加载配置文件: Syslinux读取配置文件,其中包含了引导选项和内核位置。 加载内核: Syslinux加载Linux内核到内存。...不同发行版的差异 尽管Linux启动流程有很多共通之处,但不同的发行版可能有一些细微的差异。...通过对比不同发行版的启动流程,我们能更好地理解Linux系统的运作机制,为故障排查和系统优化提供更深入的了解。希望本文能够帮助读者更好地理解Linux启动流程,并在实际应用中发挥作用。

    29310

    Linux启动流程

    启动第四步--加载内核 根据grub设定的内核映像所在路径,系统读取内存映像,并进行解压缩操作。此时,屏幕一般会输出“Uncompressing Linux”的提示。...系统将解压后的内核放置在内存之中,并调用start_kernel()函数来启动一系列的初始化函数并初始化各种设备,完成Linux核心环境的建立。...:) 嵌入式系统Linux启动流程: 一个嵌入式 Linux 系统从软件角度看可以分为四个部分:引导加载程序(Bootloader), Linux 内核,文件系统,应用程序。...Linux 内核在完成系统的初始化之后需要挂载某个文件系统作为根文件系统(Root Filesystem),然后加载必要的内核模块,启动应用程序。...从以上分析可以看出 Bootloader在运行过程中虽然具有初始化系统和执行用户输入的命令等作用,但它最根本的功能就是为了启动 Linux 内核,让我们进一步分析 Bootloader 和 Linux

    8.6K50

    Linux 启动流程分析

    程序员的成长之路 互联网/程序员/成长/职场 关注 阅读本文大概需要 5 分钟。 今天,一起探讨操作系统的启动流程。 这个部分比较有意思。...加载内核 操作系统接管硬件以后,首先读入 /boot 目录下的内核文件。...内核文件加载以后,就开始运行第一个程序 /sbin/init,它的作用是初始化系统环境。...它们在Windows叫做"服务"(service),在Linux就叫做"守护进程"(daemon)。 init进程的一大任务,就是去运行这些开机启动的程序。...但是,不同的场合需要启动不同的程序,比如用作服务器时,需要启动Apache,用作桌面就不需要。Linux允许为不同的场合,分配不同的开机启动程序,这就叫做"运行级别"(runlevel)。

    5.7K20

    Linux 启动流程分析

    今天,一起探讨操作系统的启动流程。 ? 这个部分比较有意思。因为在BIOS阶段,计算机的行为基本上被写死了,程序员可以做的事情并不多;但是,一旦进入操作系统,程序员几乎可以定制所有方面。...加载内核 操作系统接管硬件以后,首先读入 /boot 目录下的内核文件。 ?...内核文件加载以后,就开始运行第一个程序 /sbin/init,它的作用是初始化系统环境。...它们在Windows叫做"服务"(service),在Linux就叫做"守护进程"(daemon)。 init进程的一大任务,就是去运行这些开机启动的程序。...但是,不同的场合需要启动不同的程序,比如用作服务器时,需要启动Apache,用作桌面就不需要。Linux允许为不同的场合,分配不同的开机启动程序,这就叫做"运行级别"(runlevel)。

    2.7K10

    Linux 启动流程分析

    今天,一起探讨操作系统的启动流程。 ? 这个部分比较有意思。因为在BIOS阶段,计算机的行为基本上被写死了,程序员可以做的事情并不多;但是,一旦进入操作系统,程序员几乎可以定制所有方面。...加载内核 操作系统接管硬件以后,首先读入 /boot 目录下的内核文件。 ?...内核文件加载以后,就开始运行第一个程序 /sbin/init,它的作用是初始化系统环境。...它们在Windows叫做"服务"(service),在Linux就叫做"守护进程"(daemon)。 init进程的一大任务,就是去运行这些开机启动的程序。...但是,不同的场合需要启动不同的程序,比如用作服务器时,需要启动Apache,用作桌面就不需要。Linux允许为不同的场合,分配不同的开机启动程序,这就叫做"运行级别"(runlevel)。

    1.6K30

    05.内核启动流程分析之makefile

    linux内核makefile文件分类 名称 描述 顶层makefile 它是所有makefile文件的核心,从总体上控制着内核的编译、连接 .config 配置文件,在配置内核时生成。...所有makefile文件(包括顶层目录及各级子目录)都是根据.config来决定使用那些文件 arch/$(ARCH)/Makefile 对于体系结构的makefile,它用来决定那些体系结构相关的文件参与内核的生成...,并提供一些规则来生成特定格式的内核映像 scripts/Makefile.* Makefile共用的通用规则、脚本等 kbuild Makefiles 各级子目录下的Makefile,它们相对简单,被上一层...system\linux-2.6.22.6\linux-2.6.22.6\drivers\char目录下的makefile /*-y表示后面的内容会被编译进内核*/ obj-y += mem.o random.o...直接编译内核可以看出来*/ /*第一个文件:arch/arm/kernel/head.o*/ /*链接脚本:arch/arm/kernel/vmlinux.lds*/ arm-linux-ld-EL -

    74610
    领券