《30天自制操作系统》一书中第1天和第二天中有关汇编语言的程序的理解

; hello-os
; TAB=4 ORG 0x7c00 ; 指明程序的装载地址 ; 以下的记述用于标准FAT12格式的软盘 JMP entry
DB 0x90
DB "HELLOIPL" ; 启动区的名称可以是任意的字符串(8字节)
DW 512 ; 每个扇区(sector)的大小(必须为512字节)
DB 1 ; 簇(cluster)的大小(必须为1个扇区)
DW 1 ; FAT的起始位置(一般从第一个扇区开始)
DB 2 ; FAT的个数(必须为2)
DW 224 ; 根目录的大小(一般设成224项)
DW 2880 ; 该磁盘的大小(必须是2880扇区)
DB 0xf0 ; 磁盘的种类(必须是0xf0)
DW 9 ; FAT的长度(必须是9扇区)
DW 18 ; 1个磁道有几个扇区
DW 2 ; 磁头数(必须是2)
DD 0 ; 不使用分区,必须是0
DD 2880 ; 重写一次磁盘大小
DB 0,0,0x29 ; 意义不明,固定
DD 0xffffffff ; (可能是)卷标号码
DB "HELLO-OS " ; 磁盘的名称(11字节)
DB "FAT12 " ; 磁盘格式名称(8字节)
RESB 18 ; 先空出18字节 ; 程序核心 entry:
MOV AX,0 ; 初始化寄存器
MOV SS,AX
MOV SP,0x7c00
MOV DS,AX
MOV ES,AX MOV SI,msg
putloop:
MOV AL,[SI]
ADD SI,1 ; 给SI加1
CMP AL,0
JE fin
MOV AH,0x0e ; 显示一个文字
MOV BX,15 ; 指定字符颜色
INT 0x10 ; 调用显卡BIOS
JMP putloop
fin:
HLT ; 让CPU停止,等待指令
JMP fin ; 无限循环 msg:
DB 0x0a, 0x0a ; 换行两次
DB "hello, world"
DB 0x0a ; 换行
DB 0 RESB 0x7dfe-$ ; 填写0x00,直到0x001fe DB 0x55, 0xaa ; 以下是启动区以外部分的输出 DB 0xf0, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00
RESB 4600
DB 0xf0, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00
RESB 1469432
  • DB:define byte 往文件里直接写入1个字节 的指令

  • RESB:reserve byte 储备 RESB 10 储备10行

  • 0x:16进制数

  • DW:define word word表示16位 就是2字节

  • DD:define double-word 32位表示4个字节

  • RESB 0x1fe-$ $可以表示这一行现在的字节数

  • TAB=4:tab键的宽度

  • FAT12格式:(FAT12 Format)用Windows或MS-DOS格式化出来的软盘就是这种格式

  • 启动区:(boot sector):软盘的第一个扇区称为启动区 该扇区的最后两个字节的内容不是55 AA,计算机会认为这张盘没有所需的启动程序,就会保一个不能启动的错误

  • IPL:initial program loader启动程序加载器 加载操作系统本身的程序放在启动区

  • ORG:origin 告诉nask,在开始执行时,将这些机器指令装载到内存中的指定地址

    • $:代表将要读入的内存地址
  • JMP:jump goto

  • entry:标签的呃声明,用于指定JMP指令的跳转目地等 入口

  • MOV:赋值

    • AX:accumulator,累加寄存器

    • CX:counter,计数寄存器

    • DX:data,数据寄存器

    • BX:base,基址寄存器

    • SP:stack pointer,栈指针寄存器

    • BP:base pointer,基址指针寄存器

    • SI:source index,源变址寄存器

    • DI:destination index,目的变址寄存器

    • 16位寄存器,因此可以存储16位的二进制数 X表示扩展

    • ======================================================================================================================================================

    • AL:累加寄存器低位(accumulator low)

    • CL:计数寄存器低位(counter low)

    • DL:数据寄存器低位(data low)

    • BL:基址寄存器低位(base low)

    • AH:累加寄存器高位(accumulator high)

    • CH:计数寄存器高位(counter high)

    • DH:数据寄存器高位(data high)

    • BH:基址寄存器高位(base high)

    • ================================================================================================================================================================

    • AX = AL + AH

    • ================================================================================================================================================================

    • 32位寄存器:EAX、ECX、EDX、EBX、ESP、EBP、ESI、EDI

    • 段寄存器(segment register):16位寄存器

      • ES:附加段寄存器(extra segment)
      • CS:代码段寄存器(code segment)
      • SS:栈段寄存器(stack segment)
      • DS:数据段寄存器(data segment)
      • FS:没有名称(segment part 2)
      • GS:没有名称(segment part3)
    • ===========================================================================================================================================================

      • MOV BYTE [678], 123 :用内存的’678‘号地址来保存’123‘这个数值

      • MOV WORD [678], 123:678号和旁边的679都会做出反应,低位保存在678,高位保存在679

      • 数据大小[地址]

      • 可以用寄存器来指定内存地址

        只有BX、BP、SI、DI 不可以:AX、CX、DX、SP

      • MOV BX, DX

      • MOV AL, BYTE[BX]

      • 源数据和目的数据必须位数相同 MOV AL [BX]

  • CMP:比较指令

  • JE:条件跳转指令,比较结果相等,跳转到指定的地址;不相等,则不跳转,继续执行下一条指令

  • fin:标号,表示结束

  • INT:软件中断指令 interrupt

  • BIOS:basic input output system基本输入输出系统(程序) 出厂时就组装在电脑主板上的ROM单元里 各种函数的集合,可以被INT调用

  • HLT:让CPU进入待机状态 halt

