计算机系统基础知识_体系结构及指令_体系结构指令大全-程序员宅基地

技术标签: 指令集  体系结构  计算机公共知识  

概述

1964年,阿姆达尔(G.M.Amdahl)指出计算机体系结构是程序员角度所看到的的计算机属性,即要编写出正确运行的程序必须了解的概念性结构和功能特性。

1982年,梅尔斯(G.J.Myers)在其所著的《计算机体系结构的进展》一书中定义了组成计算机系统的若干层次,每一层都提供一定功能支持它上面的一层,并把不同层之间的界面定义为体系结构。Myers发展了Amdahl的概念性结构性思想,明确了传统体系结构就是硬件与软件间的界面,即指令集体系结构。

1984年,拜尔(J.L.Baer)在题为”计算机体系结构“的文章中定义:体系结构由结构、组织、实现、性能4个基本方面组成。其中,结构指计算机系统硬件的互联;组织指各种部件的动态联系与管理;实现指模块设计的组装完成;性能指计算机系统的行为表现。这个定义发展了Amdahl的功能特性思想。显然,计算机系统组织又成为体系结构的子集。

计算机体系结构、组织、实现三者关系如下:

  1. 计算机体系结构(Computer Architecture) 指计算机的概念性结构和功能属性。
  2. 计算机组织(Computer Organization) 指计算机体系结构的逻辑实现,包括数据流和控制流的组成及逻辑设计等,又被称为计算机组成原理。
  3. 计算机实现(Computer Implementation) 指计算机组织的物理实现。

计算机体系结构分类

宏观的来说,可以按处理机的数量分类,分为:

  1. 单处理系统(Uni-processing System)

    利用单一处理单元与外部设备结合,实现存储、计算、通信、输入输出等功能的系统。

  2. 并行处理与多任务处理系统(Parallel Processing and Multiprocessing System)

    将两个以上的处理机互联,彼此进行通信协调,共同求解一个大问题的计算机系统。

  3. 分布式处理系统(Distributed Processing System)

    物理上远距离又低耦合的多计算机系统。其中物理远距离意味着通信时间与处理时间相比已经无法忽略,这也是为什么需要低耦合的主要原因。

微观的来说,可以按并行程度分类,有如下几种分类法:

  1. Flynn分类法

    由M.J.Flynn于1966年提出,按指令流和数据流的数量进行分类。指令流为指令序列,数据流为指令所使用的数据序列。主要分为如下4类:

    • 单指令流、单数据流(SISD, Single Instruction stream Single Data stream)
    • 单指令流、多数据流(SIMD, Single Instruction stream Multiple Data stream)
    • 多指令流、单数据流(MISD, Multiple Instruction stream Single Data stream)
    • 多指令流、多数据流(MIMD, Multiple Instruction stream Multiple Data stream)
  2. 冯式分类法

    由冯泽云于1972年提出,按最大并行度进行分类,所谓最大并行度(Pm)即计算机系统在单位时间内能处理的最大二进制位数。主要分为如下4类:

    • 字串行、位串行(WSBS, Word Serial and Bit Serial)
    • 字并行、位串行(WPBS, Word Parallel and Bit Serial)
    • 字串行、位并行(WSBP, Word Serial and Bit Parallel)
    • 字并行、位并行(WPBP, Word Parallel and Bit Parallel)
  3. Handler分类法

    由Wolfgang Handler(汉德勒)于1977年提出,按硬件并行程度计算并行度的方法,将结构分为3个层次:处理机级、每个处理机中算数逻辑单元、每个算数逻辑单元中逻辑门电路级。然后分别计算每一级可以并行或流水处理的程序,以此求出系统并行度。

  4. Kuck分类法

    由David J.Kuck于1978年提出的与Flynn分类法类似的分类,但用的是指令流和执行流,也分为如下4类:

    • 单指令流、单执行流(SISE, Single Instruction stream Single Execution stream)
    • 单指令流、多执行流(SIME, Single Instruction stream Multiple Execution stream)
    • 多指令流、单执行流(MISE, Multiple Instruction stream Single Execution stream)
    • 多指令流、多执行流(MIME, Multiple Instruction stream Multiple Execution stream)

