3-2存储系统-主存与CPU的连接外部存储器

news2025/1/10 19:01:59

文章目录

  • 一.主存与CPU的连接
    • (一)连接原理
    • (二)主存容量的扩展
      • 1.位扩展法
      • 2.字扩展法
      • 3.字位同时扩展法
    • (三)存储芯片的地址分配和片选
      • 1.线选法
      • 2.译码片选法
  • 二.外部存储器
    • (一)磁盘储存器
      • 1.磁盘存储器
      • 2.磁盘阵列RAID
    • (二)固态硬盘

一.主存与CPU的连接

(一)连接原理

1.主存通过数据总线、地址总线和控制总线与CPU连接
2.数据总线的位数与工作频率的乘机正比于数据传输率
3.地址总线的位数决定了可寻址的最大内存空间
4.控制总线指出总线周期类型和本次输入/出操作完成的时刻

在这里插入图片描述

(二)主存容量的扩展

1.位扩展法

CPU的数据线数与存储芯片的数据位数不一定相等,此时必须对存储芯片扩位,使其数据位数与CPU的数据线数相等。
在这里插入图片描述
位扩展的连接方式是将多个存储芯片的地址端、片选端和读写控制端相应并联,数据端分别引出。位扩展用多个存储器件对字长进行扩充,增加存储字长,可以更好的发挥数据总线的数据传输能力
在这里插入图片描述
扩展完成。将8片8K×1位的存储芯片,扩展为1个8K×8位的存储器,容量为8KB

在这里插入图片描述

2.字扩展法

字扩展指增加存储器中字的数量,而位数不变。更好的利用CPU的寻址能力

在这里插入图片描述

3.字位同时扩展法

既增加存储字的数量(字),又增加存储字长(位)

①图中共8块芯片,每两块为一组,实现位扩展。
②16K=214,因此芯片内的地址需要用14位表示,可以把A0~A13作为片内地址,剩余的A14、A15高位地址接2-4译码器,正好对应4个片选信号。每一组的存储芯片有16K个存储单元,每个单元可以存8位(16K×8位)。四组即可达到64K×8位,即进行了字扩展
第一组芯片地址范围:0000 0000 0000 0000~0011 1111 1111 1111
第二组芯片地址范围:0100 0000 0000 0000~0111 1111 1111 1111
第三组芯片地址范围:1000 0000 0000 0000~1011 1111 1111 1111
第四组芯片地址范围:1100 0000 0000 0000~1111 1111 1111 1111
可以看出整个地址范围从全0到全1,连续不间断。

在这里插入图片描述

  • 简述内存(主存)扩展的方式
    (1)位扩展法:增加数据线(增加存储字长)
    (2)字扩展法:增加地址线(增加存储字的数量)
    (3)字位同时扩展法:存储芯片的字长和存储单元同时增加(存储字的数量和存储字长同时增加)

(三)存储芯片的地址分配和片选

CPU要实现对存储单元的访问,首先要选择存储芯片,即片选。选中的芯片按照地址码选择相应的存储单元,以进行数据的存取,即字选。片内的字选通常是由CPU送出的N条低位地址线完成的,地址线直接连接到所有存储芯片的地址输入端。

片选信号的产生分为线选法和译码片选法

1.线选法

通过地址线直接对芯片进行选择,若CPU有n条多余地址线,可以对应n个片选信号
优点:不需要地址译码器,线路简单
缺点:地址空间不连续,不能充分利用系统存储空间,造成地址资源浪费

A13为1,A14为0,表示左边芯片的片选信号有效,CPU提供的低13位地址只会读取出左边芯片对应存储单元的8bit数据。反之同理。片选地址线每次寻址时只能有一位有效,不允许同时有多位有效,这样才能保证每次只选中一个芯片。因此00和11开头的地址不能用,因此地址空间不连续。

左边地址范围:010 0000 0000 0000~011 1111 1111 1111
右边地址范围:100 0000 0000 0000~101 1111 1111 1111

在这里插入图片描述

2.译码片选法

通过非门,保证给左右两芯片的信号相反。地址空间连续电路复杂

这里的非门叫做1-2译码器,即一个输入,两个(21个)输出。若有3个输入端,可以对应为23=8种状态。如果CPU给出n位地址信息,通过译码器的翻译,可以得到2n个片选信号

如果给定000,则译码器的0号片选线会被选通(图3-8译码器)
在这里插入图片描述

