计组 第三章 系统总线_计组总线-程序员宅基地

技术标签: 计算机组成原理  

计组 第三章 系统总线

一、总线的基本概念

  • 为什么要总线:计算机各个部件之间需要通信,但是不能简单的使用两两连接的方式。

  • 什么是总线:

    • 连接各个部件的信息传输线
    • 是各个部件之间共享的传输介质
  • 总线上信息的传输:

    • 串行,一位一位传输
    • 并行,多位共同传输,不能远距离传输,防止互相之间的干扰​image

二、总线的结构

1、单总线

image

每次只能一对设备传输信息,总线成为瓶颈

2、双总线,以cpu为中心

image

主存和CPU之间的交流繁忙,使用专用的总线
但是CPU为中心导致了CPU的过于繁忙

3、双总线,以主存为中心

image

但是不能同时对主存进行读写操作,主存同时只能对一条总线做数据传输

三、总线分类:

  • 片内总线:芯片内部的总线

  • 系统总线:计算机各个部件之间传输信息的总线

    • 数据总线:双向,与机器字长,存储字长有关

    • 地址总线:单向,与存储地址,io地址有关

    • 控制总线:双向(有出有入),用于传输信号,例如:中断信号,存储信号等等

    • 通信总线:计算机系统之间或计算机系统与其他系统之间的传输信道

      image

总线分类:
  • 片内总线:芯片内部的总线

  • 系统总线:计算机各个部件之间传输信息的总线

    • 数据总线:双向,与机器字长,存储字长有关
    • 地址总线:单向,与存储地址,io地址有关
    • 控制总线:双向,用于传输信号,例如:中断信号,存储信号等等
    • 通信总线:计算机系统之间的传输信道

四、总线的特性和性能指标:

  • 总线物理实现
    在这里插入图片描述
    在主板上将设备插入对应的插槽就完成了总线的连接。

  • 总线特性

    • 机械特性:尺寸,形状,管脚数,排列顺序
    • 电器特性:传输方向和有效电阻范围
    • 功能特性:每根线的具体功能(地址,数据,控制)
    • 时间特性:信号的时序关系
  • 性能指标:

    • 总线宽度:数据线的根数
    • 标志传输率: 每秒传输的最大字节数
    • 时钟同步/异步:不同步、同步
    • 总线复用: 地址线和数据线复用
    • 信号线数 :地址线,数据线和控制线的总和
    • 总线控制方式: 突发,自动,仲裁,逻辑,计数
    • 其他 :负载能力,能为多少IO提供服务
  • 总线标准​image

五、总线结构:

  • 单总线

  • 多总线

    • 双总线

      image

      通道相对于一个简单的CPU,用于IO的管理

    • 三总线

      image另一形式

      image

      cache用于对于主存部分内容进行缓存,原因是主存的速度原因跟不上CPU

    • 四总线

      image

      拓展总线接口:用于连接低速设备

六、总线控制

1、判优控制:
  • 总线同一时间只能有一对设备使用,当多个设备同时发出信号如何处理

  • 基本概念:

    • 主设备:对总线有控制权

    • 从设备:响应从主设备发来的总线命令

    • 判优控制方式:

      • 集中式:集中到一个设备判断

        • 链式查询方式

          image

          *BR:总线请求,所有设备都通过这条线发出总线占用请求
          *BS:总线忙,当某个设备占用了总线控制权,通过总线忙告诉控制部件
          *BG:总线授权
          *当某个设备发出BR,总线控制部件得知,通过BG线判断哪个设备的优先级高,从而得到使用权
          *优先级和io设备的被查询位置有关
          对电路故障敏感,尤其是BG信号

        • 计算机定时查询

          image

          设备地址线:用于标记IO设备,用来询问某个设备是否发出了控制请求
          某个设备发出BR信号,总线控制部件从某设备开始查询(根据计数器决定)当询问到某设备需要总线就发出一个BS信号。获得总线使用权
          *优先级确定灵活,可以通过软件方式
          需要对设备进行编码

        • 独立请求方式

          image

          *每个IO都对总线控制部件有独立的总线连接,总线控制部件内部存在一个排队器进行判优

