Linux开机过程

linux开机过程是打开电源开关到登录用户界面

1、加载BIOS
打开电源开关,计算机会加载BIOS信息,因为BIOS中包含CPU信息、设备启动顺序信息、硬盘信息、内存信息、时钟信息、PnP特性等。
2、读取MBR
硬盘第0磁道第一扇区称为MBR,也就是Master Boot Record,即主引导记录,大小是512字节,存放预启动信息、分区信息。可分两部分:1、引导(PRE-BOOT)区,占446字节;2、分区表(PARTITION PABLE),占66字节,记录磁盘的分区信息。预引导区作用之一是找到活动的分区,并将活动分区的引导区读入内存。系统找到BIOS指定的MBR后,复制到0x7c00地址所在的物理内存中(复制的内容是boot loader,具体的指Lilo或grub)。
3、Boot Loader
Boot Loader就是操作系统内核运行之前的一段程序。通过改程序,可以初始化硬件设备、建立内存空间的映射图,将系统的软硬件环境带到合适状态,以便最终调用操作系统内核做准备。一般:Boot Loader依赖硬件实现,不同体系结构系统存在不同Boot Loader。
linux引导扇区采用汇编语言程序,源码arch/i386/boot中,有4分文件:1、bootsect.S:引导扇区主程序,汇编后代码不超过512字节;2、setup.S:引导辅助程序;3、edd.S:辅助程序的一部分,用于支持BIOS增强磁盘设备服务;4、video.S:辅助程序的另一部分,用于引导时的屏幕显示。
4、加载内核
根据grub设定的内核映像所在路径,系统读取内存映像,并进行解压缩操作。此时,屏幕一般会输出“Uncompressing Linux”的提示。当解压缩内核完成后,屏幕输出“OK, booting the kernel”。
  系统将解压后的内核放置在内存之中,并调用start_kernel()函数来启动一系列的初始化函数并初始化各种设备,完成Linux核心环境的建立。至此,Linux内核已经建立起来了,基于Linux的程序应该可以正常运行了。
  start_kenrel()定义在init/main.c中,它就类似于一般可执行程序中的main()函数,系统在此之前所做的仅仅是一些能让内核程序最低限度执行的初始化操作,真正的内核初始化过程是从这里才开始。函数start_kerenl()将会调用一系列的初始化函数,用来完成内核本身的各方面设置,目的是最终建立起基本完整的Linux核心环境。
  start_kernel()中主要执行了以下操作:
  1、 在屏幕上打印出当前的内核版本信息。
  2、 执行setup_arch(),对系统结构进行设置。
  3、执行sched_init(),对系统的调度机制进行初始化。先是对每个可用CPU上的runqueque进行初始化;然后初始化0号进程(其task struct和系统空M堆栈在startup_32()中己经被分配)为系统idle进程,即系统空闲时占据CPU的进程。
  4、执行parse_early_param()和parsees_args()解析系统启动参数。
  5、执行trap_in itQ,先设置了系统中断向量表。0-19号的陷阱门用于CPU异常处理;然后初始化系统调用向量;最后调用cpu_init()完善对CPU的初始化,用于支持进程调度机制,包括设定标志位寄存器、任务寄存器、初始化程序调试相关寄存器等等。
  6、执行rcu_init(),初始化系统中的Read-Copy Update互斥机制。
  7、执行init_IRQ()函数,初始化用于外设的中断,完成对IDT的最终初始化过程。
  8、执行init_timers(), softirq_init()和time_init()函数,分别初始系统的定时器机制,软中断机制以及系统日期和时间。
  9、执行mem_init()函数,初始化物理内存页面的page数据结构描述符,完成对物理内存管理机制的创建。
  10、执行kmem_cache_init(),完成对通用slab缓冲区管理机制的初始化工作。
  11、执行fork_init(),计算出当前系统的物理内存容量能够允许创建的进程(线程)数量。
  12、执行proc_caches_init() , bufer_init(), unnamed_dev_init() ,vfs_caches_init(), signals_init()等函数对各种管理机制建立起专用的slab缓冲区队列。
  13、执行proc_root_init()Wl数,对虚拟文件系统/proc进行初始化。
  在 start_kenrel()的结尾,内核通过kenrel_thread()创建出第一个系统内核线程(即1号进程),该线程执行的是内核中的init()函数,负责的是下一阶段的启动任务。最后调用cpues_idle()函数:进入了系统主循环体口默认将一直执行default_idle()函数中的指令,即CPU的halt指令,直到就绪队列中存在其他进程需要被调度时才会转向执行其他函数。此时,系统中唯一存在就绪状态的进程就是由kerne_hread()创建的init进程(内核线程),所以内核并不进入default_idle()函数,而是转向init()函数继续启动过程。
