当前位置: 首页 > news >正文

从按下电源键到进入系统,CPU在干什么?

本专栏更新速度较慢,简单讲讲计算机的那些事,简单讲讲那些特别散乱杂的知识,欢迎各位朋友订阅专栏啊

感谢一路相伴的朋友们

浅淡操作系统系列第2篇


目录

通电

保护模式和实模式

 内存管理单元MMU

逻辑地址?物理地址? 

段与基址

执行

MBR

操作系统

结语

快捷翻页

参考文章


通电

只要一通电,电路就会启动自检工作,把所有的寄存器全部重置,如果哪里有异常的话,就会把错误记录到EAX寄存器中,如果发现EAX的值不是0,那就不好了

一般开机的时候寄存器的值长这个样子

EAX,EBX, ECX, ESI, EDI, EBP, ESP: 0x00000000
EFLAGS: 0x00000002
CS: 0xF000
EIP: 0xFFF0
······

CS和IP这两个寄存器会决定CPU一会从哪里执行代码

CPU一般都是工作在保护模式下,使用虚拟地址来访问内存,由内存管理单元MMU负责给转换成真实的物理地址

不过在刚刚开机的时候,虚拟地址翻译所需要的页目录、页表这些信息都还没准备好,MMU还没法工作,这时候只能使用16位的寄存器,工作在实地址模式下,使用段+基址的方式来和内存读写,最多只能使用1MB的内存空间

这里来解释一下刚才涉及的知识点

保护模式和实模式

这个对于完全不懂的人解释起来太复杂了,但按照惯例,先放干货(这里引用cqwei1987大佬的文章《实模式和保护模式的区别》):

实模式:

它是Intel公司80286及以后的x86(80386,80486和80586等)兼容处理器(CPU)的一种操作模式。实模式被特殊定义为20位地址内存可访问空间上,这就意味着它的容量是2的20次幂(1M)的可访问内存空间(物理内存和BIOS-ROM),软件可通过这些地址直接访问BIOS程序和外围硬件。实模式下处理器没有硬件级的内存保护概念和多道任务的工作模式。但是为了向下兼容,所以80286及以后的x86系列兼容处理器仍然是开机启动时工作在实模式下。80186和早期的处理器仅有一种操作模式,就是后来我们所定义的实模式。实模式虽然能访问到1M的地址空间,但是由于BIOS的映射作用(即BIOS占用了部分空间地址资源),所以真正能使用的物理内存空间(内存条),也就是在640k到924k之间。1M地址空间组成是由16位的段地址和16位的段内偏移地址组成的。用公式表示为:物理地址=左移4位的段地址+偏移地址。

实模式寻址采用和8086相同的16位段和偏移量,最大寻址空间1MB,最大分段64KB。可以使用32位指令。32位的x86 CPU用做高速的8086。

保护模式:

286处理器体系结构引入了地址保护模式的概念,处理器能够对内存及一些其他外围设备做硬件级的保护设置(保护设置实质上就是屏蔽一些地址的访问)。

保护模式:寻址采用32位段和偏移量,最大寻址空间4GB,最大分段4GB (Pentium Pre及以后为64GB)。在保护模式下CPU可以进入虚拟8086方式,这是在保护模式下的实模式程序运行环境。

两者区别在cqwei1987大佬的文章中讲的很详细,这里举个简单易懂的例子:

保护模式就像一家高档餐厅,顾客在这里可以享受更加细致的服务和更加精致的美食。高档餐厅的菜品通常需要更多的时间和精力来准备,而且餐厅会为顾客提供更加周到的服务,确保顾客的用餐体验更加舒适和安全

实模式则像一家快餐店,顾客在这里可以快速地买到食物并离开。快餐店的菜品通常不需要太多的时间和精力来准备,而且餐厅也不会为顾客提供太多的服务。实模式下的计算机就像快餐店一样,可以快速地启动并运行程序,但功能和安全性都相对有限

 内存管理单元MMU

内存管理单元是计算机硬件的一部分,负责处理CPU的内存访问请求
MMU是Memory Management Unit的缩写,有时也称作分页内存管理单元(Paged Memory Management Unit,PMMU)

MMU通过将逻辑地址转换为物理地址来实现内存管理。它通过将虚拟地址空间映射到物理地址空间,使得多个进程可以同时访问相同的物理地址空间,而不会相互干扰。MMU还负责内存的访问权限管理,确保程序只能访问其被授权访问的内存区域

MMU是现代计算机系统中的重要组成部分,它与CPU紧密配合,提高了系统的性能和安全性