下图是按照Flynn分类的计算机结构示例:

Flynn

指令系统

一个处理器支持的指令和指令的字节级编码就称为指令体系结构(ISA, Instruction Set Architecture),不同的处理器支持不同的指令集体系结构。因此程序有时候能在一种处理器上运行但无法在另外一种处理器上运行。

指令集体系结构的分类

按体系结构的观点来对指令集分类,可以根据以下5个方面分类:

  1. 操作数在CPU中存储方式,即从主存取出后放在什么位置
  2. 显式操作数的数量,即典型指令中能包含的操作数个数
  3. 操作数的位置,即任一ALU指令的操作数能否位于主存中
  4. 指令的操作,即指令集提供的操作
  5. 操作数的类型和大小

按暂存机制分类,可以根据以下3个方面分类:

  1. 栈(Stack)
  2. 累加器(Accumulator)
  3. 寄存器组(a set of Registers)

CISC和RISC

指令集的发展历史中,曾出现过两种流派,一种是让单个指令能干更复杂的工作,另一种则反之,下面来简单了解一下。

复杂指令集计算机(Complex Instruction Set Computer)

因曾经计算机硬件非常昂贵,因此其基本思想是增强指令功能,用更复杂的新指令来取代子指令的功能来提升工作效率,但随着发展其已经越来越臃肿,反而在某种程度上影响效率。

Intel x86就是典型的CISC结构体系,Intel经常推出新的指令,但又不得不考虑兼容性保留以前的指令,其结果就是导致解码系统设计及其复杂。

但这种结构由于指令比较丰富,可以减少程序语言编译器的设计难度,但其仍有无法忽视的弊端:

  1. 指令集过于庞杂。
  2. 微程序技术是CISC的核心,每条复杂指令都经过一段解释性微程序来实现,这就导致需要多个CPU周期,降低处理效率。
  3. 指令集庞大虽然便于程序语言编译器的设计,但过多可选择的指令也会导致编译器本身冗长复杂,难以优化。
  4. CISC强调完善的中断控制会导致设计复杂、研制周期长。
  5. CISC芯片设计困难,出错几率大,导致其芯片种类繁多。

精简指令集计算机(Reduced Instruction Set Computer)

它的基本思想和CISC相反,通过减少指令的数量和功能,使硬件设计更为容易,指令尽量在单周期运行。通过优化编译来提高执行速度。其部分关键技术如下:

  1. 重叠寄存器窗口(Overlapping Register Windows)

    在处理机中设置大量的寄存器,并划分成一个一个“窗口”,每个过程都可以使用相邻的3个窗口和1个公共窗口。这些窗口中有一个来自上个过程,有一个与下个过程公用。这样一来过程间的结果传递就轻松许多。

  2. 优化编译技术

    前面提到,RISC设置大量的寄存器,因此优化编译使得尽可能的利用寄存器就是提高效率的最好方式。

  3. 超流水及超标量技术

  4. 硬布线逻辑与微程序结合

指令优化

面向目标程序的优化思路就是对程序中的出现的各种指令进行统计分析,得出静态和动态的使用频度。按使用频度来针对性的改进目标代码。大量统计表明,动态和静态使用频度之间非常接近。这种方式是CISC的主要优化方式。

面向高级程序语言的优化思路就是尽可能缩小高级语言和机器语言之间的语义差距,利于缩短编译的过程和编译后程序长度。

面向操作系统的优化思路则要着重于缩小操作系统与体积结构间的语义差距,利于减少操作系统运行所需的辅助时间,实际上,有很多指令都是专门为了实现操作系统而设计的。

指令的流水线

指令的执行有多个控制方式,有以按指令顺序串行执行的顺序方式;有在一条指令完成前就开始解释下一条的重叠方式;还有模仿工业生产的流水方式,将重复的处理过程分成一个一个模块单独处理;

顺序方式的缺点即是效率过低,机器可能会出现部分部件长期处于等待的状态。而重叠在顺序之上稍作优化,但通常采用的是一次重叠,即最多只会解释下一条,这样一来速度确实有所提高,但需要考虑潜在的指令冲突、转移的相关问题。

