linux x86 关机 过程,linux在x86上的中断处理过程(详细)

Linux在x86上的中断处理过程

一:引言

在Intel的文档中,把中断分为两种。一种是异常,也叫同步同断。一种称之为中断,也叫异常中断。同步中断指的是由CPU控制单元产生,之所以称之为同步,是因为只有一条指令执行完毕后才会发出中断。例如除法运算中,除数为零的时候,就会产生一个异常。异步中断是由外部设备按照CPU的时钟随机产生的。例如,网卡检测到一个数据到来就会产生一个中断。

二:x86的中断处理过程

由于中断是开着的,所以当执行完一条指令后,cs和eip这对寄存器中已经包含了下一条将要执行的指令的逻辑地址。在处理那条指令之前,控制单元会检查在运行前一条指令时是否发生了一个中断或异常。如果发生了一个中断和异常,那么控制单元执行下列操作:

1. 确定与中断或异常关联的向量i(0≤ i ≤255)

2. 读由idtr寄存器指向的IDT表中的第i项。

3. 从gdtr寄存器获得GDT的基地址,并在GDT中查找,以读取IDT表项中的选择符标识的段描述符。这个描述符指定中断或异常处理程序所在的段的基地址。

4. 确信中断是由授权的(中断)发生源发出的。首先将当前特权级CPL(存放在cs寄存器的低两位)与段描述符(存放在GDT中)的描述符特权级DPL比较。如果CPL小于DPL,就产生一个“通常保护”异常,因为中断处理程序的特权级不能低于引起中断的程序的特权。对于编程异常,则做进一步的安全检查:比较CPL与处于IDT中的门描述符的DPL,如果DPL小于CPL,就产生一个“通常保护”异常,这最后一个检查可以避免用户应用程序访问特殊的陷阱门和中断门。

5. 检查是否发生了特权级的变化,也就是说,CPL是否不同于所选择的段描述符的DPL。如果是,控制单元必须开始使用与新的特权级相关的栈,通过执行以下步骤来保证这一点:

A. 读tr寄存器,以访问运行进程的TSS段。

B. 用与新特权级相关的栈段和栈指针的正确值装载ss和esp寄存器。这些值可以在TSS中找到。

C. 在新的栈中保存ss和esp以前的值,这些值定义了与旧特权级相关的栈的逻辑地址。

6. 如果故障已发生,用引起异常的指令地址装载cs和eip寄存器,从而使得这条指令能再次被执行。

7. 在栈中保存eflag、cs和eip的内容。

8. 如果异常产生了一个硬件出错码,则将它保存在栈中。

9. 装载cs和eip寄存器,其值分别是IDT表中第i项门描述符的段选择符和偏移量字段。这些值给出了中断或者异常处理程序的第一条指令的逻辑地址。控制单元所执行的最后一步就是跳转到中断或异常处理程序。换句话说,处理完中断信号后,控制单元所执行的指令就是被选中处理程序的第一条指令。

上面的处理过程的描述摘自<>,其中有几点值得注意的地方:

1:通过门后,只能提高运行级别。就像上面所述的 “当前特权级CPL(存放在cs寄存器的低两位)与段描述符(存放在GDT中)的描述符特权级DPL比较。如果CPL小于DPL,就产生一个“通常保护”异常”。在中断处理中,通常把IDT中的相应段选择符设为__KERNEL_CS。即最高的运行级别

2:上面C所述:“在新的栈中保存ss和esp以前的值,这些值定义了与旧特权级相关的栈的逻辑地址”,那ss,esp以前的值是如何找到的呢?应该是从TSS中。在中断发生的时候,如果检测到运行级别发生了改了,将寄存器SS,ESP中的值保存进TSS的相应级别位置。再加载新的SS,ESP的值,然后从TSS中取出旧的SS,ESP值,再压栈。

3:堆栈的改变,如下图所示:

925a04e5db66152fc581af117062e2e0.png

从上图中可以看到,硬件自动保存的硬件环境是非常少,要在中断后恢复到以前的环境,还需要保存更多的寄存器值,这是由操作系统完成的。这在内核的代码中可以看到中断和异常被处理完毕后,相应的处理程序必须产生一条iret指令,把控制权转交给被中断的进程,这将迫使控制单元:

1. 用保存在栈中的值装载cs、eip和eflag寄存器。如果一个硬件出错码曾被压入栈中,并且在eip内容的上面,那么,执行iret指令前必须先弹出这个硬件出错码。

2. 检查处理程序的CPL是否等于cs中的低两位的值。如果是,iret终止返回;否则,转入下一步。

3. 从栈中转载ss和esp寄存器,因此,返回到与旧特权级相关的栈。

