写点什么

寄存器基本原理介绍(上篇)

  • 2019-10-26
  • 本文字数:2279 字

    阅读完需:约 7 分钟

寄存器基本原理介绍(上篇)

寄存器的类型众多,简要阐述几个最重要的,在此之前先来看看存储单元和总线


存储单元一般应具有存储数据和读写数据的功能,以 8 位二进制作为一个存储单元,也就是一个字节。每个单元有一个地址,是一个整数编码,可以表示为二进制整数。程序中的变量和主存储器的存储单元相对应。变量的名字对应着存储单元的地址,变量内容对应着单元所存储的数据。存储地址一般用十六进制数表示,而每一个存储器地址中又存放着一组二进制(或十六进制)表示的数,通常称为该地址的内容。


存储器被划分为若干个存储单元,编号顺序是从 0 开始,,比如一个和存储器有 100 个存储单元,那么他的编号就是 0-99。


微型储存器的容量是以字节为最小单位来计算的,对于拥有 100 的存储单元的存储器,他的容量是 100 个字节。


以上说到,存储器被划分为多个存储单元,从零开始编号,就像是一条街上的门牌号一样,那么 CPU 要读取这些数据,就像是在这一条街里找这个门牌号一样,先要确定在哪里住。


由此可见,CPU 要相对数据进行读写,必须和芯片进行下面 3 类交互:


  • 存储单元的地址(地址信息)

  • 器件的选择,读或者写命令(控制信息)

  • 读或写的数据(数据信息)


那么,CPU 是如何让将这些新词传输到存储器的芯片中的,这就涉及到一个概念,我们都知道,计算机能够处理的信息都是电信号,也就是高低电平,电信号当然是由导线来传送。在计算机中,由专门连接 CPU 和其他芯片的导线,我们通常称为总线,总线从物理的概念来讲,就是一根根导线的集合。根据传出信息的不同,总线从逻辑上讲主要分为 3 类:地址总线,控制总线以及数据总线。



分析上图,三个基础导线首先 CPU 通过地址线将信息发出,然后通过控制线发出内存读写任务,选中存储器芯片,并命令从中读取数据,最后通过数据线将数据送入 CPU。


接下来,详细介绍一下。

地址总线

现在,我们知道 CPU 是通过地址总线来指定存储单元的,那么可见地址总线上能传递多少不同的信息,就能对多少个存贮单元进行寻址。


现在假设,一个 CPU 有 10 根地址线,一根导线能传递的状态只有两种,一种是高电平,一种是低电平,就是二进制的 0 和 1,那么 10 根导线就是 10 位 2 进制数据,那么 10 位进制能组成多少不同的数据呢?2 的 10 次方个,最小为 0,最大是 1023。如果一个 CPU 由 N 根地址总线,那么可以说这个 CPU 的地址总线的宽度为 N,这样的 CPU 最多可以寻找 2 的 N 次方个内存单元。


地址总线由微处理器产生,主要用来存储输入输出接口,传送地址信息,是一条单向总线。



上图就是对地址总线一个简单的概述,帮助大家理解。上图共有 5 条地址线,一次传输五位二进制数。

数据总线

数据总线主要负责 CPU 与其他部件的数据传送,数据总线的宽度决定了 CPU 和外界的数据传输速度,8 根数据线一次性可传送一个 8 位二进制数,也就是一根一个数据,共一个字节,16 根就是传输两个字节。


数据总线是一条双向总线,CPU 和其他部件的双向传输信号。


8088CPU 的数据总线宽度为 8,8086CPU 的数据总线宽度为 16,8086 的数据传送要快一些。

控制总线

控制总线控制外部器件,控制总线只是一个总称,其实是由一些不同的控制线集合,有多少根控制总线就意味着对外部器件有多少种控制,控制总线决定着 CPU 对外部器件的控制能力。


控制总线主要传输控制信号、时序信号和状态信号,也是一条双向总线。


以上简单说了总线相关的问题,对于理解寄存器有很大帮助,接下来聊聊寄存器。寄存器是中央处理器内的组成部分,寄存器是有限存储容量的高速存储部件,可用来暂存指令、数据和地址。


寄存器是集成电路中非常重要的一种存储单元,通常由触发器组成。在集成电路设计中,寄存器可分为电路内部使用的寄存器和充当内外部接口的寄存器这两类。内部寄存器不能被外部电路或软件访问,只是为内部电路的实现存储功能或满足电路的时序要求,而接口寄存器可以同时被内部电路和外部电路或软件访问,CPU 中的寄存器就是其中一种,作为软硬件的接口,为广泛的通用编程用户所熟知。


在计算机领域,寄存器是 CPU 内部的元件,包括通用寄存器、专用寄存器和控制寄存器。寄存器拥有非常高的读写速度,所以在寄存器之间数据传送非常快。不同的 CPU 寄存器是不相同的,在此以 8086CPU 为例,8086CPU 一共有 14 个寄存器。这里不依次介绍,先介绍最主要的。