逻辑地址?物理地址? 

比如大家经常看到的,类似于:0x123456789abcdef0的就是逻辑地址

而物理地址则是二进制串,类似于:1010001001100001010011010111100001111111111010000

MMU的工作就是转换逻辑地址与物理地址

段与基址

段指的是内存中连续的存储区域,每个段的起始地址称为段基址,即此段从内存中的哪个地址开始存储。段基址是段的起始地址,但不是物理地址,它是一个线性地址

段基址通常有20位,但在某些操作系统中可能会被压缩到16位

段与基址的关系可以理解为,段是内存中连续的存储区域,而基址是段的起始地址

举个例子:段和基址的概念可以类比于现实中的地址索引方式

假设有一本书或者一篇文章,它被分为若干个章节,每个章节都是一个独立的段落,而每个段落都有一个起始页码。如果我们要引用这本书中的某个段落,我们通常会提供段落名称和页码,页码就是相对于该段落的起始页码的偏移量

例如,如果第一章的起始页码是10,而我们要引用第二章的某个段落,我们可以说“第二章第20页”,这里的20就是相对于第一章起始页码的偏移量

这种分段和偏移量的方式可以帮助我们更灵活地组织和引用文本内容,类似于计算机存储器中的段和基址的组织方式

执行

在开机的时候,内存刚刚通电,应该是空的吧?

在主板上,CPU旁边不远处有BIOS,BIOS是一个ROM芯片,一般一通电他就映射到地址空间中,按照CS:IP(0xF000:0xFFF0)

从F000:FFF0处,也就是0xFFFF0处取到的第一个地址一般是jmp到某处,一般是直接跳转到BIOS中央,BIOS会下达对主板上各单位进行检测,看看有没有异常情况,还有初始化CPU工作需要的中断向量表等等

而在这个时候,其他核心一般都不工作,只有一个核心工作,通常是1核,它会协助引导处理器加载硬件检测、内存初始化等

MBR

BIOS中的启动顺序第一位是硬盘,引导处理器会把第0盘第0道第1扇区的内容读取到了内存中的0x7C00位置,它叫做主引导记录MBR,一共512个字节

MBR是操作系统在安装的时候,写到硬盘里的。这个位置非常重要,假如有病毒占据了这个位置,解决办法只有重装系统

读取到了MBR后,要检查最后两个字节必须是0x55和0xAA,确认正常之后才能认为这是一个合法的MBR,这时会跳到了0x7C00的位置开始执行

操作系统

在操作系统上CPU会使用保护模式工作,MMU仍然没法做地址翻译工作,这时候CPU只能直接使用物理地址跟内存联系,把页目录和页表搞好MMU才可以

当启用内存分页后,MMU就会工作,CPU将可以使用虚拟地址访问内存了

在这之后其它核心就可以投入工作了


结语

作者会经常帮助有问题的小伙伴解决问题如果你有问题,可以直接到评论区指出,作者会在看到后到24小时内给予答复

如果本文有任何问题欢迎在评论去指出,如果喜欢这篇文章,希望能点赞评论关注

3000字,7个父项,2个子项,1个孙子项


快捷翻页

UNIX家族?Windows NT家族?一文讲清操作系统繁杂的家族史


参考文章

按下电源后的几秒钟,CPU在干嘛?

文心一言 

相关文章:

从按下电源键到进入系统,CPU在干什么?

本专栏更新速度较慢,简单讲讲计算机的那些事,简单讲讲那些特别散乱杂的知识,欢迎各位朋友订阅专栏啊 感谢一路相伴的朋友们 浅淡操作系统系列第2篇 目录 通电 保护模式和实模式 内存管理单元MMU 逻辑地址?物理地址&#xff1…...

TypeScript初体验

1.安装编译TS工具包 npm i -g typescript 2. 查看版本号 tsc -v 3.创建ts文件 说明:创建一个index.ts文件 4.TS编译为JS tsc index.ts 5.执行JS代码 node index.js 6.简化TS的步骤 6.1安装 npm i -g ts-node 6.2执行 ts-node index.ts...

基于 Alpine 环境源码构建 alibaba-tengine(阿里巴巴)的 Docker 镜像

About Alpine(简介) Alpine Linux 是一款极其轻量级的 Linux 发行版,基于 busybox,多被当做 Docker 镜像的底包(基础镜像),在使用容器时或多或少都会接触到此系统,本篇文章我们以该镜…...

政府网站定期巡检:构建高效、安全与透明的数字政务