而现在最主要的是流水方式,下面将详细介绍一下。

流水(Pipelining)

该技术是将并行性或并发性嵌入计算系统的形式,通过将重复的过程拆解成一个个子任务,这些子任务都可以在专用又独立的模块上有效并发工作。

如下图:

Pipelining for instruction

可以看到这种方式把一条指令拆解成几个不同的子过程来执行,这样一来机器的整体吞吐率就会上升。流水线的方式和重叠有一点类似,可以将流水看做是重叠的延伸

流水的分类

根据不同的分类标准,流水又可分为多种不同的类型:

  1. 按级别分类:

    • 部件级流水,又叫做运算操作流水线(Arithmetic Pipelines)
    • 处理机级流水,又叫做指令流水线(Instruction Pipelines),即本文主要讲的,将一条指令分解为多个子过程同时执行。
    • 系统级流水,又叫做宏流水线(Macro Pipelines)
  2. 按功能分类:

    • 单功能流水线,单条流水线只能完成一种固定任务的流水线

    • 多功能流水线,通过不同的连接方式就能实现不同功能的流水线,Texas公司的ASC处理机就是一个典型,如下图:

      Multifunction Pipeline

  3. 按连接分类:

    • 静态流水线,同一时间段只能按照一种固定的方式连接,实现固定的功能的流水线,前面提到的TI-ASC处理机就是静态流水线。
    • 动态流水线,同一时间段流水线能以不同方式连接,实现不同功能的流水线,但这种流水线是有限制的,流水线中的各个部件不能冲突的同时使用。

    下图展示了它们之间的区别,静态流水线中只有浮点加法全部流水后才能使用定点乘法,而动态则不然。

    Static&Dynamic Pipeline

  4. 按反馈回路分类:

    • 线性流水线,模块只能经过一次的流水线

    • 非线性流水线,存在反馈回路,某功能能多次通过的流水线,如下图:

      Non-Linear Pipeline

除了上面这些常见的,还有按流动顺序分类的同步流水线和异步流水线;按处理数据分类的向量流水线和标量流水线等。

流水相关的处理方式

由于流水存在多条指令被同时解释执行的过程,就有可能对同一寄存器或同一主存进行先写后读的可能,这时就出现了相关。相关又分为两类:

  1. 局部性相关

    这种相关包括指令相关、内存访问相关、通用寄存器相关等。这种相关一般不会造成大范围的影响,它只影响相关的两条或数条指令,而且最多影响部分流水线推后,不影响指令缓冲中预取出的指令,因此也称为局部性相关。

    解决这种相关有推后法和通路法,前者推后相关单元读取,直至写入完成。后者则设计特殊通路,直接取得运算结果,无需等待写入完成。

  2. 全局性相关

    这种相关则较为严重,主要是条件转移指令,它可能会使得指令缓冲中预读的指令无效,需要被修改。从而造成流水线效率下降,所以称为全局性相关。

    解决这种相关主要使用转移分支猜测技术、提前形成条件码技术、加快短循环等方式。一般来说,条件转移存在两个分支,通过猜测其中一种分支来加快流水线的处理效率,这也是现代计算机最常使用的手段。而提前形成条件码主要是通过某些数学特性,如乘法运算很容易就可以得知结果的正负等,这样一来就可以帮助进行猜测或提前转移。最后的加快段循环则是将小的循环指令整体放入指令缓冲中,大大提升循环的执行效率。

流水技术

  • 超流水线(Super Pipeline)

    通过细化流水,增加级数,提高主频,使单个时间周期内能完成一个甚至两个浮点操作,其实质是用时间换空间。

    超流水机器的特征是所有的功能单元都采用流水线,并且有更深的流水深度,比流水线机器具备更多的级数。但由于它仅限于指令级并行,所以这种机器的**每指令周期(CPI, Clock Cycles Per Instruction)**都会稍高。

  • 超标量(Super Scalar)

    与超流水相比是通过内装多条流水线来同时执行,以此来换取更高的CPI,其实质是用空间换时间。

  • 超长指令字(VLIW, Very Long Instruction Word)

    这个技术较为特殊,虽然和超标量一样目的都是共同执行多条指令,但它不同于超标量通过增加流水线来实现高效的并行处理,而是通过软件将若干个无关联的指令压缩成一个执行来实现。理论上它与超标量是等价的。

