一个操作系统的实现:搭建你的工作环境

我知道,现在你已经开始摩拳擦掌准备大干一场了, 你发现,开头并不是那么难的.你可能想到了Linus,或许他在写出第一个引导扇区并调试成功时也是同样的激动不已;你可能在想,有一天,我也要写出一个Linux那样伟大的操作系统!是的,这一切都有可能, 一切伟大必定是从平凡开始的.我知道此刻你踌躇满志,已经迫不及待要进入操作系统的殿堂.

  可是先不要着急,古人云:“工欲善其事,必先利其器”,你可能已经发现,如果每次我们编译好的东西都要写到软盘上,再重启计算机,不但费时费力,对自己的爱机简直是一种蹂躏.你一定不会满足于这样的现状,还好,我们有如此多的工具,比如前面提到过的Bochs.

  在介绍Bochs及其他工具之前,需要说明一点,这些工具并不是不可或缺的,介绍它们仅仅是为读者提供一些可供选择的方法,用以搭建自己的工作环境.但是,这并不代表这一章就不重要, 得心应手的工具不但可以愉悦身心,并且可以起到让工作事半功倍的功效.

  下面就从Bochs开始介绍.

  虚拟计算机Bochs

  即便没有听说过虚拟计算机,你至少应该听说过磁盘映像.如果经历过DOS时代,你可能就曾经用HD-COPY把一张软盘做成一个.IMG文件, 或者把一个.IMG文件恢复成一张软盘.虚拟计算机相当于此概念的外延,它与映像文件的关系就相当于计算机与磁盘.简单来讲,它相当于运行在计算机内的小 计算机.

  1.Bochs初体验

  我们先来看看Bochs是什么样子的,请看这两个屏幕截图:


要看清楚哦,你看到的不是显示器,仅仅是窗口而已.如果你是第一次接触“虚拟机”这个东西的话,一定会感到很惊讶,你会惊叹:“啊,像真的一样!”没错, 像真的一样,不过窗口的标题栏一行“Bochs x86-64 emulator”明白无误地告诉我们,这仅仅是个“emulator”──模拟器而已.在本书中我们把这种模拟器称为虚拟机, 这 个词使用得更广泛一些.不管是模拟还是虚拟,我们要的就是它,有了它,我们不再需要频繁地重启计算机,即便程序有严重的问题,也丝毫伤害不到你的爱机.更 加方便的是,你可以用这个虚拟机来进行操作系统的调试,在它面前,你就好像是上帝,你可以随时让时间停住,然后钻进这台计算机的内部,CPU的寄存器、内 存、硬盘,一切的一切都尽收眼底.这正是进行操作系统的开发实验所需要的.

 好了,既然Bochs这么好,我们就来看看如何安装,以及如何使用.

  2.Bochs的安装

  就像大部分软件一样,在不同的操作系统里面安装Bochs的过程是不同的,在Windows中,最方便的方法就是从Bochs的官方网站获取安 装程序来安装(安装时不妨将“DLX Linux Demo”选中,这样你可以参考它的配置文件).在Linux中,不同的发行版(distribution)处理方法可能不同.比如,如果你用的是 Debian GNU/Linux或其近亲(比如Ubuntu),可以使用这样的命令:

  $ sudo apt-get install vgabios bochs bochs-x bximage

  敲入这样一行命令,不一会儿就装好了.


