写一个最简单的MBR程序

写一个最简单的MBR程序
首先这个程序只有很简单的几个指令,只要有一台linux系统的电脑,只需几个步骤就能写出自己MBR程序!
什么是MBR?
当你按下电脑的开机键,你的cup第一个运行的是bios程序,这个程序在制造主板的时候就印刷在一个只读存储器里,一般来说我们无法修改它。bios程序将硬盘第一个扇区的数据传送到内存中的某一段存储单元里,然后cpu就从内存这个地方开始执行指令,bios的使命就完成了。接下来登场的就是硬盘第一个扇区的这段程序,称为MBR程序(Manage Boot Recorder)。MBR的生命也很短暂,它的使命是将操作系统的引导程序装载到内存,但如果你希望你电脑上的所有程序都是你自己写的,那么MBR将是电脑接通电源后后第一个你可以DIY的程序

当然这次我们写的程序还不足以称为MBR程序,因为他还不能装载操作系统的引导程序,但这是你能写出一个完整MBR的第一步!

只要设法将二进制指令复制到硬盘的第一个扇区,然后重启系统,cpu就单纯的执行你的指令了,没有任何操作系统的控制和干预!当然,这是个危险的做法,正如前面所说,我们写的是几个最简单的指令,这几个指令还不足以引导操作系统。所以最好你有一台实验用的电脑,或者你有修复MBR的移动介质。但是再怎么说,这样执行你的指令也很不方便,因为每执行一次新的程序,你都得重新修复一下MBR。让人高兴的是,虚拟机可以解决这个问题, 比虚拟机更方便的是QEMU。

