今天又回过头去把第一个显示“Hello,OS world”的程序看了一遍,所谓温故而知新嘛,虽然简单但是也很重要。
参考资料:《一个操作系统的实现》,《Linux内核设计的艺术》(新设计团队著,也推荐一下这本书,写的是关于linux内核讲解的书,写的很好,被翻译成了繁体和英语)
好的,关于下面的代码进行一下解释,虽然比较简,但是写下来,以后想不起来也可以翻出来看。
1.电脑的启动:
电脑加电以后通过硬件逻的办法使得CS:IP=0xF000:0xFFF0,这样CS:IP就指向了内存0xFFFF0,而BIOS程序的入口地址就在0xFFFF0处,这样BIOS程序就被执行了。BIOS程序在内存最开始的位置(0x00000)用1K的内存空间构建了中断向量表,在紧挨着的位置用256字节的内存空间构建了BIOS数据区,并在大约57k以后的位置加载了中断服务程序。
2.,由于我们是软盘启,在BIOS执行完之后,会让cpu接收到一个int0x19中断。cpu收到这个中断后,回去执行这个中断服务,这个终端服务就是启动加载服务程序,将软驱0号磁头对应盘面的0磁道1扇区的内容复制到内存0x07c00处,这也是为什么有org 07c00h这句话了。
3.在这段代码中,由于cs=ds所以指令和数据在一个段里,寻址是按照段:偏移量,所以在内存中的存储应该是这样的:
指令 ... |
数据 |
|
代码:
org 07c00h
mov ax,cs
mov ds,ax
mov es,ax
call ClearView
call DispStr
jmp $
ClearView:
mov ax,0600h
mov bx,0700h
mov cx,0
mov dx,0184fh
int 10h
ret
DispStr:
mov ax,Message
mov bp,ax
mov cx,15
mov ax,01301h
mov bx,000ch
mov dx,0
int 10h
ret
Message: db "Hello,OS World!"
times 510 - ($ - $$) db 0
dw 0xaa55
下面贴出机器码,在linux下查看机器码的方法是:
1.使用vim -b xxx.bin(后缀可无)
2.会看到乱码,然后在命令模式下输入%!xxd即可
其中b801 13这其实就是mov ax,01301h对应的机器码
0000000: 8cc8 8ed8 8ec0 e806 00e8 1200 e9fd ffb8 ................
0000010: 0006 bb00 07b9 0000 ba4f 18cd 10c3 b832 .........O.....2
0000020: 7c89 c5b9 0f00 b801 13bb 0c00 ba00 00cd |...............
0000030: 10c3 4865 6c6c 6f2c 4f53 2057 6f72 6c64 ..Hello,OS World
0000040: 2100 0000 0000 0000 0000 0000 0000 0000 !...............
0000050: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0000060: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0000070: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0000080: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0000090: 0000 0000 0000 0000 0000 0000 0000 0000 ................
00000a0: 0000 0000 0000 0000 0000 0000 0000 0000 ................
00000b0: 0000 0000 0000 0000 0000 0000 0000 0000 ................
00000c0: 0000 0000 0000 0000 0000 0000 0000 0000 ................
00000d0: 0000 0000 0000 0000 0000 0000 0000 0000 ................
00000e0: 0000 0000 0000 0000 0000 0000 0000 0000 ................
00000f0: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0000100: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0000110: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0000120: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0000130: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0000140: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0000150: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0000160: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0000170: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0000180: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0000190: 0000 0000 0000 0000 0000 0000 0000 0000 ................
00001a0: 0000 0000 0000 0000 0000 0000 0000 0000 ................
00001b0: 0000 0000 0000 0000 0000 0000 0000 0000 ................
00001c0: 0000 0000 0000 0000 0000 0000 0000 0000 ................
00001d0: 0000 0000 0000 0000 0000 0000 0000 0000 ................
00001e0: 0000 0000 0000 0000 0000 0000 0000 0000 ................
00001f0: 0000 0000 0000 0000 0000 0000 0000 55aa ............