GRUB,UEFI
2015-11-19 21:29
302 查看
—–最近三天为了给平板装Linux,看了好多UEFI和GRUB的东西,写在这里记录一下自己的理解。
—–UEFI,和EFI是一个意思。和BIOS的作用是一样的,需要主板厂商支持。对于支持BIOS的主板来讲,BIOS只能完成非常基本的硬件检测和初始化,以后的工作就都由bootleader来交接了;对于支持UEFI的主板,主板的ROM中存放EFI shell程序,会能够识别存储介质上的分区信息和文件系统,比如fat32,并从指定的EFI/boot/目录下查找.efi文件,并执行,以后的工作就是.efi文件和bootleader的任务了。
下面说说.efi和bootleader的关系。
—–bootleader有GRUB,ILIO,easyBCD等。.efi文件的目前主要就是加载grub,剩下的OS加载以及多系统选择也由grub完成。但是.efi文件实际用途可能更广泛,由于EFI定义了完整的硬件层框架,所以.efi的开发可以完成硬件层更多的初始化,甚至是交互能力。.efi代替grub也是完全可以的!
**注1:一般的操作系统提供的bootleader都含有.efi文件,此.efi文件只是简单加载bootleader。
**注2:EFI shell有32位和64位的区分,所以在开发.efi文件的时候有32位和64位的区别,想想就恶心!
**注3:对于OS,也会主动去适配EFI的安装方式,但是恶心的ubuntu32位的不支持EFI引导。
**注4:window镜像中提供/EFI/boot/bootia32.efi文件,此文件被shell读取后执行后,会转向执行,micsoft文件里的bootmgr.efi,然后就是window的传统引导方式了,先加载bootmgr–>BCD,选择系统–>system32里的boot.wim。
**注5:对于自己编译的linux,只需要加载内核镜像就可以了。对于linux发行版,还会额外提供initrd镜像,此镜像包含了驱动等更多软件支持,在内核启动main函数中的init()执行前会被用来进一步安装驱动文件!。
下面说说grub。
—-在OS上安装grub软件过程,并不以为着你的PC就会使用grub启动!安装grub到OS里,只是为grub为“启动设置”创建运行环境。接下来还需要为把启动文件写入到启动盘中,把bootleader写入到MBR中让BIOS读取或者生成标准.efi文件让EFI shell读取。简单以下:
1、安装grub到PC上,这样才能使用grub的命令;
2、使用安装的grub命令,把启动文件写入到启动盘中,写入的这些文件就是grub提供的bootleader了;
3、使用grub命令,把grub的bootleader设置为启动;此处包含两种情景。如果使用BIOS启动,那就是把bootleader的一部分写到MBR中;如果使用EFI启动,那就生成/EFI/boot/xxx.efi文件,让EFI shell自动读取!。
—–最后,实际系统的启动可以非常的灵活,对于只支持BIOS的主板,可以使用grub进入grub命令行,然后为grub添加第三方的EFI shell模块,然后就可以启动那些使用EFI启动的OS了;对于只有EFI的主板,当然可以写个.efi文件,然后转去读取MBR传统引导等等等。
—–UEFI,和EFI是一个意思。和BIOS的作用是一样的,需要主板厂商支持。对于支持BIOS的主板来讲,BIOS只能完成非常基本的硬件检测和初始化,以后的工作就都由bootleader来交接了;对于支持UEFI的主板,主板的ROM中存放EFI shell程序,会能够识别存储介质上的分区信息和文件系统,比如fat32,并从指定的EFI/boot/目录下查找.efi文件,并执行,以后的工作就是.efi文件和bootleader的任务了。
下面说说.efi和bootleader的关系。
—–bootleader有GRUB,ILIO,easyBCD等。.efi文件的目前主要就是加载grub,剩下的OS加载以及多系统选择也由grub完成。但是.efi文件实际用途可能更广泛,由于EFI定义了完整的硬件层框架,所以.efi的开发可以完成硬件层更多的初始化,甚至是交互能力。.efi代替grub也是完全可以的!
**注1:一般的操作系统提供的bootleader都含有.efi文件,此.efi文件只是简单加载bootleader。
**注2:EFI shell有32位和64位的区分,所以在开发.efi文件的时候有32位和64位的区别,想想就恶心!
**注3:对于OS,也会主动去适配EFI的安装方式,但是恶心的ubuntu32位的不支持EFI引导。
**注4:window镜像中提供/EFI/boot/bootia32.efi文件,此文件被shell读取后执行后,会转向执行,micsoft文件里的bootmgr.efi,然后就是window的传统引导方式了,先加载bootmgr–>BCD,选择系统–>system32里的boot.wim。
**注5:对于自己编译的linux,只需要加载内核镜像就可以了。对于linux发行版,还会额外提供initrd镜像,此镜像包含了驱动等更多软件支持,在内核启动main函数中的init()执行前会被用来进一步安装驱动文件!。
下面说说grub。
—-在OS上安装grub软件过程,并不以为着你的PC就会使用grub启动!安装grub到OS里,只是为grub为“启动设置”创建运行环境。接下来还需要为把启动文件写入到启动盘中,把bootleader写入到MBR中让BIOS读取或者生成标准.efi文件让EFI shell读取。简单以下:
1、安装grub到PC上,这样才能使用grub的命令;
2、使用安装的grub命令,把启动文件写入到启动盘中,写入的这些文件就是grub提供的bootleader了;
3、使用grub命令,把grub的bootleader设置为启动;此处包含两种情景。如果使用BIOS启动,那就是把bootleader的一部分写到MBR中;如果使用EFI启动,那就生成/EFI/boot/xxx.efi文件,让EFI shell自动读取!。
—–最后,实际系统的启动可以非常的灵活,对于只支持BIOS的主板,可以使用grub进入grub命令行,然后为grub添加第三方的EFI shell模块,然后就可以启动那些使用EFI启动的OS了;对于只有EFI的主板,当然可以写个.efi文件,然后转去读取MBR传统引导等等等。
相关文章推荐
- 安装win7或win8系统时UEFI和Legacy模式的设置
- UEFI是什么?与BIOS的区别在哪里?UEFI详解!
- 【嘟嘟工作室】 UEFI GUI 最新界面 duduworks@163.com
- 先安装了fedora22 后安装windows8.1双系统的引导
- kail-linux 和win8.1 uefi 实录
- win10与archlinux(UEFI+GPT)双系统
- ubuntu12.04 系统安装总结
- 计算机的启动引导过程
- UEFI模式安装Windows Linux双系统
- 在预装win8的UFI+GTP的pc上实现ubuntu和win8双系统启动
- UEFI Console Splitter 2nd
- UEFI Console Splitter
- UEFI启动模式和传统的Lagency启动模式
- UEFI Driver编写
- U盘安装Win7
- UEFI+GPT安装ubuntu14.04笔记
- 使用bcdedit修改TFTP传输blksize和windowsize以加快PXE启动速度
- win8系统EFI分区变主分区修复方法。
- UEFI+GPT安装kila linux2.0和win8.1双系统