自己动手写操作系统 1

代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
	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 ; 结束标志

上面是书中给的代码,注释写的也是很详细了。然后,这玩意叫汇编,稍微懂一点应该能大致看得懂。等我复习汇编的时候再分享一波学习笔记也可。

编译

用NASM编译

  • 打开cmd,考虑文件的整齐划一,可以在工作目录打开。
    好神奇,在生成.bin文件的时候突然报毒了。

    关闭杀毒再来一次,可以了。

写入软盘

这要用到Floppy这个工具,双击打开,选择Write File to Image

文字写的很清楚,将文件写入image文件中,所以提前应该创建一个img文件。

选择.bin文件

选择要写入的img文件

然后写入即可。写入成功,又报毒了,所以我觉得把WindowsDefender给关了……

运行

使用VirtualBox,运行成功。