任务和特权级保护(五)——《x86汇编语言:从实模式到保护模式》读书笔记36
任務(wù)和特權(quán)級(jí)保護(hù)(五)——《x86匯編語(yǔ)言:從實(shí)模式到保護(hù)模式》讀書筆記36
修改后的代碼,有需要的朋友可以去下載(c14_new文件夾)。下載地址是:
GitHub: https://github.com/LeslieChe/from-real-mode-to-protected-mode
第14章的習(xí)題2及解答
修改代碼清單14-1和13-3,使得通過(guò)調(diào)用門請(qǐng)求讀取硬盤扇區(qū)的服務(wù)時(shí),通過(guò)棧傳遞參數(shù)。而且,傳遞的參數(shù)分別是邏輯扇區(qū)號(hào)、數(shù)據(jù)段選擇子和段內(nèi)偏移。要求使用ARPL指令。
注意,題目中的“數(shù)據(jù)段選擇子”,不一定非得是DS,其他的指向數(shù)據(jù)段的段寄存也是可以的。
關(guān)于ARPL指令,可以參考我的博文
RPL的故事 ——《x86匯編語(yǔ)言:從實(shí)模式到保護(hù)模式》讀書筆記31
下面僅解釋這道題最關(guān)鍵的部分:對(duì)棧中參數(shù)的提取和ARPL指令的使用。
read_hard_disk_0: ;從硬盤讀取一個(gè)邏輯扇區(qū);---------------;| 邏輯扇區(qū)號(hào) |@1;---------------;|數(shù)據(jù)段選擇子 |@2;---------------;| 段內(nèi)偏移 |@3;---------------;| | CS |;---------------;| EIP |;---------------;| 8個(gè)寄存器 |;---------------;| | DS |;-------------- <-----EBP;| |pushad push dsmov ebp,esp因?yàn)槭怯脳鬟f參數(shù),在執(zhí)行完上面三行后,棧的示意圖如上圖所示。
mov ax,[ebp+10*4] ;提取調(diào)用者的CSmov bx,[ebp+12*4] ;提取 @2數(shù)據(jù)段選擇子arpl bx,ax ;調(diào)整段選擇子的 RPLmov ds,bxmov eax,[ebp+13*4];提取 @1邏輯扇區(qū)號(hào)mov ebx,[ebp+11*4];提取 @3段內(nèi)偏移push eax ;因?yàn)楹竺娴亩丝诓僮饕玫?AL,所以先壓棧保存扇區(qū)號(hào)接下來(lái)的代碼和配書源碼基本相同,除了最后3行。
loop .readwpop dspopad retf 3*4 ;段間返回用棧傳遞參數(shù)
除了上面的修改,我還把所有例程都改成了用棧來(lái)傳遞參數(shù)(如果需要傳參的話)。
首先,要修改例程本身,這個(gè)與上面的習(xí)題類似,這里不再贅述。
其次,要修改調(diào)用門描述符中的參數(shù)個(gè)數(shù)字段。
為此,我修改了內(nèi)核的符號(hào)表,在每個(gè)表項(xiàng)后面增加了參數(shù)個(gè)數(shù)字段(如下圖)。如果不需要傳遞參數(shù),那么這個(gè)字段應(yīng)該填寫0.這樣做是為了在安裝調(diào)用門的時(shí)候,可以方便地獲得參數(shù)個(gè)數(shù)。
光在符號(hào)表中添加參數(shù)個(gè)數(shù)字段是不行的,我們還要修改安裝調(diào)用門的代碼,只需要增加下圖中紅色的那行。
為put_string增加顏色支持
我對(duì)五彩繽紛的字符情有獨(dú)鐘,所以為put_string例程增加了顏色支持。
最后運(yùn)行結(jié)果如下圖所示:
用%include包含文件
類似在C語(yǔ)言源文件中用#include "XXX.h"包含其他文件, 在.asm源文件中也可以使用
%include "xxxxx"例如在一個(gè)源文件中寫了一句:
%include "macros.mac"這會(huì)把文件macros.mac中的內(nèi)容包含到現(xiàn)在的源文件中。用nasm編譯文件的時(shí)候,會(huì)在當(dāng)前目錄下尋找被包含的文件,也可以在nasm命令行使用-i選項(xiàng)來(lái)增加搜索路徑。
因?yàn)樵黾恿祟伾С?#xff0c;為了方便,我把一些字符屬性的值專門放在了“color.inc”文件中。
; define some colorsGREEN EQU 0X02 BLUE EQU 0X09 RED EQU 0X04 YELLOW EQU 0X0E那么引用這些符號(hào)常量(如GREEN)的時(shí)候,就需要用%include把這個(gè)文件包含進(jìn)來(lái)。
第14章的學(xué)習(xí)筆記就到這里,下次我們開始第15章的學(xué)習(xí)。敬請(qǐng)關(guān)注…
總結(jié)
以上是生活随笔為你收集整理的任务和特权级保护(五)——《x86汇编语言:从实模式到保护模式》读书笔记36的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 设计一个4*4魔方程序,让魔方的各行值的
- 下一篇: python 异常分类_Python异常