IA32体系结构6(x86加电启动过程概述)

2024-02-21 23:32

本文主要是介绍IA32体系结构6(x86加电启动过程概述),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

第一条指令物理地址

加电启动过程非常精妙,道理很简单,加电时刻,所有的硬件部件基本都是没法工作的状态。至少内存里什么有用的东西也没有,CPU的寄存器还是初始状态,各种地址转换表也没有建立好。

首先我们来看下,CPU从上电到正常工作,在地址线上发出的第一个有效物理地址是什么。这个在《Intel Architecture Software Developer Manual Volume 3》8.1.4节有说明:

第一条指令的物理地址是:0xFFFFFFF0。

怎么来的呢?该小节也说得很清楚:

80386以上cpu,CS寄存器分为两部分:可见段选择符部分和隐藏基地址部分。实地址模式,地址是按照CS*0x10+IP生成。硬件复位时刻,CS被加载为0xF000,隐藏基地址部分被加载为0xFFFF0000,EIP被加载为0xFFF0。于是:

physical address = base address + EIP = 0xFFFF0000 + 0xFFF0 = 0xFFFFFFF0

实际上,80386以上CPU在计算物理地址的时候,遵循非常简单的规则,就是将CS基地址部分和EIP简单相加,得出最终物理地址。这个貌似既不是实模式的方法,也不是保护模式的方法(保护模式需要段氏页式转换),所有有很多资料称之为一种奇特的模式。一旦CS被重新更新过,计算地址的方式就变成真正的实模式方式,就是CS*0x10+IP。

执行第一条指令

以上我们知道cpu发出的第一个物理地址是0xFFFFFFF0,到这里我们需要知道一点,cpu其实很傻逼,他根本不知道也不用知道这个地址对应的设备在哪里,并且里面有什么。本质来说,cpu从这个地址来取指令,你给他什么就是什么。当时的IBM PC机主板上,准确点说是南桥北桥芯片,里面存储了一张物理地址映射表,这张表里面将这个地址定向到了系统BIOS,在0xFFFFFFF0地址处,一般放置一条跳转指令。跳转到BIOS代码中64K范围内的某一条指令开始执行。接下来就是BIOS的执行,比如初始化、加电自检等,完了之后,会将第一个可启动设备的最开始一个扇区(512字节)的内容复制到绝对物理地址0x7c00处。linux0.11在这里放置了bootsect代码,当今的PC机,这个512字节一般存放MBR。MBR中包含446字节的执行代码和64字节分区表。比如这段代码可以存放grub引导程序第一部分,把grub后续部分引导加载运行,然后由grub来引导内核启动。

映射表可以参见《linux内核完全注释》2.3.1节和2.3.2节。

关于地址映射,可以参考:https://blog.csdn.net/sunxiaohusunke/article/details/88886233

这篇关于IA32体系结构6(x86加电启动过程概述)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

线程池ThreadPoolExecutor应用过程

《线程池ThreadPoolExecutor应用过程》:本文主要介绍如何使用ThreadPoolExecutor创建线程池,包括其构造方法、常用方法、参数校验以及如何选择合适的拒绝策略,文章还讨论... 目录ThreadPoolExecutor构造说明及常用方法为什么强制要求使用ThreadPoolExec

springboot3.x使用@NacosValue无法获取配置信息的解决过程

《springboot3.x使用@NacosValue无法获取配置信息的解决过程》在SpringBoot3.x中升级Nacos依赖后,使用@NacosValue无法动态获取配置,通过引入SpringC... 目录一、python问题描述二、解决方案总结一、问题描述springboot从2android.x

MySQL数据目录迁移的完整过程

《MySQL数据目录迁移的完整过程》文章详细介绍了将MySQL数据目录迁移到新硬盘的整个过程,包括新硬盘挂载、创建新的数据目录、迁移数据(推荐使用两遍rsync方案)、修改MySQL配置文件和重启验证... 目录1,新硬盘挂载(如果有的话)2,创建新的 mysql 数据目录3,迁移 MySQL 数据(推荐两

MyBatis-Plus逻辑删除实现过程

《MyBatis-Plus逻辑删除实现过程》本文介绍了MyBatis-Plus如何实现逻辑删除功能,包括自动填充字段、配置与实现步骤、常见应用场景,并展示了如何使用remove方法进行逻辑删除,逻辑删... 目录1. 逻辑删除的必要性编程1.1 逻辑删除的定义1.2 逻辑删php除的优点1.3 适用场景2.

检查 Nginx 是否启动的几种方法

《检查Nginx是否启动的几种方法》本文主要介绍了检查Nginx是否启动的几种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录1. 使用 systemctl 命令(推荐)2. 使用 service 命令3. 检查进程是否存在4

解决idea启动项目报错java: OutOfMemoryError: insufficient memory

《解决idea启动项目报错java:OutOfMemoryError:insufficientmemory》:本文主要介绍解决idea启动项目报错java:OutOfMemoryError... 目录原因:解决:总结 原因:在Java中遇到OutOfMemoryError: insufficient me

SpringBoot项目整合Netty启动失败的常见错误总结

《SpringBoot项目整合Netty启动失败的常见错误总结》本文总结了SpringBoot集成Netty时常见的8类问题及解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录一、端口冲突问题1. Tomcat与Netty端口冲突二、主线程被阻塞问题1. Netty启动阻

SpringBoot整合Kafka启动失败的常见错误问题总结(推荐)

《SpringBoot整合Kafka启动失败的常见错误问题总结(推荐)》本文总结了SpringBoot项目整合Kafka启动失败的常见错误,包括Kafka服务器连接问题、序列化配置错误、依赖配置问题、... 目录一、Kafka服务器连接问题1. Kafka服务器无法连接2. 开发环境与生产环境网络不通二、序

JAVA SpringBoot集成Jasypt进行加密、解密的详细过程

《JAVASpringBoot集成Jasypt进行加密、解密的详细过程》文章详细介绍了如何在SpringBoot项目中集成Jasypt进行加密和解密,包括Jasypt简介、如何添加依赖、配置加密密钥... 目录Java (SpringBoot) 集成 Jasypt 进行加密、解密 - 详细教程一、Jasyp

Java通过ServerSocket与Socket实现通信过程

《Java通过ServerSocket与Socket实现通信过程》本文介绍了Java中的ServerSocket和Socket类,详细讲解了它们的构造方法和使用场景,并通过一个简单的通信示例展示了如何... 目录1 ServerSocket2 Socket3 服务器端4 客户端5 运行结果6 设置超时总结1