标签:寄存器 十六 不清楚 开发 处理 启动 address 真机 offset
先吓唬一下读者朋友呵呵,直接发代码:(这是UOS操作系统的Bootsect)(有兴趣的朋友能够增加我们,联系方式在最后)
;------------------------------ ;文件名称:Bootsect.asm ;文件创建者:@Imcjy ;文件參与编辑者:@Imcjy ;文件编码:UTF-8 ;状态:O ;Build:3 ;文件创建日期:2015年7月24日 ;文件最后改动日期:2015年8月12日 ;备注:本文件为Nasm ;凝视等级:LV2 ;------------------------------ ORG 0x7c00 ;装载此程序至0x7c00处。由于BIOS默认会从内存0x7c00处開始运行 JMP OS_Entry ;參照《Orange's一个操作系统的实现》,感谢其作者于渊 ;參照<a target=_blank href="http://wenku.baidu.com/view/1ee907d528ea81c758f5786b.html">http://wenku.baidu.com/view/1ee907d528ea81c758f5786b.html</a> ,感谢其作者 %macro DiskAddressPacket 3 DB 16 ;数据包尺寸(默认16字节) DB 0 ;保留 DB %2 ;要传输的数据块个数(以扇区为单位),最大读128扇区 DB 0 ;保留 DD %3 ;传输缓冲地址(segment:offset) DQ %1 ;磁盘起始绝对块地址。注意此处的地址是从零開始 %endmacro OS_Kernel_S1: DiskAddressPacket 3, 128, 0x10000000 OS_Kernel_S2: DiskAddressPacket 131, 128, 0x20000000 OS_Kernel_S3: DiskAddressPacket 259, 128, 0x30000000 [bits 16] OS_Entry: ;初始化寄存器 MOV AX,CS MOV DS,AX MOV ES,AX MOV SS,AX Read_Kernel: ;读内核 KS1: ;状态1 MOV AX,OS_Kernel_S1 MOV SI,AX MOV DL,0x80 ;一号硬盘 MOV AH,0x42 ;读盘操作 INT 0x13 JC KS1 ;失败则重试 KS2: ;状态2 MOV AX,OS_Kernel_S2 MOV SI,AX MOV AH,0x42 ;读盘操作 MOV DL,0x80 ;一号硬盘 INT 0x13 JC KS2 ;失败则重试 KS3: ;状态3 MOV AX,OS_Kernel_S3 MOV SI,AX MOV DL,0x80 ;一号硬盘 MOV AH,0x42 ;读盘操作 INT 0x13 JC KS3 ;失败则重试 JMP 0x8000:0 ;跳转到段0x8000处并更新CS TIMES 510 - ($ - $$) DB 0 ;填充剩下的空间。使生成的二进制代码恰好为512字节 DB 0x55,0xAA ;BIOS认可的结束标志
这里读盘操作用的是扩展0x13号BIOS中断,假设看不懂,能够点开asm代码里的百度链接。假设打开不了能够联系我哦。
如今開始解释一下第一句,“ORG 0x7c00”,这里为什么要装载到0x7c00处呢。如今也解释不清楚。这是IBM的大叔设置的,假设有质疑能够去问问他们哦。
第二句:“JMP OS_Entry” 这里为什么要跳转呢?那我再问你一句,这一句后面的那些代码难道要运行吗?(那可不能运行)所以要跳转到Bootsect真正的入口点。
第三句:宏定义,为了降低挨个挨个设置參数的麻烦,參数能够參照intel手冊来写。
第四句:依赖宏定义定义參数,这里不用解释了把,相信学过Nasm的朋友都能看懂。
第五句:“[bits 16]”,为了使Nasm生成出来的是16位代码。(话说为什么一定要生成16位代码呢?由于BIOS仅仅认16位的中断处理),话说Nasm好笨哦。(嘻嘻)
第六句:“OS_Entry:”标签,相应第二句。
第七句——第十句:初始化寄存器。有兴趣的读者能够去掉这句看看。
第十一句——第十五句:将各个參数放到相应的寄存器里。否则虚拟器(或者真机)会出问题(或许就是重新启动吧)。
第十六句:调用0x13号BIOS中断。
后面的以此类推。
到了“JMP 0x8000:0”这一句,看一下凝视把,这里是一个长跳转。跳转到0x8000内存地址处。
最后两句:为了使BIOS认可我们的Bootsect,我们须要这段代码的大小控制到512字节以内,且最后两个字节为0x55 0xAA。
注意事项:
1:我们须要将这段代码放到硬盘的第一个扇区,(话说这也是IBM那群大叔设置的)。
2:我们须要将硬盘的第二个扇区至第三个扇区放置兴许的操作代码(比方打开A20啊,进入保护模式啊)。
3:版权归UOS项目组全部。
假设还有问题能够联系我:Email:2608184397@qq.com
假设读者朋友也有开发操作系统的想法,能够联系我。
标签:寄存器 十六 不清楚 开发 处理 启动 address 真机 offset
原文地址:http://www.cnblogs.com/brucemengbm/p/7298450.html