5、用户层init依据inittab文件设定运行等级
内核被加载后,第一个运行的程序便是/sbin/init,该文件会读取/etc/inittab文件,并依据此文件来进行初始化工作。
  其实/etc/inittab文件最主要的作用就是设定Linux的运行等级,其设定形式是“:id:5:initdefault:”,这就表明Linux需要运行在等级5上。Linux的运行等级设定如下:
  0:关机
  1:单用户模式
  2:无网络支持的多用户模式
  3:有网络支持的多用户模式
  4:保留,未使用
  5:有网络支持有X-Window支持的多用户模式
  6:重新引导系统,即重启
6、init进程执行rc.sysinit
在设定了运行等级后,Linux系统执行的第一个用户层文件就是/etc/rc.d/rc.sysinit脚本程序,它做的工作非常多,包括设定PATH、设定网络配置(/etc/sysconfig/network)、启动swap分区、设定/proc等等。如果你有兴趣,可以到/etc/rc.d中查看一下rc.sysinit文件。
  线程init的最终完成状态是能够使得一般的用户程序可以正常地被执行,从而真正完成可供应用程序运行的系统环境。它主要进行的操作有:
  1、 执行函数do_basic_setup(),它会对外部设备进行全面地初始化。
  2、 构建系统的虚拟文件系统目录树,挂接系统中作为根目录的设备(其具体的文 件系统已经在上一步骤中注册)。
  3、 打开设备/dev/console,并通过函数sys_dup()打开的连接复制两次,使得文件号0,1 ,2 全部指向控制台。这三个文件连接就是通常所说的“标准输入”stdin,“标准输出”stdout和“标准出错信息”stderr这三个标准I/O通道。
  4、 准备好以上一切之后,系统开始进入用户层的初始化阶段。内核通过系统调用execve()加载执T子相应的用户层初始化程序,依次尝试加载程序"/sbin/initl"," /etc/init"," /bin/init’,和“/bin/sh。只要其中有一个程序加载获得成功,那么系统就将开始用户层的初始化,而不会再回到init()函数段中。至此,init()函数结束,Linux内核的引导 部分也到此结束。
7、启动内核模块
具体依据/etc/modules.conf文件或/etc/modules.d下的文件装载内核模块
8、执行不同运行级别的脚本程序
根据运行级别的不同,系统会运行rc0.d到rc6.d中的相应的脚本程序,来完成相应的初始化工作和启动相应的服务。
9、执行/etc/rc.d/rc.local
打开了此文件,里面有一句话,读过之后,你就会对此命令的作用一目了然:
  # This script will be executed after all the other init scripts.
  # You can put your own initialization stuff in here if you don’t
  # want to do the full Sys V style init stuff.
  rc.local就是在一切初始化工作后,Linux留给用户进行个性化的地方。你可以把你想设置和启动的东西放到这里。
10、执行/bin/login程序,进入登录状态
此时,系统已经进入到了等待用户输入username和password的时候了,你已经可以用自己的帐号登入系统了。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值