10-5-Linux操作系统---中断、异常及系统调用.ppt

10-5-Linux操作系统---中断、异常及系统调用.ppt

  1. 1、本文档共25页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多

(4)最后do_IRQ()函数要检查是否有软中断,如有则调用do_softirq()执行软中断。(5)跳转到ret_from_intr退出,恢复中断前的现场。10.5.5 软中断──中断处理的下半部分问题背景:在响应中断并进行处理的时候往往会关闭中断,而在此期间完全可能有多个设备发出中断请求,所以希望能够尽快地响应中断以免中断丢失。Linux的解决办法──中断处理分为两部分(1)硬中断(做最关键的事情)CPU响应中断。关闭中断,确认中断,把中断设备的数据包从硬件缓冲拷贝到内核空间(如果有的话),做标记用来激活下半部分,开中断。**10.5??中断、异常及系统调用内容中断/异常的基本知识异常的处理系统调用中断的处理软中断10.5.1中断/异常的基本知识异常由CPU产生,同步中断产生的通常情况是执行指令却遇上异常情况,常见的异常有除零、溢出及页面异常等。另一种情况种是使用int指令,Linux使用该指令来实现系统调用。中断分为可屏蔽的和不可屏蔽的两类,由一些硬件设备产生,可以在指令执行的任意时刻产生中断/异常的发生都将导致核心态代码的运行中断即可能发生在用户态,也可能发生在核心态,并且中断的嵌套发生往往是允许的。异常大部分发生在用户态,但是页面异常可能发生在核心态。异常也最多可能两层嵌套,绝大多数情况是只有一级异常异常的处理过程中可能产生中断,反之则不可能中断向量表IDTIDT是中断/异常处理在内核的入口。IDT表项还记录了一些其它信息用以安全检查。IDT在系统初始化时创建。每个中断/异常都有一个向量号,该号的值在0-255之间,该值是中断/异常在IDT中的索引。每个中断/异常均有其相应的处理函数,中断/异常在使用前必须在IDT中注册信息以保证发生中断/异常时能找到相应的处理函数。IDT中向量号的使用情况如下:0-31异常与非屏蔽中断使用。32-47可屏蔽中断使用32至47128(0x80)实现系统调用。其余未使用保存现场发生异常时在核心栈的程序计数器eip的值取决于具体情况。一般情况下eip保存的下一条指令的地址,但对于页面异常,保存的产生异常的这条指令的地址而不是下一条指令的地址10.5.2异常的处理函数异常处理的一般流程如下:(1)保存大多数寄存器的值到核心模式栈上。(2)调用相应的处理函数。(3)跳转到ret_from_exception标号处退出。大多数异常处理函数的过程是:(1)硬件错误码和异常向量号存入当前进程。(2)发出一个相应的信号给当前进程非上述情况的例子:页面异常structtask_struct*tsk=current;/*current为当前进程*/tsk->thread.error_code=error_code;/*error_code为硬件错误码*/tsk->thread.trap_no=trapnr;/*trapnr为异常向量号*/if(info)force_sig_info(signr,info,tsk);elseforce_sig(signr,tsk);从ret_from_exception处返回用户空间时,将会检查进程是否有信号等待处理。如果有,则看进程是否有自己的信号处理函数,有则调用它,否则采用内核对信号的缺省处理,一般是将该进程杀死。10.5.3系统调用用户程序通过系统调用切换到核心态从而可以访问相应的资源。这样做的好处是:使编程更加容易。有利于系统安全。接口统一有利于移植。系统调用的执行过程。以fork()为例,在libc库相应的实现有如下的语句:movl$2,%eaxint$0x80int$0x80指令是所有系统调用的统一入口,fork()系统调用的编号为2。系统在初始化设置了0x80号异常的处理函数为sys_call(),该函数执行下面一条语句:call*SYMBOL_NAME(sys_call_table)(,%eax,4)sys_call_table为系统调用表,该表保存的是各个系统调用的入口地址,下面列出了系统调用表的最前面三项:ENTRY(sys_

文档评论(0)

177****7891 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档