①若A13给1,左边有效。左边地址范围:10 0000 0000 0000~11 1111 1111 1111
②若A13给0,取反为1,右边有效。右边地址范围:00 0000 0000 0000~01 1111 1111 1111
在这里插入图片描述
【使用译码片选法进行字扩展】
A14、A13均为0时,则0号选通线被选通
A14、A13分别为0和1,则1号选通线被选通

因此,此芯片(0号选通线指向的芯片)的地址范围是:000 0000 0000 0000~001 1111 1111 1111
在这里插入图片描述
同理,A14和A13分别为11时,3号选通线被选通,对应芯片的地址范围是:110 0000 0000 0000~111 1111 1111 1111

可以看出,整个主存合法的地址空间从全0到全1,地址范围是连续的。
在这里插入图片描述
此外,若接A15和A13,使得A14任意,则地址会翻倍
如选通线0对应芯片的范围(A15和A13均为0):
0000 0000 0000 0000~0001 1111 1111 1111(A14为0)
0100 0000 0000 0000~0101 1111 1111 1111(A14为1)
使得16K个地址对应到8K个存储单元上,因此实际应用中不会采用
在这里插入图片描述
若想充分利用A15,可以更换为3-8译码器,再增加四片8K×8位的存储芯片即可

【两类译码器】
不带圆圈的表示高电平有效,带圆圈的表示低电平有效

在这里插入图片描述

使能端(有圆0有效,无圆1有效,均有效才能工作):CPU可使用译码器的使能端控制片选信号的生效时间。CPU先通过地址线送出地址信号,待地址信号(电信号)稳定后再发出主存请求信号,再激活译码器使能端。

在这里插入图片描述

二.外部存储器

计算机的外存储器又称为辅助存储器,目前主要使用磁表面存储器。

(一)磁盘储存器

优点:①存储容量大,位价格低;②记录介质可重复使用;③记录信息可长期保存而不丢失,甚至可脱机存档;④非破坏性读出,读出时不需要再生。
缺点:存取速度慢,机械结构复杂,对工作环境要求较高。

详见操作系统-磁盘:4-3文件管理-磁盘组织与管理

1.磁盘存储器

(1)磁盘存储器的组成
磁盘驱动器(核心部件是磁头组件和盘片组件)、磁盘控制器(硬盘存储器和主机的接口)、盘片
(2)存储区域
一块硬盘含有若干记录面(盘面),每个记录面划分为若干磁道,而每条磁道又划分为若干扇区,扇区(也称块)是磁盘读写的最小单位,即磁盘按块存取。

在这里插入图片描述
在这里插入图片描述
(3)磁记录管理
磁头和磁性记录介质相对运动时,通过电磁转换完成读/写操作

按某种方案(规律),把一连串的二进制信息变换成存储介质磁层中一个磁化翻转状态的序列,并使读/写控制电路容易、可靠地实现转换。

磁记录方式:调频制(FM)、改进型调频制(MFM)

(4)磁盘的性能指标
①记录密度
盘片单位面积上记录的二进制信息量。记录密度是指,通常以道密度、位密度和面密度表示。
道密度是沿磁盘半径方向单位长度上的磁道数(如60道/cm表示1cm内有60个磁道),位密度是磁道单位长度上能记录的二进制代码位数(如600bit/cm表示每厘米的磁道可以存储600bit信息。同一扇区各磁道存储的比特数相等,即靠近内侧的磁道位密度要大),面密度是位密度和道密度的乘积。

②磁盘的容量
磁盘容量有非格式化容量和格式化容量两类。
非格式化容量是指磁记录表面可利用的磁化单元总数,它由道密度和位密度计算而来;格式化容量是指按照某种特定的记录格式所能存储信息的总量。
格式化后的容量比非格式化容量要小。

③平均存取时间
平均存取时间=寻道时间(磁头移动到目的磁道的时间)+旋转延迟时间(磁头定位到要读写扇区的时间,一般取转半圈的时间)+传输时间(传输数据所花费的时间)

在这里插入图片描述

④数据传输率
磁盘存储器在单位时间内向主机传送数据的字节数。设磁盘转数为r转/秒,每条磁道容量为N字节,则数据传输率为r×N

(5)磁盘地址
磁盘地址为(驱动器号(选中硬盘),柱面号(磁道号),盘面号、扇区号)

在这里插入图片描述

(6)磁盘的工作过程
硬盘的主要操作是寻址、读盘、写盘。每个操作都对应一个控制字,硬盘工作时,第一步是取控制字,第二步是执行控制字。
硬盘属于机械式部件,其读写操作是串行的,不可能在同一时刻既读又写,也不可能在同一时刻读两组数据或写两组数据。