很多Linux发行版都有自己的包管理机制,比如上面这行命令就是使用了Debian的包管理命令,不过这样安装虽然省事,但有个缺点不得不说,就是默认安装的Bochs很可能是没有调试功能的,这显然不能满足我们的需要, 最好的方法还是从源代码安装,源代码同样位于Bochs的官方网站[1],假设你下载的版本是2.3.5,那么安装过程差不多是这样的:

  $ tar vxzf bochs-2.3.5.tar.gz

  $ cd bochs-2.3.5

  $ ./configure --enable-debugger --enable-disasm

  $ make

  $ sudo make install

  注意“./configure”之后的参数便是打开调试功能的开关.在安装过程中,如果遇到任何困难,不要惊慌,其官方网站上有详细的安装说明.

  3.Bochs的使用

  好了,Bochs已经安装完毕,是时候来揭晓第1章的谜底了,下面我们就一步步来说明图1.1的画面是怎样来的.

  在第1章我们提到过,硬件方面需要的是一台计算机和一张空白软盘,现在计算机有了──就是刚刚安装好的Bochs,那么软盘呢?既然计算机都可 以“虚拟”,软盘当然也可以.在刚刚装好的Bochs组件中,就有一个工具叫做bximage,它不但可以生成虚拟软盘,还能生成虚拟硬盘,我们也称它们 为磁盘映像.创建一个软盘映像的过程如下所示:

  凡是有↩记号的地方,都是bximage提示输入的地方,如果你想使用默认值,直接按回车键就可以.在这里我们只有一个地方没有使用默认值,就是被问到创建硬盘还是软盘映像的时候,我们输入了“fd”.


完成这一步骤之后,当前目录下就多了一个a.img,这便是我们的软盘映像了.所谓映像者,你可以理解为原始设备的逐字节复制,也就是说,软盘的第$M$个字节对应映像文件的第M个字节.

  现在我们已经有了“计算机”,也有了“软盘”,是时候将引导扇区写进软盘了.我们使用dd命令[2]:

 $ dd if=boot.bin of=a.img bs=512 count=1 conv=notrunc

  注意这里多用了一个参数“conv=notrunc”,如果不用它的话软盘映像文件a.img会被截断(truncated), boot.bin比a.img要小.第1章中我们使用这个命令时不需要此参数, 真实的软盘不可能被“截断”──真的和假的总是会有一点区别.

  现在一切准备就绪,该打开电源启动了.可电源在哪儿呢?不要慌,我们还剩一样重要的东西没有介绍,那就是Bochs的配置文件.为什么要有配置文件呢? 你需要告诉Bochs,你希望你的虚拟机是什么样子的.比如,内存多大啊、硬盘映像和软盘映像都是哪些文件啊等内容.不用怕,这配置文件也没什么难的,下面的代码就是一个Linux下的典型例子.

  


可以看到,这个配置文件本来就不长,除去注释之后内容就更少了, 很 容易理解,字面上稍微不容易理解的只有romimage和vgaromimage[3],它们指定的文件对应的其实就是真实机器的BIOS和VGA BIOS,读者自己操作的时候要确保它们的路径是正确的,不然过一会儿虚拟机启动时可能会被提示“couldn't open ROM image file”.读者还要注意floppya一项,它指定我们使用哪个文件作为软盘映像.