下面进行我们的具体步骤:
1,安装NASM和虚拟机(如果你有实验用的电脑,
  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Windows XP下删除Ubuntu系统的方法(附修复MBR工具下载) 你开开心心的安装了Ubuntu系统但是发现更本不会用,甚至不能调出中文输入法(我第一次遇到的情况),在这种情况下你一气之下要删除Ubuntu系统,但是清理数据之后发现根本无法进入Windows系统。 删除Ubuntu最需要注意的地方,就是MBR(Master Boot Record)。在删除Linux分区前,我们需要将启动Windows的引导信息写入MBR,否则,MBR中的Ubuntu引导信息,当然就不能启动Windows系统了。 步骤一:将Windows的引导信息写入MBR 方法一:就是将Windows的安装盘放入计算机以后,重启计算机,进入Windows安装程序,随后,进入恢复控制台,输入命令fixmbr即可,必须要说明的这种方法仅适用于安装版的XP系统,如果你是Ghost安装或者使用精简版的话就不能使用这种方法,而且你还需要一个安装版的Windows XP光盘(市面上的以番茄花园或者雨林木风安装版较多,不过建议下载原版镜像刻盘引导)。 方法二:为没有Windows安装盘的朋友准备的,就是使用MBRFix工具进行修复。MBRFix工具修复MBR很方便,先进入cmd命令窗口(开始-运行-cmd),然后进入mbrfix工具所在的目录(用cd命令,如我将解压后的MBRFix放置在C盘根目录,输入cd \),然后输入命令 MbrFix /drive 0 fixmbr ,再确认一下即可。重启以后你会发现,没有了Ubuntu,直接可以进入Windows了。 步骤二:删除Linux分区 删除Linux所在的分区,这个很简单,您可以使用patition的分区工具,将该分区格式化成fat32或ntfs格式,就可以在Windows下使用了。最好不要使用Windows自带的分区工具进行分区,因为Windows自带的分区工具不能识别Linux分区。如果您使用了Windows自带的分区工具,那么您的硬盘数据极有可能被破坏(我有过惨痛经历)。如果您的硬盘数据被破坏了,那么请用能够修复分区的数据恢复软件进行修复,不过不一定成功喔,看人品了~ 最后 别忘了评论一下啊~~
什么是MBR和主引导引导扇区?什么是主分区、扩展分区、逻辑分区?什么是活动分区、引导分区、系统分区、启动分区?一下子罗列这么多概念,恐怕很多人都搞不清它们的区别和联系吧。网上虽然不少解释,但很多是模棱两可甚至是错误的,反而越弄越糊涂。猫猫煞费苦心的把这一大串概念研究了很长时间,试图搞明白,为了以后查阅方便,于是把对这些概念的理解总结了一下。而要想分清这些概念,真要费一点脑筋啊! 一、MBR和主引导扇区 首先简要介绍MBR和主引导扇区的关系。 主引导扇区是硬盘0号柱面,0号磁头的第一个扇区,大小为512字节。(注:硬盘可以用柱面、磁头和扇区定位) MBR,占用主引导扇区的前446字节,紧随其后的64字节是分区表DPT,最后还剩两个字节则恒为55AA,表示结束符号。(下图,演示了它们的位置关系) 然后,具体说一说MBR和分区表。 MBR,全称为Master Boot Record,即硬盘的主引导记录。MBR,共446字节,一般在操作系统安装时写入,但它并不属于操作系统。MBR就是一段引导程序,用于检测磁盘的分区合法性和加载操作系统,它的重要作用就是识别活动分区,并引导操作系统。 分区表DPT,共64字节,记录了硬盘有多少分区以及分区的各种属性。由于一个分区的信息要占用16字节,所以分区表只能定义4个分区,这就是为什么我们说硬盘一般最多只能分为4个主分区(这里说“一般”是对基本磁盘而言,而对于动态磁盘则无此限制,但大部分都在使用基本磁盘,可以暂不考虑 )。 计算机开机后BIOS加电自检,一切正常后,找到第一个启动设备(一般就是硬盘),然后从这个启动设备的主引导扇区读取MBRMBR这段引导程序识别活动分区,引导操作系统。 二、主分区、扩展分区、逻辑分区 正如前面所讲,主分区是由主引导扇区中64字节的分区表所定义的,最多只能有4个。但为了满足更多分区的需求,变产生了扩展分区。形式上,如果拥有扩展分区,就必须牺牲一个主分区,而且最多有一个扩展分区,也就是说:主分区+扩展分区<=4 and 扩展分区<=1。因此扩展分区也可以看成一种特殊的主分区。 但扩展分区并不可以直接使用,扩展分区又必须以逻辑分区的形式出现,可以这样认为:扩展分区包含着若干逻辑分区,而且至少包含一个。 扩展分区中的逻辑分区是以链式存在的。即每一个逻辑分区都记录着下一个逻辑分区的位置信息,依次串联。事实上每一个逻辑分区都有一个和主引导扇区类似的引导扇区,引导扇区里有类似的分区表。该分区表记录了该分区的信息和一个指针,指向下一个逻辑分区的引导扇区。 因此,逻辑分区是借鉴了主分区的方法,相当于在一个主分区下面建立了若干级“主分区”。从上面的描述,猫猫推测,逻辑分区是建立在操作系统级别,由操作系统识别的。另一个可以预测的现象是:一旦某一个逻辑分区损害,跟在它后面的所有逻辑分区都将丢失,而前面的逻辑分区去可以保留。这也是链式结果的特点。 三、活动分区、系统分区、启动分区、引导分区 这四个术语和前面三个不同,前面三个是讲述分区的“物理”形成。而这四个术语描述了分区的功能,并且更易混淆。 首先,根据Windows XP随机帮助文档看,引导分区就是启动分区,两者是同一概念,所以下面就只讨论活动分区、系统分区和启动分区。 系统分区和启动分区比较。 这是两个极易混淆的概念,因为两者的含义似乎和它们的名字正好颠倒了。Windows帮助文件的术语表里是这样解释他们的:”系统分区,包含加载 Windows(例如,Ntldr、Osloader、Boot.ini、Ntdetect.com)所需的硬件特定文件的分区。系统分区可以(但不是必须)与启动分区相同。启动分区,包含 Windows 操作系统及其支持文件的分区。启动分区可以(但不是必须)与系统分区相同。“ 看起来是很糊涂,但说的简单些就是:系统分区包含Ntldr、Osloader、Boot.ini、Ntdetect.com等文件,而启动分区包含Windows和system32文件。所以,真正包含操作系统内核文件的分区是启动分区,包含操作系统引导文件的确实系统分区,这是要特别注意的一点。 有些人就疑问了,我的Ntldr、Osloader、Boot.ini、Ntdetect.com和Windows、system32文件都在C盘,那是怎么回事?这很容易解释,你的C盘既是系统分区也是启动分区,只安装一个操作系统的计算机大都属于这种情况 ,所以微软在括号里说“但不是必须”。 其实系统分区时针对引导来说的,而启动分区时针对操作系统来说的。像我的电脑C盘先安装了Vista,后来D盘安装了XP,现在C盘是系统分区;至于哪个是启动分区,就要看我用那个系统了,进Vista,C盘就是启动分区,进XP,D盘就是启动分区。(再强调,启动分区包含Windows内核文件,而系统分区才包含操作系统引导文件,不然会越看越糊涂的。) 最后要搞明白的是活动分区,这一点,比较麻烦。 Windows帮助文档里的定义是:”活动分区,基于 x86 计算机的启动分区。活动分区必须是基本磁盘上的主要分区。如果只使用 Windows,则活动分区可以与系统卷相同。“补充说明有:活动分区必须是主分区,一块硬盘上只可以有一个活动分区。其他主分区可以被标记为活动分区。 而从主引导扇区处看,活动分区仅仅是在分区表中,16个字节的最前面含有80标志的分区信息所定义的分区。 但猫猫对Windows帮助文档的定义不敢苟同(也许是我错了,但是我思来想去,只有这样可以解释通)。首先,我们知道活动分区是通过主引导扇区的分区表标记的,所以理论上,每个主分区都可以被标记为活动(只是不当的标记会导致系统无法启动)。Windows帮助文档说活动分区,是基于x86的计算机的启动分区,那不就是说是Windows文件所在分区。可是对于双系统来说,这种说法显然不对,因为双系统的启动分区是依据被启动的系统而定的。所以,我假定微软也把系统分区和启动分区的概念搞混淆了。 所以,结果变为,活动分区是基于x86计算机的系统分区。换句话说,活动分区是一种系统分区。在这种情况下,一个主分区是不是系统分区似乎并不具有价值,只有被标记为活动的主分区才有价值。因为,只有标记为活动分区,这个系统分区的Windows启动支持文件才会被加载,然后通过这些引导存储在启动分区的Windows内核文件,完全Windows的启动。 所以,Windows可以被安装在逻辑分区内(我发现我的电脑就是这样的),但必须在活动分区的启动支持文件里加上对这个逻辑分区里Windows的引导信息。具体到XP,就是boot.ini文件添加上对双系统的引导,而这个boot,ini文件必须在启动分区。而我了一个实验,在XP下面通过启动和故障恢复对话框修改boot.ini文件,发现修改的并非XP所在的分区的boot.ini,而是Vista所在分区的boot.ini。(我在主分区C盘安装了Vista,逻辑分区D盘安装了XP)。同时,我通过软件废除Vista的新式引导方式,恢复xp的boot.ini式引导方式(此时,C盘Vista已无法引导),发现分别修改C盘和D盘的boot.ini,只有C盘的boot.ini才有效。再次印证了我的假设。 另外,如果两个系统都安装在主分区,则可以通过标记各自的安装分区为活动分区,而启动不同的操作系统。 参考资料: Linux引导过程内幕:http://www.ibm.com/developerworks/cn/linux/l-linuxboot/ 维基百科-主引导扇区:http://zh.wikipedia.org/wiki/%E4%B8%BB%E5%BC%95%E5%AF%BC%E6%89%87%E5%8C%BA 硬盘主引导记录详解(汇编代码详解):http://www.cnblogs.com/woodfish1988/archive/2007/11/25/971482.html Windows XP随机帮助文档(Windows帮助文档是一个很好的东西,有些人优化系统竟然把它删了,真是太不应该了。 呵呵,本文地址,猫猫的园地:http://blog.mm-share.cn/post/Partition-Comparison.html 了这么多,希望对大家有所帮助。若有不足之处,望方家指正!另外,还有基本磁盘、动态磁盘,卷和分区的区别等待问题,还要进一步研究。
使用方法 第一步 让你的U盘启动DOS 格式化软件有很多种 USBOOT HPUSBFW FIASHBOOT是用的最多的三种 HPUSBFW作的HDD启动盘兼容性最好/Flahboot作的ZIp启动盘最好 我比较喜欢用Flashboot 因为启动后盘符为A: 打开FLASHBOOT 1 选择制作一个带最小DOS系统的启动U盘 2使用内置的FreeDOS/选择你的U盘盘符 3然后是选择ZIP还是HDD模式(看你主板支持哪种 一种能用ZIP就最好用ZIP模式 兼容性较好) 按照提示作完后 你的U盘里就有了DOS启动文件 最好重起电脑试试能否用U盘启动到DOS 如果不行 尝试BIOS设置 或者用其他格式化工具 总之 要能用U盘启动到DOS 第二步 制作能启动PE的优盘 1 删掉U盘上的文件(不要使用格式化) 2 把解压包里的NTBOOT.EXE文件复制到C盘根目录 3 使用CMD进入命令行模式/在C盘根目录下执行NTBOOT.EXE X: (X为你的U盘盘符 像我的就是G:) 现在你的U盘已经有引导MBR了 现在可以直接复制PE到你的U盘上 各版本PE各不相同 对于REBOOT 需要这四个文件:RXPE.IM_ RXPE.LDR RXPE.COM RXPE.SIF 对于毛桃版 需要这些:PELDR(或是SETUPLDR.BIN) NTDETECT.com WINNT.XPE WIINPE.IS_ 及外置程序 毛桃911刚需要四个文件加OP.WIM 复制完成后,REBOOT要把RXPE.LDR改名为NTLDR 毛桃版改PELDR或SETUPLDR.BIN改名为NTLDR 不要后辍!! 至此 一个能启动PE的U盘就制作完成了 对于无法使用格式化工具使U盘启动到DOS的,可以试试量产工具先对U盘处理一下 事实上 无论任何版的PE都可以用这个方法 方法是复制*.sif *.LDR *.COM *.IM_(或者*.IS_) 这四个文件并把引导程序改名NTLDR 注意各版本的这四个文件名可能不同 有外外置工具的还要复制外置程序目录 然后用上面的方法就可以安装到U盘了 另外 对于想用GRUB多启动的,可以用GRLDR改名为NTLDR来实现,当然你得会编MENU.LST文件,或者修改GRLDR的内置MENU菜单

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值