最近学习计算机系统基础,了解到指令集体系结构。

对CPU架构、指令集和指令集体系结构的关系不清楚,特此记录。

指令集体系结构(ISA)包括 指令集、指令集编码、基本数据类型等。

CPU架构 实现了 指令集

------------------------------------------------------------------------------------------------------------------分割线------------------------------------------------------------------------------------------------------------------

下文转自http://blog.csdn.net/u010297957/article/details/49950643

作者:有且仅有

1. 指令集体系结构(Instruction-Set Architecture, ISA)


1.1 定义

一个处理器支持的指令和指令的字节级编码就是这个处理器的ISA,包括很多个部分:

  • 指令集
  • 指令集编码
  • 基本数据类型
  • 一组编程规范
  • 寄存器
  • 寻址模式
  • 存储体系
  • 异常事件处理
  • 中断
  • 外部I/O

不同的处理器家族,例如Intel IA32、IBM/Freescale PowerPC和ARM,都有不同的ISA。维基百科 - Architecture list

1.2 作用

  1. ISA在编译器编写者(CPU软件)和处理器设计人员(CPU硬件)之间提供了一个抽象层

    • 处理器设计者:依据ISA来设计处理器
    • 处理器使用者(如:写编译器的牛*程序员):依据ISA就知道CPU选用的指令集,就知道自己可以使用哪些指令以及遵循哪些规范
  2. 定义处理器上的软件如何构建,这是ISA的最重要内涵,现代处理器都是支持高级语言编程、操作系统等等特性,ISA要定义出指令集内的指令是如何支撑起C语言里堆栈、过程调用,操作系统里异常、中断,多媒体平台里数字图像处理、3D加速等等。

1.3 TIPS

  1. 常见的一个误解的答案:指令集并不存储于CPU中,应该这样说:CPU本身是指令集(结构)的一个实现/实例;
  2. 一个ISA可能包含多个指令集;



2. ISA与微体系结构

ISA只是描述了CPU应该支持的每条指令是做什么事的,即指令的功能。而微体系结构是描述处理器实际上是怎么实现的。

2.1 微体系结构

微体系结构是计算机体系结构中偏向硬件的部分,它可以理解成数字电路如何实现处理器中的各个功能,通常关心的内容包括,指令的流水线结构,计算单元的电路(加法器等等),存储器的结构(寄存器堆、Cache的结构)等等 ;

一个实例如下:
1. 拿Intel来说,(其ISA是IA-32等)其pentium
4处理器的微体系结构是NetBurst,现代,其Core(酷睿)系列CPU的微体系结构已经经历了好几代:Bloomfield(2008年)、Lynnfield(2009年)、Clarksfield(2009年)、Ar
randale(2010年)、Gulftown(2010年)、Sandy Bridge(2011年)、Ivy
Bridge(2012年)、Haswell(2013年)、Haswell Devil’s
Canyon(2014年)、Broadwell(2015年)、Skylake(2015年)。
2. 拿ARM来说,(其ISA是ARMv7等)其微体系结构是ARM11等从11往后叫cortex系列,其中cortex-A系列有32位的A7、A9、A15,64位的A53、A57。




3. 指令集(Instruction set)

3.1 定义

通常会把CPU的扩展指令集称为”CPU的指令集”(因为基本的,类似加减的指令似乎是必须被CPU所支持的指令)。每款CPU在设计时就规定了一系列与其硬件电路相配合的指令集。

指令集可分为复杂指令集(CISC:sisk)和精简指令集(RISC:risk)两部分,这部分暂不继续讨论了。

Intel的MMX(Multi Media Extended)、SSE、 SSE2(Streaming-Single
instruction multiple data-Extensions
2)、SEE3和AMD的3DNow!等都是CPU的扩展指令集,分别增强了CPU的多媒体、图形图象和Internet等的处理能力。维基百科 - Comparison instruction set

3.2 指令

一条二进制机器指令由:指令码(操作码)+操作数组成。

  1. 操作码用来说明:指令的功能和执行的操作;
  2. 操作数说明:操作所涉及的源和目的数据的位置;
    • 源:立即数(即指令中包含的常亮)、寄存器、存储器、I/O端口等;



一个流程

一个我思考出来的可能的流程是这样:

    • CPU开发商
      1. 一个CPU厂商决定开发一个CPU,他们先要决定/选定一种指令集体系结构,他们当然不想自己开发,好了他们选用ARM的ARMv7;
      2. 那么该如何实现ARMv7呢?我们还是不去自己设计微体系结构了,还是用ARM公司配套的cortex吧,这样我们就能在硅晶片上做出一个CPU了;(当然中间省去了很多步骤)
    • CPU使用者(开发一个C编译器)
      1. 这颗CPU可以运行什么样的指令呢?发现使用CPU使用的是ARMv7,那么就查看ARMv7的文档就好了,这是RISC的一种
      2. 编译器完成了,它的功能是:将C源代码编译为可以在ARMv7上执行的二进制命令代码,即目标文件
      3. 此时一个小程序员写了一段简单C程序test.c,我们调用编译器将test.c编译为ARMv7上的可执行文件test.o
      4. 目标文件中包含了程序怎么开始和结束执行、需要操作的数据、如何与操作系统交互等等。只要运行这个目标程序,CPU就能执行其中的指令了