2.磁盘阵列RAID

将多个独立的物理磁盘组成一个独立的逻辑盘,数据在多个物理盘上分割交叉存储、并行访问,具有更好的存储性能、可靠性和安全性。

在RAID1~RAID5几种方案中(可靠性逐渐提升),无论何时有磁盘损坏,都可随时拔出受损的磁盘再插入好的磁盘,而数据不会损坏,提升了系统的可靠性

(1)RAID0:无冗余和无校验(没有容错能力)的磁盘阵列。类似于低位交叉编址的多体存储器,并行访问,速度提升。

在这里插入图片描述
在这里插入图片描述

(2)RAID1:镜像磁盘阵列,存两份相同数据,可以按要求选择磁盘访问,提升速度;当某磁盘数据损坏时也可找到备份。但有冗余,容量减少一半,存在空间浪费。

在这里插入图片描述

(3)RAID2:采用纠错的海明码的磁盘阵列。类似于低位交叉编址的多体存储器,并行访问,速度提升。增加4、5、6磁盘进行校验,相当于RAID0的优化。

四位信息位,n=4,根据公式n+k≤2k-1,得k=3(满足等式的最小k值),表示校验码为3位,k也叫做需要增加的冗余信息位。结合n=4得到共7位。海明码只能纠正一位差错(单比特错误)。并且冗余信息位占用的存储空间数优于RAID1的镜像磁盘阵列

海明码详见此链接

在这里插入图片描述

(4)RAID3:位交叉奇偶校验的磁盘阵列
(5)RAID4:块交叉奇偶校验的磁盘阵列
(6)RAID5:无独立校验的奇偶校验磁盘阵列

(二)固态硬盘

见操作系统-磁盘:4-3文件管理-磁盘组织与管理-四.固态硬盘SSD

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

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

相关文章

JVM-三色标记

