一、程序查询方式
关键词:轮询
cpu先向I/O设备发送读指令,然后不断检查I/O设备的状态,当I/O设备从外部设备读取到数据并且储存带I/O设备数据寄存器中状态寄存器将状态指令修改为0,这是告诉cpu“我准备好了”,你可以进来了,然后把数据取走。程序查询的控制方式中的执行流程如下
工作流程结构图如下
二、程序中断方式
关键词:中断
CPU中断自己的任务,转而I/O设备进行数据传输,传输完毕之后再开始自己任务。
中断的流程
步骤一:中断请求
中断请求的分类
如下图:(感觉没用,不想记希望不会考)
中断标记
在cpu中有一个中断的寄存器(可以在cpu中也可以在中断源处)标记不同的中断请求,若是有终端请求则为1没有中断请求则为0(应该使研究生阶段的知识,之前学cpu使并没有说cpu中有这个寄存器,但是我已经预判了这个东西有意隐藏没有展开介绍)
步骤二:中断判优
判断谁最先执行中断的方式能通过硬件方式实现,也能通过软件方式实现。判优的方式很简单就是通过寄存器中的队列顺序一次执行(巨蠢,应该有更好的判优的方式。)
步骤三:中断响应
CPU响应中断必须满足以下3个条件:
- 中断源有中断请求。
- CPU允许中断即开中断。
- 一条指令执行完毕,且没有更紧迫的任务。
执行流程:开启中断,保存被中断程序的断点,中断结束宠重新执行被中断的程序。
步骤四:中断服务程序寻址
这个我看书没看懂准备听一遍之后再来补充
步骤五:执行中断服务程序
cpu执行中断程序时有两种方式一种使执行中断的过程中屏蔽其他中断,单重终端,一种是执行中断的过程中允许其他的中断程序发生,多重中断。
在多重中断中只允许更高优先级的中断程序的发生。
三、DMA方式
程序查询和中断的数据流向I/O设备-cpu-内存
但是DMA方式的I/O设备数据流向为I/O设备-内存。
每次读取数据都需要cpu发送一次命令,而且只能发送一个或者多个连续的块数据。
DMA控制器及其功能
DMA的核心结构是DMAC其中DMAC的核心结构如下图
DMA工作流程
cpu命令-地址寄存器-寻址取数据-数据寄存器-发送DMA请求给CPU-CPU响应-获取主线的控制权-数据传输到内存,字节计数寄存器+1,若发生寄存器溢出,则让中断机构发送中断请求,本轮传输结束。
DMA和CPU同时访问主存时会发生冲突,计算机处理这种冲突的方式有三种:
1、停止cpu访问
2、DMA和cpu交替访问
3、周期挪动
4、DMA方式和中断方式的对比
四、通道控制方式
和上一章的内容相同,并没有其他的展开。
ok计算机组成原理到此结束。