Chinaunix首页 | 论坛 | 博客
  • 博客访问: 799556
  • 博文数量: 135
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 1664
  • 用 户 组: 普通用户
  • 注册时间: 2013-07-09 16:16
个人简介

围城

文章分类

全部博文(135)

文章存档

2019年(3)

2018年(7)

2017年(14)

2016年(15)

2015年(34)

2014年(9)

2013年(53)

我的朋友

分类: LINUX

2017-05-31 15:58:39

我们知道linux的一般启动过程是uboot引导内核、内核挂载文件系统,文件系统挂载完毕之后开始执行初试化的用户程序,
这里文件系统是怎么被挂载的呢?今天就来详细的剖析一下。


我们在uboot的环境变量里经常看到root=/dev/mtdblock3这样的字样,我们知道这个是用来指定我们最后要挂载的文件系统
的位置的。但是问题出现了,/dev/mtdblock3是指文件系统当中的一个文件,但是在挂载文件系统之前根本还没有目录和文件
和文件的概念,典型的先有鸡还是先有蛋的问题。挂载文件系统需要目录文件,有目录文件的前提是要挂载了文件系统。这样
肯定是不行的。所以我们就要现提供一只“鸡”,就是文件系统,让我们能找到/dev/mtdblock3这个文件,然后再去挂载其上面
的文件系统。那么又有问题了,我们是通过什么方法和步骤提供的那只“鸡”(文件系统)的?这就是下面要讲的initrd机制和
initramfs机制



这两个机制的原理和作用有很大的相似:
1. 在挂载真正的文件系统之前,它们会挂载一个基于内存的虚拟文件系统,这个文件系统只是起个过度的作用,为了挂载
真正的文件系统(root=/dev/mtdblock3指定位置的文件系统)做铺垫的。

2. 在挂载虚拟文件系统后都会执行一个可执行文件,initrd机制会执行虚拟文件系统根目录下的linuxrc或init文件文件,initramfs会
执行虚拟文件系统根目录下的init文件。

3. 使用这两种机制还有一个好处:现在文件系统可以存在多种介质上,每一种介质都有相应的驱动,如果把这些驱动全部编进
内核,势必造成内核十分庞大。引入了这两种机制后,我们可以把各种驱动编译成模块,然后在启动的时候根据检测到的硬件
来插入模块驱动。插入模块驱动这个动作就是在上面的linuxrc或init可执行文件中。插入模块之后,就有了操作硬件的驱动,
然后就可以进行真正的文件系统挂载了


阅读(1082) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~