《操作系统真象还原》记录全流程——第二章 MBR

2024-03-22 07:52

本文主要是介绍《操作系统真象还原》记录全流程——第二章 MBR,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

提示: 写这篇文章的目的是只是激励自己完成这本书的linux内核项目,本文不够细致。

指路大佬:操作系统真象还原 自制操作系统_Love 6的博客-CSDN博客

指路大佬:

用《操作系统真象还原》写一个操作系统 第二章 编写MBR主引导记录,让我们开始掌权_哔哩哔哩_bilibili

感谢CSDN上的前辈们的热心分享。

一.基本概念

  1. CPU 的硬件电路被设计成只能运行处于内存中的程序。
  2. 所谓的载入内存,大概上分两部分:(1)程序被加载器(软件或硬件)加载到内存某个区域。 (2)CPU 的 cs:ip 寄存器被指向这个程序的起始地址。
  3. 从按下主机上的 power 键后,第一个运行的软件是 BIOS。BIOS 的主要工作是检测、初始化硬件。
  4. 在开机的一瞬间,也就是接电的一瞬间,CPU 的 cs:ip 寄存器被强制初始化为 0xF000:0xFFF0
  5. BIOS 最后一项工作校验启动盘中位于 0 盘 0 道 1 扇区。
  6. MBR 的任务是加载某个程序到指定位置,并将控制权交给它。加载 MBR 的位置取决于操作系统本身所占内存大小和内存布局。MBR 的大小必须是 512 字节,这是为了保证 0x55 和 0xaa 这两个 魔数恰好出现在该扇区的最后两个字节处,即第 510 字节处和第 511 字节处。

二、配置

0.安装NASM编译器:sudo apt-get install nasm

1. 编写主引导程序MBR

代码流程:

  1. 实模式下MBR 被 BIOS 加载到7C00,所以起始地址设置为7C00。
  2. 初始化寄存器。
  3. 准备中断功能的寄存器参数,调用中断。
  4. 获取光标位置,向光标位置打印字符串。

2. 点开text editor,把汇编代码输入进去,命名mbr.s。【我是新手,ubuntu初始时,只能新建folder,我不知道,所以特意写了这一步,本来还疑惑不能新建txt文件的。】

SECTION MBR vstart=0x7c00 ;起始地址编译在0x7c00mov ax,csmov ds,axmov es,axmov ss,axmov fs,axmov sp,0x7c00;这个时候 ds = es = ss = 0 栈指针指向MBR开始位置;ah = 0x06 al = 0x00 想要调用int 0x06的BIOS提供的中断对应的函数 即向上移动即完成清屏功能;cx dx 分别存储左上角与右下角的左边 详情看int 0x06函数调用mov ax,0x600 mov bx,0x700mov cx,0mov dx,0x184f;调用BIOS中断int 0x10 mov ah,3mov bh,0;获取光标位置 需要打印信息int 0x10mov ax,messagemov bp,axmov cx,5mov ax,0x1301mov bx,0x71;白底蓝字好cooiint 0x10 ;写字符串jmp $ ;无限循环 一直跳转到当前命令位置;字符串声明 db == define byte dw == define word ascii一个字符占一个字节message db "1 MBR" ;预留两个字节 其余空余的全部用0填满 为使检测当前扇区最后两字节为0x55 0xaa 检测是否为有效扇区;510 = 512字节-2预留字节  再减去(当前位置偏移量-段开始位置偏移量)求出来的是剩余空间times 510 - ($ - $$) db 0 db 0x55,0xaa

3. 编译文件nasm -o mbr.bin mbr.s,将编译好的mbr.bin 文件写入虚拟机,启动虚拟机。

具体可以参考:从零开始编写一个操作系统(1)---编写mbr.s文件-CSDN博客

4.记录

这篇关于《操作系统真象还原》记录全流程——第二章 MBR的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)

《java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)》:本文主要介绍java中pdf模版填充表单踩坑的相关资料,OpenPDF、iText、PDFBox是三... 目录准备Pdf模版方法1:itextpdf7填充表单(1)加入依赖(2)代码(3)遇到的问题方法2:pd

Spring Boot 中的默认异常处理机制及执行流程

《SpringBoot中的默认异常处理机制及执行流程》SpringBoot内置BasicErrorController,自动处理异常并生成HTML/JSON响应,支持自定义错误路径、配置及扩展,如... 目录Spring Boot 异常处理机制详解默认错误页面功能自动异常转换机制错误属性配置选项默认错误处理

Spring Boot从main方法到内嵌Tomcat的全过程(自动化流程)

《SpringBoot从main方法到内嵌Tomcat的全过程(自动化流程)》SpringBoot启动始于main方法,创建SpringApplication实例,初始化上下文,准备环境,刷新容器并... 目录1. 入口:main方法2. SpringApplication初始化2.1 构造阶段3. 运行阶

使用Go实现文件复制的完整流程

《使用Go实现文件复制的完整流程》本案例将实现一个实用的文件操作工具:将一个文件的内容完整复制到另一个文件中,这是文件处理中的常见任务,比如配置文件备份、日志迁移、用户上传文件转存等,文中通过代码示例... 目录案例说明涉及China编程知识点示例代码代码解析示例运行练习扩展小结案例说明我们将通过标准库 os

Zabbix在MySQL性能监控方面的运用及最佳实践记录

《Zabbix在MySQL性能监控方面的运用及最佳实践记录》Zabbix通过自定义脚本和内置模板监控MySQL核心指标(连接、查询、资源、复制),支持自动发现多实例及告警通知,结合可视化仪表盘,可有效... 目录一、核心监控指标及配置1. 关键监控指标示例2. 配置方法二、自动发现与多实例管理1. 实践步骤

Ubuntu 24.04启用root图形登录的操作流程

《Ubuntu24.04启用root图形登录的操作流程》Ubuntu默认禁用root账户的图形与SSH登录,这是为了安全,但在某些场景你可能需要直接用root登录GNOME桌面,本文以Ubuntu2... 目录一、前言二、准备工作三、设置 root 密码四、启用图形界面 root 登录1. 修改 GDM 配

Spring Security中用户名和密码的验证完整流程

《SpringSecurity中用户名和密码的验证完整流程》本文给大家介绍SpringSecurity中用户名和密码的验证完整流程,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定... 首先创建了一个UsernamePasswordAuthenticationTChina编程oken对象,这是S

在Spring Boot中集成RabbitMQ的实战记录

《在SpringBoot中集成RabbitMQ的实战记录》本文介绍SpringBoot集成RabbitMQ的步骤,涵盖配置连接、消息发送与接收,并对比两种定义Exchange与队列的方式:手动声明(... 目录前言准备工作1. 安装 RabbitMQ2. 消息发送者(Producer)配置1. 创建 Spr

Android ViewBinding使用流程

《AndroidViewBinding使用流程》AndroidViewBinding是Jetpack组件,替代findViewById,提供类型安全、空安全和编译时检查,代码简洁且性能优化,相比Da... 目录一、核心概念二、ViewBinding优点三、使用流程1. 启用 ViewBinding (模块级

k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)

《k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)》本文记录在K8s上运行的MySQL/MariaDB备份方案,通过工具容器执行mysqldump,结合定时任务实... 目录前言一、获取需要备份的数据库的信息二、备份步骤1.准备工作(X86)1.准备工作(arm)2.手