关于中断,把OS和计组串起来

前述

(个人学习总结而已)
中断就是程序在执行的过程中,因为需要,cpu停下手头工作去做其他的事情。包括硬件提出的中断(外中断:去处理硬件的请求),和程序提出的中断(内中断:异常导致的,和主动进入的)。程序提出的,一般是在用户态提出要使用操作系统的功能(即系统调用),则必须中断,以进入内核态。

例子串讲

用户在代码中使用read(); 读取字节为8个,地址200H至207H。
1、首先将库函数read,通过_systemcall3宏展开,将read转成含有int x80指令的汇编代码,和系统调用的段内偏移号。

2、进入int x80,DPL设为3,用x80传给IDT(x80),即中断向量表,通过中断向量找到系统调用表,并通过偏移找到调用函数sys_read的地址,此时CPL=0。

3、进入内核态,有栈的切换:
在这里插入图片描述
SS: 用户栈的基地址,SP:栈指针;304:中断处的下一条指令的地址;CS:代码段的基地址;1000:系统调用函数的执行处的下一条指令的地址。

4、开始系统调用:sys_read()会传入文件的fd,此时在内核态,可以访问PCB,在里面找到文件打开列表,找到对应的文件指针,在FCB里找到索引表的位置inode,然后传入file_write(inode, file, buf, cout)。文件file里存有读写指针f_pos,即地址200H,用该地址算出逻辑盘块号,再用该盘块号在inode中找到映射,即物理盘块号,再把它和buf,count包装成request,用电梯算法,放入等待队列中。

5.1、启动磁盘:从队列中拿出盘块号,折算成扇区的序号,再换算成地址(柱面号,磁头,扇区号)。将io指令和地址,读信号发到接口,接口通过逻辑电路选择设备——磁盘,磁盘根据地址开始工作。
5.2、同时,执行read的进程(P1)会被阻塞,则需要发生进程切换:操作系统执行,保存现场,切换PCB,切换至P2的核心栈,将该栈弹出,找到用户栈的SS,SP……

6、磁盘将数据传入数据缓冲器DBR,开始中断请求:根据当前磁盘对应的屏蔽字,来确定是否将接口中的状态寄存器里的INTR置为1。假设此时P2的某条指令正在执行,刚结束执行周期时,cpu会查询中断,此时可设置新的屏蔽字,来确定多个中断源的优先级,再通过排队器确定一个中断源进入中断:
在这里插入图片描述
排队器结果如果>=1,说明有中断请求,于是把中断标志INT设为1(这样随后指令能进入中断周期),同时把EINT设为0,即关中断。此刻已进入中断周期,保存断点(见下面第三张图),同时排队器的结果会传给向量形成部件(在CU里),并把向量地址传给PC。
在这里插入图片描述
指令执行阶段的标志:
指令周期的标志
中断周期过程:CU将断点保存的地址(可能是入栈,可能是指令位置)传给MAR,MAR发送地址给内存;CU发出写信号;将PC值放入MDR,MDR传给内存;CU将中断向量地址传给PC……
在这里插入图片描述
7、之后找到中断向量(是个JUMP指令),再找到中断服务程序入口地址。随后将数据缓冲器的数据传入ACC或通用寄存器,然后传给内存。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值