流水吞吐率与建立时间

吞吐率即单位时间内流出的结果率,对指令而言即单位时间内执行的指令数量。如果流水线的子过程所用时间不一,那么吞吐率p应为最长子过程的倒数: p = 1 / m a x { Δ t 1 , Δ t 2 , … , Δ t m } p = 1 / max \{ \Delta t_1, \Delta t_2, \dots , \Delta t_m \} p=1/max{ Δt1,Δt2,,Δtm}

从其原理可以看出来,流水线要达到最大效率是需要时间的,需要各级都满载,那么需要的时间就叫做建立时间。若m个子过程的所用时间一致均为 Δ t 0 \Delta t_0 Δt0,则建立时间为 T 0 = m Δ t 0 T_0 = m \Delta t_0 T0=mΔt0

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

智能推荐

免费 TR069 管理系统ACS - XACS_tr069管理系统免费-程序员宅基地

文章浏览阅读2.7w次,点赞7次,收藏15次。TR069管理系统(XACS)基于TR069协议实现的管理系统,可支持海量CPE的管理及测试。免费使用,免费测试,支持标准RPC。实现的内容主要有· 1. CPE集中管理· 2. CPE分类管理· 3. 配置模板管理及自动化下发· 4. CPE软件版本自动升级管理· 5. CPE系统日志自动备份管理· 6. CPE系统配置自动备份管理· 7. ..._tr069管理系统免费

Maven打包编译找不到com.sun.crypto.provider.SunJCE类-程序员宅基地

文章浏览阅读2.9k次。Maven配置    <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <version>3.6.0</version> <c..._com.sun.crypto.providersunjce_provider

PyQt5 打包没有icon图标,百度方法没用,终极解决之道究竟在哪(pyinstaller打包成exe文件,双击打开,没有显示图标)_把pyinstaller 生成的exe移动到别的文件夹,图标消失怎么办-程序员宅基地

文章浏览阅读4.3k次,点赞9次,收藏45次。在分享之前,先爆下粗口,wtfk。太难了,整整折腾了一下午。才搞定。pyqt5打包成exe,程序有图标,但是双击打开的任务栏和窗口都没有显示图标。百度的方法基本上用烂掉了。解决不了。最后在一个犄角旮旯的地方找到了解决方案:问题复现打包命令:pyinstaller -F -w -i favicon.ico update.py程序显示图标了,但是点进去,图标没了!直接在p..._把pyinstaller 生成的exe移动到别的文件夹,图标消失怎么办

Zynq7020_PS端 uart驱动编写-程序员宅基地

文章浏览阅读2.7k次,点赞2次,收藏22次。刚接触 zynq 网上资料也很少,整起来也比较难受。ps、pl 还有SDK。这些东西第一次用都得了解。如果你是个arm工程师,PL部分可以不用怎么了解,只要学习简单的新建硬件流就可以了。主要学习使用的是SDK。在使用方面还得对SDK进行一些配置。 所以记录自己学习zynq的过程。开发板用的是黑金的。下面开始吧!!!!一、串口初始化XScuGic Intc // 中断XGpioPs g_sGpioInstance; // gpioXUartPs Uart..._ps端 uart

Web服务器和客户端_客户端构建的运行环境-程序员宅基地

文章浏览阅读4.6k次。1 实验目的1) 掌握Java Socket编程应用;2) 阅读HTTP协议相关规范;3) 基于Java Socket构建简单的HTTP的客户端和服务器;4) 构建支持并发的HTTP服务器。资源在底部下载2 实验内容1) 阅读RFC1945和RFC2068文档。了解HTTP/1.0和HTTP/1.1的相关规范和标准,对比HTTP/1.0和HTTP/1.1的区别。..._客户端构建的运行环境

dp问题之fast food_fast food dp-程序员宅基地