在数字时代,政府网站已不仅仅是一个信息发布窗口,更是政府与公众互动的桥梁、政务服务的主要渠道以及数字化治理的重要平台。因此,确保政府网站的高效运行、信息安全与透明公开就显得尤为重要。在此背景下,定期的网站巡检与巡查成…...

C++信息学奥赛1138:将字符串中的小写字母转换成大写字母

#include<bits/stdc.h> using namespace std; int main() {string arr;// 输入一行字符串getline(cin, arr);for(int i0;i<arr.length();i){if(arr[i]>97 and arr[i]<122){char aarr[i]-32; // 将小写字母转换为大写字母cout<<a; // 输出转换后的字符}els…...

leetcode1475. 商品折扣后的最终价格 【单调栈】

简单题 第一次错误做法 class Solution { public:vector<int> finalPrices(vector<int>& prices) {int n prices.size();stack<int> st;unordered_map<int, int> mp;int i 0;while(i ! prices.size()) {int t prices[i];if (st.empty() || t …...

macOS M1使用TensorFlow GPU加速

本人是在pycharm运行代码&#xff0c;安装了tensorflow版本2.13.0 先运行代码查看有没有使用GPU加速&#xff1a; import tensorflow as tf# Press the green button in the gutter to run the script. if __name__ __main__:physical_devices tf.config.list_physical_dev…...

GNU-gcc编译选项-1

include目录 -I &#xff0c;比如: -I. -I ./Platform/include -I ./Platform/include/prototypes -I ./tpm/include -I ./tpm/include/prototypes -I ./Simulator/include -I ./Simulator/include/prototypes 编译选项 在GCC编译器中&#xff0c;-D是一个编译选项&…...

【DEVOPS】Jenkins使用问题 - 控制台输出乱码

0. 目录 1. 问题描述2. 解决方案3. 最终效果4. 总结 1. 问题描述 部门内部对于Jenkins的使用采取的是Master Slave Work Node的方式&#xff0c;即作为Master节点的Jenkins只负责任务调度&#xff0c;具体的操作由对应的Slave Work Node去执行。 最近团队成员反馈一个问题&a…...

logback-spring.xml

<?xml version"1.0" encoding"UTF-8"?> <configuration> <appender name"stdout" class"ch.qos.logback.core.ConsoleAppender"> <encoder> <springProfile name"dev"> <pattern>%d{…...

华为OD机试之报文重排序【Java源码】

题目描述 对报文进行重传和重排序是常用的可靠性机制&#xff0c;重传缓中区内有一定数量的子报文&#xff0c;每个子报文在原始报文中的顺序已知&#xff0c;现在需要恢复出原始报文。 输入描述 输入第一行为N&#xff0c;表示子报文的个数&#xff0c;0 &#xff1c;N ≤ …...

回归预测 | MATLAB实现BES-ELM秃鹰搜索优化算法优化极限学习机多输入单输出回归预测(多指标,多图)

回归预测 | MATLAB实现BES-ELM秃鹰搜索优化算法优化极限学习机多输入单输出回归预测&#xff08;多指标&#xff0c;多图&#xff09; 目录 回归预测 | MATLAB实现BES-ELM秃鹰搜索优化算法优化极限学习机多输入单输出回归预测&#xff08;多指标&#xff0c;多图&#xff09;效…...

DPU在东数西算背景下如何赋能下一代算力基础设施 中科驭数在未来网络发展大会论道

以ChatGPT为代表的人工智能大模型的快速发展&#xff0c;对网络信息技术创新发展提出了新的挑战&#xff0c;我国东数西算重大工程也在加速布局。以确定性网络、算力网络为代表的未来网络核心技术&#xff0c;正成为决定未来经济和产业发展的关键。 8月23日&#xff0c;第七届…...

2021年12月 C/C++(四级)真题解析#中国电子学会#全国青少年软件编程等级考试

第1题:移动路线 桌子上有一个m行n列的方格矩阵,将每个方格用坐标表示,行坐标从下到上依次递增,列坐标从左至右依次递增,左下角方格的坐标为(1,1),则右上角方格的坐标为(m,n)。 小明是个调皮的孩子,一天他捉来一只蚂蚁,不小心把蚂蚁的右脚弄伤了,于是蚂蚁只能向上或向右…...

ArcGIS Serve Windows下用户密码变更导致Server服务无法启动问题

问题&#xff1a; 因未知原因Windows下的Server安装账户密码变更&#xff0c;但是又忘记了密码&#xff0c;导致&#xff0c;Server服务启动失败&#xff0c;错误1069&#xff1a; 解决方法&#xff1a; 在账户管理界面&#xff0c;重置对应的arcgis账户的密码&#xff0c;…...

React 面试题集锦

目录 如果想要在组件第一次加载后获取该组件的dom元素&#xff0c;应当在以下哪个生命周期中进行 React支持的键盘事件是 使用严格模式&#xff08;Strict Mode&#xff09;优点 React 动态引入组件 当使用ReactDOM.unmountComponentAtNode从DOM中卸载组件时 说一下useS…...

xargs命令解决“Argument list too long”

一、xargs命令概述 xargs命令是给其他命令传递参数的一个过滤器&#xff0c;也是组合多个命令的一个工具。它擅长将标准输入数据转换成命令行参数&#xff0c;xargs能够处理管道或者stdin并将其转换成特定命令的命令参数。空格是其默认定界符&#xff0c;管道传递给xargs的输入…...

R语言中<- 的含义

一般语言的赋值是 号&#xff0c;但是 R 语言是数学语言&#xff0c;所以赋值符号与我们数学书上的伪代码很相似&#xff0c;是一个左箭头 <- &#xff1a; 举个例子&#xff1a; a <- 12 b <- 45 print(a b) 以上代码执行结果&#xff1a;57 这个赋值符号是 R …...

知识图谱Neo4j安装到实践全过程

前言&#xff1a; Hello大家好&#xff0c;我是Dream。 在本次实战中&#xff0c;我们将一起完成知识图谱Neo4j安装到实践全过程&#xff0c;探索其中的关系和属性。知识图谱是一种以三元组形式存储的数据结构&#xff0c;由实体、关系和属性组成&#xff0c;能够帮助我们更好地…...

贪心算法:简单而高效的优化策略

在计算机科学中&#xff0c;贪心算法是一种简单而高效的优化策略&#xff0c;用于解决许多组合优化问题。虽然它并不适用于所有问题&#xff0c;但在一些特定情况下&#xff0c;贪心算法能够产生近似最优解&#xff0c;而且计算成本较低。在本文中&#xff0c;我们将深入探讨贪…...

一生一芯6——ubuntu rpm软件安装

ubuntu不支持rpm&#xff0c;需要将rpm软件安装包转成deb进行安装 安装alien sudo apt-get install alien格式转换 sudo alien xxx.rpm 在目录下会生成deb的安装包 软件安装 sudo dpkg -i xxx_amd64.deb 安装完成...

Python练习 函数取列表最小数

练习2&#xff1a;构造一个功能函数&#xff0c;可以解决如下问题&#xff1a; 要求如下&#xff1a; 1&#xff0c;任意输入一个列表&#xff0c;函数可以打印出列表中最小的那个数&#xff0c; 例&#xff1a;输入: 23,56,67,4,17,9 最小数是 &#xff1a;4 方法一: #内置函…...

五种重要的 AI 编程语言

推荐&#xff1a;使用 NSDT场景编辑器 助你快速搭建3D应用场景 简而言之&#xff1a;决定从哪种语言开始可能会令人生畏。 不用担心&#xff01;本文将解释 AI 中使用的最流行编程语言背后的基础知识&#xff0c;并帮助您决定首先学习哪种语言。对于每种语言&#xff0c;我们将…...

【linux】2 make/Makefile和gitee

文章目录 一、Linux项目自动化构建工具-make/Makefile1.1 背景1.2 实例代码1.3 原理1.4 项目清理 二、linux下第一个小程序-进度条2.1 行缓冲区2.2 进度条 三、git以及gitee总结 ヾ(๑╹◡╹)&#xff89;" 人总要为过去的懒惰而付出代价ヾ(๑╹◡╹)&#xff89;" 一…...

db-gpt安装指南(docker版本)

1 下载源码 下载v0.3.5的源码&#xff0c;截止今天&#xff08;20230823&#xff09;建议安装这个“稳定”版本。 2 构建镜像 依照自己硬件环境&#xff0c;看看是否要调整一下启动参数。 bash docker/build_all_images.sh \ --base-image nvidia/cuda:11.7.1-devel-ubuntu…...

「Java」《深度解析Java Stream流的优雅数据处理》

《深度解析Java Stream流的优雅数据处理》 一、引言1.1 背景1.2 Stream流的意义 二、Stream流的基本概念2.1 什么是Stream流2.2 Stream与传统集合的对比 三、创建Stream流3.1 通过集合创建Stream3.2 使用Arrays和Stream.of创建Stream3.3 从文件和网络流创建Stream 四、 中间操作…...

【云驻共创】华为云之手把手教你搭建IoT物联网应用充电桩实时监控大屏

文章目录 前言1.什么是充电桩2.什么是IOT3.什么是端、边、云、应用协同4.什么是Astro轻应用 一、玩转lOT动态实时大屏&#xff08;线下实际操作&#xff09;1.Astro轻应用说明1.1 场景说明1.2 资费说明1.3 整体流程 2.操作步骤2.1 开通设备接入服务2.2 创建产品2.3 注册设备2.4…...

Hadoop分布式计算与资源调度:打开专业江湖的魔幻之门

文章目录 版权声明一 分布式计算概述1.1 分布式计算1.2 分布式&#xff08;数据&#xff09;计算模式1.3 小结 二 MapReduce概述2.1 分布式计算框架 - MapReduce2.2 MapReduce执行原理2.3 小结 三 YARN概述3.1 YARN & MapReduce3.2 资源调度3.3 程序的资源调度3.4 YARN的资…...

为什么叫源表?源表是如何四象限工作的?

为何称呼为源表&#xff1f; “源”为电压源和电流源&#xff0c;“表”为测量表&#xff1b; “源表”即指一种可作为四象限的电压源或电流源提供精确的电压或电流&#xff0c;同时可同步测量电流值或电压值的测量仪表。&#xff08;恒流源时测电压&#xff0c;恒压源时测电…...

云原生周刊:Kubernetes v1.28 正式发布 | 2023.8.21

开源项目推荐 kurt 一个 Kubernetes 插件&#xff0c;可提供 Kubernetes 集群中重启内容的上下文信息。 Kubean Kubean 是一个基于 kubespray 的 Kubernetes 集群生命周期管理工具。 k8sgpt k8sgpt 是一款用简单的英语扫描 Kubernetes 集群、诊断和分流问题的工具。 它将…...

重庆茶叶网站建设/推广营销网络

性能测试需求分析 性能测试需求分析与传统的功能测试需求有所不同&#xff0c;功能测试需求分析重点在于从用户层面分析被测对象的功能性、易用性等质量特性&#xff0c;性能测试则需要从终端用户应用、系统架构设计、硬件配置等多个纬度分析系统可能存在性能瓶颈的业务。 性…...

wordpress 角色权限/成都网络营销公司排名

http://www.icbc.com.cn/ https://mybank.icbc.com.cn/ HTTPS的通信过程 总的可以分为3大阶段 ① TCP的3次握手 ② TLS的连接 ③ HTTP请求和响应 TLS 1.2 的连接&#xff08;ECDHE密钥交换算法&#xff09; wireshark 抓包 tcp port 443 控制端口 ip.addr xxx.xxx.xxx.x…...

杭州房产网二手房/南昌seo方案

Vector3(x,y,z)x代表左右&#xff0c;y代表上下&#xff0c;z代表前后 Vector3.magnitude 长度 计算两点之间的距离 。如果只给了一点的话。算出的长度其实就是和Vector3.zero点之间的长度 公式&#xff1a;a2b2c2&#xff08;勾股定理&#xff09; 2D:3D: 计算机实现&…...

高明做网站/百度移动首页

译者注&#xff1a;gitlabhq gitolite是目前为止个人认为最好用的 git 中心库管理系统&#xff0c;但是其安装配置不是一般的复杂&#xff0c;找了半天没发现完整的中文安装文档&#xff0c;只好依靠自己蹩脚的英文班门弄斧下&#xff0c;若有错误还请见谅。 原文地址&#xf…...

小红书推广文案怎么写/佛山企业用seo策略

https://zhuanlan.zhihu.com/p/28010894 https://www.zhihu.com/question/20021164 classmethod staticmethod 定义: 高层模块不应该依赖低层模块, 二者都应该依赖其抽象, 抽象不应该依赖细节, 细节应该依赖抽象 问题由来: A直接依赖B, 如果将A改为依赖C, 则必须修改A的代码, 解…...

wordpress contact us/企业网站怎么注册

# 面向对象的三大特征 - 继承 - 封装 - 多态 # 继承 - 子类可以使用父类定义的内容或者行为等 - 继承的实现 - 父类&#xff1a;基类&#xff0c;超类&#xff1a;被继承的类&#xff0c; Base Class, Super Class - 子类&#xff1a;有继承行为的类 - 所有类都必须有…...