4. 检查ds、es、fs及gs段寄存器的内容,如果其中一个寄存器包含的选择符是一个段描述符,并且其DPL值小于CPL,那么,清相关的段寄存器。控制单元这么做是为了禁止用户态的程序利用内核以前所用的段寄存器。如果不清除这些寄存器的话,恶意的用户程序就会利用他们来访问内核地址空间。

注意到4:举例说明一下。如果通过系统调用进入内核态。然后将DS,ES的值赋为__KERNEL_DS(在2。4的内核里),处理完后(调用iret后),恢复CS,EIP的值,此时CS的CPL是3。因为DS,ES被设为了__KERNEL_DS,所以其DPL是0,所以要将DS,ES中的值清除。在2。6内核中,发生中断或异常后,将DS,ES的值设为了__USER_DS,避免了上述的清除过程,提高了效率。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/534768.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

linux 显卡转码,ffmpeg用GPU转码

8种机械键盘轴体对比本人程序员&#xff0c;要买一个写代码的键盘&#xff0c;请问红轴和茶轴怎么选&#xff1f;有些视频编码太屌&#xff0c;播放起来对CPU消耗巨大&#xff0c;而在电视上或者电视盒子上看视频&#xff0c;编码就需要合适&#xff0c;楼主用的FireTV Stick&a…

c语言课程设计作业五子棋,C语言课程设计报告五子棋游戏课程设计

C语言课程设计报告五子棋游戏课程设计 C语言课程设计报告_五子棋游戏-课程设计C语言课程设计报告_五子棋游戏|c语言程序代码编程小程序设计|c语言课程设计报告课程案例**********************************************************//* 本程序在Turbo C或Borland C下编译通过 */…

redis内存淘汰和持久化_redis 持久化

一、RDB持久化&#xff08;一&#xff09;、RDB介绍可以在指定的时间间隔内生成数据集的 时间点快照&#xff08;point-in-time snapshot&#xff09;&#xff0c;新快照会覆盖老快照&#xff08;二&#xff09;、优点压缩格式&#xff0c;恢复速度快&#xff0c;适合于用做备份…

最新变态传奇android,新开变态传奇单职业

新开变态传奇单职业这款传奇手游中拥有这极为丰富的游戏玩法&#xff0c;玩家既可以进入各种副本中&#xff0c;挑战那些强大的副本boss&#xff0c;也可以和自己的兄弟好友们一起组队&#xff0c;前往各种跨服战场&#xff0c;和全服的高手玩家们一起进行最激烈的战斗。游戏中…

android手机微信收藏功能实现,Android模仿微信收藏文件的标签处理功能

最近需要用到微信的标签功能(如下图所示)。该功能可以添加已有标签&#xff0c;也可以自定义标签。也可以删除已编辑菜单。研究了一番。发现还是挺有意思的&#xff0c;模拟实现相关功能。该功能使用类似FlowLayout的功能。Flowlayout为一个开源软件(https://github.com/ApmeM/…

android 电话号码标记,强化电话标记功能 360手机卫士3.0安卓版体验

作为“房产商”&#xff0c;上海仁恒置地集团营销总监姚伟示通常每天也要接到20个左右房产或其他推销电话。“现在已经形成了一个机械的对应方式&#xff0c;对于此类推销电话&#xff0c;很多人包括我自己已经麻木了。”针对这种情况&#xff0c;360手机卫士发布了3.0.0正式版…

android 左滑按钮,android开发类似微信列表向左滑动按钮操作

话不多说&#xff0c;直接上代码&#xff0c;有详细的注释的。layout布局中&#xff1a;主要是跟大家说一下listview怎么写&#xff1a;android:id"id/pull_refresh_viewId"android:layout_width"match_parent"android:layout_height"match_parent&qu…

向量表示 运动抛物线_流动的美丽函数——抛物线浅谈

事先说明&#xff1a;笔者初三&#xff0c;如在叙述中有不严谨的地方&#xff0c;还请诸位指出&#xff0c;自当感激不尽。&#xff08;本文默认受众对象为初高中生&#xff0c;因此抛物线一律采取了yax的形式&#xff0c;高中的同学们可以应用旋转矩阵把它变到y2px的形式QAQ笔…

android 获取已安装 错误代码,android获取手机已经安装的app信息