通用寄存器

8086CPU 所有的寄存器都是 16 位的,可以存放两个字节。AX、BX、CX 和 DX 这四个寄存器主要用来存放一般性数据,也称为通用寄存器。以 AX 为例,来看下其内部结构。



上图只是一个简易的逻辑图,每一个小格就是一个存储单元,一共 16 个 ,编号 0-15,左边是高位,右边低位,这四个寄存器每一个 8 位都可以当作独立的寄存器来使用:


  • AX 可以分为 AH 和 AL

  • BX 可以分为 BH 和 BL

  • CX 可以分为 CH 和 CL

  • DX 可以分为 DH 和 DL


AX 的低八位,也就是 0 到 7 位,构成了 AL 寄存器,高八位,8 到 15 位,构成了 AH 寄存器,AH 和 AL 是可以独立使用的 8 位寄存器。例如,数据 1001 1100 0100 000(4E20H)是在寄存器中的数据。



寄存器 AH(4EH)



寄存器 AH(20H)


由此可见,在寄存器中高位存高位,当然以后会涉及到大端小端的问题,目前只需要理解高位存高位,低位存低位就可以了。


最后简单介绍计算机中较为常用的单位。我们大家应该都了解基本的换算单位,1KB=1024B,1MB=1024KB,1GB=1024MB,1TB=1024GB。在这个里面有一个新的单位—字(word),一个字由两个字节构成,这两个字节称为这个字的高位字节和低位字节,这就能够很好的理解通用寄存器的问题,一个通用寄存器是 16 位,两个字节也就是一个字,AH 就是对应的高位字节,AL 也就是低位字节,这两个字节可以划分为两个独立的数据。


2019-10-26 08:008337

评论

发布
暂无评论
发现更多内容

向量化执行引擎框架 Gluten 宣布正式开源,并亮相 Spark 技术峰会

Kyligence

spark Gluten

音视频开发进阶|第四讲:音频自动增益控制 AGC

ZEGO即构

音视频开发 AGC

龙蜥开发者说:社区首个支持 LoongArch架构的操作系统构建之路 | 第 9 期

OpenAnolis小助手

开源 操作系统 龙蜥开发者说 龙芯 LoongArch 架构

如何快速有效的定位应用抖动问题?| 龙蜥技术

OpenAnolis小助手

Linux 系统 龙蜥技术 SysAK 抖动

查找——B-树

乔乔

7月月更

语音质量监控

Damon

7月月更

边无际 Shifu IoT 开源开发框架 助力物联网应用开发加速十倍

亚马逊云科技 (Amazon Web Services)

开源 Kubernetes 物联网 应用开发

不会吧!钉钉都下载了,你还不知道可以这样玩?

Jianmu

钉钉 持续集成 自动化运维 建木CI 通知

TPC藏宝计划质押系统开发(Dapp)

薇電13242772558

智能合约 dapp

模块七作业 - 王者荣耀商城异地多活架构设计

Elvis FAN

2022年浙江省等保备案流程指南

行云管家

等保 等保备案

Kyligence 正式支持 Amazon EMR Serverless,构建高效低成本云上数据分析

Kyligence

Cloud Kyligence Amazon EMR

Okaleido或杀出NFT重围,你看好它吗?

鳄鱼视界

python小知识-rethinking python 生成器

AIWeker

Python python小知识 7月月更

B站挂了登上全网热搜!技术人员为你还原前因后果

雨果

nacos注册中心之服务注册

急需上岸的小谢

7月月更

《黑客与画家》作者:18 个会杀死初创公司的错误

雨果

创业者

4 个 JavaScript 最基础的问题 —— Eric Elliott

掘金安东尼

JavaScript 面试 前端 7月月更

云计算和大数据的关系以及区别详细讲解

行云管家

云计算 大大数据

即刻报名|前沿技术探索:如何让 Spark 更强劲、更灵活

Kyligence

spark 开源

TiKV & TiFlash 加速复杂业务查询

TiDB 社区干货传送门

声网传输层协议 AUT 的总结与展望丨Dev for Dev 专栏

声网

传输协议 Dev for Dev

jdbc自带MySQL连接池实践

FunTester

异想天开 | 假如用中文写代码,是一种什么体验?

雨果

程序员 开发者

SAP Fiori Launchpad 应用的两个实用技巧分享

汪子熙

JavaScript SAP SAP UI5 ui5 7月月更

还在羡慕其它平台有跨店满减,其实你也可以!

CRMEB

MySQL数据库优化

五分钟学大数据

MySQL 7月月更

Google上网神器Ghelper

源字节1号

软件开发 小程序开发

CSS重复线性渐变之画格子

南城FE

CSS 前端 7月月更

ABAP-OOALV实现

桥下本有油菜花

SAP abap

Lite Actor:方舟Actor并发模型的轻量级优化

HarmonyOS开发者

HarmonyOS

寄存器基本原理介绍(上篇)_语言 & 开发_周澳_InfoQ精选文章