2、通信控制
  • 目的:通信双方协调配合问题

  • 总线传输周期:完成一次传输需要的时间

    • 申请分配:判优问题
    • 寻址阶段:主设备向从设备给出地址和命令
    • 传输阶段:主设备和从设备交换数据
    • 结束阶段:主设备撤销相关信息
  • 方式:

    • 同步通信:统一时标控制数据传输
    • 异步通信:采用应答方式,没有公共时钟标准
    • 半同步通信:同步异步结合
    • 分离式通信:可以充分发掘总线的效率
  • 同步数据输入
    在这里插入图片描述

    假设一次数据传输使用了四个时钟周期,其中在第一个时钟周期的上升沿,主设备发出地址信号并持续,第二个时钟周期发出读信号,第三个时钟周期从设备需要将需要数据发送到数据线上,第四个时钟周期主设备取消地址的传送和命令的传送。

  • 同步数据输出
    在这里插入图片描述

    先给出数据,保证数据存在,再给出写命令,保证当写命令到达从设备,可以立即将数据写入从设备相应地址中

  • 异步通信
    需要增加两条线路,请求线和应答线
    在这里插入图片描述
    *不互锁:主设备发出请求,从设备接收数据,都到了一段时间断开
    *半互锁:主设备收到从设备的对应自己的请求的回答后再断开

    • Tips:当回答未接收到,但是从设备中断了,会发生主设备的请求持续,这有点类似与TCP/IP协议的四次挥手,当客户端回应了对于服务器的断开连接的请求,这时候客户端进入了time_wait状态持续时间为最大报文生存时间,这就是防止出现,当客户端发送了ACK包,但是服务器没有接收到导致了服务器一直处于连接状态。

    *全互锁:主设备收到对方的回应后再断开
    *这种方式可以做到当一段时间后主设备没有收到从设备的中断回复再发出一次询问,TCP的四次挥手也是作用超时重发FIN包的方式。

  • 半同步通信

    • 为了解决低速设备不能及时提供数据的问题

    • 同步:使用时标的方式

    • 异步:允许不同速度的模块和谐工作

    • 增加一条等待信号线

      image

      当主设备接收到wait信号表示从设备没有准备好数据

    • image

  • 总结上述三种方式:

    • 一个总线传输周期:
      1、主模块发送地址和命令,占用总线
      2、从模块准备数据,不占用总线
      3、从模块发送数据,占用总线
      找到一个合适的方式利用此模块的准备数据的时间,以此来节约时间。
  • 分离式通信:
    1、将总线传输周期分为两个子周期
    2、子周期1:主模块申请占用总线,使用完放弃总线使用权
    3、子周期2:从模块申请占用总线,发送数据
    4、使用这种方式可以充分的利用总线,不会因为从模块准备数据的时间太长而导致作用总线的时间过长,浪费总线资源。

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/m0_74022462/article/details/137018978

智能推荐

海康威视网络摄像头开发流程(五)------- 直播页面测试_ezuikit 测试的url-程序员宅基地

文章浏览阅读3.8k次。1、将下载好的萤石js插件,添加到SoringBoot项目中。位置可参考下图所示。(容易出错的地方,在将js插件在html页面引入时,发生路径错误的问题)所以如果对页面中引入js的路径不清楚,可参考下图所示存放路径。2、将ezuikit.js引入到demo-live.html中。(可直接将如下代码复制到你创建的html页面中)<!DOCTYPE html><html lan..._ezuikit 测试的url

如何确定组态王与多动能RTU的通信方式_组态王ua-程序员宅基地

文章浏览阅读322次。第二步,在弹出的对话框选择,设备驱动—>PLC—>莫迪康—>ModbusRTU—>COM,根据配置软件选择的协议选期期,这里以此为例,然后点击“下一步”。第四步,把使用虚拟串口打勾(GPRS设备),根据需要选择要生成虚拟口,这里以选择KVCOM1为例,然后点击“下一步”设备ID即Modbus地址(1-255) 使用DTU时,为下485接口上的设备地址。第六步,Modbus的从机地址,与配置软件相同,这里以1为例,点击“下一步“第五步,Modbus的从机地址,与配置软件相同,这里以1为例,点击“下一步“_组态王ua

npm超详细安装(包括配置环境变量)!!!npm安装教程(node.js安装教程)_npm安装配置-程序员宅基地

文章浏览阅读9.4k次,点赞22次,收藏19次。安装npm相当于安装node.js,Node.js已自带npm,安装Node.js时会一起安装,npm的作用就是对Node.js依赖的包进行管理,也可以理解为用来安装/卸载Node.js需要装的东西_npm安装配置

火车头采集器AI伪原创【php源码】-程序员宅基地

