《自己动手写操作系统》第一章 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





  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值