Intel8086处理器使用NASM汇编语言实现操作系统18-保护模式与特权级概述

本文主要是介绍Intel8086处理器使用NASM汇编语言实现操作系统18-保护模式与特权级概述,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

实模式下,任意程序,可以操作任意内存位置,为了避免这种情况的发生,所以有了保护模式,保护的就是用户程序之间的相互隔离(当然了,外挂之类的那都是后文要说的了,暂不考虑)

80386及它以后的处理器,都支持三种模式
1.实模式

x86是32位的cpu,所以无法运行早期8086那种16位汇编程序的时候,为了能运行16位程序,这种方式就叫做实模式,计算机启动的时候,是从实模式开始启动的,包括我们如今的电脑

2.保护模式

支持多个任务,每个任务都有自己的内存,且互相不干扰,可以理解成多进程

3.虚拟86模式

实模式有个缺点,就是它是单进程的,因为8086就这样,为了支持多进程,其实就是为了支持32位程序和16位程序能一起运行,这就出现了虚拟86模式,该模式是保护模式的一个子模式,因为这是建立在保护模式基础上的

特权级

CPU采用下面的方式进行优化
1.乱序执行
2.指令流水行(微指令,深度)->分支预测
3.寄存器重命名->隐退
4.地址回绕(第21根地址线,进入保护模式很麻烦)

特权级
特权级分为0-3,0特权级最高,3最低
0:操作系统的权限是0特权级,用来处理任意端口数据,任意设置CPU运行模式和状态,处理任意一段内存
1和2:驱动和一些服务的特权级是1或者2
3:最后用户程序的特权级是3

lgdt,lldt,ltr等等等等很多指令只能有特权为0的指令才能执行,实模式的代码是特权级=0,即使进入保护模式,也是特权级=0,in,out指令也有特权级

注意:特权级不是作用于程序上的概念,而是具体到某个段上的,一个程序所有代码段都具有相同的特权级,如果一个程序的特权级3,那么就意味着该程序所有代码段的特权级都是3,反过来也一样

当前特权级:CPL,当前执行的代码段的特权级,在段描述符高速缓存器中
,在段寄存器最低2位(保护模式中)

描述符特权级:DPL

代码段:不允许高特权级的段转移到低特权级的段(低访问高)
数据段:代码段A如果访问某个数据段B,A的CPL必须大于B的DPL(高访问低)

原则上低特权级的代码段不能跳转到高特权级的代码段,但是如果将高特权代码段设置成依从的代码段,那么就可以,如果不使用依从的代码段,还有方法二,通过调用门

特权级和表格检查,包括栈切换,都浪费时间。所以说用户态切换到内核态很费时间

这篇关于Intel8086处理器使用NASM汇编语言实现操作系统18-保护模式与特权级概述的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java的volatile和sychronized底层实现原理解析

《Java的volatile和sychronized底层实现原理解析》文章详细介绍了Java中的synchronized和volatile关键字的底层实现原理,包括字节码层面、JVM层面的实现细节,以... 目录1. 概览2. Synchronized2.1 字节码层面2.2 JVM层面2.2.1 ente

Linux下修改hostname的三种实现方式

《Linux下修改hostname的三种实现方式》:本文主要介绍Linux下修改hostname的三种实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux下修改ho编程stname三种方式方法1:修改配置文件方法2:hFvEWEostnamectl命

Java使用Mail构建邮件功能的完整指南

《Java使用Mail构建邮件功能的完整指南》JavaMailAPI是一个功能强大的工具,它可以帮助开发者轻松实现邮件的发送与接收功能,本文将介绍如何使用JavaMail发送和接收邮件,希望对大家有所... 目录1、简述2、主要特点3、发送样例3.1 发送纯文本邮件3.2 发送 html 邮件3.3 发送带

Java实现数据库图片上传功能详解

《Java实现数据库图片上传功能详解》这篇文章主要为大家详细介绍了如何使用Java实现数据库图片上传功能,包含从数据库拿图片传递前端渲染,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、前言2、数据库搭建&nbsChina编程p; 3、后端实现将图片存储进数据库4、后端实现从数据库取出图片给前端5、前端拿到

Java实现将byte[]转换为File对象

《Java实现将byte[]转换为File对象》这篇文章将通过一个简单的例子为大家演示Java如何实现byte[]转换为File对象,并将其上传到外部服务器,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言1. 问题背景2. 环境准备3. 实现步骤3.1 从 URL 获取图片字节数据3.2 将字节数组

Win32下C++实现快速获取硬盘分区信息

《Win32下C++实现快速获取硬盘分区信息》这篇文章主要为大家详细介绍了Win32下C++如何实现快速获取硬盘分区信息,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 实现代码CDiskDriveUtils.h#pragma once #include <wtypesbase

Nginx实现前端灰度发布

《Nginx实现前端灰度发布》灰度发布是一种重要的策略,它允许我们在不影响所有用户的情况下,逐步推出新功能或更新,通过灰度发布,我们可以测试新版本的稳定性和性能,下面就来介绍一下前端灰度发布的使用,感... 目录前言一、基于权重的流量分配二、基于 Cookie 的分流三、基于请求头的分流四、基于请求参数的分

使用DeepSeek搭建个人知识库(在笔记本电脑上)

《使用DeepSeek搭建个人知识库(在笔记本电脑上)》本文介绍了如何在笔记本电脑上使用DeepSeek和开源工具搭建个人知识库,通过安装DeepSeek和RAGFlow,并使用CherryStudi... 目录部署环境软件清单安装DeepSeek安装Cherry Studio安装RAGFlow设置知识库总

Python Excel实现自动添加编号

《PythonExcel实现自动添加编号》这篇文章主要为大家详细介绍了如何使用Python在Excel中实现自动添加编号效果,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、背景介绍2、库的安装3、核心代码4、完整代码1、背景介绍简单的说,就是在Excel中有一列h=会有重复

Python FastAPI入门安装使用

《PythonFastAPI入门安装使用》FastAPI是一个现代、快速的PythonWeb框架,用于构建API,它基于Python3.6+的类型提示特性,使得代码更加简洁且易于绶护,这篇文章主要介... 目录第一节:FastAPI入门一、FastAPI框架介绍什么是ASGI服务(WSGI)二、FastAP