30天自制操作系统day2汇编语言的更多相关文章

  1. 30天自制操作系统-day2

    30天自制操作系统(linux)-day2 使用简单的汇编语言 首先Centos环境安装nasm,使用vim工具编辑一个os.asm文件,文件内容如下: DB 0xeb, 0x4e, 0x90, 0x ...

  2. 《30天自制操作系统》笔记3 --- (Day2 上节)完全解析文件系统

    Day2 汇编语言学习与Makefile入门 本文仅带着思路,研究源码里关于文件系统的参数 关于day2主程序部分及更多内容,请看<30天自制操作系统>笔记 导航 发现学习中的变化 源码差 ...

  3. 《30天自制操作系统》笔记(03)——使用Vmware

    <30天自制操作系统>笔记(03)——使用Vmware 进度回顾 在上一篇,实现了用IPL加载OS程序到内存,然后JMP到OS程序这一功能:并且总结出下一步的OS开发结构.但是遇到了真机测 ...

  4. 《30天自制操作系统》笔记(02)——导入C语言

    <30天自制操作系统>笔记(02)——导入C语言 进度回顾 在上一篇,记录了计算机开机时加载IPL程序(initial program loader,一个nas汇编程序)的情况,包括IPL ...

  5. 30天自制操作系统(三)进入32位模式并导入C语言

    1 制作真正的IPL IPL(Initial Program Loader),启动程序装载器,但是之前并没有实质性的装载任何程序,这次作者要开始装载程序了. 虽然现在开发的操作系统啥功能也没有,作者说 ...

  6. 《30天自制操作系统》笔记(06)——CPU的32位模式

    <30天自制操作系统>笔记(06)——CPU的32位模式 进度回顾 上一篇中实现了启用鼠标.键盘的功能.屏幕上会显示出用户按键.点击鼠标的情况.这是通过设置硬件的中断函数实现的,可以说硬件 ...

  7. 《30天自制操作系统》笔记(01)——hello bitzhuwei’s OS!

    <30天自制操作系统>笔记(01)——hello bitzhuwei's OS! 最初的OS代码 ; hello-os ; TAB=4 ORG 0x7c00 ; 指明程序的装载地址 ; 以 ...

  8. 从你的u盘启动:30天自制操作系统第四天u盘启动学习笔记

    暑假学习小日本的那本书:30天自制操作系统 qq交流群:122358078    ,更多学习中的问题.资料,群里分享 developing environment:ubuntu 关于u盘启动自己做的操 ...

  9. 30天自制操作系统第八天学习笔记(u盘软盘双启动版本)

    暑假学习小日本的那本书:30天自制操作系统 qq交流群:122358078    ,更多学习中的问题.资料,群里分享 environment:开发环境:ubuntu 第八天的学习思考: 关于鼠标是怎么 ...

随机推荐

  1. CSS基础 背景图片的相关属性

    属性名: background-size: 宽度 高度; 属性值 说明 数字+px 简单方便,常用 百分比 相当于盒子自身的百分比,如:百分百,就是就算是图片变形也要显示 contain 动比例缩放, ...

  2. Sentry 企业级数据安全解决方案 - Relay 监控 & 指标收集

    内容整理自官方文档 系列 Sentry 企业级数据安全解决方案 - Relay 入门 Sentry 企业级数据安全解决方案 - Relay 运行模式 Sentry 企业级数据安全解决方案 - Rela ...

  3. Redis_客户端命令和数据操作(3)

    更多命令请查找:http://c.biancheng.net/redis_command/ 切换数据库 redis数据库没有名称,默认有16个,通过0-15来标识,连接redis默认选择第一个数据库, ...

  4. PowerShell 管道符之Where-Object的使用方法

    1 Get-Process|Select-Object -Property Name|Where-Object{$_ -match 'QQ'} 可以匹配到QQ为名的结果

  5. vert.x框架与tomcat的关系

    1.前言 大学4年,老师唯一让我们学习的web服务器是tomcat,配置方式是先从官网下载阿帕奇的tomcat文件,然后在开发平台导入,然后再配置web.xml等文件, 是一个可同步可异步请求的服务器 ...

  6. Linux上天之路(六)之Linux文件管理

    文件与文件夹的操作 1) 新建 2)改名 3)查看 4)删除 5)拷贝 6)移动 1. 文件的操作 文件的新建:touch filename 文件的改名:mv 文件的查看:ls 文件内容的查看:cat ...

  7. EgLine V0.3—LVGL官方拖拽式UI编辑工具(可导出代码)

    ** EdgeLine ** 是LVGL官方团队退出的一款拖拽式UI编辑工具,现在还处于测试间断,目前最新版本为v0.3,已经可导出代码. 注意: 使用该软件需要注册lvgl账号,这一步可能需要代理 ...

  8. JPA与hibernate-------JPA01

    ORM概述 ORM(Object-Relational Mapping) 表示对象关系映射.在面向对象的软件开发中,通过ORM,就可以把对象映射到关系型数据库中.只要有一套程序能够做到建立对象与数据库 ...

  9. 大型站点TCP/IP协议优化

    作为一个DAU上百万或千万的站点,不仅仅需要做好网站应用程序.数据库的优化,还应从TCP/IP协议层去进行相关的优化: 在我的工作中,曾使用到了以下的几种基本的优化方式: 增大最大连接数 在Linux ...

  10. 《剑指offer》面试题42. 连续子数组的最大和

    问题描述 输入一个整型数组,数组里有正数也有负数.数组中的一个或连续多个整数组成一个子数组.求所有子数组的和的最大值. 要求时间复杂度为O(n). 示例1: 输入: nums = [-2,1,-3,4 ...