30天自制操作系统 学习笔记2

第二天的内容就比第一天要有趣多了。

 

首先解释了一下helloos的汇编代码,代码如下:

开始的时候一直不知道64行打下是干什么用的,注释写的是启动区以外部分的输出。我随意改了很多,也没见到输出的run有什么不同。加上后来看的内容,觉得这段就是没用的。现在写的这个启动区的代码,更本没用尽到本职工作,而是仅仅输出了hello, world而已。所以对启动区以外的东西,无法操控,自然,以外的东西都木有用了。

 

ORG    0x7c00

ORG是在nask开始执行的时候,会告诉它这些机器指令装载到内存中的哪些地址(CPU放不下全部),而后面的0x7c00是被Intel那帮老头子规定的,具体历史原因未知~

0x00007c00-0x00007dff  内存中,是启动区内容的装载地址

$也变成了将要读入的内存地址。

 

不同名称的寄存器有不同的用途,具体见书。

书中介绍的主要是16位的寄存器,提到的8位寄存器其实只是16位寄存器里的高8位和低8位抽象出来的一个逻辑概念。还略提了一下32位寄存器。

 

汇编里所有的标号都是单纯的数字,对应着指定的内存地址(标号所在地的地址)

 

内存离CPU很远(10cm),相比于CPU中的半导体。

 

MOV BYTE [678],123

MOV WORD [678],123

MOV DWORD [678],123

MOV指令的元数据和目的数据的数据必须位数相同,否则会因找不到相对应的机器语言而出错。

 

只有BX, BP, SI, DI可以用来指定内存地址。其余不行是因为CPU没有相应的处理电路。

 

INT    0x10

BIOS功能很多,是为操作系统开发人员准备的各种函数的集合。而INT就是用来调用这些函数的指令。0x10代表是16号函数(控制显卡)。函数的参数存于指定寄存器中。

 

在玩helloos03的时候,我改了改代码,想在结尾循环输出't'这个字符。一开始频繁出错,最终发现,程序要正确跑的话,无论怎样不能影响原有的结构(代码加在RESB0x7dfe-$前还是后就影响很大)。效果图如下:

 

还讲了讲make和Makefile. 虽然接触Linux的时候已经了解过,不过真的用在实际中还是少数。这次用了之后对这两个的理解加深了很多。

 

貌似明天开始要用C了,速度要大大加快了估计。

 

转载于:https://www.cnblogs.com/HenryThinker/archive/2013/03/30/2989945.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值