jjzjj

自己动手从零写桌面操作系统GrapeOS系列教程——11.MBR介绍

成宇佳的技术博客 2023-03-28 原文

学习操作系统原理最好的方法是自己写一个简单的操作系统。


前面我们介绍过电脑的启动过程:

上电->BIOS->MBR(boot)->loader->kernel->交互界面(图形/命令行)

本讲我们要介绍的是MBR(Master Boot Record,主引导记录)。在电脑中对磁盘的读写是按扇区为基本单位的,一般每个扇区为512个字节。也就是说每读一次磁盘,读取的字节数是512字节的整数倍。同样每写一次磁盘,写入的字节数也是512字节的整数倍。MBR是磁盘的第一个扇区,又叫做主引导扇区,特点是最后2个字节的内容必须是0x55和0xAA。

下面我们来做几个实验来加深对MBR的了解。

1.不加载虚拟磁盘启动QEMU

Windows键+R键打开运行窗口,输入cmd并回车打开命令行窗口。

在命令行中输入qemu-system-i386并回车:

此时会打开QEMU窗口:

注意最后会输出一行话“No bootable device.”,意思是没有可引导启动的设备。

2.创建空虚拟硬盘

在CentOS中我们输入如下一行命令:

dd if=/dev/zero of=/media/VMShare/GrapeOS.img bs=1M count=4

dd命令简单来说是一个复制命令。参数if是指input file输入文件,参数of是指output file输出文件,意思就是将输入文件复制到输出文件中。这里的输入文件/dev/zero是Linux中的一个特殊文件,它可以提供无限的零。参数bs表示一次复制多少字节数据,也就是一个数据块的大小,count表示复制多少个块。bs乘以count表示总共复制多少数据,我们这里总共复制1M✖4=4M数据。运行上面这行命令的结果就是生成了一个4M大小的文件GrapeOS.img,该文件中每个字节都是0。截图如下:

由于GrapeOS.img是在Windows和CentOS的共享文件夹中,所以我们在Windows也能看到:

每个字节都是0的文件也叫空白文件,我们下面用hexdump命令来验证一下:

hexdump GrapeOS.img -C

从上面的截图可以看到GrapeOS.img这个文件中每个字节都是0。

3.加载空虚拟硬盘启动QEMU

在cmd命令行中输入如下命令:

qemu-system-i386 d:\GrapeOS\VMShare\GrapeOS.img

上面这行命令是为QEMU指定虚拟硬盘文件并启动QEMU。截图如下:

从上面截图可以看到,虽然给QEMU指定了虚拟硬盘,但最后的提示还是“No bootable device.”

4.将虚拟硬盘的第一个扇区变为MBR

我们在Lesson11文件夹下新建文件mbr.asm,并输入如下代码:

;生成一个空的MBR
times 510 db 0 ;前510个字节全为0
db 0x55,0xaa   ;最后两个字节是0x55和0xaa。

在VSCode中的截图如下:

使用nasm汇编器汇编:

nasm mbr.asm -o mbr.bin

从上面的截图我们看到,生成了一个叫mbr.bin的文件,大小为512字节。下面来看一下mbr.bin文件中的数据:

hexdump mbr.bin -C

从上图可以看到mbr.bin文件中共512字节,除最后2个字节是0x55和0xaa,其它字节都是0。
下面我们将mbr.bin写入到虚拟硬盘文件的头512个字节中:

dd conv=notrunc if=mbr.bin of=/media/VMShare/GrapeOS.img

上面这里命令中多了个参数conv=notrunc,表示不截断。如果不写该参数,执行完命令,GrapeOS.img就只剩512字节了。
执行完上面这行命令,我们验证一下是否写入成功:

hexdump /media/VMShare/GrapeOS.img -C

从上面截图可以看到总共4MB的文件,其中第511个字节为0x55,第512个字节0xaa,其它字节都为0。此时虚拟硬盘GrapeOS.img中第一个扇区已经是MBR了。

