从零开始写一个操作系统 —— 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...

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

相关推荐
饼干哥哥18 小时前
ChatGPT会员掉了,代充黑幕藏不住了
人工智能·操作系统·产品
小宇子2B19 小时前
五、内核里的 GS / swapgs,与现代 TSS
操作系统
小宇子2B2 天前
四、x86-64 的简化:段机制基本退场,FS/GS 为什么留下
操作系统
小宇子2B2 天前
二、保护模式的段:选择子、GDT,与那张 64 位的段描述符
操作系统
小宇子2B5 天前
三、内核入口 el0_svc / entry_SYSCALL_64 的汇编做了什么——从异常向量到 C 函数
操作系统
小宇子2B5 天前
四、从 write(1, "hello", 5) 到 ksys_write() —— sys_call_table 怎么路由的
操作系统
小宇子2B5 天前
一、printf("hello") 怎么变成 write(1, "hello", 5) —— libc 的 stdout 缓冲机制
操作系统
小宇子2B11 天前
一个 pthread_mutex_lock() 到底锁了什么——从用户态 CAS 到内核调度
操作系统
小宇子2B12 天前
多线程 malloc 为什么会变慢——glibc 的 arena 到 bins 全景
操作系统
fakerth16 天前
【OpenHarmony】communication_ipc模块
操作系统·openharmony