Android获取手机已安装APP(系统/非系统)效果图主体代码private ListView mlistview;private ListpackageInfoList;private ListapplicationInfoList;private MyAdapter myAdapter;private PackageManager pm;Overrideprotected void onCreate(Bundle savedInstanceState) {supe…

android与ios ui切图关系,APP-IOS与Android界面设计与切图

做一全套的APP设计&#xff0c;流程是&#xff1a;1、界面设计&#xff1a;设计IOS界面&#xff1b;设计Android界面。2、切图&#xff1a;切IOS的2倍图和3倍图&#xff1b;切Android的hdpi,xhdpi,xxhdpi这三个尺寸的图。3、标注&#xff1a;以px为单位标注IOS界面的尺寸&#…

android app应用后台休眠,安卓手机锁屏后程序自动关闭,怎么设置手机app允许锁屏后台运行...

原标题&#xff1a;安卓手机锁屏后程序自动关闭&#xff0c;怎么设置手机app允许锁屏后台运行安卓手机锁屏后&#xff0c;很多程序就会自动关闭&#xff0c;实际上&#xff0c;这是安卓手机的一种保护机制。为了使系统能够流畅稳定的运行以及更加省电&#xff0c;它都会在手机锁…

linux和windows和鸿蒙,linux很好,但为何大家都用Win,鸿蒙系统站错阵营了吗?

原标题&#xff1a;linux很好&#xff0c;但为何大家都用Win&#xff0c;鸿蒙系统站错阵营了吗&#xff1f;由目前已知信息可知&#xff0c;华为“鸿蒙系统”很可能基于linux开源程序搭建&#xff0c;这个特点与苹果微软由很大不同。苹果手机目前主要使用Objective-C程序语言开…

pos共识机制_OK区块链60讲 | 第17集:什么是PoS共识机制

什么是PoS共识机制https://www.zhihu.com/video/1196092110837805056《OK区块链60讲》是由OKEx&#xff06;新浪科技联合出品的区块链科普动画视频&#xff0c;针对区块链零基础用户&#xff0c;通过系列文章、科普动画等形式&#xff0c;从概念、技术、应用等角度&#xff0c;…

ps导出gif颜色不对_PS基础知识(1)

视图平移命令&#xff1a;1,使用工具箱中的抓手工具或着&#xff08;H&#xff09;2按住空格键&#xff0c;上下左右移动视图。&#xff08;常用方法&#xff09;图像格式PSD&#xff1a;原始的图像文件&#xff0c;包含所有的 Photoshop 处理信息&#xff0c;如图层&#xff0…

音乐分享 html,支付宝朋友圈可以分享音乐嘛

打开手机&#xff0c;找到手机里面的支付宝应用点击进入在进入的支付宝界面里&#xff0c;选择底下的朋友点击进入在弹出的朋友界面选择生活圈选择生活圈下方的朋友动态进到朋友动态界面&#xff0c;点击右上角的照相机图标支付宝 怎么发朋友圈动态&#xff1f;进入支付宝页面中…

eplan单线原理图多线原理图_EPLAN-黑盒-2

3、黑盒的功能定义制作完成的黑盒仅仅图形化描述了一个变频器&#xff0c;它实现逻辑上的智能了吗&#xff1f;双击黑盒弹出属性标签&#xff0c;它的主标签还是现实黑盒&#xff0c;如图&#xff0c;图形和逻辑还没匹配。因此&#xff0c;必须为它重新定义功能。EPLAN的功能定…

html图片热点新窗口,HTML基础必看---表单,图片热点,网页划区和拼接详解

html表单里面的图片点击相应图片跳转到本页其他去在表格里面选了这个 鼠标点击一下跳转到相应区块 代码要怎么写&#xff0c;夜影驱动编程小编今天和大家分享大神需要在一张图片上设置多个能点击跳转的链接区域时&#xff0c;推荐使用网页的热点链接。 参考代码如下&#xff1a…

2021辽宁高考艺考成绩查询系统入口,2019年辽宁省艺考统考成绩查询官方入口

2019年辽宁省普通高等学校招生美术类、音乐舞蹈类专业统考成绩已经公布。考生可以通过以下方式查询美术类、音乐舞蹈类专业统考成绩&#xff1a;一、美术类专业统考合格分数线美术类本科专业统考合格分数线为185分&#xff0c;且3门科目中至少有2门各不低于60分;专科专业统考合…

微型计算机硬盘为什么要分区,为什么懂电脑的人,都说硬盘不需要分区?看完你就知道了...

你的电脑有多少个分区呢&#xff1f;当你拿到一台新电脑的时候&#xff0c;一般只能看到一个系统分区。这时候就会开始进行系统分区&#xff0c;将硬盘分为C、D、E等等盘符&#xff0c;用途也各不相同&#xff0c;系统盘&#xff0c;资料盘&#xff0c;娱乐盘等等。似乎所有人都…

php imagecreatefromjpeg图片太大_PHP图像处理技术及应用

基本图像处理技术1体理解&#xff1a;1&#xff0c;创建(得到)一个图像资源(resource)——它相当于一个“画板”(画布)2&#xff0c;在该画板上进行“绘制图线”&#xff1b;3&#xff0c;将该画布输出到网页上显示出来&#xff0c;或保存为图片文件。图像处理技术&#xff0c;…