操作系统真象还原:编写MBR主引导记录,让我们开始掌权

2024-05-30 15:28

本文主要是介绍操作系统真象还原:编写MBR主引导记录,让我们开始掌权,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

第2章-编写MBR主引导记录,让我们开始掌权

这是一个网站有所有小节的代码实现,同时也包含了Bochs等文件

在开机的一瞬间,也就是接电的一瞬间, CPU 的 CS: ip 寄存器被强制初始化为 0XF000: 0XFFF0。由于开机的时候处于实模式,再重复一遍加深印象,在实模式下的段基址要乘以 16,也就是左移位,于是0XF000: 0XFFF0的等效地址将是 0XFFFF0

BIOS 最后一项工作校验启动盘中位于 0 盘。道 1 扇区的内容。 如果此扇区末尾的两个字节分别是魔数 0x550xaa, BIOS 便认为此扇区中确实存在可执行的程序(在此先剧透一下,此程序便是久闻大名的主引导记录 MBR),便加载到物理地址 0x7c00,随后跳转到此地址,继续执行 。

0xfe05b 处,这是 BIOS 代码真正开始的地方 ,BIOS 跳转到 0x7c00 是用 jmp 0: 0x7c00 实现的,这是 jmp 指令的直接绝对远转移用法,段寄存器 cs 会被替换,这里的段基址是 0,即 cs 由之前的 0xf000 变成了0

$$$是编译器 NASM 预留的关键字,用来表示当前行和本 section 的地址,起到了标号的作用,它是 NASM 提供的,并不是 CPU 原生支持的 。

用8086汇编语言编写显示字符的程序。该程序共512字节(不足部分补0),且最后两个字节是0x55与0xaa。该程序用NASM编译后,用dd命令写入bochs启动硬盘的0盘0道1扇区,BIOS会自动加载程序到内存中,然后自动跳转执行该程序。

                                ;主引导程序 ;------------------------------------------------------------
SECTION MBR vstart=0x7c00         mov ax,cs                   ;此时cs寄存器为0,自然可以用来将ax寄存器置0mov ds,axmov es,axmov ss,axmov fs,axmov sp,0x7c00; 清屏 利用0x06号功能,上卷全部行,则可清屏。; -----------------------------------------------------------;INT 0x10   功能号:0x06	   功能描述:上卷窗口;------------------------------------------------------;输入:;AH 功能号= 0x06;AL = 上卷的行数(如果为0,表示全部);BH = 上卷行属性;(CL,CH) = 窗口左上角的(X,Y)位置;(DL,DH) = 窗口右下角的(X,Y)位置;无返回值:mov ax, 0x600               ;ah中输入功能号mov bx, 0x700               ;设置上卷行属性,0x70表示用黑底白字的属性填充空白行mov cx, 0                   ;左上角: (0, 0)mov dx, 0x184f	            ;右下角: (80,25),;VGA文本模式中,一行只能容纳80个字符,共25行。;下标从0开始,所以0x18=24,0x4f=79int 0x10                    ;int 0x10;;;;;;;;;    下面这三行代码是获取光标位置    ;;;;;;;;;mov ah, 3		            ;输入: 3号子功能是获取光标位置,需要存入ah寄存器mov bh, 0		            ;bh寄存器存储的是待获取光标的页号int 0x10		            ;输出: ch=光标开始行,cl=光标结束行;dh=光标所在行号,dl=光标所在列号;;;;;;;;;    获取光标位置结束    ;;;;;;;;;;;;;;;;;;;;;;;;;     打印字符串    ;;;;;;;;;;;;还是用10h中断,不过这次是调用13号子功能打印字符串mov ax, message mov bp, ax		            ; es:bp 为串首地址, es此时同cs一致,; 开头时已经为sreg初始化; 光标位置要用到dx寄存器中内容,cx中的光标位置可忽略mov cx, 5		            ; cx 为串长度,不包括结束符0的字符个数mov ax, 0x1301	            ; 子功能号13是显示字符及属性,要存入ah寄存器,; al设置写字符方式 ah=01: 显示字符串,光标跟随移动mov bx, 0x2		            ; bh存储要显示的页号,此处是第0页,; bl中是字符属性, 属性黑底绿字(bl = 02h,07是黑底白字)int 0x10		            ; 执行BIOS 0x10 号中断;;;;;;;;;      打字字符串结束	 ;;;;;;;;;;;;;;;jmp $		                ; 使程序悬停在此message db "1 MBR"times 510-($-$$) db 0db 0x55,0xaa

vstart:主要是把地址编译为0x7c00

vstartorg ,它们的功能是告诉编译器:“嘿,老兄,你帮我把后面所有数据〈指令和变量 )的地址以 xxxx 为起始开始编吧”

