由于我使用的是 Ubuntu 20.04.4 LTS 系统,所以,本系列开发环境及代码均在 Ubuntu 20.04.4 LTS 上进行,其他系统请自行查询解决,但核心原理应该都一样的。

安装 Bochs & Nasm

Bochs 是一个通用的硬件模拟器,系统内核的调试运行均在这个模拟器上进行

sudo apt-get install build-essential xorg-dev bison g++ bochs-x -y

sudo apt-get install nasm

要是以上安装过程中有问题,可以直接去官网下载源码包编译安装。在安装过程中可能会遇到一些第三方依赖的库不全的问题,在这里不细说了,网上也有一些教程可以参考。

制作虚拟磁盘

Bochs 自带了一个命令行工具 bximage,可用来制作磁盘文件。

bximage -mode=create -hd=10M -q tinyOS.img

也可通过图形界面方式进行创建

运行 Bochs

bochs需要配置文件描述硬件信息,配置文件的命名是任意的,bochs默认的配置文件名为bochsrc.txt,如下:

# 虚拟机内存大小,单位为 MB
megs: 32

# # 对应真实机器的BIOS和VGA BIOS
romimage: file=$BXSHARE/BIOS-bochs-latest
vgaromimage: file=$BXSHARE/VGABIOS-lgpl-latest

boot: disk 
log: bochsout.log

mouse: enabled=0
#keyboard: keymap=/usr/local/share/bochs/keymaps/sdl-pc-us.map

ata0: enabled=1, ioaddr1=0x1f0, ioaddr2=0x3f0, irq=14
ata0-master: type=disk, path="tinyOS.img", mode=flat

clock: sync=realtime
cpu: ips=1000000

#gdbstub: enabled=1, port=1234, text_base=0, data_base=0, bss_base=0

运行bochs:

bochs -f bochsrc.txt

编写Makefile

对于 Makefile的编写,就请参考左耳朵耗子写的 《跟我一起写Makefile》

对于上述零散的操作,集中到如下Makefile中:

SRC_DIR=src
BIN_DIR=bin
USER_DIR=user

all: image

prepare: ${SRC_DIR}/*
	mkdir -p $(BIN_DIR)

image: prepare mbr
	rm -rf tinyOS.img && bximage -mode=create -hd=10M -q tinyOS.img
	dd if=$(BIN_DIR)/mbr of=tinyOS.img bs=512 count=1 conv=notrunc

mbr: $(SRC_DIR)/boot/mbr.asm
	nasm -o $(BIN_DIR)/mbr $<

clean:
	rm -rf ${BIN_DIR} tinyOS.img bochsout.log 


可通过以下 shell 脚本方便运行:

make && bochs -f bochsrc.txt

编写MBR

;----BIOS把启动区加载到内存的该位置,所以需设置地址偏移量
section mbr vstart=0x7c00

;----卷屏中断,目的是清屏
mov ax,0x0600
mov bx,0x0700
mov cx,0
mov dx,0x184f
int 0x10	; 此处调用了 BIOS 的中断把 bochs模拟器 输出信息清空

;----直接往显存中写数据,后续可以调用中断抽离出方法来专门输出
mov ax,0xb800
mov gs,ax
mov byte [gs:0x00],'M'
mov byte [gs:0x02],'B'
mov byte [gs:0x04],'R'

;----512字节的最后两字节是启动区标识
times 510-($-$$) db 0
db 0x55,0xaa

在 Makefile所在目录下,执行:

make && bochs -f bochsrc.txt

运行如下:

原文地址:http://www.cnblogs.com/jfunny/p/16834295.html

1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长! 2. 分享目的仅供大家学习和交流,请务用于商业用途! 3. 如果你也有好源码或者教程,可以到用户中心发布,分享有积分奖励和额外收入! 4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解! 5. 如有链接无法下载、失效或广告,请联系管理员处理! 6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需! 7. 如遇到加密压缩包,默认解压密码为"gltf",如遇到无法解压的请联系管理员! 8. 因为资源和程序源码均为可复制品,所以不支持任何理由的退款兑现,请斟酌后支付下载 声明:如果标题没有注明"已测试"或者"测试可用"等字样的资源源码均未经过站长测试.特别注意没有标注的源码不保证任何可用性