从功能层次,阐述CPU、接口和外设之间的交互

在这里插入图片描述

我们从功能抽象层次,阐述一下CPU、接口芯片和外设之间的交互情况:

  • 三个器件
  • 4个箭头

我们依次将其描述清楚。

数据

箭头①和③

CPU给接口可以发送数据,然后接口暂存数据,之后再发给外设,这就是数据缓冲。

发送的数据,是外设数据,因为接口的最终目的,就是让CPU处理外设的数据,接口暂存的数据,也是外设数据

控制字与读写控制

这里的接口,都是可编程多功能接口,它自己还有控制字和状态字要存储,那是它自己的数据,不是外设数据。

箭头①

CPU给外设发送控制字,并且让外设能够进行读写(读写控制),这就是所谓的编程,外设就能够被设置为某种工作方式了。

此时发送的二进制信息是控制

这种CPU不管接口状态直接地传控制数据的方式,就是直接控制,程序控制方式,无条件传输数据

状态字

箭头①

CPU有的时候,需要先查询一下,看能不能给外设送数据,得先问问外设,这就是查询控制方式
在这里插入图片描述

箭头②

如何此时外设是允许的,将会发送状态字给CPU,告诉它,可以给我发数据,或者,不行你先等着吧。
在这里插入图片描述
在接口与外设,也发生着同样的事情,(箭头③)接口看看外设是不是存在,能不能发数据,然后(箭头④)外设告诉接口,可以可以,或者,不行不行,你等着吧。
在这里插入图片描述
到这里,我们阐述的都是

  • CPU负责外设数据的传送和处理
  • 接口是多功能可编程芯片

在这个前提下,我们知道了

接口芯片的

  • 数据寄存器
  • 控制字和状态字(都是寄存器)
  • 读写控制、clk、reset

CPU的

  • 外设数据发送
  • 控制字和读写控制发送
  • 查询发送与状态字接收

外设的

  • 外设数据接收
  • 接口查询信号接收
  • 应答发送

这里有一个需要补充的,也没什么好说的,就是外设数据的发送,然后给接口,接口再给CPU。

这就是CPU、接口和外设之间的交互的宏观理解了。

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

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

相关文章

【接口技术】8086的IN和OUT指令

x86采用独立编址的方式,IO端口地址和存储器地址是分开的。 对于IO存储器访问,需要使用独立的IO指令,也就是IN和OUT 两类地址 地址空间大小在8位以下地址空间大小在16位以下 两种格式 对于两类不同的地址,IO指令的格式不一样。…

Vivado工程文件分类

只需要在创建的时候,选择自定义路径即可,最好在原有的new文件夹下新建文件夹。 至于路径的匹配,可以自己试试,在原有默认new下创建文件夹,选中新的文件夹后,内部的Verilog文件可以访问外部new文件夹的文件&…

【微机原理与接口技术】具体芯片(1)并行接口8255A(1):全局观

并行接口8255A 首先,它是传输并行数据的,与CPU一样,然后,它是可编程的,也是多功能的,CPU可以对其进行一些控制。 管脚 先从最宏观层面分类 一部分引脚与外设相连一部分引脚与CPU相连GND和Vcc 注意&…

【微机原理与接口技术】多功能可编程芯片 与 多功能电饭煲

多功能可编程芯片,就像你的多功能电饭煲,你点了不同的按键,就启动了不同的工作方式,是熬粥还是做米饭,之后你又得选择压力和时间。 而在芯片上,你得先设置控制字,也就是 先选择工作方式&#…

什么是地址译码 理解二进制编码

我们知道存储器都是有多个芯片组合而成的,必然涉及到片选,因此我们将地址分开看 前面的一部分,是片选,也就是选中某个芯片(使用译码器,2-4译码器就是2位地址可以选择4个芯片)后面的部分&#x…

【微机原理与接口技术】具体芯片(1)并行接口8255A(2):控制字概述

核心 对于一个多功能可编程接口芯片,我们要想使用它,必须 先确定需求,要用什么芯片去干什么设置芯片的工作方式然后再让芯片工作 至于设置的方式,当然是软件编程。 同时重点注意,例如8255A,它一次只能写…

【算法】【殊途同归】搜索算法之(深度优先 || 广度优先) (约束条件 || 限界函数)

对于所谓的分支限界法和回溯法,我们完全可以更加灵活,请看表格。 深度优先广度优先约束条件限界函数算法策略√√回溯法局部判定√√√分支限界法局部判定√√√加限界的回溯法局部判定√枚举法全局判定√枚举法全局判定 前两种是我们常见的&#xff0c…

【算法】学习方法

