一、前言
最近参加三个一学习活动,学到了十七章,由于之前的实验都是在Windows系统下进行的,非常顺利,但这次实验让我吃了鳖,花了两天时间才找到一个不是特别令人满意的解决方案。所以打算记录在本博客,涨涨教训。
首先,阐述一下实验背景和环境,学习汇编语言的环境大多都是Windows或Liunx系统下,使用Dosbox0.74以及汇编语言三件套(masm,link,debug)环境,的确,一般程序只需要这种环境就可以编写大多数程序了,但基于保护模式的操作系统的运行机制和DOS的实模式却有着很大的区别,比如中断向量表的加载.
我们先整理一下书上关于操作系统启动时的内容(16位系统):
开机后,CPU自动进入到FFFF:0单元处执行,此处有一条跳转指令,CPU执行该指令后,转去执行BIOS中的硬件系统检测和初始化程序。
初始化程序将建立BIOS所支持的中断向量,即将BIOS提供的中断例程的入口地址登记在中断向量表中。
硬件系统检测和初始化完成后,调用 int 19h 进行操作系统的引导。
如果设为从软盘启动操作系统,则int 19h将主要完成以下工作。
(1)控制0号软驱,读取软盘0道0面1扇区的内容到0:7c00;
(2)将CS:IP指向0:7c00.
软盘的0道0面1扇区中装有操作系统引导程序。int 19h将其装到 0:7c00处后,设置CPU从0:7c00开始执行此处的引导程序,操作系统被激活,控制计算机。
如果0号软驱中没有软盘,或发生软盘I/O错误,则int 19h将主要完成以下工作。
(1) 读取硬盘C的0道0面1扇区的内容到0:7c00;