一个操作系统的实现_最小的"操作系统" (1)

环境: WSL(window下linux子系统) Ubuntu18 使用Bochs来模拟系统

于渊老师的第一个程序差点就把我困住了 T_T
在这里做笔记, 文中加了❓的地方表示还没懂, 先不深究, "囫囵吞枣"一下, 看到后面再回来解决

代码

show me the code!
先写个汇编

; file_name: boot.asm
	org	07c00h ; 告诉编译器程序加载到7c00处, 规定程序的起始地址(偏移地址)在7c00, 
	mov	ax, cs
	mov	ds, ax ; 
	mov	es, ax ; 代码段数据段附加段在同一个段 ?可以去掉吗
	call DispStr ; 调用显示字符串
	jmp	$ ; 无限循环
; 以上就是主体部分了
DispStr:
	mov	ax, message
	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
	
message		db	"Hello, Js world!" ; 字符串+回车换行
times 	510-($-$$)	db	0	; 填充剩下的空间,使得到这里二进制代码有510字节
	dw 	0xaa55				; 结束标志, 最后两个字节是 aa55 才是符合要求的引导程序, 代码共计512字节
  • $: 汇编后 当前行的地址
  • $$: 汇编后 一个节(section)开始处的地址
  • $-$$: 本行距离本节开始处的相对距离(这段代码只有一节, 所以就是程序的开头)

操作步骤

制作镜像文件

  1. 准备好 boot.asm 后, 编译成 boot.bin
    $ nasm  boot.asm -o boot.bin
    
  2. 制作512字节的镜像文件 boot.img
    $ dd if=boot.bin of=boot.img bs=512 count=1 conv=notrunc
    

写Bochs的配置文件

使用自己的bochs配置文件, 不用默认的

# file_name: bochsrc
##############################################################
# Configuration file for Bochs
###############################################################
# how much memory the emulated machine will have
megs: 32

# filename of ROM images
romimage: file=/usr/share/bochs/BIOS-bochs-latest
vgaromimage: file=/usr/share/vgabios/vgabios.bin

# what disk images will be used
floppya: 1_44=boot.img, status=inserted

# choose the boot disk.
boot: floppy

# where do we send log messages?
log: bochsout.txt

# disable the mouse
mouse: enabled=0

# enable key mapping, using US layout as default.
keyboard_mapping: enabled=1, map=/usr/share/bochs/keymaps/x11-pc-us.map
  • 注意 romimage vgaromimage 路径要根据自身情况做修改, 否则可能会报错couldn't open ROM image file
  • floppya之后的文件名也要按自己的情况修改

启动

  1. 在window中启动 VcXsrv (XLanuch) 安装看这里 link
  2. 在命令行中运行
    $ bochs -f bochsrc
    
  3. 顺利的话可以看到
    黑色屏幕
  4. 输入 b 0x7c00 (在0x7c00处设置断点)
  5. 输入 c (让代码执行), 再输入c
    在这里插入图片描述
    最后看到
    在这里插入图片描述
    成功了!
计算机做的事情
  1. 计算机检查软盘的0面0磁道1扇区, 如果发现它以0xaa55结束(一个特殊的标记), 则BIOS把它当成引导扇区
  2. 512字节的内容被转载到内存 0000:7c00 处 ?为什么是7c00
  3. 跳转到 0000:7c00 处, 将控制权交给这段引导代码, CPU开始执行代码逻辑
可能出现的错误情况
  • Message: dlopen failed for module ‘x’: file not found没有图形界面的模块, 看这里 link

好命令和附录

  • 反汇编
    $ ndisasm -o 0x7c00 boot.bin >> disboot.asm
    
  • bochs 调试指令
    在这里插入图片描述

reference

  • https://blog.csdn.net/hdxxjhuahuo/article/details/78234996
  • <<oranges: 一个操作系统的实现>>
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对x86架构的处理器,业界一向是褒贬不一。但是毫无疑问的是,x86架构的处理器是迄今为止在市场上最成功的处理器。它既催生了Intel、微软这样的业界巨头,也改变了普通人们的生活。到今天,虽然有arm的异军突起,但是大部分程序员所编写的程序依然在运行在x86架构上。 虽然很多上层的程序员绕过了对CPU架构本身的理解,而直接使用高级语言进行编程,但是对CPU本身的熟悉,其实依然是所有想被称为优秀的程序员所难以绕过的一道坎。对CPU的不熟悉,实际上限制了程序员的思维方式、对程序的理解和实际解决问题的能力。 对于普通的芯片,阅读几页的说明书就可以大致理解如何让它工作。CPU是比较复杂的一种,对于比较简单的CPU架构,阅读几十页的文档也能大致熟悉。然而 x86架构的CPU的说明可不是这么简单,其手册估计有一共有四、五千页之巨。不要说理解透彻,就是从头到尾翻一遍也不是一件简单的事情。并非Intel 有意将它做得复杂,这里有历史的原因。因为这个架构的应用实在太广了,全世界有无数的软件都在它的基础之上工作。为此它自身的升级也就变得举步维艰。每次升级都不得不要兼容之前的特性。这也就导致了新旧指令层层堆积,种种特性互相兼顾,最终变成如今的一团乱麻了。 对于入门级的选手,读完那些手册可不是一件容易的事情。但是于渊的这本《orange's:一个操作系统实现》却是一条难得的终南捷径。因为要理解如何让一个芯片正常工作,最简单的办法就是从头开始去写程序让它运行起来,然后操作它做自己想做的事情。如果是平时的编程,这些下层的工作都已经有操作系统帮你做了,对理解x86架构的帮助就大为有限。如果去读那几千页的文档,不但读起来很痛苦,中间又没有多少可以实际操作的工作来帮助你温故而知新,这其中的枯燥乏味,绝对不是一般人可以忍受的了。而且更重要的手册中虽然包含了x86所有的特性,然而其中有些特性是现代操作系统根本就没有用到的。努力的去理解的话,又是吃力不讨好了。如果每个读者都可以随着这本书的介绍,去逐步的实现一个操作系统,不但这中间其乐无穷,而且实现到最后,对x86架构的理解也就不在话下。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值