mbr 用 vstart=0x7c00 来修饰的原因,是因为开发人员知道 mbr 要被加载器( BIOS )加载到物理地址0x7c00, mbr 中后续的物理地址都是 0x7c00+。另外,因为 BIOS 进入 mbr 是通过 jmp 0: 7c00 来实现的,故此时 cs 己经变成 0,相当于“平坦模型”了,只不过此“平坦模型”大小只是 65536 字节,而不是 4GB 。
所以 mbr 中各数据编译出来的地址(大于等于 0x7c00 )实际上都成了偏移地址,这样“俨 16:偏移地址。0x7c00+”来访问被加载到 0x7c00 的 mbr 是正确无误的。所以说,用 vstart 的时机是:我预先知道我的程序将来被加载到某地址处。程序只有加载到非 0 地址时 vstart 才是有用的,程序默认起始地址是 0 。

此时的一个内存结构图为:
在这里插入图片描述

这篇关于操作系统真象还原:编写MBR主引导记录,让我们开始掌权的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1016445

相关文章

51单片机学习记录———定时器

文章目录 前言一、定时器介绍二、STC89C52定时器资源三、定时器框图四、定时器模式五、定时器相关寄存器六、定时器练习 前言 一个学习嵌入式的小白~ 有问题评论区或私信指出~ 提示:以下是本篇文章正文内容,下面案例可供参考 一、定时器介绍 定时器介绍:51单片机的定时器属于单片机的内部资源,其电路的连接和运转均在单片机内部完成。 定时器作用: 1.用于计数系统,可

Javascript高级程序设计(第四版)--学习记录之变量、内存

原始值与引用值 原始值:简单的数据即基础数据类型,按值访问。 引用值:由多个值构成的对象即复杂数据类型,按引用访问。 动态属性 对于引用值而言,可以随时添加、修改和删除其属性和方法。 let person = new Object();person.name = 'Jason';person.age = 42;console.log(person.name,person.age);//'J

【Linux进阶】UNIX体系结构分解——操作系统,内核,shell

1.什么是操作系统? 从严格意义上说,可将操作系统定义为一种软件,它控制计算机硬件资源,提供程序运行环境。我们通常将这种软件称为内核(kerel),因为它相对较小,而且位于环境的核心。  从广义上说,操作系统包括了内核和一些其他软件,这些软件使得计算机能够发挥作用,并使计算机具有自己的特生。这里所说的其他软件包括系统实用程序(system utility)、应用程序、shell以及公用函数库等

vcpkg安装opencv中的特殊问题记录(无法找到opencv_corexd.dll)

我是按照网上的vcpkg安装opencv方法进行的(比如这篇:从0开始在visual studio上安装opencv(超详细,针对小白)),但是中间出现了一些别人没有遇到的问题,虽然原因没有找到,但是本人给出一些暂时的解决办法: 问题1: 我在安装库命令行使用的是 .\vcpkg.exe install opencv 我的电脑是x64,vcpkg在这条命令后默认下载的也是opencv2:x6

【操作系统】信号Signal超详解|捕捉函数

🔥博客主页: 我要成为C++领域大神🎥系列专栏:【C++核心编程】 【计算机网络】 【Linux编程】 【操作系统】 ❤️感谢大家点赞👍收藏⭐评论✍️ 本博客致力于知识分享,与更多的人进行学习交流 ​ 如何触发信号 信号是Linux下的经典技术,一般操作系统利用信号杀死违规进程,典型进程干预手段,信号除了杀死进程外也可以挂起进程 kill -l 查看系统支持的信号

记录AS混淆代码模板

开启混淆得先在build.gradle文件中把 minifyEnabled false改成true,以及shrinkResources true//去除无用的resource文件 这些是写在proguard-rules.pro文件内的 指定代码的压缩级别 -optimizationpasses 5 包明不混合大小写 -dontusemixedcaseclassnames 不去忽略非公共

操作系统实训复习笔记(1)

目录 Linux vi/vim编辑器(简单) (1)vi/vim基本用法。 (2)vi/vim基础操作。 进程基础操作(简单) (1)fork()函数。 写文件系统函数(中等) ​编辑 (1)C语言读取文件。 (2)C语言写入文件。 1、write()函数。  读文件系统函数(简单) (1)read()函数。 作者本人的操作系统实训复习笔记 Linux

SQL Server中,用Restore DataBase把数据库还原到指定的路径

restore database 数据库名 from disk='备份文件路径' with move '数据库文件名' to '数据库文件放置路径', move '日志文件名' to '日志文件存放置路径' Go 如: restore database EaseWe from disk='H:\EaseWe.bak' with move 'Ease

数控系统资料记录

数控技术:数控系统刀补功能的软件实现及其仿真--数控仿真程序开发实战 https://github.com/mai4567/CNC 下载编译报错:error: src/dxflib.a: 没有那个文件或目录: 解决:下载dxflibhttps://www.ribbonsoft.com/en/dxflib-downloads,下载完后编译,编译后得到libdxflib.a,替换掉项目makefi

pixel_link记录

export PYTHONPATH=/path2to/pixel_link/pylib/src:$PYTHONPATH   https://blog.csdn.net/northeastsqure/article/details/83655200   https://blog.csdn.net/u011440558/article/details/78606662   报错: All