一、什么叫三色标记三色也叫三色抽象,它是所有mutator和collector都必须遵守的定律。它把对象标记为三种颜色:白色:对象还未被垃圾收集器访问,在回收的开始阶段所有的对象均为白色(当然了这只是指概念上的,…

PaddleNLP开源UTC通用文本分类技术,斩获ZeroCLUE、FewCLUE双榜第一

飞桨PaddlePaddle 2023-01-12 20:02 发表于湖北 针对产业级分类场景中任务多样、数据稀缺、标签迁移难度大等挑战,百度提出了一个大一统的通用文本分类技术UTC(Universal Text Classfication)。 UTC在ZeroCLUE和FewCLUE两个榜单上均位居榜首…

css加载会造成阻塞吗?

目录 A.设置网络加载速度 B.css加载会阻塞DOM树的解析渲染吗? 1.css会阻塞DOM树解析? 2.css加载会阻塞DOM树渲染? 3.个人对这种机制的评价 3.css加载会阻塞js运行吗? 4.结论 可以使用以下几种方法解决CSS加载速度的问题: …

曲线曲率介绍和python求法

目录曲率1.1 弧长参数 s参考资料曲率 比如我们想知道曲线 AB\boldsymbol{AB}AB 上任一点处的弯曲程度怎么办呢?这时就需要一个十分重要的概念——曲率。 维基百科: 在数学中,曲率(curvature)是描述几何体弯曲程度的量…

Octave安装与使用

1. 介绍 Octave是一种编程语言,旨在解决线性和非线性的数值计算问题。Octave为GNU项目下的开源软件,早期版本为命令行交互方式,4.0.0版本发布基于QT编写的GUI交互界面。Octave语法与Matlab语法非常接近,可以很容易的将matlab程序…

机器学习/人工智能 实验二:图像特征自动学习方法实践与分析

写在前面 参考的是https://zh.d2l.ai/index.html 一、实验目的与要求 (1)利用基于深度学习的特征自动学习方法完成图像特征提取的实验方案的设计。 (2)编程并利用相关软件完成实验测试,得到实验结果。 (3)通过对实验数据的分析、整理,得出实验结论&am…

Unity | 序列化(Serialized)和反序列化(NonSerialized)是什么意思

一、什么是序列化 官方叙述:序列化是将对象的状态信息转换为可以存储或传输的形式的过程。 人话叙述:我们平时输入的代码,实际上是不能储存或者传输的,所以我们需要翻译一下,翻译成能储存或者翻译的文字,这…

【SpringBoot 学习】52、SpringBoot 使用 grpc 实现远程服务调用

文章目录一、SpringBoot 使用 grpc 实现远程服务调用1、服务端编写2、客户端编写一、SpringBoot 使用 grpc 实现远程服务调用 gRPC 是一个现代的、开源的、高性能的远程过程调用(RPC)框架,可以在任何地方运行。gRPC 使客户端和服务器应用程序…

Java-Thread多线程的使用

Java-Thread多线程的使用一、线程,进程,并发,并行的概念1.进程2.线程3.并发和并行二、线程的创建和使用1.通过继承Thread类,重写run方法2.实现Runnable接口,重写run方法3.使用案例三、线程的常用方法四、线程的退出和中…

关于机器人状态估计(11)-VIO单目与双目/雷达Lidar SLAM/未来的机器人

写这篇文章的时候刚发生行业大事件: Google收购ROS 其实一开始还是水,绝对大量文不对题,但是必有干货,毕竟用的是这个关键的系列标题。 最近有几件行业内发生的大小事,让我觉得有必要更一下。 首先是Livox的mid-360…

VueUse(中文)——核心函数:State相关函数

VueUse官方地址 一、createGlobalState 将状态保持在全局范围内,以便跨Vue实例重用 1、没有持久性(存储在内存中) 例如: 或者 2、持久性存储 使用useStorage()存储在localStorage:例如: 组件使用: 二、createInjectionSt…

【图灵商城】前、后端项目搭建与运行

【图灵商城】前、后端项目搭建与运行 项目介绍 图灵商城-基础班架构图,如下所示: 本节是项目代码的初始化,今天是2023-01-15,先预祝大家新年快乐!!! 图灵商城这个项目是一个前后端分离的项目…

我这是这样知道 React TS 中的 Event Handler 类型的

开头 现在 TypeScript 的发展也越来越成熟,已逐渐应用到我们开发的前端项目之中,它能够带来类型提示,提前规避类型上的错误,来提高项目代码的健壮性,以及更高效的编码效率,前提就是我们需要定义好相应的类…

创客匠人赋能线上瑜伽健身实现流量增长

近年来,我国的儿童、成年人肥胖率逐年攀升。身边发胖的人越来越多,尤其是步入中年的人群,很多都有“发福”的现象。 超重肥胖已经成为影响我国居民健康的重要公共卫生问题。在身材焦虑和疫情肆虐下,很多人开始重视自己的健康问题…

python学习笔记---Python基础【廖雪峰】

Python基础 数据类型和变量 整数 对于很大的数,例如10000000000,很难数清楚0的个数。Python允许在数字中间以_分隔,因此,写成10_000_000_000和10000000000是完全一样的。十六进制数也可以写成0xa1b2_c3d4。 >>> prin…

Qt opencv编译详细教程(windows版)

在Qt中使用opencv这个算法视觉库,前期环境步骤搭建如下: 1、下载cmake。 2、下载opencv库,我这里下载的是opencv-3.3.1版本。 3、没有安装Qt的下载Qt软件,Qt的环境安装部署,这里不做介绍。 4、安装cmake后,…

python学习笔记---IO编程【廖雪峰】

IO编程 ​ IO在计算机中指Input/Output,也就是输入和输出。由于程序和运行时数据是在内存中驻留,由CPU这个超快的计算核心来执行,涉及到数据交换的地方,通常是磁盘、网络等,就需要IO接口。 ​ IO编程中,S…

冒泡排序算法的实现和优化~

冒泡排序算法: 算法思想: 反复扫描待排序记录序列,在扫描的过程中,顺次比较相邻的两个元素的大小,若逆序就交换位置 文字描述该算法: 以升序为例: 依次比较数组中相邻两个元素大小&#xf…

win10+ubuntu23.04双系统安装

win10win10先安装好(确保主板上各个螺丝稳定,至少4对螺丝铜柱,否则会各种蓝屏)如果双系统安装失败了,连win10都进不去了,用原版ISO刻录的U盘或者光驱来修复引导。Easybcd安装Ubuntu23.04使用的ubuntu镜像文…

【项目实战】使用Java Keytool工具生成的CSR给第三方云平台签名

一、背景 客户要求我们提供一个CSR文件,给他们签名,他们的服务器是部署在Amazon上的。 二、Keytool是什么? Keytool 是一种 Java中的数字证书管理工具,用于管理密钥和证书。 它可以用来生成/申请数字证书、导入证书、导出证书、…