计算机组成原理-第七章 I/O系统 第五节I/O方式

一、程序查询方式

关键词:轮询

cpu先向I/O设备发送读指令,然后不断检查I/O设备的状态,当I/O设备从外部设备读取到数据并且储存带I/O设备数据寄存器中状态寄存器将状态指令修改为0,这是告诉cpu“我准备好了”,你可以进来了,然后把数据取走。程序查询的控制方式中的执行流程如下

 工作流程结构图如下

二、程序中断方式

关键词:中断

CPU中断自己的任务,转而I/O设备进行数据传输,传输完毕之后再开始自己任务。

中断的流程

步骤一:中断请求

中断请求的分类

如下图:(感觉没用,不想记希望不会考) 

中断标记

在cpu中有一个中断的寄存器(可以在cpu中也可以在中断源处)标记不同的中断请求,若是有终端请求则为1没有中断请求则为0(应该使研究生阶段的知识,之前学cpu使并没有说cpu中有这个寄存器,但是我已经预判了这个东西有意隐藏没有展开介绍) 

步骤二:中断判优

判断谁最先执行中断的方式能通过硬件方式实现,也能通过软件方式实现。判优的方式很简单就是通过寄存器中的队列顺序一次执行(巨蠢,应该有更好的判优的方式。)

步骤三:中断响应

CPU响应中断必须满足以下3个条件:

  1. 中断源有中断请求。
  2. CPU允许中断即开中断。
  3. 一条指令执行完毕,且没有更紧迫的任务。

执行流程:开启中断,保存被中断程序的断点,中断结束宠重新执行被中断的程序。

步骤四:中断服务程序寻址

这个我看书没看懂准备听一遍之后再来补充

步骤五:执行中断服务程序

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计算机组成原理到此结束。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值