《自己动手写操作系统》第一章 boot.asm源码剖析

       1.代码:

 org     07c00h                  ; 告诉编译器程序加载到7c00处

        mov     ax, cs

        mov     ds, ax

        mov     es, ax

        call    DispStr                 ; 调用显示字符串例程

        jmp     $                       ; 无限循环

DispStr:

        mov     ax, BootMessage

        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

        int     10h                     ; 10h 号中断

        ret

BootMessage:            db      "Hello, OS world!"

times   510-($-$$)      db      0       ; 填充剩下的空间,使生成的二进制代码恰好

为512字节



dw      0xaa55                          ; 结束标志


2.疑问解答:

1)org:告诉操作系统,将这一段代码加载到地址0x7c00,为什么?因为机器启动,先执行bios程序,bios程序执行完毕,会将控制权转移到操作系统引导程序入口处,这个入口地址就是0x7c00.具体可以参考linux启动前传

2)mov     ax, cs:这一句是将cs的值赋给ax,但是cs的值是多少呢?是0xffff,这个cpu厂商约定的结果,原因可以参考:linux启动前传

3)int 10h: 10H号中断, BIOS 对屏幕及显示器所提供的服务程序。具体可以参考这里。



参考文献:

【1】全面剖析《自己动手写操作系统》第一章:http://blog.csdn.net/zgh1988/article/details/7060032





你可能感兴趣的:(操作系统)