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

相关文章

将Mybatis升级为Mybatis-Plus的详细过程

《将Mybatis升级为Mybatis-Plus的详细过程》本文详细介绍了在若依管理系统(v3.8.8)中将MyBatis升级为MyBatis-Plus的过程,旨在提升开发效率,通过本文,开发者可实现... 目录说明流程增加依赖修改配置文件注释掉MyBATisConfig里面的Bean代码生成使用IDEA生

C# WinForms存储过程操作数据库的实例讲解

《C#WinForms存储过程操作数据库的实例讲解》:本文主要介绍C#WinForms存储过程操作数据库的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、存储过程基础二、C# 调用流程1. 数据库连接配置2. 执行存储过程(增删改)3. 查询数据三、事务处

JSON Web Token在登陆中的使用过程

《JSONWebToken在登陆中的使用过程》:本文主要介绍JSONWebToken在登陆中的使用过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录JWT 介绍微服务架构中的 JWT 使用结合微服务网关的 JWT 验证1. 用户登录,生成 JWT2. 自定义过滤

java中使用POI生成Excel并导出过程

《java中使用POI生成Excel并导出过程》:本文主要介绍java中使用POI生成Excel并导出过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录需求说明及实现方式需求完成通用代码版本1版本2结果展示type参数为atype参数为b总结注:本文章中代码均为

SpringBoot启动报错的11个高频问题排查与解决终极指南

《SpringBoot启动报错的11个高频问题排查与解决终极指南》这篇文章主要为大家详细介绍了SpringBoot启动报错的11个高频问题的排查与解决,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一... 目录1. 依赖冲突:NoSuchMethodError 的终极解法2. Bean注入失败:No qu

一文带你了解SpringBoot中启动参数的各种用法

《一文带你了解SpringBoot中启动参数的各种用法》在使用SpringBoot开发应用时,我们通常需要根据不同的环境或特定需求调整启动参数,那么,SpringBoot提供了哪些方式来配置这些启动参... 目录一、启动参数的常见传递方式二、通过命令行参数传递启动参数三、使用 application.pro

SpringBoot项目启动报错"找不到或无法加载主类"的解决方法

《SpringBoot项目启动报错找不到或无法加载主类的解决方法》在使用IntelliJIDEA开发基于SpringBoot框架的Java程序时,可能会出现找不到或无法加载主类com.example.... 目录一、问题描述二、排查过程三、解决方案一、问题描述在使用 IntelliJ IDEA 开发基于

SpringCloud之LoadBalancer负载均衡服务调用过程

《SpringCloud之LoadBalancer负载均衡服务调用过程》:本文主要介绍SpringCloud之LoadBalancer负载均衡服务调用过程,具有很好的参考价值,希望对大家有所帮助,... 目录前言一、LoadBalancer是什么?二、使用步骤1、启动consul2、客户端加入依赖3、以服务

Oracle存储过程里操作BLOB的字节数据的办法

《Oracle存储过程里操作BLOB的字节数据的办法》该篇文章介绍了如何在Oracle存储过程中操作BLOB的字节数据,作者研究了如何获取BLOB的字节长度、如何使用DBMS_LOB包进行BLOB操作... 目录一、缘由二、办法2.1 基本操作2.2 DBMS_LOB包2.3 字节级操作与RAW数据类型2.

C#原型模式之如何通过克隆对象来优化创建过程

《C#原型模式之如何通过克隆对象来优化创建过程》原型模式是一种创建型设计模式,通过克隆现有对象来创建新对象,避免重复的创建成本和复杂的初始化过程,它适用于对象创建过程复杂、需要大量相似对象或避免重复初... 目录什么是原型模式?原型模式的工作原理C#中如何实现原型模式?1. 定义原型接口2. 实现原型接口3