美文网首页
第四章:处理器体系结构

第四章:处理器体系结构

作者: 加大装益达 | 来源:发表于2017-12-05 21:04 被阅读112次

处理器体系结构

一个处理器支持的指令和指令的字节级编码称为它的指令集体系结构(Instruction-Set Architecture,ISA)。

Y86-64指令集体系结构

程序员可见状态

Y86-64程序中的每条指令都会读取或修改处理器状态的某些部分,这称为程序员可见状态。


4.1.1.png

每个程序寄存器存储一个64位的字。寄存器%rsp被入栈、出栈、调用和返回指令作为栈指针,除此之外寄存器没有固定的含义或固定值。条件码ZF、SF、OF保存着最近的算术或逻辑指令所造成影响的有关信息。程序计数器PC存放当前正在执行指令的地址。

内存从概念上说是一个很大的字节数组,保存着程序和数据。Y86-64程序用虚拟地址来引用内存位置。硬件和操作系统软件联合起来将虚拟地址翻译成实际或物理地址,指明数据实际存在内存中哪个地方。

状态码Stat表明程序执行的总体状态,会指示是正常运行还是出现了某种异常。

Y86-64指令

4.1.2.png
  • movq指令分成了4个不同指令:irmovq,rrmovq,mrmovq,rmmovq,分别显式的指明源和目的的格式,源可以时立即数i,寄存器r,内存m。指令名字第一个字母表明源的类型。目的可以是寄存器或内存,第二个字母指明了目的类型。
  • 有4个整数操作指令,addq、subq、andq、xorq,只对寄存器数据进行操作。这些指令会设置三个条件码,ZF零,SF符号,OF溢出。
  • 7个跳转指令,jmp,jle,jl,je,jne,jge,jg。根据指令的类型和条件代码的设置来选择分支。
  • 6个条件传送指令,cmovle,cmovl,cmove,cmovne,cmovge,cmovq。这些指令的格式与寄存器-寄存器传送指令rrmovq一样,但是只有当条件码满足所需要的约束时,才会更新目的寄存器的值。
  • call指令将返回地址入栈,然后跳转到目的地址,ret指令从这样的调用中返回。
  • pushq和popq指令实现了入栈和出栈。
  • halt指令停止指令的执行,执行halt指令会导致处理器停止,并将状态码设置为HLT。

指令编码

每条指令需要1-10个字节不等。每条指令的第一个字节表明指令的类型,这个字节分为两个部分,高4位是代码code部分,低4位是功能function部分。

4.1.3.png

15个程序寄存器中每一个都有一个相对应的范围在0到0xE之间的寄存器标识符Register ID。

Y86-64异常

状态码:AOK表示程序执行正常,其他的代码表示发生了某种类型的异常。HLT表示处理器执行了一条halt指令。ADR表示处理器试图从一个非法内存地址读或者向一个非法内存地址写。INS表示遇到了非法的指令代码。

逻辑设计和硬件控制语言HCL

大多数现代电路技术都是用信号线上的高电压或低电压来表示不同的位值,当前技术中,逻辑1是用1.0伏特左右的高电压表示的,逻辑0是用0.0伏特左右的低电压表示的。

实现一个数字系统,需要三个主要组成部分:计算对位进行操作的函数的组合逻辑,存储位的存储器单元,控制存储器单元更新的时钟信号。

逻辑门

逻辑门是数字电路的基本计算单元。

组合电路和HCL布尔表达式

将很多的逻辑门组合成一个网,就能构建计算块,成为组合电路。

字级的组合电路和HCL整数表达式

算术/逻辑单元ALU。

集合关系

存储器和时钟

组合电路从本质上讲,不存储任何信息。相反,它们只是简单的 相应输入信号,产生等于输入的某个函数的输出。为了产生时序电路,也就是有状态并且在这个状态上进行计算的系统,我们必须引入按位存储信息的设备。存储设备都是由同一个时钟控制的,时钟是一个周期性信号,决定什么时候要把新值加载到设备中。

  • 时钟寄存器,存储单个位或字,时钟信号控制寄存器加载输入值。
  • 随即访问存储器,存储多个字,用地址来选择该读或写哪个字。

Y86-64的顺序实现

将处理组织成阶段

  • 取指fetch,取指阶段从内存读取指令字节,地址为程序计数器PC的值,从指令中抽取出指令指示符字节的两个四位部分,称为icode指令代码和ifun指令功能。
  • 译码decode,译码阶段从寄存器文件读入最多两个操作数。
  • 执行execute,在执行阶段,算术/逻辑单元ALU要么执行指令指明的操作,计算内存引用的有效地址,要么增加或减少指针。
  • 访存memory,访存阶段可以将数据写入内存,或者从内存读出数据。
  • 写回write back,写回阶段最多可以写两个结果到寄存器文件。
  • 更新PC PC update,将PC设置成下一条指令的地址。

SEQ硬件结构

流水线的通用原理

(未完成)

相关文章

  • 12.27 嵌入式

    郭老师今天介绍了ARM Cotrex-M3体系结构,包括处理器核结构,内核为哈佛体系结构,处理器工作模式,寄存器,...

  • 第四章:处理器体系结构

    处理器体系结构 一个处理器支持的指令和指令的字节级编码称为它的指令集体系结构(Instruction-Set Ar...

  • ARM体系结构与汇编指令

    ARM体系结构 ARMnTDMI ARM处理器状态 ARM状态:32位,处理器执行字方式的ARM指令,处理器在系统...

  • ARM处理器体系架构详细说明

    ARM 体系结构是构建每个 ARM 处理器的基础。ARM 体系结构随着时间的推移不断发展,其中包含的体系结构功能可...

  • 第一章 第二章 导论/操作系统结构

    计算机系统的体系结构 单处理器系统 多处理器系统2.1 对称多处理 (Symmetric MultiProcess...

  • 第四章:处理器体系结构

    本章通过一个精简的指令集Y86-64,对处理器的体系结构进行了一个较为系统地介绍。主要包括指令的构成,处理器执行指...

  • ARM课程-(NO.6.寄存器)

    ARM ARM体系结构的数据存储方式 处理器用于存储数据的方式有:大端小端法 ARM9处理器微处理器支持字节(8字...

  • 12月27日

    郭老师今天讲的是ARM Cotrex-M3体系结构,主要是从这几方面讲的 1.处理器核结构,内核为哈佛体系结构 2...

  • 《计算机组成与体系结构》——2.2性能设计

    芯片组成和体系结构的改进 有三种办法可以实现处理器的提速: 提高处理器硬件速度:这个提速基本上要归功于处理器芯片上...

  • jmeter体系结构及基本原理。

    1,体系结构拆分成三个纬度。 x:负载模拟的一个过程,包括5个部分:取样器,(前置处理器,配置元件,后置处理器),...

网友评论

      本文标题:第四章:处理器体系结构

      本文链接:https://www.haomeiwen.com/subject/aqkhixtx.html