操作系统真象还原:编写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

相关文章

MySQL INSERT语句实现当记录不存在时插入的几种方法

《MySQLINSERT语句实现当记录不存在时插入的几种方法》MySQL的INSERT语句是用于向数据库表中插入新记录的关键命令,下面:本文主要介绍MySQLINSERT语句实现当记录不存在时... 目录使用 INSERT IGNORE使用 ON DUPLICATE KEY UPDATE使用 REPLACE

Python 中的异步与同步深度解析(实践记录)

《Python中的异步与同步深度解析(实践记录)》在Python编程世界里,异步和同步的概念是理解程序执行流程和性能优化的关键,这篇文章将带你深入了解它们的差异,以及阻塞和非阻塞的特性,同时通过实际... 目录python中的异步与同步:深度解析与实践异步与同步的定义异步同步阻塞与非阻塞的概念阻塞非阻塞同步

Python Dash框架在数据可视化仪表板中的应用与实践记录

《PythonDash框架在数据可视化仪表板中的应用与实践记录》Python的PlotlyDash库提供了一种简便且强大的方式来构建和展示互动式数据仪表板,本篇文章将深入探讨如何使用Dash设计一... 目录python Dash框架在数据可视化仪表板中的应用与实践1. 什么是Plotly Dash?1.1

Spring Boot中定时任务Cron表达式的终极指南最佳实践记录

《SpringBoot中定时任务Cron表达式的终极指南最佳实践记录》本文详细介绍了SpringBoot中定时任务的实现方法,特别是Cron表达式的使用技巧和高级用法,从基础语法到复杂场景,从快速启... 目录一、Cron表达式基础1.1 Cron表达式结构1.2 核心语法规则二、Spring Boot中定

国内环境搭建私有知识问答库踩坑记录(ollama+deepseek+ragflow)

《国内环境搭建私有知识问答库踩坑记录(ollama+deepseek+ragflow)》本文给大家利用deepseek模型搭建私有知识问答库的详细步骤和遇到的问题及解决办法,感兴趣的朋友一起看看吧... 目录1. 第1步大家在安装完ollama后,需要到系统环境变量中添加两个变量2. 第3步 “在cmd中

基于.NET编写工具类解决JSON乱码问题

《基于.NET编写工具类解决JSON乱码问题》在开发过程中,我们经常会遇到JSON数据处理的问题,尤其是在数据传输和解析过程中,很容易出现编码错误导致的乱码问题,下面我们就来编写一个.NET工具类来解... 目录问题背景核心原理工具类实现使用示例总结在开发过程中,我们经常会遇到jsON数据处理的问题,尤其是

Spring Retry 实现乐观锁重试实践记录

《SpringRetry实现乐观锁重试实践记录》本文介绍了在秒杀商品SKU表中使用乐观锁和MybatisPlus配置乐观锁的方法,并分析了测试环境和生产环境的隔离级别对乐观锁的影响,通过简单验证,... 目录一、场景分析 二、简单验证 2.1、可重复读 2.2、读已提交 三、最佳实践 3.1、配置重试模板

在 Spring Boot 中使用异步线程时的 HttpServletRequest 复用问题记录

《在SpringBoot中使用异步线程时的HttpServletRequest复用问题记录》文章讨论了在SpringBoot中使用异步线程时,由于HttpServletRequest复用导致... 目录一、问题描述:异步线程操作导致请求复用时 Cookie 解析失败1. 场景背景2. 问题根源二、问题详细分

关于Spring @Bean 相同加载顺序不同结果不同的问题记录

《关于Spring@Bean相同加载顺序不同结果不同的问题记录》本文主要探讨了在Spring5.1.3.RELEASE版本下,当有两个全注解类定义相同类型的Bean时,由于加载顺序不同,最终生成的... 目录问题说明测试输出1测试输出2@Bean注解的BeanDefiChina编程nition加入时机总结问题说明

将sqlserver数据迁移到mysql的详细步骤记录

《将sqlserver数据迁移到mysql的详细步骤记录》:本文主要介绍将SQLServer数据迁移到MySQL的步骤,包括导出数据、转换数据格式和导入数据,通过示例和工具说明,帮助大家顺利完成... 目录前言一、导出SQL Server 数据二、转换数据格式为mysql兼容格式三、导入数据到MySQL数据