看理论学示例做图示 最重要的是 最开始直接抄别人的优秀的代码,就是如此简单,摆正心态,最开始不要非得自己想怎么做。

【算法】学习笔记(0):算法初探(逻辑抽象 + 示例 + 代码实现)

什么是算法? 人生皆算法,算法的本质,是解决问题的方法,遇到问题,寻找答案,解决问题,是作为一个人,一生都在做的事情。 算法是人类思维的产物,是解决问题的方案,并且&a…

【Verilog】数据流建模传输问题:赋值传输有方向

这次,我们说明的是,assign语句实现的数据流建模,包含的是两个层面 建立联系传输方向 assign A B的本质含义是 A与B建立关联B的值传给A 这个传输方向至关重要,实际情况是什么,就必须按照顺序进行,不是单…

【计算机系统设计】实践笔记(2)数据通路构建:第一类R型指令分析(2)

待办事项 时钟频率高,取指周期长,远大于执行周期,如何处理? 不可综合逻辑的处理 接上一篇 【计算机系统设计】实践笔记(2)数据通路构建:第一类R型指令分析(1) 8.2 ALU运…

【计算机系统设计】实践笔记(2)插叙:综合与实现

接上一篇文章的第10节 之前完成了功能仿真,下面我们进行综合实现。 10.1.1 综合 综合成功。 实现试试 这真是令人悲伤……找Bug吧。 我们看看综合后的门级网表。 发现综合后的并不是我们想要的……看了看可能是综合的目录错误,我们再试试。 不是这…

【电路原理】学习笔记(1):电路模型的基本变量

上一讲说到了电路模型,这一电路的抽象,现在我们看看它的基本组成。 1 电流 1.1 概念 对于一根管道,它能够流通电荷,定向移动就形成了电流。 单位时间t内,,某一横截面,穿过电荷量是q&#xf…

【电路原理】学习笔记(0):电路与电路模型

东北大学电路原理MOOC 电路原理的核心点:研究电路模型 我们实际看见的,是真实电路 我们高中学的,是电原理图 现在,我们要研究的是电路模型,它是实际电路的抽象模型,并且是理想化的。 对于电路模型&#…

【计算机系统设计】实践笔记(3)改进数据通路:移位R型指令分析

0 回顾 前面的内容中,第一类R型指令分析,我们完成了一类R型指令的设计,完成了其数据通路,构建了相应的部件,并且完成了从ROM中取指,成功进行了基本的功能仿真,进行了综合和实现,但是…

【计算机系统设计】实践笔记(3)改进数据通路:jr指令分析与实现

1 jr指令分析 instructionoprsrtrdshamtfuncjr000000rs000000000000000001000 举例&#xff1a;jr $31 功能&#xff1a;PC <- &#xff08;$31&#xff09; 这是个跳转指令&#xff0c;将指定寄存器的值&#xff0c;放入PC中&#xff0c;是无条件跳转。 我们需要 更新P…

【计算机系统设计】实践笔记(4)改进数据通路:第一类I型指令分析与实现

0 回顾 之前&#xff0c;我们完成了17条R型指令的设计&#xff0c;接下来&#xff0c;我们逐步完成I型指令的设计。 1 核心思想&#xff1a;增量思维 & 复用思维 & 学会选择 & 分治思想 增量思维 我们从无到有&#xff0c;构建了支持R型指令的CPU&#xff0c;接…

【算法】学习笔记(1):算法就是人类去教会计算机的方法

人生处处皆算法&#xff0c;算法是解决问题之道。 对于计算机科学中的算法&#xff0c;我更喜欢将其理解为利用人类思维之一&#xff1a;计算机思维&#xff0c;去解决一些人类不擅长的问题&#xff0c;比如大量重复运算&#xff0c;然后&#xff0c;人类使用计算机编程语言去…

【算法】学习笔记(2):递归思想

0 回顾 之前的笔记&#xff08;0&#xff09;和笔记&#xff08;1&#xff09;&#xff0c;我们介绍了算法的基本含义&#xff0c;并且举了一些实例&#xff0c;同时理解了&#xff0c;算法就是人类在教计算机做事情&#xff01; 我们知道&#xff0c;算法就是解决问题的方案…

【计算机系统设计】实践笔记(5)插叙:内外有别之CPU和Memory

区分CPU的内外 首先明确&#xff0c;内存&#xff0c;不在CPU内&#xff0c;我们的CPU是会有数据和指令端口的&#xff0c;然后去访问内存和外设。 而CPU设计&#xff0c;我们所说的单周期&#xff0c;多周期和流水线&#xff0c;描述的都是CPU&#xff0c;而不是Memory&…