文章浏览阅读748次,点赞21次,收藏26次。大家好,小编来为大家解答以下问题,python基础训练100题,python入门100例题,现在让我们一起来看看吧!宝子们还在新手村练级的时候,不单要吸入基础知识,夯实自己的理论基础,还要去实际操作练练手啊!由于文章篇幅限制,不可能将100道题全部呈现在此除了这些,下面还有我整理好的基础入门学习资料,视频和讲解文案都很齐全,用来入门绝对靠谱,需要的自提。保证100%免费这不,贴心的我爆肝给大家整理了这份今天给大家分享100道Python练习题。大家一定要给我三连啊~

Linux Ubuntu 安装 Sublime Text (无法使用 wget 命令,使用安装包下载)_ubuntu 安装sumlime text打不开-程序员宅基地

文章浏览阅读1k次。 为了在 Linux ( Ubuntu) 上安装sublime,一般大家都会选择常见的教程或是 sublime 官网教程,然而在国内这种方法可能失效。为此,需要用安装包安装。以下就是使用官网安装包安装的教程。打开 sublime 官网后,点击右上角 download, 或是直接访问点击打开链接,即可看到各个平台上的安装包。选择 Linux 64 位版并下载。下载后,打开终端,进入安装..._ubuntu 安装sumlime text打不开

CrossOver for Mac 2024无需安装 Windows 即可以在 Mac 上运行游戏 Mac运行exe程序和游戏 CrossOver虚拟机 crossover运行免安装游戏包-程序员宅基地

文章浏览阅读563次,点赞13次,收藏6次。CrossOver24是一款类虚拟机软件,专为macOS和Linux用户设计。它的核心技术是Wine,这是一种在Linux和macOS等非Windows操作系统上运行Windows应用程序的开源软件。通过CrossOver24,用户可以在不购买Windows授权或使用传统虚拟机的情况下,直接在Mac或Linux系统上运行Windows软件和游戏。该软件还提供了丰富的功能,如自动配置、无缝集成和实时传输等,以实现高效的跨平台操作体验。

随便推点

一个用聊天的方式让ChatGPT写的线程安全的环形List_为什么gpt一写list就卡-程序员宅基地

文章浏览阅读1.7k次。一个用聊天的方式让ChatGPT帮我写的线程安全的环形List_为什么gpt一写list就卡

Tomcat自带的设置编码Filter-程序员宅基地

文章浏览阅读336次。我们在前面的文章里曾写过Web应用中乱码产生的原因和处理方式,旧文回顾:深度揭秘乱码问题背后的原因及解决方式其中我们提到可以通过Filter的方式来设置请求和响应的encoding,来解..._filterconfig selectencoding

javascript中encodeURI和decodeURI方法使用介绍_js encodeur decodeurl-程序员宅基地

文章浏览阅读651次。转自:http://www.jb51.net/article/36480.htmencodeURI和decodeURI是成对来使用的,因为浏览器的地址栏有中文字符的话,可以会出现不可预期的错误,所以可以encodeURI把非英文字符转化为英文编码,decodeURI可以用来把字符还原回来_js encodeur decodeurl

Android开发——打包apk遇到The destination folder does not exist or is not writeable-程序员宅基地

文章浏览阅读1.9w次,点赞6次,收藏3次。前言在日常的Android开发当中,我们肯定要打包apk。但是今天我打包的时候遇到一个很奇怪的问题Android The destination folder does not exist or is not writeable,大意是目标文件夹不存在或不可写。出现问题的原因以及解决办法上面有说报错的中文大意是:目标文件夹不存在或不可写。其实问题就在我们的打包界面当中图中标红的Desti..._the destination folder does not exist or is not writeable

Eclipse配置高大上环境-程序员宅基地

文章浏览阅读94次。一、配置代码编辑区的样式 <1>打开Eclipse,Help —> Install NewSoftware,界面如下: <2>点击add...,按下图所示操作: name:随意填写,Location:http://eclipse-color-th..._ecplise高大上设置

Linux安装MySQL-5.6.24-1.linux_glibc2.5.x86_64.rpm-bundle.tar_linux mysql 安装 mysql-5.6.24-1.linux_glibc2.5.x86_6-程序员宅基地

文章浏览阅读2.8k次。一,下载mysql:http://dev.mysql.com/downloads/mysql/; 打开页面之后,在Select Platform:下选择linux Generic,如果没有出现Linux的选项,请换一个浏览器试试。我用的谷歌版本不可以,换一个别的浏览器就行了,如果还是不行,需要换一个翻墙的浏览器。 二,下载完后解压缩并放到安装文件夹下: 1、MySQL-client-5.6.2_linux mysql 安装 mysql-5.6.24-1.linux_glibc2.5.x86_64.rpm-bundle