欢迎来到三一办公! | 帮助中心 三一办公31ppt.com(应用文档模板下载平台)
三一办公
全部分类
  • 办公文档>
  • PPT模板>
  • 建筑/施工/环境>
  • 毕业设计>
  • 工程图纸>
  • 教育教学>
  • 素材源码>
  • 生活休闲>
  • 临时分类>
  • ImageVerifierCode 换一换
    首页 三一办公 > 资源分类 > DOCX文档下载  

    全存使用isolinux制作Linux启动光盘.docx

    • 资源ID:3292766       资源大小:54.58KB        全文页数:30页
    • 资源格式: DOCX        下载积分:6.99金币
    快捷下载 游客一键下载
    会员登录下载
    三方登录下载: 微信开放平台登录 QQ登录  
    下载资源需要6.99金币
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    全存使用isolinux制作Linux启动光盘.docx

    全存使用isolinux制作Linux启动光盘使用isolinux制作Linux启动光盘- 原理: 任何一个操作系统在任何一个硬件平台上的运行都需要一个引导的过程,即,初始化软件环境、把内核从存储介质放到内存当中去,并开始运行。当然对于某些简单软硬件系统,这个过程可能及其简单,而对于 PC 就要略微复杂一些了。 PC 的引导程序上承 BIOS,下接内核的初始化代码,虽然开一次机只运行一次后就不留痕迹了,不过还是相当重要的。所有的引导程序都在做类似的事情: 驻留在存贮介质的特殊位置可以被 BIOS 启动,或是自己是某一系统的可执行文件,可以被用户显式或隐式在该系统内启动; 了解要被启动的必要启动文件的位置,包括系统内核、ramdisk 等,并把它们读取出来、装载到内存之中; 构造环境、运行操作系统的内核,自己则就此退出历史舞台。 历史上,用于 Linux 的最著名的引导程序莫过于 LILO 和 Grub 了,作为通用的引导程序,二者用途广泛,但对于一些特殊的场合,譬如引导程序可利用的空间比较有限的可移动存储介质 (通俗地说,包括光盘、软盘、u 盘等),它们有些过于厚重了,这就引出了我们今天的主角SYSLINUX/ISOLINUX。 SYSLINUX/ISOLINUX 是专门用来引导可移动介质的轻量级引导程序,因为这样的介质通常不会固定只针对一种硬件。我们主要介绍以下ISOLINUX 引导安装程序。ISOLINUX其实是一个简单的Linux系统。其构造很简单。主要包括以下几个方面的内容: 引导程序isolinux.bin 这个文件是ISOLINUX的引导文件。相当于Linux系统中的grub程序一样,在系统启动时,先加载isolinux.bin来启动系统,当isolinux.bin启动以后,会根据下面的配置文件isolinux.cfg来选择不同的启动选项来启动系统。 这个文件是一个二进制文件,在编译isolinux时可以得到,在这里不做过多讲述。 配置引导项文件isolinux.cfg 这个文件是ISOLINUX启动的配置文件,有了这个文件,引导程序isolinux.bin在引导时才会根据该配置文件的配置内容的不同,而选择不同的引导项来启动系统。 isolinux.cfg中的配置项有很多,用户可以根据自己的需求来选择性的加入跟自己相关的配置项即可。但是下面的这些配置项是必须要有的: default linux指定 label 是 linux 的启动选项为缺省,当然也可以是别的。 label linux kernel vmlinuz append initrd=initrd26.gz ramdisk_size=1000000 vga=791 这就是一个启动描述项,前面的 label 是指Linux系统启动时的引导选项。相当于grub中的title。kernel制定了启动时的内核。initrd= 指定 initrd 的文件和 ramdisk_size= 指定 initrd 的尺寸上限。其余的内核参数还可能有很多。其实Linux内核中启动的所有参数,在这里都是可以加入的。 prompt=1这是说,向用户提示输入选择,直接回车就是缺省选项了。当然,如果使其等于0则,不向用户提示输入选择。 timeout=0没有时间限制,当然也可以指定一定时间之后自动进入缺省选项。这个时间是秒数的10倍。例如,如果要等待30秒进入,则应该在这里输入timeout=300。 这些是系统引导时的必有选项,当然,有些选项是可以没有的。下面的这些选项可以没有。 display xxx.txt这指定了一个文件名,会在启动的时候显示的内容,该文件甚至可以包含一个 RLE 编码的图形文件,也就是大家在安装光盘启动时看到的那个;不过这个字段不甚重要,我们就略过了。 gfxboot bootlogo 这指定了启动时的图形界面。一般的Linux系统安装盘中都会加入此项,但是在一些特殊需求下,是不需要用图形界面的,而需要字符模式。具体如何制作图形启动模式,如何制作字符启动模式,需要根据选择的内核选项以及设置选项有关系。这将在下面进行详细介绍。 include ×××这是引入一个已经写好的配置选项文件到配置文件中。这在执行时,会将引入的文件中的全部内容给添加到此文件中,形成一个零时的配置文件来启动系统。 基本的配置项就这么多,当然还有很多的配置项,还是需要用户去参考相关的权威手册来一一了解。 系统启动内核程序 ISOLINUX系统在使用isolinux.bin文件引导完成以后,就会调用一个启动内核来启动一个简单的Linux系统。实际上无论是安装,还是修复Linux系统都需要一个简单的Linux系统来调用相应的程序来完成。在启动盘中使用的Linux内核程序跟普通的Linux系统内核是完全一致的,这里比较特殊的是其initrd镜像文件。该文件实际就是一个最小化的Linux系统。里面包含了shell,mount,fdisk之外,主要要包含Linux系统下各种常用的基本驱动。尤其是硬盘驱动,键盘鼠标驱动。如果没有这些驱动,那么系统将无法找到硬盘,导致系统无法正常启动。 initrd文件特殊,就特殊在该文件中不仅要包含上述的这些文件,还需要包含一些跟该光盘功能相关的文件。例如,如果要进行安装,那么简单的格式化命令也必须要有的。除了这些,为了让制作的iso文件被大部分PC 所使用,所以必须要包含各种驱动在里面。 initrd文件很好制作,可以将Linux系统启动时的initrd文件作为一个基本文件,在里面修改即可。如果有需要添加的内容,直接将linux系统中的相应文件拷贝进去就可以了。另外,initrd下面的启动脚本是init文件,建议根据自己的需求修改该文件,该文件是一个用shell写的脚本。在Linux系统启动时,加载完成内核以后,就开始调用该脚本了,所以有什么需要启动的,都可以在该脚本中添加。甚至可以将该脚本作为一个自己安装,修复等的基本脚本来做。但是建议不要如此,因为这样做会不易调试。建议将系统启动相关的内容放置在这里执行,而将自己的脚本放置在可执行目录下bin/sbin等,在init脚本中调用该脚本再执行。 举例说明 有了上面的这几步,基本上就对ISOLinux了解了。接下来的工作就是要靠自己的本事和自己的需求来调整initrd,以及iso目录下的内容了。 我在这里主要介绍一下,几种启动界面的制作: 字符模式启动界面 字符模式的启动界面,使用的是menu.c32内核做为启动内核。menu.c32文件由ISOLINUX包提供。可以直接从ISOLINUX包中编译产生。 有了该文件,我们只需要对isolinux.cfg文件进行修改一下即可。具体的修改可以参照下面的配置项 default menu.c32 prompt 0 menu title My Distro Installer timeout 600 f1 help.txt f2 version.txt label bls menu label Normal install menu default kernel vmlinuz append initrd=cpio.gz rdinit=/init label bad menu label Bad hardware install kernel vmlinuz append initrd=cpio2.gz badhardware rdinit=/init 可以看的出来,这里的主要调整是,调整default选项,修改其为menu.c32文件。因为如此是指定,默认使用menu.c32引导。接下来就是几个menu选项的加入。这几个选项的主要目的是设置启动的选择项。在命名时建议能够设置成容易识别的名称。 另外,注意menu default选项是指定,默认从那项启动。 当然,使用menu时,还可以加入下面的一些参数来设置选项窗口的宽高比: MENU WIDTH 80 /*设置宽度*/ MENU MARGIN 10 MENU ROWS 12 /*设置行数*/ MENU TABMSGROW 18 MENU CMDLINEROW 12 MENU ENDROW 24 MENU TIMEOUTROW 20 这几个选项可以添加,也可以不添加,可以均添加,也可以一个都不添加。设置很方便。 此种启动,都是字符模式,而且是用ascii码绘制出来的。其优点是占用内存小,启动快。缺点是界面单调。 2. 使用vesamenu制作启动界面 使用vesamenu启动的方法与使用menu的使用方法基本是一致的。所不同的是default的引导项不一样,此种模式下,default的启动项要设置成vesamenu。 另外,vesamenu的默认背景色是灰色,如果想更换背景图片,可以加入MENU BACKGROUND os102.png来更换背景图片。但是值得注意的是背景图片不能够制作的过于绚丽,因为该图片如果比较绚丽,则无法被正常加载。 这种方法的有点在于启动快,而且可以制作一个图形启动界面。缺点是无法制作一个比较绚丽的启动界面。 3. 使用bootlogo文件制作启动界面 使用bootlogo制作启动界面的方法是,先制作一个比较绚丽的bootlogo文件。这个文件是一个加入图片的二进制文件,具体如何制作,还需要高手能够帮忙指点一下,小弟还不是很清楚。另外,只需要在isolinux.cfg文件中加入gfxboot bootlogo选项即可。 制作ISO镜像文件 配置文件写完了,现在进入实质阶段。 在准备制作ISO的目录里添加一个子目录,比如boot/isolinux/,然后放入 isolinux.cfg和一个对所有光盘都一样的isolinux提供的引导介质 isolinux.bin,当然还要放入相应的kernel,initrd等我们需要在引导时调用到的文件,然后制作iso的时候要使用-b参数,来指明要使用isolinux.bin文件启动: mkisofs -o output.iso -b boot/isolinux/isolinux.bin -c boot/isolinux/boot.cat -no-emul-boot -boot-load-size 4 -boot-info-table for-iso-dir/ 最后的参数就是指定的光盘的目录了,-c参数的那个文件是自动生成的,不用太担心,其余参数都是固定的。事实上,也常常有人用isolinux/而不是 boot/isolinux/,这都是约定俗成的,你完全可以用自己的。这里的路径都是相对于光盘的根的,而和制作光盘时的工作目录没有关系。 至此,整个系统的启动和制作过程就已经完成了。可以说有了这些知识,就可以设计一个简单的启动光盘,至于光盘的功能,需要用户根据自己的需求来修改和调整! Linux2.6 内核的 Initrd 机制解析 Linux 的 initrd 技术是一个非常普遍使用的机制,linux2.6 内核的 initrd 的文件格式由原来的文件系统镜像文件转变成了 cpio 格式,变化不仅反映在文件格式上, linux 内核对这两种格式的 initrd 的处理有着截然的不同。本文首先介绍了什么是 initrd 技术,然后分别介绍了 Linux2.4 内核和 2.6 内核的 initrd 的处理流程。最后通过对 Linux2.6 内核的 initrd 处理部分代码的分析,使读者可以对 initrd 技术有一个全面的认识。为了更好的阅读本文,要求读者对 Linux 的 VFS 以及 initrd 有一个初步的了解。 1什么是 Initrd initrd 的英文含义是 boot loader initialized RAM disk,就是由 boot loader 初始化的内存盘。在 linux内核启动前, boot loader 会将存储介质中的 initrd 文件加载到内存,内核启动时会在访问真正的根文件系统前先访问该内存中的 initrd 文件系统。在 boot loader 配置了 initrd 的情况下,内核启动被分成了两个阶段,第一阶段先执行 initrd 文件系统中的"某个文件",完成加载驱动模块等任务,第二阶段才会执行真正的根文件系统中的 /sbin/init 进程。这里提到的"某个文件",Linux2.6 内核会同以前版本内核的不同,所以这里暂时使用了"某个文件"这个称呼,后面会详细讲到。第一阶段启动的目的是为第二阶段的启动扫清一切障爱,最主要的是加载根文件系统存储介质的驱动模块。我们知道根文件系统可以存储在包括IDE、SCSI、USB在内的多种介质上,如果将这些设备的驱动都编译进内核,可以想象内核会多么庞大、臃肿。 Initrd 的用途主要有以下四种: 1. linux 发行版的必备部件 linux 发行版必须适应各种不同的硬件架构,将所有的驱动编译进内核是不现实的,initrd 技术是解决该问题的关键技术。Linux 发行版在内核中只编译了基本的硬件驱动,在安装过程中通过检测系统硬件,生成包含安装系统硬件驱动的 initrd,无非是一种即可行又灵活的解决方案。 2. livecd 的必备部件 同 linux 发行版相比,livecd 可能会面对更加复杂的硬件环境,所以也必须使用 initrd。 3. 制作 Linux usb 启动盘必须使用 initrd usb 设备是启动比较慢的设备,从驱动加载到设备真正可用大概需要几秒钟时间。如果将 usb 驱动编译进内核,内核通常不能成功访问 usb 设备中的文件系统。因为在内核访问 usb 设备时, usb 设备通常没有初始化完毕。所以常规的做法是,在 initrd 中加载 usb 驱动,然后休眠几秒中,等待 usb设备初始化完毕后再挂载 usb 设备中的文件系统。 4. 在 linuxrc 脚本中可以很方便地启用个性化 bootsplash。 2Linux2.4内核对 Initrd 的处理流程 为了使读者清晰的了解Linux2.6内核initrd机制的变化,在重点介绍Linux2.6内核initrd之前,先对linux2.4内核的initrd进行一个简单的介绍。Linux2.4内核的initrd的格式是文件系统镜像文件,本文将其称为image-initrd,以区别后面介绍的linux2.6内核的cpio格式的initrd。 linux2.4内核对initrd的处理流程如下: 1. boot loader把内核以及/dev/initrd的内容加载到内存,/dev/initrd是由boot loader初始化的设备,存储着initrd。 2. 在内核初始化过程中,内核把 /dev/initrd 设备的内容解压缩并拷贝到 /dev/ram0 设备上。 3. 内核以可读写的方式把 /dev/ram0 设备挂载为原始的根文件系统。 4. 如果 /dev/ram0 被指定为真正的根文件系统,那么内核跳至最后一步正常启动。 5. 执行 initrd 上的 /linuxrc 文件,linuxrc 通常是一个脚本文件,负责加载内核访问根文件系统必须的驱动, 以及加载根文件系统。 6. /linuxrc 执行完毕,真正的根文件系统被挂载。 7. 如果真正的根文件系统存在 /initrd 目录,那么 /dev/ram0 将从 / 移动到 /initrd。否则如果 /initrd 目录不存在, /dev/ram0 将被卸载。 8. 在真正的根文件系统上进行正常启动过程 ,执行 /sbin/init。 linux2.4 内核的 initrd 的执行是作为内核启动的一个中间阶段,也就是说 initrd 的 /linuxrc 执行以后,内核会继续执行初始化代码,我们后面会看到这是 linux2.4 内核同 2.6 内核的 initrd 处理流程的一个显著区别。 3Linux2.6 内核对 Initrd 的处理流程 linux2.6 内核支持两种格式的 initrd,一种是前面第 3 部分介绍的 linux2.4 内核那种传统格式的文件系统镜像image-initrd,它的制作方法同 Linux2.4 内核的 initrd 一样,其核心文件就是 /linuxrc。另外一种格式的 initrd 是 cpio 格式的,这种格式的 initrd 从 linux2.5 起开始引入,使用 cpio 工具生成,其核心文件不再是 /linuxrc,而是 /init,本文将这种 initrd 称为 cpio-initrd。尽管 linux2.6 内核对 cpio-initrd和 image-initrd 这两种格式的 initrd 均支持,但对其处理流程有着显著的区别,下面分别介绍 linux2.6 内核对这两种 initrd 的处理流程。 cpio-initrd 的处理流程 1 boot loader 把内核以及 initrd 文件加载到内存的特定位置。 2 内核判断initrd的文件格式,如果是cpio格式。 3 将initrd的内容释放到rootfs中。 4 执行initrd中的/init文件,执行到这一点,内核的工作全部结束,完全交给/init文件处理。 image-initrd的处理流程 1 boot loader把内核以及initrd文件加载到内存的特定位置。 2 内核判断initrd的文件格式,如果不是cpio格式,将其作为image-initrd处理。 3 内核将initrd的内容保存在rootfs下的/initrd.image文件中。 4 内核将/initrd.image的内容读入/dev/ram0设备中,也就是读入了一个内存盘中。 5 接着内核以可读写的方式把/dev/ram0设备挂载为原始的根文件系统。 6 .如果/dev/ram0被指定为真正的根文件系统,那么内核跳至最后一步正常启动。 7 执行initrd上的/linuxrc文件,linuxrc通常是一个脚本文件,负责加载内核访问根文件系统必须的驱动, 以及加载根文件系统。 8 /linuxrc执行完毕,常规根文件系统被挂载 9 如果常规根文件系统存在/initrd目录,那么/dev/ram0将从/移动到/initrd。否则如果/initrd目录不存在, /dev/ram0将被卸载。 10 在常规根文件系统上进行正常启动过程 ,执行/sbin/init。 通过上面的流程介绍可知,Linux2.6内核对image-initrd的处理流程同linux2.4内核相比并没有显著的变化, cpio-initrd的处理流程相比于image-initrd的处理流程却有很大的区别,流程非常简单,在后面的源代码分析中,读者更能体会到处理的简捷。 4cpio-initrd同image-initrd的区别与优势 没有找到正式的关于cpio-initrd同image-initrd对比的文献,根据笔者的使用体验以及内核代码的分析,总结出如下三方面的区别,这些区别也正是cpio-initrd的优势所在: cpio-initrd的制作方法更加简单 cpio-initrd的制作非常简单,通过两个命令就可以完成整个制作过程 #假设当前目录位于准备好的initrd文件系统的根目录下 bash# find . | cpio -c -o > ./initrd.img bash# gzip ./initrd.img 而传统initrd的制作过程比较繁琐,需要如下六个步骤 #假设当前目录位于准备好的initrd文件系统的根目录下 bash# dd if=/dev/zero of=./initrd.img bs=512k count=5 bash# mkfs.ext2 -F -m0 ./initrd.img bash# mount -t ext2 -o loop ./initrd.img /mnt bash# cp -r * /mnt bash# umount /mnt bash# gzip -9 ./initrd.img 本文不对上面命令的含义作细节的解释,因为本文主要介绍的是linux内核对initrd的处理,对上面命令不理解的读者可以参考相关文档。 cpio-initrd的内核处理流程更加简化 通过上面initrd处理流程的介绍,cpio-initrd的处理流程显得格外简单,通过对比可知cpio-initrd的处理流程在如下两个方面得到了简化: 1 cpio-initrd并没有使用额外的ramdisk,而是将其内容输入到rootfs中,其实rootfs本身也是一个基于内存的文件系统。这样就省掉了ramdisk的挂载、卸载等步骤。 2 cpio-initrd启动完/init进程,内核的任务就结束了,剩下的工作完全交给/init处理;而对于image-initrd,内核在执行完/linuxrc进程后,还要进行一些收尾工作,并且要负责执行真正的根文件系统的/sbin/init。通过图1可以更加清晰的看出处理流程的区别: 图1内核对cpio-initrd和image-initrd处理流程示意图 cpio-initrd的职责更加重要 如图1所示,cpio-initrd不再象image-initrd那样作为linux内核启动的一个中间步骤,而是作为内核启动的终点,内核将控制权交给cpio-initrd的/init文件后,内核的任务就结束了,所以在/init文件中,我们可以做更多的工作,而不比担心同内核后续处理的衔接问题。当然目前linux发行版的cpio-initrd的/init文件的内容还没有本质的改变,但是相信initrd职责的增加一定是一个趋势。 5linux2.6内核initrd处理的源代码分析 上面简要介绍了Linux2.4内核和2.6内核的initrd的处理流程,为了使读者对于Linux2.6内核的initrd的处理有一个更加深入的认识,下面将对Linuxe2.6内核初始化部分同initrd密切相关的代码给予一个比较细致的分析,为了讲述方便,进一步明确几个代码分析中使用的概念: rootfs: 一个基于内存的文件系统,是linux在初始化时加载的第一个文件系统,关于它的进一步介绍可以参考文献4。 initramfs: initramfs同本文的主题关系不是很大,但是代码中涉及到了initramfs,为了更好的理解代码,这里对其进行简单的介绍。Initramfs是在 kernel 2.5中引入的技术,实际上它的含义就是:在内核镜像中附加一个cpio包,这个cpio包中包含了一个小型的文件系统,当内核启动时,内核将这个cpio包解开,并且将其中包含的文件系统释放到rootfs中,内核中的一部分初始化代码会放到这个文件系统中,作为用户层进程来执行。这样带来的明显的好处是精简了内核的初始化代码,而且使得内核的初始化过程更容易定制。Linux 2.6.12内核的 initramfs还没有什么实质性的东西,一个包含完整功能的initramfs的实现可能还需要一个缓慢的过程。对于initramfs的进一步了解可以参考文献123。 cpio-initrd: 前面已经定义过,指linux2.6内核使用的cpio格式的initrd。 image-initrd: 前面已经定义过,专指传统的文件镜像格式的initrd。 realfs: 用户最终使用的真正的文件系统。 内核的初始化代码位于 init/main.c 中的 static int init(void * unused)函数中。同initrd的处理相关部分函数调用层次如下图,笔者按照这个层次对每一个函数都给予了比较详细的分析,为了更好的说明,下面列出的代码中删除了同本文主题不相关的部分: 图2 initrd相关代码的调用层次关系图 init函数是内核所有初始化代码的入口,代码如下,其中只保留了同initrd相关部分的代码。 static int init(void * unused) 1 2 3 populate_rootfs; if (sys_access(const char _user *) "/init", 0) = 0) else prepare_namespace; execute_command = "/init" if (sys_open(const char _user *) "/dev/console", O_RDWR, 0) < 0) printk(KERN_WARNING "Warning: unable to open an initial console.n"); 4 (void) sys_dup(0); (void) sys_dup(0); if (execute_command) run_init_process(execute_command); run_init_process("/sbin/init"); run_init_process("/etc/init"); run_init_process("/bin/init"); run_init_process("/bin/sh"); panic("No init found. Try passing init= option to kernel."); 代码1:populate_rootfs函数负责加载initramfs和cpio-initrd,对于populate_rootfs函数的细节后面会讲到。 代码2:如果rootfs的根目录下中包含/init进程,则赋予execute_command,在init函数的末尾会被执行。否则执行prepare_namespace函数,initrd是在该函数中被加载的。 代码3:将控制台设置为标准输入,后续的两个sys_dup(0),则复制标准输入为标准输出和标准错误输出。 代码4:如果rootfs中存在init进程,就将后续的处理工作交给该init进程。其实这段代码的含义是如果加载了cpio-initrd则交给cpio-initrd中的/init处理,否则会执行realfs中的init。读者可能会问:如果加载了cpio-initrd, 那么realfs中的init进程不是没有机会运行了吗?确实,如果加载了cpio-initrd,那么内核就不负责执行realfs的init进程了,而是将这个执行任务交给了cpio-initrd的init进程。解开fedora core4的initrd文件,会发现根目录的下的init文件是一个脚本,在该脚本的最后一行有这样一段代码: . switchroot -movedev /sysroot 就是switchroot语句负责加载realfs,以及执行realfs的init进程。 对cpio-initrd的处理 对cpio-initrd的处理位于populate_rootfs函数中。 void _init populate_rootfs(void) 1 char *err = unpack_to_rootfs(_initramfs_start, 2 3 4 5 _initramfs_end - _initramfs_start, 0); if (initrd_start) if (!err) fd = sys_open("/initrd.image", O_WRONLY|O_CREAT, 700); if (fd >= 0) sys_write(fd, (char *)initrd_start, initrd_end - initrd_start); printk(" it isn"); unpack_to_rootfs(char *)initrd_start, initrd_end - initrd_start, 0); err = unpack_to_rootfs(char *)initrd_start, initrd_end - initrd_start, 1); free_initrd_mem(initrd_start, initrd_end); return; sys_close(fd); free_initrd_mem(initrd_start, initrd_end); 代码1:加载initramfs, initramfs位于地址_initramfs_start处,是内核在编译过程中生成的,initramfs的是作为内核的一部分而存在的,不是 boot loader加载的。前面提到了现在initramfs没有任何实质内容。 代码2:判断是否加载了initrd。无论哪种格式的initrd,都会被boot loader加载到地址initrd_start处。 代码3:判断加载的是不是cpio-initrd。实际上 unpack_to_rootfs有两个功能一个是释放cpio包,另一个就是判断是不是cpio包, 这是通过最后一个参数来区分的, 0:释放 1:查看。 代码4:如果是cpio-initrd则将其内容释放出来到rootfs中。 代码5:如果不是cpio-initrd,则认为是一个image-initrd,将其内容保存到/initrd.image中。在后面的image-initrd的处理代码中会读取/initrd.image。 对image-initrd的处理 在prepare_namespace函数里,包含了对image-initrd进行处理的代码,相关代码如下: void _init prepare_namespace(void) 1 out: 2 umount_devfs("/dev"); sys_mount(".", "/", NULL, MS_MOVE, NULL); sys_chroot("."); security_sb_post_mountroot; mount_devfs_fs ; if (initrd_load) goto out; 代码1:执行initrd_load函数,将initrd载入,如果载入成功的话initrd_load函数会将realfs的根设置为当前目录。 代码2:将当前目录即realfs的根mount为Linux VFS的根。initrd_load函数执行完后,将真正的文件系统的根设置为当前目录。 initrd_load函数负责载入image-initrd,代码如下: int _init initrd_load(void) 1 2 if (mount_initrd) sys_unlink("/initrd.image"); return 0; create_dev("/dev/ram", Root_RAM0, NULL); if (rd_load_image("/initrd.image") && ROOT_DEV != Root_RAM0) sys_unlink("/initrd.image"); handle_initrd; return 1; 代码1:如果加载initrd则建立一个ram0设备 /dev/ram。 代码2:/initrd.image文件保存的就是image-initrd,rd_load_image函数执行具体的加载操作,将image-nitrd的文件内容释放到ram0里。判断ROOT_DEV!=Root_RAM0的含义是,如果你在grub或者lilo里配置了 root=/dev/ram0 ,则实际上真正的根设备就是initrd了,所以就不把它作为initrd处理 ,而是作为realfs处理。 handle_initrd函数负责对initrd进行具体的处理,代码如下: 1 2 3 4 5 6 7 8 9 static void _init handle_initrd(void) real_root_dev = new_encode_dev(ROOT_DEV); create_dev("/dev/root.old", Root_RAM0, NULL); mount_block_root("/dev/root.old", root_mountflags & MS_RDONLY); sys_mkdir("/old", 0700); root_fd = sys_open("/", 0, 0); old_fd = sys_open("/old", 0, 0); /* move initrd over / and chdir/chroot in initrd root */ sys_chdir("/root"); sys_mount(".", "/", NULL, MS_MOVE, NULL); sys_chroot("."); mount_devfs_fs ; pid = kernel_thread(do_linuxrc, "/linuxrc", SIGCHLD); if (pid > 0) /* move initrd to rootfs' /old */ sys_fchdir(old_fd); sys_mount("/", ".", NULL, MS_MOVE, NULL); /* switch root and cwd back to / of rootfs */ sys_fchdir(root_fd); sys_chroot("."); sys_close(old_fd); sys_close(root_fd); umount_devfs("/old/dev"); if (new_decode_dev(real_root_dev) = Root_RAM0) ROOT_DEV = new_decode_dev(real_root_dev); mount_root; printk(KERN_NOTICE "Trying to move old root to /initrd . "); sys_chdir("/old"); return; while (pid != sys_wait4(-1, &i, 0, NUL

    注意事项

    本文(全存使用isolinux制作Linux启动光盘.docx)为本站会员(牧羊曲112)主动上传,三一办公仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一办公(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    备案号:宁ICP备20000045号-2

    经营许可证:宁B2-20210002

    宁公网安备 64010402000987号

    三一办公
    收起
    展开