《操作系统真象还原》记录全流程——第二章 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

相关文章

Nginx分布式部署流程分析

《Nginx分布式部署流程分析》文章介绍Nginx在分布式部署中的反向代理和负载均衡作用,用于分发请求、减轻服务器压力及解决session共享问题,涵盖配置方法、策略及Java项目应用,并提及分布式事... 目录分布式部署NginxJava中的代理代理分为正向代理和反向代理正向代理反向代理Nginx应用场景

Spring Boot分层架构详解之从Controller到Service再到Mapper的完整流程(用户管理系统为例)

《SpringBoot分层架构详解之从Controller到Service再到Mapper的完整流程(用户管理系统为例)》本文将以一个实际案例(用户管理系统)为例,详细解析SpringBoot中Co... 目录引言:为什么学习Spring Boot分层架构?第一部分:Spring Boot的整体架构1.1

nodejs打包作为公共包使用的完整流程

《nodejs打包作为公共包使用的完整流程》在Node.js项目中,打包和部署是发布应用的关键步骤,:本文主要介绍nodejs打包作为公共包使用的相关资料,文中通过代码介绍的非常详细,需要的朋友可... 目录前言一、前置准备二、创建与编码三、一键构建四、本地“白嫖”测试(可选)五、发布公共包六、常见踩坑提醒

Ubuntu向多台主机批量传输文件的流程步骤

《Ubuntu向多台主机批量传输文件的流程步骤》:本文主要介绍在Ubuntu中批量传输文件到多台主机的方法,需确保主机互通、用户名密码统一及端口开放,通过安装sshpass工具,准备包含目标主机信... 目录Ubuntu 向多台主机批量传输文件1.安装 sshpass2.准备主机列表文件3.创建一个批处理脚

一个Java的main方法在JVM中的执行流程示例详解

《一个Java的main方法在JVM中的执行流程示例详解》main方法是Java程序的入口点,程序从这里开始执行,:本文主要介绍一个Java的main方法在JVM中执行流程的相关资料,文中通过代码... 目录第一阶段:加载 (Loading)第二阶段:链接 (Linking)第三阶段:初始化 (Initia

Linux中查看操作系统及其版本信息的多种方法

《Linux中查看操作系统及其版本信息的多种方法》在服务器运维或者部署系统中,经常需要确认服务器的系统版本、cpu信息等,在Linux系统中,有多种方法可以查看操作系统及其版本信息,以下是一些常用的方... 目录1. lsb_pythonrelease 命令2. /etc/os-release 文件3. h

docker编写java的jar完整步骤记录

《docker编写java的jar完整步骤记录》在平常的开发工作中,我们经常需要部署项目,开发测试完成后,最关键的一步就是部署,:本文主要介绍docker编写java的jar的相关资料,文中通过代... 目录all-docker/生成Docker打包部署文件配置服务A的Dockerfile (a/Docke

MySQL使用EXISTS检查记录是否存在的详细过程

《MySQL使用EXISTS检查记录是否存在的详细过程》EXISTS是SQL中用于检查子查询是否返回至少一条记录的运算符,它通常用于测试是否存在满足特定条件的记录,从而在主查询中进行相应操作,本文给大... 目录基本语法示例数据库和表结构1. 使用 EXISTS 在 SELECT 语句中2. 使用 EXIS

Git打标签从本地创建到远端推送的详细流程

《Git打标签从本地创建到远端推送的详细流程》在软件开发中,Git标签(Tag)是为发布版本、标记里程碑量身定制的“快照锚点”,它能永久记录项目历史中的关键节点,然而,仅创建本地标签往往不够,如何将其... 目录一、标签的两种“形态”二、本地创建与查看1. 打附注标http://www.chinasem.cn

通过Docker容器部署Python环境的全流程

《通过Docker容器部署Python环境的全流程》在现代化开发流程中,Docker因其轻量化、环境隔离和跨平台一致性的特性,已成为部署Python应用的标准工具,本文将详细演示如何通过Docker容... 目录引言一、docker与python的协同优势二、核心步骤详解三、进阶配置技巧四、生产环境最佳实践