【转载】CPU架构、指令集与指令集体系结构(ISA)的更多相关文章

  1. 手机CPU架构体系分类及各大厂商

    手机cpu相关知识,这对于开发Android应用程序适应各个机型有一定的辅助作用 . 手机cpu架构体系分类 指令集可分为复杂指令集(CISC)和精简指令集(RISC)两部分,代表架构分别是x86.A ...

  2. 关于CPU 架构与指令集的一些个人理解

    关于CPU 架构与指令集的一些个人理解 (理解不一定正确,只是目前的理解) 1.一般所说的X86,是指基于Intel X86架构处理器的一套指令集,即X86指令集: 2.CPU的架构是最底层的,是处理 ...

  3. 【转帖】超能课堂(186) CPU中的那些指令集都有什么用?

    超能课堂(186)CPU中的那些指令集都有什么用? https://www.expreview.com/68615.html 不明觉厉 开始的地方 第一大类:基础运算类x86.x86-64及EM64T ...

  4. 让你分分钟读懂CPU架构及芯片厂商

    CPU架构是CPU厂商给属于同一系列的CPU产品定的一个规范,主要目的是为了区分 不同类型CPU的重要标示.目前市面上的CPU指令集分类主要分有两大阵营,一个是intel.AMD为首的复杂指令集CPU ...

  5. 略谈cpu架构种类

    一直对x86/i386/i686/x86_64这些东西感觉很不清楚,查些资料,解决部分问题,小记一番. Question1:什么是x86? x86或80x86是英特尔Intel首先开发制造的一种微处理 ...

  6. 嵌入式cpu架构

    原文:http://www.kaixin001.com/repaste/11007221_7220618944.html### 内容: 目前主要CPU架构有ARM.X86/Atom.MIPS.Powe ...

  7. CPU架构:CPU架构详细介绍

    1 概述 CPU架构是CPU商给CPU产品定的一个规范,主要目的是为了区分不同类型的CPU.目前市场上的CPU分类主要分有两大阵营,一个是intel.AMD为首的复杂指令集CPU,另一个是以IBM.A ...

  8. MySQL该使用哪种CPU架构服务器?

    1. 摘要 近期,阿里云推出基于 ARM 架构的 RDS MySQL 和 RDS PostgreSQL 实例,现处于邀测阶段,阿里云宣传 ARM 架构的亮点是:在价格下降13%的基础上,平均性能 AR ...

  9. 几种CPU架构

    原文链接:http://blog.csdn.net/wyzxg/article/details/5027738 这几天在下载RPM包的时候,总会看见x86,x86-64,IA64,i386,i586等 ...

随机推荐

  1. 云上建站快速入门:博客、论坛、CMS、电子商务网站统统搞定

    现在制作一个网站已经越来越容易了,只要知道清晰的流程之后都是可以很快的建好一个企业或者个人网站的!免费的建站程序很多,下面听哥给你亮出来,建站一般来说分主要有这四步:申请域名.申请虚拟主机.制作网页, ...

  2. Oracle的分页查询及内联视图和函数处理

    1.Oracle的分页常用方式: select * from(select * ,ROWNUM num from table where ROWNUM<=20 ) where num>0; ...

  3. BZOJ4545: DQS的trie 广义后缀自动机_LCT

    特别鸣神犇 fcwww 替我调出了无数个错误(没他的话我都快自闭了),祝大佬省选rp++ 板子题,给我写了一天QAQ...... 用 LCT 维护后缀树,暴力更新用 LCT 区间更新链即可 其实,在计 ...

  4. 51nod 237 最大公约数之和 V3 杜教筛

    Code: #include <bits/stdc++.h> #include <tr1/unordered_map> #define setIO(s) freopen(s&q ...

  5. PAT 天梯赛练习集 L2-004. 这是二叉搜索树吗?

    题目链接: https://www.patest.cn/contests/gplt/L2-004 一棵二叉搜索树可被递归地定义为具有下列性质的二叉树:对于任一结点, 其左子树中所有结点的键值小于该结点 ...

  6. 洛谷 P3420 [POI2005]SKA-Piggy Banks

    P3420 [POI2005]SKA-Piggy Banks 题目描述 Byteazar the Dragon has NN piggy banks. Each piggy bank can eith ...

  7. 日志工具全面理解及配置应用---以Log4j例子

    一.日志系统基本常识 1.日志系统作用:将日志信息输出到控制台和文本文件,以追踪代码运行信息. 2.日志系统操作的是什么?日志系统打印信息,也是调用日志系统的log.Info(),log.Warn() ...

  8. HDOJ 5294 Tricks Device 最短路(记录路径)+最小割

    最短路记录路径,同一时候求出最短的路径上最少要有多少条边, 然后用在最短路上的边又一次构图后求最小割. Tricks Device Time Limit: 2000/1000 MS (Java/Oth ...

  9. poj 3311 Hie with the Pie (TSP问题)

    Hie with the Pie Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 4491   Accepted: 2376 ...

  10. IOS 数据存储之 SQLite具体解释

    在IOS开发中常常会须要存储数据,对于比較少量的数据能够採取文件的形式存储,比方使用plist文件.归档等,可是对于大量的数据,就须要使用数据库,在IOS开发中数据库存储能够直接通过SQL訪问数据库, ...