从零开始写一个操作系统 —— 4.qemu

1.qemu的作用

qemu属于虚拟机模拟器。操作系统属于软件,软件需要依托于硬件(正如你所见到的实体电脑)运行。qemu使用软件模拟出一种硬件环境,让我们编写的操作系统认为它被运行到了硬件中。

2.qemu的安装

这里我们使用的是Linux环境,使用apt工具安装:

bash 复制代码
sudo apt install qemu-system-x86

安装完成后,我们即可在/usr/bin目录下发现

bash 复制代码
user@pc:/usr/bin$ ls|grep qemu
...
qemu-system-i386
qemu-system-x86_64
...

其中qemu-system-i386就是我们需要用到的intel i386架构虚拟机程序。

3.qemu的使用

正如我们使用普通的Linux命令行工具一样,qemu的使用也是在命令行中输入该命令加上参数并运行,最简单的使用方法为:

bash 复制代码
qemu-system-i386 -drive file=system,format=raw -nographic

其中-drive file=system,format=raw参数的意义为选择当前目录下的system文件作为操作系统来驱动我们的i386虚拟机,并且format=raw视该文件为原始的操作系统文件。-nographic不使用可视化窗口,将输出引导至终端。

3.1一个有意思的最小交互操作系统

以下为一个小操作系统system.s的示例代码:

asm 复制代码
org 0x7c00
    
    mov dx, 0x3f8
scant:
    in  al, dx
    out dx, al
    
    jmp scant
    
times 510 - ($ - $$) db 0
dw 0xaa55

使用nasm工具编译之:

bash 复制代码
nasm system.s -o system

我们就可以得到一个可交互的非常小的操作系统system。 使用前面提到的命令:

bash 复制代码
qemu-system-i386 -drive file=system,format=raw -nographic

运行后即可观察到:

bash 复制代码
SeaBIOS (version 1.13.0-1ubuntu1.1)


iPXE (http://ipxe.org) 00:03.0 CA00 PCI2.10 PnP PMM+07F8CA10+07ECCA10 CA00



Booting from Hard Disk...

按下键盘,开始与"操作系统"交互吧!

相关推荐
fakerth1 天前
【OpenHarmony文件管理子系统】文件访问接口解析
操作系统·openharmony
Layflok1 天前
第三章 内存管理
笔记·操作系统·内存管理·王道笔记
fakerth3 天前
【OpenHarmony文件管理子系统】文件访问接口mod_fileio解析
操作系统·openharmony
fakerth3 天前
【OpenHarmony文件管理子系统】文件访问接口mod_file解析
操作系统·openharmony
IT成长日记4 天前
【Linux基础】Linux系统管理:深入理解Linux运行级别及其应用
linux·运维·服务器·操作系统·运行级别
Ziyoung4 天前
国产操作系统调研报告:产业现状与未来方向
操作系统
OpenAnolis小助手4 天前
睿思芯科正式加入龙蜥社区,携手共建 RISC-V 服务器生态新标杆
操作系统·龙蜥社区·risc-v·龙蜥生态
CYRUS_STUDIO4 天前
深入内核交互:用 strace 看清 Android 每一个系统调用
android·操作系统·逆向
码达拉4 天前
Linux开发必备:yum/vim/gcc/make全攻略
linux·面试·编辑器·操作系统·vim
CYRUS_STUDIO5 天前
FART 自动化脱壳框架优化实战:Bug 修复与代码改进记录
android·操作系统·逆向