如果你在Windows下的话,romimage和vgaromimage两项指定的文件应该是安装目录下的BIOS-bochs-latest和 VGABIOS-lgpl-latest.当然,最保险的方法是参考安装程序自带的DLX linux的配置文件,将其稍作修改即可.

  好了,现在一切准备就绪,是时候启动了,输入命令:

  $ bochs -f bochsrc

  一个回车[4],你想要的画面就呈现在眼前了.是不是很有趣呢?

  顺便告诉你个窍门,如果你输入一个不带任何参数的Bochs并执行之,那么Bochs将在当前目录顺序寻找以下文件作为默认配置文件:

  · .bochsrc

  · bochsrc

  · bochsrc.txt

  · bochsrc.bxrc (仅对Windows有效)

   刚才我们的“-f bochsrc”参数其实是可以省略的.读者在给配置文件命名时不妨从这些文件里选一个,这样可以省去许多输入命令的时间.

  此外,Bochs的配置文件还有许多其他选项,读者如果想详细了解的话,可以到其主页上看一看. 本书中所用到的选项有限,在此不一一介绍.

  4.用Bochs调试操作系统

  如果单是需要一个虚拟机的话,你有许许多多的选择,本书下文也会对其他虚拟机有所介绍,之 Bochs称为我们的首选,最重要的还在于它的调试功能.

  假设你正在运行一个有调试功能的Bochs,那么启动后,你会看到控制台出现若干选项,默认选项为“6. Begin simulation”, 直接按回车键,Bochs就启动了,不过既然是可调试的,Bochs并没有急于让虚拟机进入运转状态,而是继续出现一个提示符,等待你的输入,这时,你就可以尽情操纵你的虚拟机了.

 还是以我们那个最轻巧的引导扇区为例,假如你想让它一步步地执行,可以先在07c00h处设一个断点──引导扇区就是从这里开始执行的, 这里就是我们的入口地址──然后单步执行,就好像所有其他调试工具一样.在任何时刻,你都可以查看CPU寄存器,或者查看某个内存地址处的内容.下面我就来模拟一下这个过程:用Bochs调试操作系统.pdf

  以上带有?符号并以加粗字体显示的是输入,其他均为Bochs的输出.如果你用过GDB,你会觉得这个过程很亲切.没错,它跟用GDB调试程序的感觉是很相似的,最大的区别可能就在于在Bochs的调试模式下我们需要跟CPU、内存、机器指令等内容打更多交道.

  在上面的演示过程中,最开始的“b 0x7c00”在0x7c00处设置了断点,随后的命令“c”让代码继续执行,一直到我们设置的断点处停止,然后演示的是用“dump_cpu”指令查看 CPU寄存器以及用“x”指令查看内存.随后用一个“n”指令让代码向下走了一步,“trace-reg on”的功能是让Bochs每走一步都显示主要寄存器的值.之 选择演示这些命令, 它们基本是调试过程中最常用到的.


如果你在调试过程中忘记了指令的用法,或者根本就忘记了该使用什么指令,可以随时使用help命令,所有命令的列表就呈现在眼前了.你将会发现Bochs的调试命令并不多,不需要多久就可以悉数掌握.Table 1列出了常用的指令以及其典型用法.


其中“xp /40bx 0x9013e”这样的格式可能显得有点复杂,读者可以用“help x”这一指令在Bochs中亲自看一下它代表的意义.

  好了,虽然你可能还无法熟练运用Bochs进行调试,但至少你应该知道,即便你的操作系统出现了问题也并不可怕,有强大的工具可以帮助你进行调试. Bochs是开放源代码的,如果你愿意,你甚至可以通过读Bochs的源代码来间接了解计算机的运行过程── Bochs就是一台计算机.

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1.1 计算机启动过程 计算机启动过程一般是指计算机从点亮到加载操作系统一个过程。对于IBM 兼容机(个人电 脑)来讲,这个过程大致是这样的: 1. 加电电源开关被按下时,机器就开始供电,主板的控制芯片组会向CPU(Central Processing Unit,中央处理器)发出并保持一个RESET(重置)信号,让CPU恢复到初始状态。当芯片组 检测到电源已经开始稳定供电时就会撤去RESET信号(松开台式机的重启键是一样的效果), 这时CPU就从0xffff0处开始执行指令。这个地址在系统BIOS(Basic Input/Output System, 基本输入输出系统)的地址范围内,大部分系统BIOS厂商放在这里的都只是一条跳转指令,跳 到系统BIOS真正的启动代码处。 2. 自检系统BIOS的启动代码首先要做的事情就是进行POST(Power-On Self Test,加电后自 检),POST的主要任务是检测系统中一些关键设备是否存在和能否正常工作,例如内存和显卡 等。由于POST是最早进行的检测过程,此时显卡还没有初始化,如果系统BIOS在POST的 过程中发现了一些致命错误,例如没有找到内存或者内存有问题(此时只会检查640K常规内 存),那么系统BIOS就会直接控制喇叭发声来报告错误,声音的长短和次数代表了错误的类 型。 3. 初始化设备接下来系统BIOS将查找显卡的BIOS,存放显卡BIOS的ROM芯片的起始地址通 常设在0xC0000处,系统BIOS在这个地方找到显卡BIOS之后就调用它的初始化代码,由显卡

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值