文章浏览阅读114次。对于这个问题我刚开始看时,感觉没有思路,不过让我想到了了中位数,但是中位数只有一个但是这道题不只有一个,涉及商店和仓库,应该是二位dp用dp[i][j]表示,但是i和j分别代表什么?值得考虑一下,可以让i表示仓库,j表示商店,而dp的表示前j个商店有i个仓库的所有距离和,则第i-1个仓库(即之前的一个状态)假设在第k个,要不要选这个仓库,得比较一下选前与选后距离和的变化如果选了的话如何来表示呢?迎来第二个难题,这个思想来源是中位数思想,第k+1个到j个(即第i个仓库要不要选)如果选了的话与当前的dp值在_fast food dp

随便推点

运维人最爱的八本书,送给十一不出门的你-程序员宅基地

文章浏览阅读8.9k次,点赞2次,收藏15次。12闲来无事拾书籍十一长假已经过去一半,今天小编给大家安利几本书,陪宅在家或者旅游在外的同学们度过漫长岁月~( ̄▽ ̄~)~中国数据中心运维管理指针作者 钟景华本书以数据中心为背景,从数据中心全生命周期管理的角度,围绕数据中心运维管理、数据中心监控系统、数据中心基础设施管理三个方面,定义系统概念,描述系统架构确立性能指标,规范设计与施工_数据中心运维必读书籍有哪些

【Ubuntu】命令行安装deb安装包_ubuntu mingling anzhuang deb-程序员宅基地

文章浏览阅读1.6k次。如果ubuntu要安装新软件,已有deb安装包(例如:iptux.deb),但是无法登录到桌面环境。那该怎么安装?答案是:使用dpkg命令。dpkg命令常用格式如下:sudo dpkg -I iptux.deb#查看iptux.deb软件包的详细信息,包括软件名称、版本以及大小等(其中-I等价于--info)sudo dpkg -c iptux.deb#查看iptux.deb软件包中包_ubuntu mingling anzhuang deb

Guava Cache原理_guava cache原理 csdn-程序员宅基地

文章浏览阅读469次。基本用法构建 public static void initCache(LoadingCache cache) throws ExecutionException { for(int i =1;i<=3;i++){ //连接数据源 ,如果缓存没有就读取数据源 cache.get(String.valueOf(i)); } } /** * 获得当前缓存的记录 * @pa_guava cache原理 csdn

记录:多种方法实现文字超出省略号显示 css/js_链接文字超过最大长度省略号显示-程序员宅基地

文章浏览阅读559次。超出文字,变省略号的多种实现方式描述CSS方式实现情况一:一行溢出情况二:多行溢出正常情况(中文)异常情况(英文,数字,符号等)总结JS方式实现问题部分:(英文和其他)最终方式:视觉欺骗描述超出文字变省略号的实现方式有多种。在这里简单列出来几种。然后在最后,根据特殊需求。有【展开全部】式样的需求的实现。CSS方式实现情况一:一行溢出<div class="content1-css"> <div class="contentText1-css">这里是数据,有可能会超过_链接文字超过最大长度省略号显示

Java程序员如何顺利拿下阿里P6的offer?(面试篇)-程序员宅基地

文章浏览阅读175次。本屌现今四年开发经验;前前后后为进阿里面试十次(阿里旗下——蚂蚁金服,天猫的offer都被hr因学历而被拒,最后的菜鸟面幸运的被录用,拿到P6offer,真正的“十面”阿里!)。本文前半部分主要分享面试总结,后半部分分享程序员我个人架构开发之路的学习经验。阿里十面面试总结虽然天猫,蚂蚁金,菜鸟都归属阿里旗下,但每个面试官问的问题都不一样,相同点主要在流程方面。面试开始会让自我介绍,主要业务架构和技..._csdn资源java高级程序员面试阿里p6必备宝典

Faster RCNN代码理解(Python)-程序员宅基地

文章浏览阅读460次。转自http://www.infocool.net/kb/Python/201611/209696.html#原文地址第一步,准备从train_faster_rcnn_alt_opt.py入:初始化参数:args = parse_args() 采用的是Python的argparse主要有–net_name,–gpu,–cfg等(在cfg中只是修改了几个参数,其他大部分参数在con..._缩放尺度8,16,32