5.加载带MBR的虚拟硬盘启动QEMU

在cmd命令行中输入和刚才一样的命令:

qemu-system-i386 d:\GrapeOS\VMShare\GrapeOS.img

截图如下:

从上面的截图中可以看到,在QEMU中的提示信息已经和刚才不一样了。最后一行显示的是“Booting from Hard Disk...”,意思是从硬盘启动中,也就是说程序已经从BIOS跳转到MBR了。

通过上面的实验我们证明只要磁盘第一个扇区中的最后两个字节是0x55和0xaa,BIOS就会认为该扇区是一个有效的MBR,同时认为该磁盘是一个有效的启动项。
如果大家的实验做到这里会发现CPU占用率高,如果是笔记本电脑能听到CPU风扇呼呼的转。这是因为CPU跑飞了,我们后面会解决这个问题。

本讲小结:BIOS将电脑的控制权交棒给了MBR,我们可以在MBR中写程序,MBR是我们程序的起点,之后电脑的运行都由我们来控制。


本讲对应的视频版地址:https://www.bilibili.com/video/BV1pe4y1w7Co/
GrapeOS操作系统交流QQ群:643474045

有关自己动手从零写桌面操作系统GrapeOS系列教程——11.MBR介绍的更多相关文章

  1. Unity 热更新技术 | (三) Lua语言基本介绍及下载安装 - 2

    ?博客主页:https://xiaoy.blog.csdn.net?本文由呆呆敲代码的小Y原创,首发于CSDN??学习专栏推荐:Unity系统学习专栏?游戏制作专栏推荐:游戏制作?Unity实战100例专栏推荐:Unity实战100例教程?欢迎点赞?收藏⭐留言?如有错误敬请指正!?未来很长,值得我们全力奔赴更美好的生活✨------------------❤️分割线❤️-------------------------

  2. Observability:从零开始创建 Java 微服务并监控它 (二) - 2

    这篇文章是继上一篇文章“Observability:从零开始创建Java微服务并监控它(一)”的续篇。在上一篇文章中,我们讲述了如何创建一个Javaweb应用,并使用Filebeat来收集应用所生成的日志。在今天的文章中,我来详述如何收集应用的指标,使用APM来监控应用并监督web服务的在线情况。源码可以在地址 https://github.com/liu-xiao-guo/java_observability 进行下载。摄入指标指标被视为可以随时更改的时间点值。当前请求的数量可以改变任何毫秒。你可能有1000个请求的峰值,然后一切都回到一个请求。这也意味着这些指标可能不准确,你还想提取最小/

  3. ruby - 安装libv8(3.11.8.13)出错,Bundler无法继续 - 2

    运行bundleinstall后出现此错误:Gem::Package::FormatError:nometadatafoundin/Users/jeanosorio/.rvm/gems/ruby-1.9.3-p286/cache/libv8-3.11.8.13-x86_64-darwin-12.gemAnerroroccurredwhileinstallinglibv8(3.11.8.13),andBundlercannotcontinue.Makesurethat`geminstalllibv8-v'3.11.8.13'`succeedsbeforebundling.我试试gemin

  4. ruby - 如何使用 Selenium Webdriver 根据 div 的内容执行操作? - 2

    我有一个使用SeleniumWebdriver和Nokogiri的Ruby应用程序。我想选择一个类,然后对于那个类对应的每个div,我想根据div的内容执行一个Action。例如,我正在解析以下页面:https://www.google.com/webhp?sourceid=chrome-instant&ion=1&espv=2&ie=UTF-8#q=puppies这是一个搜索结果页面,我正在寻找描述中包含“Adoption”一词的第一个结果。因此机器人应该寻找带有className:"result"的div,对于每个检查它的.descriptiondiv是否包含单词“adoption

  5. ruby-on-rails - 如何处理 Grape 中特定操作的过滤器之前? - 2

    我正在我的Rails项目中安装Grape以构建RESTfulAPI。现在一些端点的操作需要身份验证,而另一些则不需要身份验证。例如,我有users端点,看起来像这样:moduleBackendmoduleV1classUsers现在如您所见,除了password/forget之外的所有操作都需要用户登录/验证。创建一个新的端点也没有意义,比如passwords并且只是删除password/forget从逻辑上讲,这个端点应该与用户资源。问题是Grapebefore过滤器没有像except,only这样的选项,我可以在其中说对某些操作应用过滤器。您通常如何干净利落地处理这种情况?

  6. ruby-on-rails - 在 Ruby on Rails 中发送响应之前如何等待多个异步操作完成? - 2

    在我做的一些网络开发中,我有多个操作开始,比如对外部API的GET请求,我希望它们同时开始,因为一个不依赖另一个的结果。我希望事情能够在后台运行。我找到了concurrent-rubylibrary这似乎运作良好。通过将其混合到您创建的类中,该类的方法具有在后台线程上运行的异步版本。这导致我编写如下代码,其中FirstAsyncWorker和SecondAsyncWorker是我编写的类,我在其中混合了Concurrent::Async模块,并编写了一个名为“work”的方法来发送HTTP请求:defindexop1_result=FirstAsyncWorker.new.async.

  7. ruby - 在 Ruby 中是否有一种惯用的方法来操作 2 个数组? - 2

    a=[3,4,7,8,3]b=[5,3,6,8,3]假设数组长度相同,是否有办法使用each或其他一些惯用方法从两个数组的每个元素中获取结果?不使用计数器?例如获取每个元素的乘积:[15,12,42,64,9](0..a.count-1).eachdo|i|太丑了...ruby1.9.3 最佳答案 使用Array.zip怎么样?:>>a=[3,4,7,8,3]=>[3,4,7,8,3]>>b=[5,3,6,8,3]=>[5,3,6,8,3]>>c=[]=>[]>>a.zip(b)do|i,j|c[[3,5],[4,3],[7,6],

  8. ruby-on-rails - 如何让 Rails View 返回其关联的操作名称? - 2

    我有一个非常简单的Controller来管理我的Rails应用程序中的静态页面:classPagesController我怎样才能让View模板返回它自己的名字,这样我就可以做这样的事情:#pricing.html.erb#-->"Pricing"感谢您的帮助。 最佳答案 4.3RoutingParametersTheparamshashwillalwayscontainthe:controllerand:actionkeys,butyoushouldusethemethodscontroller_nameandaction_nam

  9. ruby-on-rails - 如何测试自己对 Ruby/ROR 的了解? - 2

    是否有self验证的问题列表。看着那个,我可以确定我知道。我应该复习一下。在学习的过程中,我列了一个这样的list,但它只包含我在某处听说过的项目。我需要一段时间才能找到新的东西。 最佳答案 以下是针对ruby​​和Rails的一些测试列表。证书名称:RubyonRails谁提供:oDeskIncorporation认证费用:免费网站:https://www.odesk.com/tests/985?pos=0证书名称:RubyonRails提供者:Techgig.com(TimesBusinessSolutionsLimited(T

  10. ruby - ri 有空文件 – Ubuntu 11.10, Ruby 1.9 - 2

    我正在运行Ubuntu11.10并像这样安装Ruby1.9:$sudoapt-getinstallruby1.9rubygems一切都运行良好,但ri似乎有空文档。ri告诉我文档是空的,我必须安装它们。我执行此操作是因为我读到它会有所帮助:$rdoc--all--ri现在,当我尝试打开任何文档时:$riArrayNothingknownaboutArray我搜索的其他所有内容都是一样的。 最佳答案 这个呢?apt-getinstallri1.8编辑或者试试这个:(非rvm)geminstallrdocrdoc-datardoc-da

随机推荐