开始读 《自己动手写操作系统》,开始读第一段程序时,就感到很痛苦,虽然作者已经简化,也做了说明,但我还是有很多一知半解,于是下决心以后看程序要搞懂没一句,万事开头难,希望我能坚持,下面附上我对我今天看的一段代码的详细解释,一来自己以后可以回过头再来看看,也想也许和我也有同样的困惑的人,希望我的解释对有困惑一起学习的人有些帮助。一起在这条路上坚持走下去,虽有乏味,但也有无穷的乐趣。勉励在这条战线上的同志们。
org 07c00h ; 告诉编译器程序加载到7c00处
mov ax, cs ; 段寄存和段寄存器不能直接赋值,用AX作中介
mov ds, ax ;ds是数据段,
mov es, ax ;es是附加段,使es,ds指向与cs相同的段,以便在以后进行数据操作的时候能定位到正确的位置
call DispStr ; 调用显示字符串例程
jmp $ ; 无限循环
DispStr:
mov ax, BootMessage ;附加段的偏移地址,其实现在这个整个都在代码段,前面已经说明cs,es,ds段基址是相同的
mov bp, ax ; ES:BP = 串地址
mov cx, 16 ; 规定CX = 串长度
mov ax, 01301h ; AH = 13, AL = 01h
mov bx, 000ch ; 页号为0(BH = 0) 黑底红字(BL = 0Ch,高亮) 属性
mov dl, 0 ;dh,dl 分别表示显示的坐标的行列
int 10h ; 10h 号中断,前面相当于做准备,发生中断,传出数据,我们所要的显示
ret ;中断结束
BootMessage: db "Hello, OS world!!" 伪操作符,定义数据
;0这个字节重复510-($-$$)遍,在剩余的空间中不断地填充0
times 510-($-$$) db 0 ; 填充剩下的空间,使生成的二进制代码恰好为512字节 $表示当前行被被汇编的地址
dw 0xaa55 ; 结束标志 $$表示一个节(se