CN108351778A - 用于检测浮点抵消效应的指令和逻辑 - Google Patents

用于检测浮点抵消效应的指令和逻辑 Download PDF

Info

Publication number
CN108351778A
CN108351778A CN201680067629.5A CN201680067629A CN108351778A CN 108351778 A CN108351778 A CN 108351778A CN 201680067629 A CN201680067629 A CN 201680067629A CN 108351778 A CN108351778 A CN 108351778A
Authority
CN
China
Prior art keywords
instruction
processor
cancellation
logic
threshold
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
CN201680067629.5A
Other languages
English (en)
Inventor
E.奥尔德-艾哈迈德-瓦尔
N.阿斯塔费夫
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Intel Corp
Original Assignee
Intel Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Intel Corp filed Critical Intel Corp
Publication of CN108351778A publication Critical patent/CN108351778A/zh
Pending legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/30003Arrangements for executing specific machine instructions
    • G06F9/30007Arrangements for executing specific machine instructions to perform operations on data operands
    • G06F9/30029Logical and Boolean instructions, e.g. XOR, NOT
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/30003Arrangements for executing specific machine instructions
    • G06F9/30007Arrangements for executing specific machine instructions to perform operations on data operands
    • G06F9/3001Arithmetic instructions
    • G06F9/30014Arithmetic instructions with variable precision
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F7/00Methods or arrangements for processing data by operating upon the order or content of the data handled
    • G06F7/38Methods or arrangements for performing computations using exclusively denominational number representation, e.g. using binary, ternary, decimal representation
    • G06F7/48Methods or arrangements for performing computations using exclusively denominational number representation, e.g. using binary, ternary, decimal representation using non-contact-making devices, e.g. tube, solid state device; using unspecified devices
    • G06F7/483Computations with numbers represented by a non-linear combination of denominational numbers, e.g. rational numbers, logarithmic number system or floating-point numbers
    • G06F7/485Adding; Subtracting
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F7/00Methods or arrangements for processing data by operating upon the order or content of the data handled
    • G06F7/38Methods or arrangements for performing computations using exclusively denominational number representation, e.g. using binary, ternary, decimal representation
    • G06F7/48Methods or arrangements for performing computations using exclusively denominational number representation, e.g. using binary, ternary, decimal representation using non-contact-making devices, e.g. tube, solid state device; using unspecified devices
    • G06F7/499Denomination or exception handling, e.g. rounding or overflow
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F7/00Methods or arrangements for processing data by operating upon the order or content of the data handled
    • G06F7/38Methods or arrangements for performing computations using exclusively denominational number representation, e.g. using binary, ternary, decimal representation
    • G06F7/48Methods or arrangements for performing computations using exclusively denominational number representation, e.g. using binary, ternary, decimal representation using non-contact-making devices, e.g. tube, solid state device; using unspecified devices
    • G06F7/499Denomination or exception handling, e.g. rounding or overflow
    • G06F7/49905Exception handling
    • G06F7/4991Overflow or underflow
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/30003Arrangements for executing specific machine instructions
    • G06F9/30007Arrangements for executing specific machine instructions to perform operations on data operands
    • G06F9/30021Compare instructions, e.g. Greater-Than, Equal-To, MINMAX
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/30145Instruction analysis, e.g. decoding, instruction word fields
    • G06F9/3016Decoding the operand specifier, e.g. specifier format
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/38Concurrent instruction execution, e.g. pipeline or look ahead
    • G06F9/3861Recovery, e.g. branch miss-prediction, exception handling

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Software Systems (AREA)
  • General Engineering & Computer Science (AREA)
  • Mathematical Optimization (AREA)
  • Pure & Applied Mathematics (AREA)
  • Mathematical Analysis (AREA)
  • Computational Mathematics (AREA)
  • Computing Systems (AREA)
  • Nonlinear Science (AREA)
  • Quality & Reliability (AREA)
  • Executing Machine-Instructions (AREA)
  • Advance Control (AREA)

Abstract

处理器包含对指令解码的前端以及将指令指配给执行单元以执行指令来计算受到抵消效应的浮点结果的分配器。执行单元包含控制抵消效应的通知的阈限、根据源值计算最大指数的逻辑、计算浮点指数的逻辑、计算检测的抵消值的逻辑以及将检测的抵消值与阈限作比较的逻辑。

Description

用于检测浮点抵消效应的指令和逻辑
技术领域
本公开涉及处理逻辑、微处理器以及关联的指令集架构的领域,指令集架构当由处理器或其它处理逻辑执行时执行逻辑、数学或其它函数运算。
背景技术
多处理器系统正在变得越来越普遍。多处理器系统的应用包含浮点数。多处理器系统的应用包含动态域分区一直到桌面计算。为了利用多处理器系统,要执行的代码可被分成多个线程以便由各种处理实体执行。每个线程可以彼此并行执行。指令当它们在处理器上接收时可被解码成对于在处理器上执行是原生的或者更加原生的项或指令字。处理器可在片上系统中实现。浮点数可被添加或减去。浮点数的相加或相减可用在数学模拟中。
附图说明
在附图的图中作为示例而非限制示出了实施例:
图1A是按照本公开的实施例用可包含执行指令的执行单元的处理器形成的示范计算机系统的框图;
图1B示出了按照本公开的实施例的数据处理系统;
图1C示出了用于执行文本字符串比较操作的数据处理系统的其它实施例;
图2是按照本公开的实施例可包含执行指令的逻辑电路的处理器的微架构的框图;
图3A示出了按照本公开的实施例的多媒体寄存器中的各种打包数据类型表示;
图3B示出了按照本公开的实施例的可能寄存器中的数据存储格式;
图3C示出了按照本公开的实施例的多媒体寄存器中的各种有符号和无符号的打包数据类型表示;
图3D示出了操作编码格式的实施例;
图3E示出了按照本公开的实施例的具有40位或更多位的另一可能操作编码格式;
图3F示出了按照本公开的实施例的又一可能操作编码格式;
图4A是示出按照本公开实施例的有序流水线和寄存器重命名阶段、无序发布/执行流水线的框图;
图4B是示出按照本公开实施例的要包含在处理器中的有序架构核以及寄存器重命名逻辑、无序发布/执行逻辑的框图;
图5A是按照本公开实施例的处理器的框图;
图5B是按照本公开实施例的核的示例实现的框图;
图6是按照本公开实施例的系统的框图;
图7是按照本公开实施例的第二系统的框图;
图8是按照本公开实施例的第三系统的框图;
图9是按照本公开实施例的片上系统的框图;
图10示出了按照本公开的实施例的可执行至少一个指令的含有中央处理单元和图形处理单元的处理器;
图11是示出按照本公开实施例的IP核的开发的框图;
图12示出根据本公开的实施例,第一类型的指令可如何由不同类型的处理器仿真;
图13示出根据本公开的实施例的对比将源指令集中的二进制指令转换成目标指令集中二进制指令的软件指令转换器的使用的框图;
图14是根据本公开的实施例的处理器的指令集架构的框图;
图15是根据本公开的实施例的处理器的指令集架构的更详细框图;
图16是根据本公开的实施例的用于处理器的指令集架构的执行流水线的框图;
图17是根据本公开的实施例的用于利用处理器的电子装置的框图;
图18是根据本公开实施例用于检测浮点抵消效应(cancellation effect)的系统的框图;
图19是根据本公开实施例用于检测浮点抵消效应的系统元件的更详细框图;以及
图20是根据本公开实施例用于检测浮点抵消效应的方法的操作图解。
具体实施方式
如下描述描述了用于检测浮点抵消效应的指令和处理逻辑。指令和处理逻辑可实现在无序处理器上。在如下描述中,阐述了众多特定细节,诸如处理逻辑、处理器类型、微架构条件、事件、启动(enablement)机制等,以便提供本公开实施例的更透彻理解。然而,本领域技术人员将认识到,没有此类特定细节也可实践实施例。此外,一些众所周知的结构、电路等未详细示出,以避免不必要地使本公开的实施例混淆。
尽管如下实施例参考处理器进行描述,但其它实施例可应用于其它类型集成电路和逻辑器件。本公开实施例的类似技术和教导可应用于可受益于更高流水线吞吐量和改进性能的其它类型电路或半导体器件。本公开实施例的教导可应用于执行数据操纵的任何处理器或机器。然而,实施例不限于执行512位、256位、128位、64位、32位或16位数据操作的处理器或机器,并且可应用于其中可执行数据操纵或管理的任何处理器和机器。此外,如下描述提供了示例,并且附图为了示出目的示出了各种示例。然而,这些示例不应被理解为限制意义,因为它们仅仅意图提供本公开实施例的示例,而不是提供本公开的实施例的所有可能实现的详尽列表。
尽管以下示例在执行单元和逻辑电路的上下文中描述了指令处置和分布,但本公开的其它实施例可通过存储在机器可读有形介质上的数据或指令实现,所述指令当由机器执行时使机器执行与本公开的至少一个实施例一致的功能。在一个实施例中,与本公开实施例关联的功能体现在机器可执行指令中。指令可用于使可用指令编程的通用或专用处理器执行本公开的步骤。本公开的实施例可提供为计算机程序产品或软件,该产品或软件可包括机器或计算机可读介质,其上存储有可用于编程计算机(或其它电子装置)以执行根据本公开的实施例的一个或更多个操作的指令。更进一步,本公开的实施例的步骤可由包含用于执行所述步骤的固定功能逻辑的特定硬件组件执行,或者由编程的计算机组件和固定功能硬件组件的任何组合执行。
用于对逻辑编程以执行本公开的实施例的指令可被存储在系统中的存储器内,诸如DRAM、高速缓存、闪速存储器或其它存储装置内。更进一步,指令可经由网络或通过其它计算机可读介质分布。从而,机器可读介质可包含用于存储或传送由机器(例如计算机)可读形式的信息的任何机制,但其不限于软盘、光盘、紧凑盘只读存储器(CD-ROM)、以及磁光盘、只读存储器(ROM)、随机存取存储器(RAM)、可擦除可编程只读存储器(EPROM)、电可擦除可编程只读存储器(EEPROM)、磁卡或光卡、闪速存储器或在因特网上经由电、光、声或其它形式传播信号(例如载波、红外信号、数字信号等)传送信息中使用的有形机器可读存储装置。相应地,计算机可读介质可包含适合于存储或传送由机器(例如计算机)可读形式的电子指令或信息的任何类型有形机器可读介质。
设计从创建到模拟到制造可经过各种阶段。表示设计的数据可用多种方式表示该设计。首先,如在模拟中可能有用的,硬件可使用硬件描述语言或另一功能描述语言表示。附加地,在设计过程的某些阶段,可产生具有逻辑和/或晶体管栅的电路级模型。更进一步,设计在某一阶段可达到用硬件模型表示各种器件的物理布局的数据级。在其中使用一些半导体制造技术的情况下,表示硬件模型的数据可以是规定在用于产生集成电路的掩膜的不同掩膜层上存在或缺乏各种特征的数据。在设计的任何表示中,数据都可存储在任何形式的机器可读介质中。存储器或者磁或光存储装置(诸如盘)可以是机器可读介质,以存储经由调制或以其它方式生成以传送信息的光波或电波传送的此类信息。在传送指示或携带代码或设计的电载波时,就执行电信号的复制、缓冲或重新传送而言,可进行新的拷贝。从而,通信提供商或网络提供商可在有形机器可读介质上至少暂时存储体现本公开实施例的技术的制品,诸如被编码到载波中的信息。
在现代处理器中,可使用若干不同执行单元来处理和执行各种代码和指令。一些指令可能更快地完成,而其它指令可能花了若干时钟循环完成。指令吞吐量越快,处理器的总体性能越好。从而,使许多指令尽可能快地执行会是有利的。然而,可存在具有更大复杂性并且在执行时间和处理器资源方面要求更大的某些指令,诸如浮点指令、加载/存储操作、数据移动等。
当在因特网、文本和多媒体应用中使用更多计算机系统时,已经随时间引入了附加处理器支持。在一个实施例中,指令集可与一个或多个计算机架构关联,包含数据类型、指令、寄存器架构、寻址模式、存储器架构、中断和异常处置以及外部输入和输出(I/O)。
在一个实施例中,指令集架构(ISA)可由一个或多个微架构实现,微架构可包含用于实现一个或多个指令集的处理器逻辑和电路。相应地,具有不同微架构的处理器至少可共享部分公共指令集。例如,Intel® Pentium 4处理器、Intel® Core™处理器以及来自加利福尼亚州,Sunnyvale 的Advanced Micro devices, Inc的处理器实现了几乎相同版本的x86指令集(具有已经对于较新版本被添加的一些扩展),但具有不同的内部设计。类似地,由其它处理器开发公司(诸如ARM Holding, Ltd、MIPS或他们的许可方或采纳方)设计的处理器至少可共享一部分公共指令集,但可包含不同处理器设计。例如,ISA的相同寄存器架构可使用新或公知的技术在不同微架构中以不同方式实现,包括专用物理寄存器、使用寄存器重命名机制(例如,使用寄存器别名表(RAT)、重新排序缓冲器(ROB)和引退寄存器文件)的一个或更多个动态分配的物理寄存器。在一个实施例中,寄存器可包括一个或更多个寄存器、寄存器架构、寄存器文件或可以或可以不由软件编程器可寻址的其它寄存器集。
指令可包含一个或多个指令格式。在一个实施例中,除了其它之外,指令格式还可指示要规定的各种字段(位数、位的位置等)、要执行的操作以及在其上将执行操作的操作数。在另外实施例中,一些指令格式可由指令模板(或子格式)进一步定义。例如,给定的指令格式的指令模板可被定义成具有指令格式字段的不同子集,和/或定义成具有不同解译的给定字段。在一个实施例中,指令可使用指令格式(并且如果定义了,则在那个指令格式的指令模板中的给定一个模板中)表述,并且规定或指示操作以及操作将在其上进行操作的操作数。
科学、金融、自动向量化通用、RMS(识别、挖掘和合成)及视觉和多媒体应用(例如,2D/3D图形、图像处理、视频压缩/解压、语音识别算法和音频操纵)可要求对大量数据项执行相同操作。在一个实施例中,单指令多数据(SIMD)指使得处理器对多个数据元素执行操作的指令的类型。在逻辑上可将寄存器中的位划分成多个固定大小或可变大小数据元素(每个元素表示单独的值)的SIMD技术可使用在处理器中。例如,在一个实施例中,可将64位寄存器中的位组织为包含4个单独16位数据元素的源操作数,每个元素表示单独的16位值。此类型的数据可称为“打包”(packed)数据类型或“向量”数据类型,并且此数据类型的操作数可称为打包数据操作数或向量操作数。在一个实施例中,打包数据项或向量可以是在单个寄存器内存储的打包数据元素的序列,并且打包数据操作数或向量操作数可以是SIMD指令(或“打包数据指令”或“向量指令”)的源或目的地操作数。在一个实施例中,SIMD指令指定要对两个源向量操作数执行的单向量操作,以生成相同或不同大小的具有相同或不同数量的数据元素和以相同或不同的数据元素顺序的目的地向量操作数(也称为结果向量操作数)。
例如由具有包括x86、MMX™、流播SIMD扩展(SSE)、SSE2、SSE3、SSE4.1及SSE4.2指令的指令集的Intel® Core™处理器,诸如ARM Cortex®系列处理器的具有包括向量浮点(VFP)和/或NEON指令的指令集的ARM处理器,以及诸如由中国科学院的计算技术研究所(ICT)开发的龙芯(Loongson)系列处理器的MIPS处理器所采用的SIMD技术已经在应用性能方面实现了相当大的改进(Core™和MMX™是加利福尼亚州Santa Clara的IntelCorporation的注册商标或商标)。
在一个实施例中,目的地和源寄存器/数据可以是表示对应数据或操作的源和目的地的常规术语。在一些实施例中,它们可通过具有与描绘的那些名称或功能不同的名称或功能的寄存器、存储器或其它存储区域来实现。例如,在一个实施例中,“DEST1”可以是临时存储寄存器或其它存储区域,而“SRC1”和“SRC2”可以是第一和第二源存储寄存器或其它存储区域并以此类推。在其它实施例中,两个或更多个SRC和DEST存储区域可对应于相同存储区域(例如,SIMD寄存器)内的不同数据存储元素。在一个实施例中,例如通过将对第一和第二源数据执行的操作的结果写回到用作目的地寄存器的所述两个源寄存器中的一个,源寄存器之一也可充当目的地寄存器。
图1A是根据本公开的实施例的用可包括执行单元以执行指令的处理器形成的示范计算机系统的框图。根据本公开(例如本文描述的实施例中的),系统100可包括诸如处理器102的组件,以采用包括执行用于处理数据的算法的逻辑的执行单元。系统100可表示基于根据加利福尼亚州Santa Clara的Intel Corporation可用的PENTIUM® III、PENTIUM®4、Xeon™、Itanium®、XScale™和/或StrongARM™微处理器的处理系统,尽管也可使用其它系统(包括具有其它微处理器的PC、工程工作站、机顶盒等)。在一个实施例中,样本系统100可执行从华盛顿Redmond的Microsoft Corporation可得到的Windows™操作系统的某个版本,尽管也可使用其它操作系统(例如,UNIX和Linux)、嵌入式软件和/或图形用户界面。因此,本公开的实施例不限于硬件电路和软件的任何特定组合。
实施例并不限于计算机系统。本公开的实施例可在诸如手持式装置和嵌入式应用的其它装置中使用。手持式装置的一些示例包括蜂窝电话、因特网协议装置、数码相机、个人数字助理(PDA)及手持式PC。嵌入式应用可包括微控制器、数字信号处理器(DSP)、片上系统、网络计算机(NetPC)、机顶盒、网络集线器、广域网(WAN)交换机或可执行根据至少一个实施例的一个或更多个指令的任何其它系统。
计算机系统100可包含处理器102,处理器102可包含一个或多个执行单元108以执行按照本公开一个实施例执行至少一个指令的算法。一个实施例可在单个处理器桌上型计算机或服务器系统的上下文中描述,而其它实施例可包含在多处理器系统中。系统100可以是“集线器”系统架构的示例。系统100可包含用于处理数据信号的处理器102。处理器102可包含复杂指令集计算机(CISC)微处理器、精简指令集计算(RISC)微处理器、超长指令字(VLIW)微处理器、实现指令集组合的处理器或任何其它处理装置,诸如例如数字信号处理器。在一个实施例中,处理器102可耦合到处理器总线110,其可在处理器102与系统100中的其它组件之间传送数据信号。系统100的元件可执行本领域技术人员众所周知的常规功能。
在一个实施例中,处理器102可包含一级(L1)内部高速缓冲存储器104。取决于架构,处理器102可具有单个内部高速缓存或多级内部高速缓存。在另一实施例中,高速缓冲存储器可驻留在处理器102外部。取决于具体实现和需要,其它实施例也可包含内部和外部高速缓存二者的组合。寄存器文件106可将不同类型的数据存储在各种寄存器中,包含整数寄存器、浮点寄存器、状态寄存器和指令指针寄存器。
执行单元108(包含执行整数和浮点运算的逻辑)也驻留在处理器102中。处理器102也可包含存储某些宏指令的微代码的微代码(ucode)ROM。在一个实施例中,执行单元108可包含处置打包指令集109的逻辑。通过在通用处理器102的指令集中包括打包指令集109,连同执行指令的关联电路,可使用通用处理器102中的打包数据执行由许多多媒体应用使用的操作。从而,通过使用处理器的数据总线的完全宽度来对打包数据执行操作,可加速和更有效地执行许多多媒体应用。这可消除跨处理器的数据总线传输更小数据单元来一次一个数据元素执行一个或更多个操作的需要。
执行单元108的实施例也可用在微控制器、嵌入式处理器、图形装置、DSP以及其它类型逻辑电路中。系统100可包含存储器120。存储器120可实现为动态随机存取存储器(DRAM)装置、静态随机存取存储器(SRAM)装置、闪速存储器装置或其它存储器装置。存储器120可存储由数据信号表示的可由处理器102执行的指令和/或数据。
系统逻辑芯片116可耦合到处理器总线110和存储器120。系统逻辑芯片116可包含存储器控制器集线器(MCH)。处理器102可经由处理器总线110与MCH 116通信。MCH 116可提供到存储器120的高带宽存储器路径118,其用于指令和数据存储以及用于图形命令、数据和结构(texture)的存储。MCH 116可在处理器102、存储器120和系统100中的其它组件之间引导数据信号,并在处理器总线110、存储器120和系统I/O 122之间桥接数据信号。在一些实施例中,系统逻辑芯片116可提供用于耦合到图形控制器112的图形端口。MCH 116可通过存储器接口118耦合到存储器120。图形卡112可通过加速图形端口(AGP)互连114耦合到MCH116。
系统100可使用专有集线器接口总线122将MCH 116耦合到I/O控制器集线器(ICH)130。在一个实施例中,ICH 130可经由本地I/O总线提供到一些I/O装置的直接连接。本地I/O总线可包含用于将外设连接到存储器120、芯片集和处理器102的高速I/O总线。示例可包含音频控制器、固件集线器(闪速BIOS)128、无线收发器126、数据存储装置124、含有用户输入和键盘接口的遗留I/O控制器、串行扩展端口(诸如通用串行总线(USB))和网络控制器134。数据存储装置124可包括硬盘驱动器、软盘驱动器、CD-ROM装置、闪速存储器装置或其它大容量存储装置。
对于系统的另一实施例,按照一个实施例的指令可与片上系统一起使用。片上系统的一个实施例由处理器和存储器组成。用于一个此类系统的存储器可包含闪速存储器。闪速存储器可位于与处理器和其它系统组件相同的管芯上。此外,诸如存储器控制器或图形控制器的其它逻辑块也可位于片上系统上。
图1B示出了实现本公开的实施例的原理的数据处理系统140。本领域技术人员将容易认识到,本文描述的实施例可通过备选处理系统操作,而不脱离本公开实施例的范围。
按照一个实施例,计算机系统140包括用于执行至少一个指令的处理核159。在一个实施例中,处理核159表示任何类型架构的处理单元,包含但不限于CISC、RISC或VLIW型架构。处理核159还可适合于以一个或多个工艺技术的制造,并且通过充分详细地表示在机器可读介质上,处理核159可适合于促进所述制造。
处理核159包括执行单元142、一组寄存器文件145、以及解码器144。处理核159还可包含对理解本公开实施例不必要的附加电路(未示出)。执行单元142可执行由处理核159接收的指令。除了执行典型处理器指令,执行单元142可执行打包指令集143中的指令,以便执行对打包数据格式的操作。打包指令集143可包含用于执行本公开实施例的指令以及其它打包指令。执行单元142可通过内部总线耦合到寄存器文件145。寄存器文件145可表示处理核159上的用于存储信息(包含数据)的存储区域。如先前所提到的,要理解到,存储区域可存储可能不关键的打包数据。执行单元142可耦合到解码器144。解码器144可将由处理核159接收的指令解码成控制信号和/或微代码入口点。响应于这些控制信号和/或微代码入口点,执行单元142执行适当操作。在一个实施例中,解码器可解译指令的操作码,其将指示应该对在指令内指示的对应数据执行什么操作。
处理核159可与总线141耦合,以便与各种其它系统装置通信,所述各种其它系统装置例如可包含但不限于:同步动态随机存取存储器(SDRAM)控制146、静态随机存取存储器(SRAM)控制147、突发闪速存储器接口148、个人计算机存储卡国际协会(PCMCIA)/紧凑型闪存(CF)卡控制149、液晶显示器(LCD)控制150、直接存储器存取(DMA)控制器151以及备选总线主接口152。在一个实施例中,数据处理系统140还可包括I/O桥154以便经由I/O总线153与各种I/O装置通信。此类I/O装置例如可包含但不限于通用异步接收器/传送器(UART)155、通用串行总线(USB) 156、蓝牙无线UART 157和I/O扩展接口158。
数据处理系统140的一个实施例规定移动、网络和/或无线通信以及可执行包含文本字符串比较操作的SIMD操作的处理核159。处理核159可采用各种音频、视频、成像和通信算法编程,所述算法包含:离散变换,诸如Walsh-Hadamard变换,快速傅里叶变换(FFT)、离散余弦变换(DCT)以及它们的相应逆变换;压缩/解压技术,诸如色彩空间变换、视频编码运动估计或视频解码运动补偿;以及调制/解调(MODEM)功能,诸如脉冲译码调制(PCM)。
图1C示出了执行SIMD文本字符串比较操作的数据处理系统的其它实施例。在一个实施例中,数据处理系统160可包含主处理器166、SIMD协处理器161、高速缓冲存储器167和输入/输出系统168。输入/输出系统168可选地可耦合到无线接口169。SIMD协处理器161可执行包含按照一个实施例的指令的操作。在一个实施例中,处理核170可适合于以一个或多个工艺技术的制造,并且通过充分详细地在机器可读介质上表示,处理核170可适合于促进制造所有或部分数据处理系统160(包含处理核170)。
在一个实施例中,SIMD协处理器161包括执行单元162和一组寄存器文件164。主处理器165的一个实施例包括解码器165以识别指令集163中的指令(包含按照一个实施例的指令)以用于由执行单元162执行。在其它实施例中,SIMD处理器161还包括至少部分解码器165以解码指令集163中的指令。处理核170还可包含对理解本公开实施例可不必要的附加电路(未示出)。
在操作中,主处理器166执行数据处理指令流,其控制通用类型的数据处理操作(包含与高速缓冲存储器167和输入/输出系统168的交互)。嵌入在数据处理指令流内的可以是SIMD协处理器指令。主处理器166的解码器165将这些SIMD协处理器指令识别为应该由附连的SIMD协处理器161执行的类型。相应地,主处理器166在协处理器总线166上发布这些SIMD协处理器指令(或表示SIMD协处理器指令的控制信号)。从协处理器总线166,可由任何附连的SIMD协处理器接收这些指令。在此情况下,SIMD协处理器161可接受并执行预期用于它的任何接收的SIMD协处理器指令。
数据可经由无线接口169接收以便由SIMD协处理器指令处理。对于一个示例,语音通信可以以数字信号形式被接收,其可由SIMD协处理器指令处理以重新生成代表语音通信的数字音频样本。对于另一个示例,压缩的音频和/或视频可以数字位流形式被接收,其可由SIMD协处理器指令处理以重新生成数字音频样本和/或运动视频帧。在处理核170的一个实施例中,主处理器166和SIMD协处理器161可被集成到单个处理核170中,处理核170包括执行单元162、一组寄存器文件164、以及识别指令集163中的指令(包含按照一个实施例的指令)的解码器165。
图2是按照本公开的实施例的可包含执行指令的逻辑电路的处理器200的微架构的框图。在一些实施例中,可实现按照一个实施例的指令,以对具有字节、字、双字、四字等大小以及诸如单和双精度整数和浮点数据类型的数据类型的数据元素进行操作。在一个实施例中,有序前端201可实现处理器200的一部分,该部分可获得要执行的指令,并且有序前端201准备所述指令以稍后在处理器流水线中进行使用。前端201可包含几个单元。在一个实施例中,指令预获取器226从存储器中获取指令,并将指令馈送到指令解码器228,其又解码或解译这些指令。例如,在一个实施例中,解码器将接收的指令解码成机器可执行的称为“微指令”或“微操作”(也称为microop或uop)的一个或多个操作。在其它实施例中,解码器将指令解析成操作码和对应的数据以及控制字段,它们可由微架构使用以执行按照一个实施例的操作。在一个实施例中,追踪(trace)高速缓存230可将解码的uop汇编成uop队列234中的程序排序的序列或追踪以便执行。当追踪高速缓存230遇到复杂指令时,微代码ROM232提供完成该操作所需的uop。
一些指令可被转换成单个微-op,而其它指令需要几个微-op来完成整个操作。在一个实施例中,如果需要多于四个微-op来完成指令,则解码器228可访问微代码ROM 232以执行指令。在一个实施例中,指令可被解码成小数量的微-op,以便在指令解码器228进行处理。在另一实施例中,指令可被存储在微代码ROM 232内,如果需要若干微-op来完成操作的话。追踪高速缓存230指的是入口点可编程逻辑阵列(PLA),其用来确定针对读取微代码序列的正确微指令指针,以完成来自微代码ROM 232的按照一个实施例的一个或多个指令。在微代码ROM 232完成对指令的微-op进行排序后,机器的前端201可恢复从追踪高速缓存230获取微-op。
无序执行引擎203可准备指令以用于执行。无序执行逻辑具有多个缓冲器,以在指令沿流水线向下并且被调度用于执行时,平滑处理和重新排序指令的流以优化性能。分配器逻辑分配每个uop为了执行而所需要的机器缓冲器和资源。寄存器重命名逻辑将逻辑寄存器重命名到寄存器文件中的条目上。在指令调度器(存储器调度器、快速调度器202、慢速/通用浮点调度器204和简单浮点调度器206)前面,分配器还为两个uop队列(一个用于存储器操作,并且一个用于非存储器操作)之一中的每个uop分配条目。Uop调度器202、204、206基于其相关性输入寄存器操作数源的准备度和uop完成其操作需要的执行资源的可用性,确定uop何时准备就绪执行。一个实施例的快速调度器202可在主时钟循环的每半个循环上进行调度,而其它调度器可每主处理器时钟循环仅调度一次。调度器对于分派端口进行裁决以调度uop以便执行。
寄存器文件208、210可布置在调度器202、204、206与执行块211中的执行单元212、214、216、218、220、222、224之间。寄存器文件208、210中的每个分别执行整数运算和浮点运算。每个寄存器文件208、210可包含旁路网络,其可向新的相关uop进行旁路或转发尚未写入寄存器文件中的刚刚完成的结果。整数寄存器文件208和浮点寄存器文件210可相互传递数据。在一个实施例中,整数寄存器文件208可被分成两个单独的寄存器文件,一个寄存器文件用于数据的低阶32位,而第二寄存器文件用于数据的高阶32位。浮点寄存器文件210可包含128位宽条目,因为浮点指令通常具有从64位到128位宽的操作数。
执行块211可含有执行单元212、214、216、218、220、222、224。执行单元212、214、216、218、220、222、224可执行指令。执行块211可包含存储微指令需要执行的整数和浮点数据操作数值的寄存器文件208、210。在一个实施例中,处理器200可包括若干执行单元:地址生成单元(AGU) 212、AGU 214、快速ALU 216、快速ALU 218、慢速ALU 220、浮点ALU 222、浮点移动单元224。在另一实施例中,浮点执行块222、224可执行浮点、MMX、SIMD和SSE或其它运算。在又一个实施例中,浮点ALU 222可包含64位×64位浮点除法器以执行除法、平方根和余数微-op。在各种实施例中,涉及浮点值的指令可用浮点硬件处置。在一个实施例中,ALU运算可传到高速ALU执行单元216、218。高速ALU 216、218可以通过时钟循环一半的有效等待时间执行快速运算。在一个实施例中,最复杂的整数操作去到慢速ALU 220,因为慢速ALU 220可包括用于长等待时间类型操作的整数执行硬件,如乘法器、位移、标记逻辑和分支处理。存储器加载/存储操作由AGU 212、214执行。在一个实施例中,整数ALU 216、218、220可对64位数据操作数执行整数运算。在其它实施例中,可实现ALU 216、218、220以支持各种数据位大小,包含16、32、128、256等。类似地,可实现浮点单元222、224以支持具有各种宽度位的一系列操作数。在一个实施例中,浮点单元222、224可结合SIMD和多媒体指令对128位宽打包数据操作数进行操作。
在一个实施例中,在父载荷已经完成执行之前,uop调度器202、204、206分派相关操作。由于在处理器200中可推测性地调度和执行uop,故处理器200还可包含处置存储器丢失的逻辑。如果数据加载在数据高速缓存中丢失,则流水线中可存在执行中(in flight)相关操作,其为调度器留下了暂时不正确的数据。重放机制跟踪和重新执行使用不正确数据的指令。可能只需要重放相关操作,并且可允许完成独立操作。处理器的一个实施例的调度器和重放机制也可设计成捕捉用于文本字符串比较运算的指令序列。
术语“寄存器”可指代可用作识别操作数的部分指令的板载处理器存储位置。换而言之,寄存器可以是从处理器的外部可使用的那些寄存器(从编程器的角度而言)。然而,在一些实施例中,寄存器可能不限于特定类型的电路。相反,寄存器可存储数据,提供数据,并且执行本文中描述的功能。本文中描述的寄存器可由处理器内的电路使用任何数量的不同技术实现,诸如专用物理寄存器、使用寄存器重命名的动态分配物理寄存器、专用和动态分配物理寄存器的组合等。在一个实施例中,整数寄存器存储32位整数数据。一个实施例的寄存器文件也包含用于打包数据的8个多媒体SIMD寄存器。对于下面的讨论,可将寄存器理解为设计成保持打包数据的数据寄存器,诸如来自加利福尼亚州Santa Clara的IntelCorporation的以MMX技术实现的微处理器中的64位宽MMX™寄存器(在一些实例中也称为“mm”寄存器)。在整数和浮点形式两者中可用的这些MMX寄存器可与伴随SIMD 和SSE指令的打包数据元素一起操作。类似地,与SSE2、SSE3、SSE4或更高版本(一般称为“SSEx”)技术有关的128位宽XMM寄存器可保持此类打包数据操作数。在一个实施例中,在存储打包数据和整数数据中,寄存器无需区分所述两种数据类型。在一个实施例中,整数和浮点可包含在相同寄存器文件或不同寄存器文件中。此外,在一个实施例中,浮点和整数数据可存储在不同寄存器或相同寄存器中。
在以下图形的示例中,可描述多个数据操作数。图3A示出根据本公开的实施例的在多媒体寄存器中的各种打包数据类型表示。图3A示出用于128位宽操作数的打包字节310、打包字320和打包双字(dword) 330的数据类型。此示例的打包字节格式310可以为128位长,并且包含16个打包字节数据元素。字节例如可定义为8位的数据。用于每个字节数据元素的信息可存储在针对字节0的位7到位0、针对字节1的位15到位8、针对字节2的位23到位16及最后针对字节15的位120到位127中。因此,在寄存器中可使用所有可用位。此存储布置增大了处理器的存储效率。此外,利用访问的16个数据元素,现在可并行对16个数据元素执行一个操作。
通常,数据元素可包括与相同长度的其它数据元素一起存储在单个寄存器或存储器位置中的单独数据段。在与SSEx技术有关的打包数据序列中,XMM寄存器中存储的数据元素的数量可以是128位除以单独数据元素的以位为单位的长度。类似地,在与MMX和SSE技术有关的打包数据序列中,MMX寄存器中存储的数据元素的数量可以是64位除以单独数据元素的以位为单位的长度。虽然图3A中示出的数据类型可以为128位长,但本公开的实施例也可利用64位宽或其它大小的操作数操作。此示例的打包字格式320可以为128位长,并且包含8个打包字数据元素。每个打包字包含16位的信息。图3A的打包双字格式330可以为128位长,并且包含4个打包双字数据元素。每个打包双字数据元素包含32位的信息。打包四字可以为128位长,并且包含2个打包四字数据元素。
图3B示出根据本公开的实施例的可能寄存器中的数据存储格式。每个打包数据可包括多于一个独立数据元素。示出了三个打包数据格式;打包半(half)341、打包单342和打包双343。打包半341、打包单342和打包双343的一个实施例包含固定点数据元素。对于另一实施例,打包半341、打包单342和打包双343中的一个或更多个可包含浮点数据元素。打包半341的一个实施例可以为128位长,其包含8个16位数据元素。打包单342的一个实施例可以为128位长,并且包含4个32位数据元素。打包双343的一个实施例可以为128位长,并且包含2个64位数据元素。将领会的是,此类打包数据格式可进一步扩展到其它寄存器长度,例如,96位、160位、192位、224位、256位、512位或更多。
图3C示出根据本公开的实施例的在多媒体寄存器中的各种有符号和无符号的打包数据类型表示。无符号的打包字节表示344示出在SIMD寄存器中的无符号的打包字节的存储。每个字节数据元素的信息可存储在针对字节0的位7到位0、针对字节1的位15到位8、针对字节2的位23到位16及最后针对字节15的位120到位127中。因此,在寄存器中可使用所有可用位。此存储布置可增大处理器的存储效率。此外,利用访问的16个数据元素,现在可以并行方式对16个数据元素执行一个操作。有符号的打包字节表示345示出有符号的打包字节的存储。要注意的是,每个字节数据元素的第8位可以是符号指示符。无符号的打包字表示346示出在SIMD寄存器中可如何存储字7到字0。有符号的打包字表示347可类似于无符号的打包字寄存器中的表示346。要注意的是,每个字数据元素的第16位可以是符号指示符。无符号的打包双字表示348显示如何存储双字数据元素。有符号的打包双字表示349可类似于无符号的打包双字寄存器中的表示348。要注意的是,必需的符号位可以是每个双字数据元素的第32位。
图3D示出操作编码(操作码)的实施例。此外,格式360可包括寄存器/存储器操作数寻址模式,其与万维网(www) at intel.com/design/litcentr上从加利福尼亚州圣克拉拉Intel Corporation可获得的“IA-32 Intel架构软件开发员手册第2卷:指令集参考”(IA-32 Intel Architecture Software Developer's Manual Volume 2: InstructionSet Reference)中描述的操作码格式的类型相对应。在一个实施例中,且指令可通过字段361和362中的一个或更多个字段编码。可识别直到每指令两个操作数位置,包括直到两个源操作数标识符364和365。在一个实施例中,目的地操作数标识符366可与源操作数标识符364相同,而在其它实施例中,它们可不同。在另一实施例中,目的地操作数标识符366可与源操作数标识符365相同,而在其它实施例中,它们可不同。在一个实施例中,通过源操作数标识符364和365识别的源操作数之一可通过文本字符串比较运算的结果被改写,而在其它实施例中,标识符364对应于源寄存器元素,并且标识符365对应于目的地寄存器元素。在一个实施例中,操作数标识符364和365可识别32位或64位源和目的地操作数。
图3E示出根据本公开的实施例的具有40或更多个位的另一可能操作编码(操作码)格式370。操作码格式370与操作码格式360相对应,并且包括可选前缀字节378。根据一个实施例的指令可通过字段378、371和372的一个或更多个字段编码。通过源操作数标识符374和375以及通过前缀字节378,可识别直到每指令两个操作数位置。在一个实施例中,前缀字节378可用于识别32位或64位源和目的地操作数。在一个实施例中,目的地操作数标识符376可与源操作数标识符374相同,而在其它实施例中,它们可不同。对于另一实施例,目的地操作数标识符376可与源操作数标识符375相同,而在其它实施例中,它们可不同。在一个实施例中,指令对通过操作数标识符374和375识别的一个或更多个操作数进行操作,并且通过操作数标识符374和375识别的一个或更多个操作数可通过指令的结果被改写,而在其它实施例中,通过标识符374和375识别的操作数可被写入另一寄存器中的另一数据元素。操作码格式360和370允许由MOD字段363和373和由可选比例-索引-基础和位移字节部分地指定的寄存器到寄存器、存储器到寄存器、寄存器接(by)存储器、寄存器接寄存器、寄存器接中间物、寄存器到存储器寻址。
图3F示出根据本公开的实施例的又一可能操作编码(操作码)格式。64位单指令多数据(SIMD)算术运算可通过协处理器数据处理(CDP)指令被执行。操作编码(操作码)格式380描绘具有CDP操作码字段382和389的一个此类CDP指令。CDP指令的类型,对于另一实施例,操作可通过字段383、384、387和388的一个或更多个字段编码。可识别直到每指令三个操作数位置,包括直到两个源操作数标识符385、390和一个目的地操作数标识符386。协处理器的一个实施例可对8、16、32和64位值进行操作。在一个实施例中,可对整数数据元素执行指令。在一些实施例中,可使用条件字段381,有条件地执行指令。对于一些实施例,源数据大小可由字段383编码。在一些实施例中,可对SIMD字段进行零(Z)、负(N)、进位(C)和溢出(V)检测。对于一些指令,饱和的类型可由字段384编码。
图4A是根据本公开的实施例的示出有序流水线和寄存器重命名阶段、无序发布/执行流水线的框图。图4B是根据本公开的实施例的示出有序架构核和寄存器重命名逻辑、无序发布/执行流水线(要被包括在处理器中)的框图。图4A中的实线框示出有序流水线,而虚线框示出寄存器重命名、无序发布/执行流水线。类似地,图4B中的实线框示出有序架构逻辑,而虚线框示出寄存器重命名逻辑和无序发布/执行逻辑。
在图4A中,处理器流水线400可包括获取阶段402、长度解码阶段404、解码阶段406、分配阶段408、重命名阶段410、调度(也称为分派或发布)阶段412、寄存器读取/存储器读取阶段414、执行阶段416、写回/存储器写入阶段418、异常处理阶段422及提交阶段424。
在图4B中,箭头表示在两个或更多个单元之间的耦合,并且箭头的方向指示在那些单元之间数据流的方向。图4B显示处理器核490,其包括耦合到执行引擎单元450的前端单元430,并且两者均可耦合到存储器单元470。
核490可以是精简指令集计算(RISC)核、复杂指令集计算(CISC)核、超长指令字(VLIW)核或混合或备选核类型。在一个实施例中,核490可以是专用核,诸如,例如网络或通信核、压缩引擎、图形核或诸如此类。
前端单元430可包括耦合到指令高速缓存单元434的分支预测单元432。指令高速缓存单元434可耦合到指令转化后备缓冲器(TLB) 436。TLB 436可耦合到指令获取单元438,其耦合到解码单元440。解码单元440可将指令解码,并且生成作为输出的一个或更多个微操作、微代码入口点、微指令、其它指令或其它控制信号,它们可从原始指令解码或者以其它方式反映原始指令或者可从原始指令得到。解码器可使用各种不同机制实现。适合机制的示例包括但不限于查找表、硬件实现、可编程逻辑阵列(PLA)、微代码只读存储器(ROM)等。在一个实施例中,指令高速缓存单元434可还耦合到存储器单元470中的2级(L2)高速缓存单元476。解码单元440可耦合到执行引擎单元450中的重命名/分配器单元452。
执行引擎单元450可包括耦合到引退单元454和一个或更多个调度器单元456的集合的重命名/分配器单元452。调度器单元456表示任何数量的不同调度器,包括预留站、中央指令窗口等。调度器单元456可耦合到物理寄存器文件单元458。每个物理寄存器文件单元458表示一个或更多个物理寄存器文件,这些寄存器文件中的不同寄存器文件存储一个或更多个不同数据类型,诸如标量整数、标量浮点、打包整数、打包浮点、向量整数、向量浮点、等,状态(例如,作为要执行的下一指令的地址的指令指针)等。物理寄存器文件单元458可由引退单元154重叠以示出其中可实现寄存器重命名和无序执行的各种方式(例如,使用一个或更多个重排序缓冲器和一个或更多个引退寄存器文件;使用一个或更多个将来文件、一个或更多个历史缓冲器和一个或更多个引退寄存器文件;使用寄存器映射和寄存器池等)。通常,架构寄存器可从处理器外部或者从程序员的角度而言是可见的。寄存器可能不限于任何已知特定类型的电路。各种不同类型的寄存器只要如本文中所述存储和提供数据,它们便是适合的。适合寄存器的示例包括但不限于专用物理寄存器、使用寄存器重命名的动态分配物理寄存器、专用和动态分配物理寄存器的组合等。引退单元454和物理寄存器文件单元458可耦合到执行集群460。执行集群460可包括一个或更多个执行单元162的集合和一个或更多个存储器存取单元464的集合。执行单元462可执行各种操作(例如,移位、加法、减法、乘法),并且对各种类型的数据(例如,标量浮点、打包整数、打包浮点、向量整数、向量浮点)进行执行。虽然一些实施例可包括专用于特定功能或功能的集合的多个执行单元,但其它实施例可只包括一个执行单元或全部执行所有功能的多个执行单元。调度器单元456、物理寄存器文件单元458和执行集群460示为可能是多个,这是因为某些实施例为某些类型的数据/操作创建单独的流水线(例如,标量整数流水线、标量浮点/打包整数/打包浮点/向量整数/向量浮点流水线和/或存储器存取流水线,每个流水线具有其自己的调度器单元、物理寄存器文件单元和/或执行集群 - 并且在单独的存储器存取流水线的情况下,可实现其中仅此流水线的执行集群具有存储器存取单元464的某些实施例)。还应理解的是,在使用单独流水线的情况下,一个或更多个这些流水线可以是无序发布/执行,并且其余的流水线是有序的。
存储器存取单元464的集合可耦合到存储器单元470,其可包括耦合到数据高速缓存单元474的数据TLB单元472,数据高速缓存单元474耦合到2级(L2)高速缓存单元476。在一个示范实施例中,存储器存取单元464可包括载荷单元、存储地址单元和存储数据单元,它们中的每个可耦合到存储器单元470中的数据TLB单元472。L2高速缓存单元476可耦合到一个或更多个其它级的高速缓存,并且最终耦合到主存储器。
通过示例,示范寄存器重命名、无序发布/执行核架构可如下实现流水线400:1)指令获取438可执行获取阶段402和长度解码阶段404;2)解码单元440可执行解码阶段406;3)重命名/分配器单元452可执行分配阶段408和重命名阶段410;4)调度器单元456可执行调度阶段412;5)物理寄存器文件单元458和存储器单元470可执行寄存器读取/存储器读取阶段414;执行集群460可执行执行阶段416;6)存储器单元470和物理寄存器文件单元458可执行写回/存储器写入阶段418;7)各种单元可涉及异常处理阶段422的执行;以及8)引退单元454和物理寄存器文件单元458可执行提交阶段424。
核490可支持一个或更多个指令集(例如,x86指令集(其中对于较新版本已添加一些扩展);加利福尼亚州Sunnyvale的MIPS Technologies的MIPS指令集;加利福尼亚州Sunnyvale的ARM Holdings的ARM指令集(具有诸如NEON的可选另外扩展))。
应理解的是,核可以以多种方式支持多线程(执行两个或更多个并行的操作或线程的集合)。例如通过包括时间片多线程、同时多线程(其中,单个物理核提供用于物理核在同时进行多线程的每个线程的逻辑核)或其组合,可执行多线程支持。此类组合例如可包括时间片获取和解码及之后的同时多线程,诸如在Intel®超线程技术中一样。
虽然寄存器重命名可在无序执行的上下文中描述,但应理解的是,可在有序架构中使用寄存器重命名。虽然处理器的所示实施例也可包括单独的指令和数据高速缓存单元434/474及共享L2高速缓存单元476,但其它实施例可具有用于指令和数据两者的单个内部高速缓存,诸如例如1级(L1)内部高速缓存,或多个级的内部高速缓存。在一些实施例中,系统可包括内部高速缓存和可在核和/或处理器外的外部高速缓存的组合。在其它实施例中,所有高速缓存可在核和/或处理器的外部。
图5A是根据本公开的实施例的处理器500的框图。在一个实施例中,处理器500可包括多核处理器。处理器500可包括以通信方式耦合到一个或更多个核502的系统代理510。此外,核502和系统代理510可以通信方式耦合到一个或更多个高速缓存506。核502、系统代理510和高速缓存506可经一个或更多个存储器控制单元552以通信方式耦合。此外,核502、系统代理510和高速缓存506可经存储器控制单元552以通信方式耦合到图形模块560。
处理器500可包括用于将核502、系统代理510和高速缓存506及图形模块560互连的任何适合机制。在一个实施例中,处理器500可包括基于环形的互连单元508以将核502、系统代理510和高速缓存506及图形模块560互连。在其它实施例中,处理器500可包括用于将此类单元互连的任何数量的公知技术。基于环形的互连单元508可利用存储器控制单元552以促进互连。
处理器500可包括存储器层级,该层级包括核内的一个或更多个级的高速缓存、诸如高速缓存506的一个或更多个共享高速缓存单元或耦合到集成存储器控制器单元552的集合的外部存储器(未示出)。高速缓存506可包括任何适合的高速缓存。在一个实施例中,高速缓存506可包括诸如2级(L2)、3级(L3)、4级(L4)或其它级的高速缓存的一个或更多个中间级高速缓存、末级高速缓存(LLC)和/或其组合。
在各种实施例中,一个或更多个核502可执行多线程。系统代理510可包括用于协调和操作核502的组件。系统代理510例如可包括功率控制单元(PCU)。PCU可以是或者包括对于调节核502的功率状态所需的逻辑和组件。系统代理510可包括用于驱动一个或更多个外部连接的显示器或图形模块560的显示引擎512。系统代理510可包括用于针对图形的通信总线的接口。在一个实施例中,接口可通过PCI高速 (PCIe)来实现。在其它的实施例中,接口可通过PCI高速图形(PEG)514来实现。系统代理510可包括直接媒体接口(DMI)516。DMI516可在计算机系统的母板或其它部分上的不同桥之间提供链路。系统代理510可包括用于提供PCIe链路到计算系统的其它元素的PCIe桥518。PCIe桥518可使用存储器控制器520和一致性逻辑522实现。
核502可以以任何适合的方式实现。核502可在架构和/或指令集方面是同构或异构的。在一个实施例中,一些核502可以是有序的,而其它核可以是无序的。在另一实施例中,两个或更多个核502可执行相同指令集,而其它核可只执行该指令集的子集或不同指令集。
处理器500可包括诸如可从加利福尼亚州Santa Clara的Intel Corporation获得的Core™ i3、i5、i7、2 Duo和Quad、Xeon™、Itanium™、XScale™或StrongARM™处理器等通用处理器。处理器500可从诸如ARM Holdings, Ltd、MIPS的另一公司提供。处理器500可以是专用处理器,诸如例如网络或通信处理器、压缩引擎、图形处理器、协处理器、嵌入式处理器或诸如此类。处理器500可在一个或更多个芯片上实现。处理器500可以是使用诸如例如BiCMOS、COMS或NMOS的多个处理技术的任何技术的一个或更多个衬底的一部分,和/或可在衬底上实现。
在一个实施例中,高速缓存506的一个给定高速缓存可由核502的多个核共享。在另一实施例中,高速缓存506的一个给定高速缓存可专用于核502之一。高速缓存506到核502的指派可由高速缓存控制器或其它适合机制处理。通过实现给定高速缓存506的时间片,可由两个或更多个核502共享高速缓存506的一个给定高速缓存。
图形模块560可实现集成图形处理子系统。在一个实施例中,图形模块560可包括图形处理器。此外,图形模块560可包括媒体引擎565。媒体引擎565可提供媒体编码和视频解码。
图5B是根据本公开的实施例的核502的示例实现的框图。核502可包括以通信方式耦合到无序引擎580的前端570。核502可通过高速缓存层级503,以通信方式耦合到处理器500的其它部分。
前端570可以以任何适合的方式实现,例如,如上所述部分或完全由前端201实现。在一个实施例中,前端570可通过高速缓存层级503与处理器500的其它部分进行通信。在另外实施例中,前端570可从处理器500的部分获取指令,并且在指令传递到无序执行引擎580时准备处理器流水线中以后要使用的指令。
无序执行引擎580可以以任何适合的方式实现,例如,如上所述部分或完全通过无序执行引擎203来实现。无序执行引擎580可准备从前端570接收到的指令以供执行。无序执行引擎580可包括分配模块1282。在一个实施例中,分配模块1282可分配处理器500的资源或诸如寄存器或缓冲器的其它资源以执行给定指令。分配模块1282可在调度器中进行分配,如存储器调度器、快速调度器或浮点调度器。此类调度器可在图5B中由资源调度器584表示。分配模块1282可完全或部分通过结合图2描述的分配逻辑来实现。资源调度器584可基于给定资源的源的准备度和执行指令需要的执行资源的可用性,确定指令何时准备就绪以执行。资源调度器584可例如通过如上所述的调度器202、204、206来实现。资源调度器584可对一个或更多个资源调度指令的执行。在一个实施例中,此类资源可在核502的内部,并且例如可示出为资源586。在另一实施例中,此类资源可在核502的外部,并且例如可由高速缓存层级503访问。资源例如可包括存储器、高速缓存、寄存器文件或寄存器。核502内部的资源可由图5B中的资源586表示。在必需时,可例如通过高速缓存层级503,协调写入资源586或从中读取的值和处理器500的其它部分。在指令是指派的资源时,可将它们置于重新排序缓冲器588中。重新排序缓冲器588可在指令执行时跟踪指令,并且可基于处理器500的任何适合准则,选择性地将其执行重新排序。在一个实施例中,重新排序缓冲器588可识别可独立执行的指令或一系列指令。此类指令或一系列指令可与其它此类指令并行执行。核502中的并行执行可通过任何适合数量的单独执行块或虚拟处理器执行。在一个实施例中,给定核502内的多个虚拟处理器可访问诸如存储器、寄存器和高速缓存的共享资源。在其它实施例中,处理器500内的多个处理实体可访问共享资源。
高速缓存层级503可以以任何适合的方式实现。例如,高速缓存层级503可包括诸如高速缓存572、574的一个或更多个更低或中级高速缓存。在一个实施例中,高速缓存层级503可包括以通信方式耦合到高速缓存572、574的LLC 595。在另一实施例中,LLC 595可在对处理器500的所有处理实体可访问的模块590中实现。在另外的实施例中,模块590可在来自Intel, Inc的处理器的非核心模块中实现。模块590可包括对于执行核502所必需,但可能不在核502内实现的处理器500的部分或子系统。除LLC 595外,模块590例如可包括硬件接口、存储器一致性协调器、处理器间互连、指令流水线或存储器控制器。通过模块590,并且更具体地说,通过LLC 595,可对可用于处理器500的RAM 599进行访问。此外,核502的其它实例可类似地访问模块590。可部分通过模块590,促进核502的实例的协调。
图6-8可示出适合于包含处理器500的示范系统,而图9可示出可包含一个或多个核502的示范性片上系统(SoC)。在本领域已知的用于膝上型计算机、桌面型计算机、手持PC、个人数字助理、工程设计工作站、服务器、网络装置、网络集线器、交换机、嵌入式处理器、数字信号处理器(DSP)、图形装置、视频游戏装置、机顶盒、微控制器、蜂窝电话、便携式媒体播放器、手持装置和各种其它电子装置的其它系统设计和实现也是适合的。一般而言,结合处理器和/或本文所公开的其它执行逻辑的大量系统或电子装置一般可以是适合的。
图6示出了按照本公开实施例的系统600的框图。系统600可包含一个或多个处理器610、615,它们可耦合到图形存储器控制器集线器(GMCH) 620。在图6中用虚线指代附加处理器615的可选性质。
每个处理器610、615可以是某版本的处理器500。然而,应该指出,在处理器610、615中可能不存在集成图形逻辑和集成存储器控制单元。图6示出了GMCH 620可耦合到存储器640,存储器640例如可以是动态随机存取存储器(DRAM)。对于至少一个实施例,DRAM可与非易失性高速缓存关联。
GMCH 620可以是芯片集,或者芯片集的一部分。GMCH 620可与处理器610、615通信,并控制处理器610、615与存储器640之间的交互。GMCH 620也可充当处理器610、615与系统600其它元件之间的加速总线接口。在一个实施例中,GMCH 620经由多点总线(诸如前侧总线(FSB) 695)与处理器610、615通信。
更进一步,GMCH 620可耦合到显示器645(诸如平板显示器)。在一个实施例中,GMCH 620可包含集成图形加速器。GMCH 620可进一步耦合到输入/输出(I/O)控制器集线器(ICH) 650,其可用于将各种外设装置耦合到系统600。外部图形装置660可包含耦合到ICH650的分立图形装置,连同另一外设装置670。
在其它实施例中,在系统600中也可存在附加的或不同的处理器。例如,附加处理器610、615可包含可与处理器610相同的附加处理器、可与处理器610异质或不对称的附加处理器、加速器(诸如例如图形加速器或数字信号处理(DSP)单元)、现场可编程门阵列或任何其它处理器。在品质度量谱(包含架构、微架构、热、功耗特性等)方面,在物理资源610、615之间可能存在各种差异。这些差异在处理器610、615之间可有效地将它们自己标明为不对称并且异质。对于至少一个实施例,各种处理器610、615可驻留在同一管芯封装中。
图7示出了按照本公开实施例的第二系统700的框图。如图7中所示,多处理器系统700可包含点对点互连系统,并且可包经由点对点互连750耦合的第一处理器770和第二处理器780。处理器770和780中的每个可以如一个或更多个处理器610,615一样,是某一版本的处理器500。
虽然图7可示出两个处理器770、780,但要理解到,本公开的范围不限于此。在其它实施例中,在给定处理器中可存在一个或多个附加处理器。
分别示出处理器770和780包含集成存储器控制器单元772和782。处理器770还可包含点对点(P-P)接口776和778作为其总线控制器单元的一部分;类似地,第二处理器780可包含P-P接口786和788。处理器770、780可经由点对点(P-P)接口750使用P-P接口电路778、788交换信息。如图7中所示,IMC 772和782可将处理器耦合到相应存储器,即存储器732和存储器734,它们在一个实施例中可以是本地附连到相应处理器的主存储器的部分。
处理器770、780可各经由单独P-P接口752、754使用点对点接口电路776、794、786、798与芯片集790交换信息。在一个实施例中,芯片集790还可经由高性能图形接口739与高性能图形电路738交换信息。
共享高速缓存(未示出)可被包含在任一处理器中或两个处理器外,仍经由P-P互连与处理器连接,使得任一或两个处理器的本地高速缓存信息可被存储在共享高速缓存中(如果处理器被置于低功率模式)。
芯片集790可经由接口796耦合到第一总线716。在一个实施例中,第一总线716可以是外设组件互连(PCI)总线,或诸如PCI高速总线的总线,或另一个第三代I/O互连总线,尽管本公开的范围不限于此。
如图7中所示,各种I/O装置714可耦合到第一总线716,连同将第一总线716耦合到第二总线720的总线桥718。在一个实施例中,第二总线720可以是低管脚计数(LPC)总线。在一个实施例中,各种装置可耦合到第二总线720,例如包含键盘和/或鼠标722、通信装置727和存储单元728,诸如盘驱动器或可包含指令/代码和数据730的其它大容量存储装置。进一步说,音频I/O 724可耦合到第二总线720。要指出,其它架构是可能的。例如,代替图7的点对点架构,系统可实现多点总线或其它此类架构。
图8示出了按照本公开实施例的第三系统800的框图。图7和图8中的相同的元件承载相同的附图标记,并且已经从图8中省略了图7的某些方面,以便避免使图8的其它方面混淆。
图8示出处理器870、880可分别包含集成存储器和I/O控制逻辑(“CL”) 872和882。对于至少一个实施例,CL 872、882可包含集成存储器控制器单元,诸如上面结合图5和图7所描述的。此外,CL 872、882也可包含I/O控制逻辑。图8不仅示出了存储器832、834可耦合到CL 872、882,而且I/O装置814也可耦合到控制逻辑872、882。传统I/O装置815可耦合到芯片集890。
图9示出了按照本公开实施例的SoC 900的框图。图5中的相同元件承载相同附图标记。还有,虚线框可表示更高级SoC上的可选特征。互连单元902可耦合到:应用处理器910,其可包含一个或多个核902A-N的集合以及共享高速缓存单元906;系统代理单元910;总线控制器单元916;集成存储器控制器单元914;一组或一个或多个媒体处理器920,其可包含集成图形逻辑908、用于提供静止和/或视频相机功能性的图像处理器924、用于提供硬件音频加速的音频处理器926以及用于提供视频编码/解码加速的视频处理器928;静态随机存取存储器(SRAM)单元930;直接存储器存取(DMA)单元932;以及用于耦合到一个或多个外部显示器的显示单元940。
图10示出了按照本公开的实施例的可执行至少一个指令的含有中央处理单元(CPU)和图形处理单元(GPU)的处理器。在一个实施例中,执行根据至少一个实施例的操作的指令可由CPU执行。在另一实施例中,指令可由GPU执行。在又一实施例中,指令可通过由GPU和CPU执行的操作组合执行。例如,在一个实施例中,按照一个实施例的指令可被接收和解码以便在CPU上执行。然而,解码指令内的一个或多个操作可由CPU执行,并且结果返回到GPU用于指令的最后引退。相反,在一些实施例中,CPU可充当主处理器,并且GPU充当协处理器。
在一些实施例中,受益于高度并行吞吐量处理器的指令可由GPU执行,而受益于处理器(其受益于深流水线架构)的性能的指令可由CPU执行。例如,图形、科学应用、金融应用和其它并行工作负荷可受益于GPU的性能,并被相应地执行,而更多序列应用(诸如操作系统内核或应用代码)可更适合于CPU。
在图10中,处理器1000包含CPU 1005、GPU 1010、图像处理器1015、视频处理器1020、USB控制器1025、UART控制器1030、SPI/SDIO控制器1035、显示装置1040、存储器接口控制器1045、MIPI控制器1050、闪速存储器控制器1055、双数据速率(DDR)控制器1060、安全性引擎1065和I2S/I2C控制器1070。其它逻辑和电路可包含在图10的处理器中,包含更多CPU和GPU以及其它外设接口控制器。
至少一个实施例的一个或多个方面可由存储在表示处理器内的各种逻辑的机器可读介质上的代表性数据实现,其当由机器读取时使机器制造执行本文描述的技术的逻辑。称为“IP核”的此类表示可存储在有形机器可读介质(“带”)上,并供应给各种消费者或制造设施,以加载到实际上制造逻辑或处理器的制造机器中。例如,诸如由ARM Holdings,Ltd开发的Cortex™族处理器和中国科学院计算技术研究所(ICT)开发的龙芯IP核的IP核可许可或销售到各种客户或被许可人,如Texas Instruments、Qualcomm、Apple或Samsung,并且在由这些客户或被许可人生产的处理器中实现。
图11示出了按照本公开实施例示出开发IP核的框图。存储装置1130可包含模拟软件1120和/或硬件或软件模型1110。在一个实施例中,表示IP核设计的数据可经由存储器1140(例如硬盘)、有线连接(例如因特网)1150或无线连接1160提供给存储装置1130。由模拟工具和模型生成的IP核信息然后可被传送到制造设施,其中它可由第三方制造以执行按照至少一个实施例的至少一个指令。
在一些实施例中,一个或多个指令可对应于第一类型或架构(例如x86),并且在不同类型或架构(例如ARM)的处理器上转化或仿真。根据一个实施例,指令因此可在任何处理器或处理器类型(包含ARM、x86、MIPS、GPU)或其它处理器类型或架构上执行。
图12示出了按照本公开实施例,可如何由不同类型的处理器仿真第一类型的指令。在图12中,程序1205含有可与根据一个实施例的指令执行相同或基本上相同功能的一些指令。然而,程序1205的指令可属于与处理器1215不同或不兼容的类型和/或格式,意味着,程序1205中的类型的指令可能不能够由处理器1215本地执行。然而,在仿真逻辑1210的帮助下,程序1205的指令可被转化成可由处理器1215本地执行的指令。在一个实施例中,仿真逻辑可实施在硬件中。在另一实施例中,仿真逻辑可实施在有形、机器可读介质中,其含有将程序1205中的类型的指令转化成由处理器1215本地可执行的类型。在其它实施例中,仿真逻辑可以是固定功能或可编程硬件以及存储在有形、机器可读介质上的程序的组合。在一个实施例中,处理器含有仿真逻辑,而在其它实施例中,仿真逻辑存在于处理器外部,并且可由第三方提供。在一个实施例中,处理器可通过执行在处理器中含有的或与处理器关联的微代码或固件来加载实施在含有软件的有形、机器可读介质中的模拟逻辑。
图13示出了按照本公开的实施例的对比使用软件指令转换器将源指令集中的二进制指令转换成目标指令集中的二进制指令的框图。在所示出的实施例中,指令转换器可以是软件指令转换器,尽管指令转换器可以用软件、固件、硬件或它们的各种组合实现。图13示出可使用x86编译器1304编译高级语言1302的程序以生成x86二进制代码1306,其可由具有至少一个x86指令集核1316的处理器本地执行。具有至少一个x86指令集核的处理器1316表示可通过兼容执行或以其它方式处理(1) Intel x86指令集核的指令集的实质部分或(2)定向为在具有至少一个x86指令集核的Intel处理器上运行的应用或其它软件的对象代码版本,执行与具有至少一个x86指令集核的Intel处理器基本上相同功能,以便实现与具有至少一个x86指令集核的Intel处理器基本上相同结果的任何处理器。x86编译器1304表示可操作以生成x86二进制代码1306(例如对象代码)的编译器,二进制代码1306可在具有或没有附加连锁处理的情况下在具有至少一个x86指令集核1316的处理器上执行。类似地,图13示出采用高级语言1302的程序可使用备选指令集编译器1308编译以生成备选指令集二进制代码1310,其可由没有至少一个x86指令集核1314的处理器(例如,具有执行加利福尼亚州Sunnyvale的MIPS Technologies的MIPS指令集,和/或执行加利福尼亚州Sunnyvale的ARM Holdings的ARM指令集的核的处理器)本地执行。指令转换器1312可用于将x86二进制代码1306转换成可由没有x86指令集核1314的处理器本地执行的代码。这个转换的代码可能不与备选指令集二进制代码1310相同;然而,转换的代码将完成一般操作,并且由来自备选指令集的指令组成。从而,指令转换器1312表示通过仿真、模拟或任何其它过程,允许不具有x86指令集处理器或核的处理器或其它电子装置执行x86二进制代码1306的软件、固件、硬件或其组合。
图14是按照本公开实施例的处理器的指令集架构1400的框图。指令集架构1400可包含任何适合数量或种类的组件。
例如,指令集架构1400可包含处理实体,诸如一个或多个核1406、1407和图形处理单元1415。核1406、1407可通过任何适合的机制(诸如通过总线或高速缓存)以通信方式耦合到其余指令集架构1400。在一个实施例中,核1406、1407可通过L2高速缓存控制1408以通信方式耦合,L2高速缓存控制1408可包含总线接口单元1409和L2高速缓存1410。核1406、1407和图形处理单元1415可通过互连1410以通信方式彼此耦合,并耦合到指令集架构1400的剩余部分。在一个实施例中,图形处理单元1415可使用视频代码1420(其定义其中具体视频信号将被编码和解码以便输出的方式)。
指令集架构1400还可包含任何数量或种类的接口、控制器或用于与电子装置或系统的其它部分对接或通信的其它机制。此类机制例如可促进与外设、通信装置、其它处理器或存储器的交互。在图14的示例中,指令集架构1400可包含液晶显示器(LCD)视频接口1425、订户接口模块(SIM)接口1430、引导ROM接口1435、同步动态随机存取存储器(SDRAM)控制器1440、闪存控制器1445和串行外设接口(SPI)主单元1450。LCD视频接口1425例如可从GPU 1415并且例如通过移动工业处理器接口(MIPI)1490或高清多媒体接口(HDMI)1495向显示器提供视频信号的输出。此类显示器例如可包含LCD。SIM接口1430可提供对或从SIM卡或装置的访问。SDRAM控制器1440可提供对或从诸如SDRAM芯片或模块的存储器的访问。闪存控制器1445可提供对或从诸如闪存存储器或RAM的其它实例的存储器的访问。SPI主单元1450可提供对或从诸如蓝牙模块1470、高速3G调制解调器1475、全球定位系统模块1480或实现诸如802.11的通信标准的无线模块1485的通信模块的访问。
图15是按照本公开实施例的处理器的指令集架构1500的更详细框图。指令架构1500可实现指令集架构1400的一个或多个方面。更进一步,指令集架构1500可示出用于执行处理器内指令的模块和机制。
指令架构1500可包含以通信方式耦合到一个或多个执行实体1565的存储器系统1540。更进一步,指令架构1500可包含以通信方式耦合到执行实体1565和存储器系统1540的高速缓存和总线接口单元(诸如单元1510)。在一个实施例中,将指令加载到执行实体1564可由一个或多个执行阶段执行。此类阶段例如可包含指令预获取阶段1530、双指令解码阶段1550、寄存器重命名阶段155、发布阶段1560和写回阶段1570。
在一个实施例中,存储器系统1540可包含执行的指令指针1580。执行的指令指针1580可存储标识一批指令内最旧的、未指派的指令的值。最旧的指令可对应于最低程序指令(PO)值。PO可包含唯一数量的指令。此类指令可以是由多个指令串(strand)表示的线程内的单个指令。PO可在排序指令中用于确保代码的正确执行语义。PO可通过诸如评估指令中编码的PO的增量而不是绝对值的机制来重构。此类重构的PO可被称为“RPO”。尽管本文可提到PO,但此类PO可与RPO互换使用。指令串可包含是取决于彼此的数据的指令序列。在编译时间,指令串可由二进制转化器布置。执行指令串的硬件可按根据各种指令的PO的次序执行给定指令串的指令。线程可包含多个指令串,使得不同指令串的指令可取决于彼此。给定指令串的PO可以是指令串中尚未从发布阶段分派执行的最旧的指令的PO。相应地,给定多个指令串的线程,每个指令串包含按PO排序的指令,执行的指令指针1580可存储线程中最旧的——由最低号码示出的——PO。
在另一个实施例中,存储器系统1540可包含引退指针1582。引退指针1582可存储标识最后引退的指令的PO的值。引退指针1582例如可由引退单元454设置。如果尚没有指令引退,则引退指针1582可包含空值。
执行实体1565可包含处理器通过其可执行指令的任何适合数量和种类的机制。在图15的示例中,执行实体1565可包含ALU/乘法单元(MUL)1566、ALU 1567和浮点单元(FPU)1568。在一个实施例中,此类实体可利用在给定地址1569内含有的信息。执行实体1565与阶段1530、1550、1555、1560、1570组合可共同形成执行单元。
单元1510可用任何适合的方式实现。在一个实施例中,单元1510可执行高速缓存控制。在此类实施例中,单元1510从而可包含高速缓存1525。在另外实施例中,高速缓存1525可实现为具有任何适合大小(诸如0、128k、256k、512k、1M或2M字节的存储器)的L2统一高速缓存。在另一、另外的实施例中,高速缓存1525可实现在纠错代码存储器中。在另一实施例中,单元1510可执行到处理器或电子装置的其它部分的总线对接。在此类实施例中,单元1510从而可包含用于通过互连、处理器内总线、处理器间总线或其它通信总线、端口或线路通信的总线接口单元1520。总线接口单元1520可提供对接以便例如执行生成存储器和输入/输出地址,以便在执行实体1565与指令架构1500外部的系统部分之间传送数据。
为了进一步促进其功能,总线接口单元1520可包含用于生成中断和到处理器或电子装置的其它部分的其它通信的中断控制和分布单元1511。在一个实施例中,总线接口单元1520可包含处置针对多个处理核的高速缓存访问和一致性的探听控制单元1512。在另外的实施例中,为了提供此类功能性,探听控制单元1512可包含处置不同高速缓存之间信息交换的高速缓存到高速缓存传送单元。在另一、另外实施例中,探听控制单元1512可包含一个或多个探听过滤器1514,其监视其它高速缓存(未示出)的一致性,使得高速缓存控制器(诸如单元1510)不用必须直接执行此类监视。单元1510可包含用于同步指令架构1500的动作的任何适合数量的定时器1515。还有,单元1510可包含AC端口1516。
存储器系统1540可包含用于存储对于指令架构1500的处理需要的信息的任何适合的数量和种类的机制。在一个实施例中,存储器系统1504可包含用于存储信息(诸如写入到存储器或寄存器或从存储器或寄存器读回的缓冲器)的载荷存储单元1530。在另一实施例中,存储器系统1504可包含转化后备缓冲器(TLB)1545,其提供了物理地址与虚拟地址之间的地址值的查找。在又一实施例中,总线接口单元1520可包含用于促进访问虚拟存储器的存储器管理单元(MMU)1544。在又一实施例中,存储器系统1504可包含预获取器1543,用于在指令实际需要被执行之前从存储器请求此类指令以便减少延时。
执行指令的指令架构1500的操作可通过不同阶段执行。例如,使用单元1510指令预获取阶段1530可通过预获取器1543访问指令。检索的指令可被存储在指令高速缓存1532中。预获取阶段1530可实现用于快速环路模式的选项1531,其中执行形成环路的一系列指令,环路足够小以在给定高速缓存内拟合。在一个实施例中,执行此类执行例如可无需从指令高速缓存1532访问附加指令。预获取什么指令的确定例如可由分支预测单元1535进行,单元1535可访问全局历史1536中的执行指示、目标地址1537的指示或确定接下来将执行代码的分支1557中的哪个的返回栈1538的内容。此类分支有可能作为结果预获取。分支1557可通过如下面所描述的其它操作阶段产生。指令预获取阶段1530可提供指令及有关将来指令的任何预测到双指令解码阶段。
双指令解码阶段1550可将接收的指令转化成可执行的基于微代码的指令。双指令解码阶段1550每时钟循环可同时解码两个指令。更进一步,双指令解码阶段1550可将其结果传到寄存器重命名阶段1555。此外,双指令解码阶段1550可从其解码和微代码的最终执行中确定任何结果分支。此类结果可输入到分支1557中。
寄存器重命名阶段1555可将对虚拟寄存器或其它资源的引用转化成对物理寄存器或资源的引用。寄存器重命名阶段1555可包含寄存器池1556中此类映射的指示。寄存器重命名阶段1555可更改所接收的指令,并将结果发送到发布阶段1560。
发布阶段1560可向执行实体1565发布或分派命令。此类发布可按无序方式执行。在一个实施例中,多个指令可在执行之前在发布阶段1560保持。发布阶段1560可包含用于保持此类多个命令的指令队列1561。可基于任何可接受的判据,诸如用于执行给定指令的资源的可用性或适用性,由发布阶段1560向具体处理实体1565发布指令。在一个实施例中,发布阶段1560可重新排序指令队列1561内的指令,使得所接收的第一指令可能不是所执行的第一指令。基于指令队列1561的排序,附加分支信息可被提供给分支1557。发布阶段1560可将指令传到执行实体1565以用于执行。
在执行时,写回阶段1570可将数据写入到寄存器、队列或指令集架构1500的其它结构中,以传递给定命令的完成。取决于在发布阶段1560中布置的指令次序,写回阶段1570的操作可实现要被执行的附加指令。指令集架构1500的执行可由追踪单元1575监视或调试。
图16是按照本公开实施例的用于处理器的指令集架构的执行流水线1600的框图。执行流水线1600例如可示出图15的指令架构1500的操作。
执行流水线1600可包含步骤或操作的任何适合的组合。在1605,可进行接下来要执行的分支的预测。在一个实施例中,此类预测可基于先前指令的执行及其结果。在1610,对应于预测的执行分支的指令可被加载到指令高速缓存中。在1615,可获取指令高速缓存中的一个或多个此类指令以便执行。在1620,已经获取的指令可被解码成微代码或更特定的机器语言。在一个实施例中,可同时解码多个指令。在1625,可重新指配解码指令内对寄存器或其它资源的引用。例如,可引用对应物理寄存器替换对虚拟寄存器的引用。在1630,指令可被分派给队列以便执行。在1640,可执行指令。可按任何适合的方式执行此类执行。在1650,可向适合的执行实体发布指令。其中执行指令的方式可取决于执行指令的特定实体。例如,在1655,ALU可执行算术函数。ALU可针对其操作利用单个时钟循环以及两个移位器。在一个实施例中,可采用两个ALU,并且从而在1655可执行两个指令。在1660,可进行结果分支的确定。程序计数器可用于指定分支将进行到其的目的地。1660可在单个时钟循环内执行。在1665,浮点算术可由一个或多个FPU执行。浮点操作可需要执行多个时钟循环,诸如2个到10个循环。在1670,可执行乘法和除法运算。此类运算可在4个时钟循环中执行。在1675,可执行对寄存器或流水线1600其它部分的加载和存储操作。操作可包含加载和存储地址。此类运算可在4个时钟循环中执行。在1680,写回操作可根据需要由1655-1675的结果操作执行。
图17是根据本公开的实施例的用于利用处理器1710的电子装置1700的框图。电子装置1700例如可包括笔记本、超级本、计算机、塔式服务器、机架服务器、刀片服务器、膝上型计算机、桌上型计算机、平板、移动装置、电话、嵌入式计算机或任何其它适合的电子装置。
电子装置1700可包括以通信方式耦合到任何适合数量或种类的组件、外设、模块或装置的处理器1710。此类耦合可通过任何适合种类的总线或接口来实现,如I2C总线、系统管理总线(SMBus)、低引脚计数(LPC)总线、SPI、高清晰音频(HDA)总线、串行高级技术附件(SATA)总线、USB总线(版本1、2、3)或通用异步接收器/传送器(UART)总线。
此类组件例如可包括显示器1724、触摸屏1725、触摸板1730、近场通信(NFC)单元1745、传感器集线器1740、热传感器1746、高速芯片集(EC)1735、可信平台模块(TPM)1738、BlOS/固件/闪存存储器1722、数字信号处理器1760、诸如固态磁盘(SSD)或硬盘驱动器(HDD)的驱动器1720、无线局域网(WLAN)单元1750、蓝牙单元1752、无线广域网(WWAN)单元1756、全球定位系统(GPS)、诸如USB 3.0摄像头的摄像头1754、或例如以LPDDR3标准实现的低功率双倍数据率(LPDDR)存储器单元1715。这些组件每个可以以任何适合的方式实现。
此外,在各种实施例中,其它组件可通过上面讨论的组件以通信方式耦合到处理器1710。例如,加速计1741、环境光传感器(ALS)1742、罗盘1743和陀螺仪1744可以以通信方式耦合到传感器集线器1740。热传感器1739、风扇1737、键盘1746和触摸板1730可以以通信方式耦合到EC 1735。扬声器1763、耳机1764和麦克风1765可以以通信方式耦合到音频单元1764,音频单元又可以通信方式耦合到DSP 1760。音频单元1764例如可包括音频编解码器和D类放大器。SIM卡1757可以以通信方式耦合到WWAN单元1756。诸如WLAN单元1750和蓝牙单元1752以及WWAN单元1756的组件可以以下一代规格(next generation form factor)(NGFF)实现。
本公开的实施例涉及用于检测浮点抵消效应的指令和处理逻辑。图18是对于用于检测浮点抵消效应的指令和逻辑的系统1800的示例实施例的图示。系统1800可包含处理器、SoC、集成电路或其它机制。例如,系统1800可包含处理器1802。尽管处理器1802被显示和描述为图18中的示例,但可使用任何适合的机制。处理器1802可包含用于检测浮点抵消效应的任何适合的机制。在一个实施例中,此类机制可用硬件实现。处理器1802可完全或部分由在图1-17中描述的元件实现。
在一个实施例中,系统1800可包含用于浮点算术的抵消效应检测单元1826。系统1800可将抵消效应检测单元1826包含在系统1800的任何适合的部分中。例如,抵消效应检测单元1826可实现为有序或无序执行流水线1816内的执行单元1822。在另一示例中,抵消效应检测单元1826可被实现在独立于处理器1802的主核1814的知识产权(IP)核1828内。抵消效应检测单元1826可由处理器的电路或硬件计算逻辑的任何适合的组合实现。
浮点单元可在高性能计算(HPC)和其它应用(包含移动和桌面计算)中使用,以采用科学记数法表示数字。此表示包含导致舍入误差的有限准确性。彼此靠近的值的相加或相减可导致在操作之前累计的舍入误差的意外放大。从而,连锁的浮点计算可促使抵消效应或大变动抵消。在各种实施例中,抵消效应检测单元1826可分析浮点运算以检测是否已经发生了抵消效应。
当处理浮点值时检测和发信号通知抵消效应的存在可能是计算上昂贵的。基于软件的解决方案(其中用于检测和发信号通知抵消效应的代码在处理器1802上的解码时简单地在典型的执行单元上执行)经常是慢的或者功率紧缺的。抵消效应检测单元1826可实现用于有效地检测抵消效应的块。处理器1802可隐含地或者通过解码和执行特定指令来识别,浮点计算需要针对抵消效应的存在而被检查。在此类情况下,抵消效应检测的计算可被卸载到抵消效应检测单元1826。在一个实施例中,要在指令流1804中执行的特定指令可以以抵消效应检测单元1826作为目标。此类特定指令例如可由编译器生成,或者可由导致指令流1804的代码起草器指定。指令可被包含在对于由处理器1802或抵消效应检测单元1826的执行而定义的库中。在另一实施例中,处理器1802的部分可以以抵消效应检测单元1826为目标,其中处理器1802识别指令流1804中对于采用用于检测抵消效应的期望阈限执行浮点指令的尝试。
指令1830可对应于抵消效应检测单元1826的使用。可使用单独指令或者通过将额外操作数包含在计算浮点结果的每个指令中来设置阈限控制设置THLD。在一个实施例中,具有THLD控制参数的SETCONTROLFPQQ指令可在控制寄存器中设置适当字段。在另一实施例中,具有浮点结果的每个指令可包含THLD控制设置。例如,基本浮点指令(诸如FADD、FADDP、FIADD、FSUB、 FSUBP、FISUB)可包含THLD参数(除可包含两个源浮点寄存器和目的地浮点寄存器的典型操作数之外)。类似地,ADD和SUB指令或者这些指令VADD和VSUB的向量形式能包含THLD参数。不管运算的数据类型是什么,都可包含此参数,数据类型包含标量单精度(SS)、标量双精度(SD)、打包单精度(PS)和打包双精度(PD)。同样,复算术指令(诸如ADDSUBPD和ADDSUBPS)可包含THLD参数。最后,FMA指令(诸如VFMADD、VFNMADD、VFMSUB、VFNMSUB、VFMADDSUB和VFMSUBADD)可包含THLD参数以规定用于抵消效应检测的阈限。FMA指令包含任何适合的数据类型,包含对于上面的向量指令列出的那些,以及其中处理源操作数的任何适合的次序。该参数THLD与定义浮点结果的指令的任何其它参数一起可采取任何适合的形式,包含用于置换指令的参数标志、显式参数、要求的参数、具有假定默认值的可选参数、或者存储在寄存器中或者不要求信息要显式地作为参数传递的其它已知位置中的固有参数。
可以从指令流1804接收指令,指令流可驻留在系统1800的存储器子系统内。指令流1804可被包含在系统1800的处理器1802的任何适合的部分中。在一个实施例中,指令流1804A可被包含在SoC系统或其它机制中。在另一实施例中,指令流1804B可被包含在处理器、集成电路或其它机制中。处理器1802可包含前端1806,其可从指令流1804接收指令并对指令进行解码(使用解码流水线阶段)。解码的指令可被分派、分配和调度以用于由执行流水线1816的分配单元1818和调度器1820执行,并分配给特定执行单元1822。在执行之后,指令可由引退单元1824中的写回阶段或引退阶段引退。如果处理器1802无序执行指令,则分配单元1818可给指令重命名,并且指令可被输入到与引退单元关联的重排序缓冲器1824中。指令可以被引退,如同它们被有序执行一样。此类执行流水线的各种部分可由一个或更多核1814执行。
抵消效应检测单元1826可用任何适合的方式实现。在一个实施例中,抵消效应检测单元1826可由浮点单元中的电路实现。在另一实施例中,抵消效应检测单元1826可包含或者可以以通信方式耦合到存储器元件以存储对于检测抵消效应所必需的信息。在另外的实施例中,抵消效应检测单元1826可以是具有对浮点指令操作数访问权的单独执行单元。
在一个实施例中,抵消效应检测单元1826可包含确定在检测到抵消效应的情况下是否发信号通知异常的电路。在另一实施例中,抵消效应检测单元1826可以在与抵消效应关联的状态寄存器字段中设置标志。
在另一实施例中,抵消效应检测单元1826在给定输入值A和B中的ɛ 和δ的初始相对误差的情况下可以计算结果的相对误差,以及t的有效数字(significand)中的同等前导位的数量。如下等式描述了计算:
假定值A和B彼此靠近,相对误差可与t的指数和位置成比例。对应地,归一化结果可具有2t(ɛ–δ)的误差,其中初始相关误差通过归一化被放大,这将误差乘以2t
尽管各种操作在此公开中被描述为由处理器1802的特定组件执行,但是功能性可由处理器1802的任何适合的部分执行。
图19图示了根据本公开实施例的各种部分的实现和系统1800的示例操作。
在一个实施例中,抵消效应的检测可由单独指令控制。指令可以指示必须超过的期望阈限以便抵消效应要被发信号通知。在另一实施例中,抵消效应的检测可由合并乘加(fused multiply-add)(FMA)指令或关联的浮点SIMD的可选标志控制。例如,FMA指令可将相乘和相加组合成单个指令,或者将相乘和相减组合成单个指令。FMA指令可操作在标量浮点或SIMD数据上。FMA指令的目的地寄存器可存储将两个值相乘并且加上第三值或者从该乘积中减去第三值的结果,在此期间可发生抵消效应。
在一个实施例中,抵消效应可发生在减去两个浮点数时。在浮点SIMD或FMA指令内可减去两个浮点数。具有有效数字1902的第一浮点操作数可乘以(1918)基数(base)1912。具有有效数字1904的第二浮点操作数可乘以(1920)另一基数1910。在1926中可从第一操作数减去第二操作数。变量t可以是其中值不同的两个操作数的尾数中的第一位置。位置1932和1934可对应于在t处的第一尾数和第二尾数的值。尾数的前导位可以是等同的,包含前导位1938和1940,以及由a1至at-1标示的前t-1位。尾随的尾数的位在由xt+1至x52 与yt+1至y52标示的两个操作数之间是独一无二的。
相减1926的结果可以是具有有效数字1906乘以(1922)基数1914的输出。输出可包含具有0值的前导位1942,因为两个源操作数在值上可以类似。类似地,在位置1936中的t前面的有效数字1906中的所有位置都可以是0。为了将前导位位置更新为非零值,在1928中输出可被左移t位。这种移位操作可在段1946中插入用于t个尾随位的零。如果源操作数包含误差,其可以在先前计算或测量期间累计,则归一化过程可将误差的相对有效位以2t放大。由于在浮点相加或相减运算期间消除前导有效位引起的相对误差的放大可被称为大变动抵消。代码的起草器可能需要进一步分析大变动抵消以重新起草代码。
在另一实施例中,归一化的结果1930可以是浮点相加运算的输出。在另外的实施例中,归一化的结果1930可以是SIMD相加或相减运算的输出,其中可输出一组结果。在又一实施例中,归一化结果1930可以是SIMD值上的FMA运算或者相减、相加的FMA运算的输出。
在一个实施例中,抵消效应检测单元1826可分析两个源操作数以确定归一化结果1930是否包含大变动抵消。该单元可使用第一操作数的基数1912内的指数和第二操作数的基数1910内的指数。抵消效应检测单元1826还可计算对应于两个输入的两个指数的最大值。两个输入可具有浮点表示或者采取另一种格式。抵消效应检测单元1826可以通过求值浮点结果的浮点指数与最大指数之间的差来确定大变动抵消是否发生。在一个实施例中,如果求值的差大于0,则可发信号通知抵消效应。在另一实施例中,阈限确定是否可发信号通知抵消效应。在一个实施例中,阈限可由软件代码的编译器设置。在另一实施例中,阈限可由代码的起草器设置。
图20是根据本公开实施例用于检测浮点抵消效应的示例方法2000的框图。方法2000可由在图1-19中示出的任何元件实现。方法2000可由任何适合的准则发起,并且可在任何适合的点发起操作。在一个实施例中,方法2000可在2005发起操作。方法2000可包含比图示的那些步骤要更多或更少的步骤。而且,方法2000可按与下面图示的那些次序不同的次序执行其步骤。方法2000可终止于任何适合的步骤。更进一步,方法2000可在任何适合的步骤重复操作。方法2000可在其它方法中或者与方法2000的其它步骤并行执行其任何步骤。
在2005,在一个实施例中,可接收计算用浮点表示的结果的一个或更多指令。指令可被接收、解码、分配和执行。指令可规定,抵消效应检测单元1826确定在指令执行期间是否发生抵消效应。在另一实施例中,可以接收指令以实现浮点抵消效应的检测。指令可被接收、解码、分配和执行。指令可确切地指定由抵消效应检测单元1826进行处置,或者可以确定,指令能由抵消效应检测单元进行处置。与检测抵消效应有关的输入可被切换到抵消效应检测单元以进行处理。2005比如可由前端、核、执行单元或者其它适合的元件执行。
在2010,在一个实施例中,可分析一个或更多指令以设置用于抵消通知的阈限。所检测的计算的抵消可能需要超过该阈限,以便方法2000发信号通知已经发生大变动抵消,或者以便方法2000设置指示已经发生大变动抵消的标志。在一个实施例中,阈限可被存储在通用寄存器中。在另一实施例中,阈限可作为字段存储在浮点控制寄存器中。在另外的实施例中,阈限可被规定为与所述一个或更多指令关联的立即值。
在2015,在一个实施例中,可在带有具有浮点表示的结果的两个源操作数之间确定最大指数。在另一实施例中,可根据源操作数计算最大指数。源操作数可采取浮点表示或者另一种格式。在2020,在一个实施例中,可以确定浮点结果的浮点指数。浮点结果的浮点指数可由浮点逻辑单元计算。相应地,结果的浮点指数可以是相关计算的函数,包含其中结果使用浮点表示的源值的相加和相减。
在2025,在一个实施例中,可通过从最大指数中减去结果的浮点指数来计算检测的抵消。
在2030,在一个实施例中,可对比阈限来求值检测的抵消值。阈限可默认成0或者某一其它固定值。阈限也可由代码编译器或者代码起草器设置。如果检测的值大于阈限,则可发信号通知抵消效应。
在2035,在一个实施例中,可设置对应于检测的抵消的标志。具有0值的标志可对应于没有抵消效应,而1值可对应于存在抵消效应。可使用抵消效应检测单元1826针对每个浮点结果更新标志,或者可针对所有指令将标志初始化成0。标志可驻留在对应于指令执行的状态寄存器字段内。编程器可能需要检查状态寄存器字段中的标志的状态,以确定抵消效应的存在。
在2040,在一个实施例中,可以确定掩蔽位是否被设置成控制是否发信号通知抵消异常。掩蔽位可由代码编译器或者代码起草器设置。掩蔽位可驻留在对应于指令执行的控制字段中,诸如在MXCSR控制字段中。
在2045,在一个实施例中,通过基于掩蔽位未被设置的确定报告异常,发信号通知抵消效应。如果掩蔽位被设置,则可以不报告抵消效应异常。在一个实施例中,掩蔽位可控制在2035中的标志设置以及在2045中的异常的发信号通知。
在2050,一个或更多指令例如可由引退单元引退。方法2000可选地可重复或终止。
公开提供一组技术方案,如下:
1. 一种处理器,包括:
前端,用于对指令进行解码,所述指令用于计算受到抵消效应的浮点结果;
执行单元;
分配器,用于将所述指令指配给所述执行单元以执行所述指令;
其中所述执行单元包含:
阈限,用于控制所述抵消效应的通知;
第一逻辑,用于根据两个源值计算最大指数;
第二逻辑,用于确定所述浮点结果的浮点指数;
第三逻辑,用于通过从所述最大指数减去所述浮点指数来计算检测的抵消值;以及
第四逻辑,用于将所述检测的抵消值与所述阈限作比较。
. 如技术方案1所述的处理器,其中所述执行单元进一步包含:第五逻辑,用于基于所述检测的抵消值与所述阈限之间的所述比较来设置标志。
. 如技术方案1所述的处理器,其中所述执行单元进一步包含:
第五逻辑,用于确定掩蔽位是否设置成阻止发信号通知所述
抵消效应;以及
第六逻辑,用于基于所述掩蔽位未被设置的所述确定并基于所述检测的抵消值与所述阈限的所述比较来发信号通知异常,其中所述比较确定所述检测的抵消值是否大于所述阈限。
. 如技术方案1所述的处理器,其中所述指令是浮点相加指令,并且所述执行单元进一步包含用于将所述两个源值相加的第五逻辑。
. 如技术方案1所述的处理器,其中所述指令是合并乘加指令,其中到所述合并乘加指令的一个输入对应于所述两个源值中的一个,并且到所述合并乘加指令的两个其它输入的乘积对应于所述两个源值中的另一个。
. 如技术方案1所述的处理器,其中使用浮点控制寄存器设置所述阈限。
. 如技术方案1所述的处理器,其中所述阈限由先前指令设置。
. 一种方法,包括:
将阈限设置成控制与计算浮点结果关联的抵消效应的通知;
根据两个源值计算最大指数;
确定所述浮点结果的浮点指数;
通过从所述最大指数减去所述浮点指数来计算检测的抵消值;以及
将所述检测的抵消值与所述阈限作比较。
. 如技术方案8所述的方法,进一步包括:基于所述检测的抵消值与所述阈限之间的所述比较设置标志。
. 如技术方案8所述的方法,进一步包括:
确定掩蔽位是否设置成阻止发信号通知所述抵消效应;以及
基于所述掩蔽位未被设置的所述确定并基于所述检测的抵消值与所述阈限的所述比较来发信号通知异常,其中所述比较确定所述检测的抵消值是否大于所述阈限。
. 如技术方案8所述的方法,进一步包括:处理浮点相加运算。
. 如技术方案8所述的方法,进一步包括:通过将两个输入的乘积计算成合并乘加运算并使用所述乘积作为所述两个源值中的一个来处理所述合并乘加运算。
. 如技术方案8所述的方法,进一步包括:使用浮点控制寄存器设置所述阈限。
. 一种抵消效应检测单元,包括:
阈限,用于控制与计算浮点结果关联的抵消效应的通知;
第一逻辑,用于根据两个源值计算最大指数;
第二逻辑,用于确定所述浮点结果的浮点指数;
第三逻辑,用于通过从所述最大指数减去所述浮点指数来计算检测的抵消值;以及
第四逻辑,用于将所述检测的抵消值与所述阈限作比较。
. 如技术方案14所述的抵消效应检测单元,进一步包括:第五逻辑,用于基于所述检测的抵消值与所述阈限之间的所述比较设置标志。
. 如技术方案14所述的抵消效应检测单元,进一步包括:
第五逻辑,用于确定掩蔽位是否设置成阻止发信号通知所述抵消效应;以及
第六逻辑,用于基于所述掩蔽位未被设置的所述确定以及所述检测的抵消值与所述阈限的所述比较来发信号通知异常,其中所述比较确定所述检测的抵消值是否大于所述阈限。
. 如技术方案14所述的抵消效应检测单元,进一步包括:到浮点逻辑单元的接口,其包含用于处理浮点相加运算的第五逻辑。
. 如技术方案14所述的抵消效应检测单元,进一步包括:到合并乘加指令逻辑单元的接口,其包含用于处理合并乘加运算的第五逻辑,其中到所述合并乘加运算的一个输入对应于所述两个源值中的一个,并且到所述合并乘加运算的两个其它输入的乘积对应于所述两个源值中的另一个。
. 如技术方案14所述的抵消效应检测单元,其中使用浮点控制寄存器设置所述阈限。
. 如技术方案14所述的抵消效应检测单元,其中所述阈限由先前指令设置。
本文公开的机制的实施例可以用硬件、软件、固件或此类实现方法的组合来实现。本公开的实施例可实现为在包括至少一个处理器、存储系统(包含易失性和非易失性存储器和/或存储元件)、至少一个输入装置和至少一个输出装置的可编程系统上执行的计算机程序或程序代码。
程序代码可应用于输入指令以执行本文描述的功能并生成输出信息。输出信息可以以已知方式应用于一个或多个输出装置。为了此申请的目的,处理系统可包含具有处理器的任何系统,处理器诸如例如数字信号处理器(DSP)、微控制器、专用集成电路(ASIC)或微处理器。
程序代码可用高级面向过程或面向对象的编程语言实现,以与处理系统通信。程序代码也可用汇编语言或机器语言实现(如果期望的话)。实际上,本文描述的机制在范围上不限于任何具体编程语言。在任何情况下,语言都可以是编译语言或解译语言。
至少一个实施例的一个或多个方面可由存储在表示处理器内各种逻辑的机器可读介质上的代表性指令实现,这些指令当由机器读取时使机器制造执行本文描述的技术的逻辑。称为“IP核”的此类表示可存储在有形、机器可读介质上,并供应给各种消费者或制造设施,以加载到实际上制造逻辑或处理器的制造机器中。
此类机器可读存储介质可包含但不限于由机器或装置制造或形成的制品的非暂态、有形布置,包含存储介质,诸如硬盘、任何其它类型盘,包含软盘、光盘、紧凑盘只读存储器(CD-ROM)、紧凑盘可重写(CD-RW)以及磁光盘、半导体器件,诸如只读存储器(ROM)、随机存取存储器(RAM)(诸如动态随机存取存储器(DRAM)、静态随机存取存储器(SRAM))、可擦除可编程只读存储器(EPROM)、闪速存储器、电可擦除可编程只读存储器(EEPROM)、磁卡或光卡或适合于存储电子指令的任何其它类型介质。
相应地,本公开的实施例还可包含非暂态、有形机器可读介质,其含有指令或含有设计数据(诸如硬件描述语言(HDL),其定义本文描述的结构、电路、设备、处理器和/或系统特征)。此类实施例也可称为程序产品。
在一些情况下,指令转换器可用于将指令从源指令集转换到目标指令集。例如,指令转换器可转化(例如使用静态二进制转化、动态二进制转化,包含动态编译)、变形、仿真或以其它的方式将指令转换成要由核处理的一个或多个其它指令。指令转换器可用软件、硬件、固件或它们的组合实现。指令转换器可以在处理器上、在处理器外或者部分在处理器上且部分在处理器外。
从而,公开了用于执行根据至少一个实施例的一个或多个指令的技术。虽然已经在附图中描述和示出了某些示范实施例,但要理解的是,此类实施例仅仅是说明性的并且不对其它实施例进行约束,并且此类实施例不限于所示出和描述的特定构造和布置,因为本领域技术人员在学习本公开时可想到各种其它修改。在诸如其中增长快速并且进一步进步不容易预见的此类的技术领域中,所公开的实施例在布置和细节上可容易地修改(如通过实现技术进步所促进的)而并不脱离本公开的原理或所附权利要求书的范围。
在本公开的一些实施例中,处理器可包含对指令进行解码的前端、执行单元和分配器或者将指令指配给执行单元以执行指令的其它机制。所述指令可以用于计算受到抵消效应的浮点结果。在与以上任何实施例组合时,在实施例中,执行单元可包含阈限。阈限可用于控制抵消效应的通知。在与以上任何实施例组合时,在实施例中,执行单元可包含第一逻辑,其可用于根据两个源值计算最大指数。在与以上任何实施例组合时,在实施例中,执行单元可包含第二逻辑,其可用于确定浮点结果的浮点指数。在与以上任何实施例组合时,在实施例中,执行单元可包含第三逻辑,其可用于通过从所述最大指数减去所述浮点指数来计算检测的抵消值。在与以上任何实施例组合时,在实施例中,执行单元可包含第四逻辑,其可用于将检测的抵消值与阈限作比较。
在与以上任何实施例组合时,在实施例中,执行单元可包含第五逻辑,其可用于基于所述检测的抵消值与所述阈限之间的比较设置标志。在与以上任何实施例组合时,在实施例中,执行单元可包含第五逻辑和第六逻辑。第五逻辑可用于确定掩蔽位是否设置成阻止发信号通知所述抵消效应。第六逻辑可用于基于掩蔽位未被设置的确定以及基于检测的抵消值与阈限的比较来发信号通知异常。在与以上任何实施例组合时,在实施例中,比较可以确定检测的抵消值是否大于阈限。在与以上任何实施例组合时,在实施例中,指令可以是浮点相加指令。在与以上任何实施例组合时,在实施例中,执行单元可包含第五逻辑,其可用于将两个源值相加。在与以上任何实施例组合时,在实施例中,指令可以是合并乘加指令。在与以上任何实施例组合时,在实施例中,到合并乘加指令的两个输入的乘积对应于两个源值中的另一个。在与以上任何实施例组合时,在实施例中,到合并乘加指令的一个输入对应于两个源值中的一个。在与以上任何实施例组合时,在实施例中,可使用浮点控制寄存器设置阈限。在与以上任何实施例组合时,在实施例中,所述阈限可由先前指令设置。
在一些目前的实施例中,方法可包含将阈限设置成控制与计算浮点结果关联的抵消效应的通知。在与以上任何实施例组合时,在实施例中,该方法可包含根据两个源值计算最大指数。在与以上任何实施例组合时,在实施例中,该方法可包含确定所述浮点结果的浮点指数。在与以上任何实施例组合时,在实施例中,方法可包含通过从所述最大指数减去所述浮点指数来计算检测的抵消值。在与以上任何实施例组合时,在实施例中,该方法可包含将检测的抵消值与阈限作比较。
在与以上任何实施例组合时,在实施例中,该方法可包含基于所述检测的抵消值与所述阈限之间的比较设置标志。在与以上任何实施例组合时,在实施例中,该方法可包含确定掩蔽位是否设置成阻止发信号通知所述抵消效应。在与以上任何实施例组合时,在实施例中,该方法可包含基于掩蔽位未被设置的确定以及基于检测的抵消值与阈限的比较来发信号通知异常。在与以上任何实施例组合时,在实施例中,比较可以确定检测的抵消值是否大于阈限。在与以上任何实施例组合时,在实施例中,该方法可包含处理浮点相加运算。在与以上任何实施例组合时,在实施例中,该方法可包含通过将两个输入的乘积计算到所述合并乘加运算并使用所述乘积作为所述两个源值中的一个来处理合并乘加运算。在与以上任何实施例组合时,在实施例中,该方法可包含使用浮点控制寄存器设置所述阈限。
在本公开的一些实施例中,系统可包含对指令进行解码的前端、执行单元和分配器或者将指令指配给执行单元以执行指令的其它机制。所述指令可以用于计算受到抵消效应的浮点结果。在与以上任何实施例组合时,在实施例中,执行单元可包含阈限。阈限可用于控制抵消效应的通知。在与以上任何实施例组合时,在实施例中,执行单元可包含第一逻辑,其可用于根据两个源值计算最大指数。在与以上任何实施例组合时,在实施例中,执行单元可包含第二逻辑,其可用于确定浮点结果的浮点指数。在与以上任何实施例组合时,在实施例中,执行单元可包含第三逻辑,其可用于通过从所述最大指数减去所述浮点指数来计算检测的抵消值。在与以上任何实施例组合时,在实施例中,执行单元可包含第四逻辑,其可用于将检测的抵消值与阈限作比较。
在与以上任何实施例组合时,在实施例中,执行单元可包含第五逻辑,其可用于基于所述检测的抵消值与所述阈限之间的比较设置标志。在与以上任何实施例组合时,在实施例中,执行单元可包含第五逻辑和第六逻辑。第五逻辑可用于确定掩蔽位是否设置成阻止发信号通知所述抵消效应。第六逻辑可用于基于掩蔽位未被设置的确定以及基于检测的抵消值与阈限的比较来发信号通知异常。在与以上任何实施例组合时,在实施例中,比较可以确定检测的抵消值是否大于阈限。在与以上任何实施例组合时,在实施例中,指令可以是浮点相加指令。在与以上任何实施例组合时,在实施例中,执行单元可包含第五逻辑,其可用于将两个源值相加。在与以上任何实施例组合时,在实施例中,指令可以是合并乘加指令。在与以上任何实施例组合时,在实施例中,到合并乘加指令的两个输入的乘积对应于两个源值中的另一个。在与以上任何实施例组合时,在实施例中,到合并乘加指令的一个输入对应于两个源值中的一个。在与以上任何实施例组合时,在实施例中,可使用浮点控制寄存器设置阈限。在与以上任何实施例组合时,在实施例中,所述阈限可由先前指令设置。
在本公开的一些实施例中,抵消效应检测单元可包含阈限。阈限可控制与计算浮点结果关联的抵消效应的通知。在与以上任何实施例组合时,在实施例中,抵消检测单元可包含第一逻辑,其可用于根据两个源值计算最大指数。在与以上任何实施例组合时,在实施例中,抵消检测单元可包含第二逻辑,其可用于确定浮点结果的浮点指数。在与以上任何实施例组合时,在实施例中,抵消检测单元可包含第三逻辑,其可用于通过从所述最大指数减去所述浮点指数来计算检测的抵消值。在与以上任何实施例组合时,在实施例中,抵消检测单元可包含第四逻辑,其可用于将检测的抵消值与阈限作比较。
在与以上任何实施例组合时,在实施例中,抵消效应检测单元可包含第五逻辑,其可用于基于所述检测的抵消值与所述阈限之间的比较设置标志。在与以上任何实施例组合时,在实施例中,抵消效应检测单元可包含第五逻辑和第六逻辑。第五逻辑可用于确定掩蔽位是否设置成阻止发信号通知所述抵消效应。第六逻辑可用于基于掩蔽位未被设置的确定以及检测的抵消值与阈限的比较来发信号通知异常。在与以上任何实施例组合时,在实施例中,比较可以确定检测的抵消值是否大于阈限。在与以上任何实施例组合时,在实施例中,抵消效应检测单元可包含到浮点逻辑单元的接口。接口或浮点逻辑单元可包含第五逻辑,其可用于处理浮点相加运算。在与以上任何实施例组合时,在实施例中,抵消效应检测单元可包含到合并乘加指令逻辑单元的接口。接口或逻辑单元可包含第五逻辑,其可用于处理合并乘加运算。在与以上任何实施例组合时,在实施例中,到所述合并乘加运算的一个输入可对应于两个源值中的一个,并且到所述合并乘加运算的两个其它输入的乘积可对应于两个源值中的另一个。在与以上任何实施例组合时,在实施例中,可使用浮点控制寄存器设置阈限。在与以上任何实施例组合时,在实施例中,所述阈限可由先前指令设置。
在本公开的一些实施例中,设备可包含用于检测抵消效应的部件。在与以上任何实施例组合时,在实施例中,用于检测抵消效应的部件可包含阈限部件。阈限部件可控制与计算浮点结果关联的抵消效应的通知。在与以上任何实施例组合时,在实施例中,用于检测抵消效应的部件可包含用于根据两个源值计算最大指数的部件。在与以上任何实施例组合时,在实施例中,用于检测抵消效应的部件可包含用于确定浮点结果的浮点指数的部件。在与以上任何实施例组合时,在实施例中,用于检测抵消效应的部件可包含用于通过从所述最大指数减去所述浮点指数来计算检测的抵消值。在与以上任何实施例组合时,在实施例中,用于检测抵消效应的部件可包含用于将检测的抵消值与阈限作比较的部件。
在与以上任何实施例组合时,在实施例中,用于检测抵消效应的部件可包含用于基于检测的抵消值与阈限之间的比较设置标志的部件。在与以上任何实施例组合时,在实施例中,用于确定掩蔽位是否被设置成阻止发信号通知抵消效应的部件和用于基于掩蔽位未被设置的确定而发信号通知异常的部件,以及比较部件。比较部件可以确定检测的抵消值是否大于阈限。在与以上任何实施例组合时,在实施例中,用于检测抵消效应的部件可包含到浮点逻辑单元的接口部件。接口部件可包含用于处理浮点相加运算的部件。在与以上任何实施例组合时,在实施例中,用于检测抵消效应的部件可包含到合并乘加指令逻辑部件的接口部件。接口部件或逻辑单元可包含用于处理合并乘加运算的部件。到合并乘加运算的一个输入可对应于两个源值中的一个,并且到所述合并乘加运算的两个其它输入的乘积可对应于两个源值中的另一个。在与以上任何实施例组合时,在实施例中,可使用浮点控制寄存器设置阈限部件。在与以上任何实施例组合时,在实施例中,阈限部件可由先前指令设置。

Claims (22)

1.一种处理器,包括:
前端,用于对指令进行解码,所述指令用于计算受到抵消效应的浮点结果;
执行单元;
分配器,用于将所述指令指配给所述执行单元以执行所述指令;
其中所述执行单元包含:
阈限,用于控制所述抵消效应的通知;
第一逻辑,用于根据两个源值计算最大指数;
第二逻辑,用于确定所述浮点结果的浮点指数;
第三逻辑,用于通过从所述最大指数减去所述浮点指数来计算检测的抵消值;以及
第四逻辑,用于将所述检测的抵消值与所述阈限作比较。
2.如权利要求1所述的处理器,其中所述执行单元进一步包含:第五逻辑,用于基于所述检测的抵消值与所述阈限之间的所述比较来设置标志。
3.如权利要求1所述的处理器,其中所述执行单元进一步包含:
第五逻辑,用于确定掩蔽位是否设置成阻止发信号通知所述抵消效应;以及
第六逻辑,用于基于所述掩蔽位未被设置的所述确定并基于所述检测的抵消值与所述阈限的所述比较来发信号通知异常,其中所述比较确定所述检测的抵消值是否大于所述阈限。
4.如权利要求1所述的处理器,其中所述指令是浮点相加指令,并且所述执行单元进一步包含用于将所述两个源值相加的第五逻辑。
5.如权利要求1所述的处理器,其中所述指令是合并乘加指令,其中到所述合并乘加指令的一个输入对应于所述两个源值中的一个,并且到所述合并乘加指令的两个其它输入的乘积对应于所述两个源值中的另一个。
6.如权利要求1所述的处理器,其中使用浮点控制寄存器设置所述阈限。
7.如权利要求1所述的处理器,其中所述阈限由先前指令设置。
8.一种方法,包括:
将阈限设置成控制与计算浮点结果关联的抵消效应的通知;
根据两个源值计算最大指数;
确定所述浮点结果的浮点指数;
通过从所述最大指数减去所述浮点指数来计算检测的抵消值;以及
将所述检测的抵消值与所述阈限作比较。
9.如权利要求8所述的方法,进一步包括:基于所述检测的抵消值与所述阈限之间的所述比较设置标志。
10.如权利要求8所述的方法,进一步包括:
确定掩蔽位是否设置成阻止发信号通知所述抵消效应;以及
基于所述掩蔽位未被设置的所述确定并基于所述检测的抵消值与所述阈限的所述比较来发信号通知异常,其中所述比较确定所述检测的抵消值是否大于所述阈限。
11.如权利要求8所述的方法,进一步包括:处理浮点相加运算。
12.如权利要求8所述的方法,进一步包括:通过将两个输入的乘积计算成合并乘加运算并使用所述乘积作为所述两个源值中的一个来处理所述合并乘加运算。
13.如权利要求8所述的方法,进一步包括:使用浮点控制寄存器设置所述阈限。
14.如权利要求8所述的方法,进一步包括:使用先前指令设置所述阈限。
15.一种抵消效应检测单元,包括:
阈限,用于控制与计算浮点结果关联的抵消效应的通知;
第一逻辑,用于根据两个源值计算最大指数;
第二逻辑,用于确定所述浮点结果的浮点指数;
第三逻辑,用于通过从所述最大指数减去所述浮点指数来计算检测的抵消值;以及
第四逻辑,用于将所述检测的抵消值与所述阈限作比较。
16.如权利要求15所述的抵消效应检测单元,进一步包括:第五逻辑,用于基于所述检测的抵消值与所述阈限之间的所述比较设置标志。
17.如权利要求15所述的抵消效应检测单元,进一步包括:
第五逻辑,用于确定掩蔽位是否设置成阻止发信号通知所述抵消效应;以及
第六逻辑,用于基于所述掩蔽位未被设置的所述确定以及所述检测的抵消值与所述阈限的所述比较来发信号通知异常,其中所述比较确定所述检测的抵消值是否大于所述阈限。
18.如权利要求15所述的抵消效应检测单元,进一步包括:到浮点逻辑单元的接口,其包含用于处理浮点相加运算的第五逻辑。
19.如权利要求15所述的抵消效应检测单元,进一步包括:到合并乘加指令逻辑单元的接口,其包含用于处理合并乘加运算的第五逻辑,其中到所述合并乘加运算的一个输入对应于所述两个源值中的一个,并且到所述合并乘加运算的两个其它输入的乘积对应于所述两个源值中的另一个。
20.如权利要求15所述的抵消效应检测单元,其中使用浮点控制寄存器设置所述阈限。
21.如权利要求15所述的抵消效应检测单元,其中所述阈限由先前指令设置。
22.一种设备,包括用于执行如权利要求8-14中任一项所述的方法的部件。
CN201680067629.5A 2015-12-20 2016-11-18 用于检测浮点抵消效应的指令和逻辑 Pending CN108351778A (zh)

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US14/975811 2015-12-20
US14/975,811 US10114642B2 (en) 2015-12-20 2015-12-20 Instruction and logic for detecting the floating point cancellation effect
PCT/US2016/062921 WO2017112191A1 (en) 2015-12-20 2016-11-18 Instruction and logic for detecting the floating point cancellation effect

Publications (1)

Publication Number Publication Date
CN108351778A true CN108351778A (zh) 2018-07-31

Family

ID=59064336

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201680067629.5A Pending CN108351778A (zh) 2015-12-20 2016-11-18 用于检测浮点抵消效应的指令和逻辑

Country Status (5)

Country Link
US (1) US10114642B2 (zh)
EP (1) EP3391198B1 (zh)
CN (1) CN108351778A (zh)
TW (1) TWI738681B (zh)
WO (1) WO2017112191A1 (zh)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN111915003A (zh) * 2019-05-09 2020-11-10 深圳大普微电子科技有限公司 一种神经网络硬件加速器

Families Citing this family (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10114642B2 (en) 2015-12-20 2018-10-30 Intel Corporation Instruction and logic for detecting the floating point cancellation effect
US20170177336A1 (en) * 2015-12-22 2017-06-22 Intel Corporation Hardware cancellation monitor for floating point operations
WO2021041139A1 (en) * 2019-08-23 2021-03-04 Google Llc Signed multiword multiplier

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5583805A (en) * 1994-12-09 1996-12-10 International Business Machines Corporation Floating-point processor having post-writeback spill stage
CN1415087A (zh) * 1999-10-29 2003-04-30 英特尔公司 检测推测性浮点运算ieee下溢异常的机制
US20090228690A1 (en) * 2008-03-10 2009-09-10 Adam James Muff Early Exit Processing of Iterative Refinement Algorithm Using Register Dependency Disable
US20140006467A1 (en) * 2012-06-29 2014-01-02 Sridhar Samudrala Double rounded combined floating-point multiply and add
CN104050077A (zh) * 2013-03-15 2014-09-17 英特尔公司 利用多个测试源来提供或(or)测试和与(and)测试功能的可融合指令和逻辑

Family Cites Families (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP3544846B2 (ja) * 1997-02-13 2004-07-21 株式会社東芝 論理回路及び浮動小数点演算装置
US6631392B1 (en) 1999-07-30 2003-10-07 Mips Technologies, Inc. Method and apparatus for predicting floating-point exceptions
US8239441B2 (en) * 2008-05-15 2012-08-07 Oracle America, Inc. Leading zero estimation modification for unfused rounding catastrophic cancellation
US8219605B2 (en) 2010-05-28 2012-07-10 International Business Machines Corporation Decimal floating-pointing quantum exception detection
US8965945B2 (en) * 2011-02-17 2015-02-24 Arm Limited Apparatus and method for performing floating point addition
US8775494B2 (en) 2011-03-01 2014-07-08 Nvidia Corporation System and method for testing whether a result is correctly rounded
US9317478B2 (en) * 2012-09-10 2016-04-19 Crossfield Technology LLC Dual-path fused floating-point add-subtract
US9104515B2 (en) 2012-12-14 2015-08-11 Fujitsu Limited Floating-point error detection and correction
US10114642B2 (en) 2015-12-20 2018-10-30 Intel Corporation Instruction and logic for detecting the floating point cancellation effect

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5583805A (en) * 1994-12-09 1996-12-10 International Business Machines Corporation Floating-point processor having post-writeback spill stage
CN1415087A (zh) * 1999-10-29 2003-04-30 英特尔公司 检测推测性浮点运算ieee下溢异常的机制
US20090228690A1 (en) * 2008-03-10 2009-09-10 Adam James Muff Early Exit Processing of Iterative Refinement Algorithm Using Register Dependency Disable
US20140006467A1 (en) * 2012-06-29 2014-01-02 Sridhar Samudrala Double rounded combined floating-point multiply and add
CN104050077A (zh) * 2013-03-15 2014-09-17 英特尔公司 利用多个测试源来提供或(or)测试和与(and)测试功能的可融合指令和逻辑

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
MICHAEL O. LAM 等: "dynamic floating-point cancellation detection", 《PARALLEL COMPUTING》 *

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN111915003A (zh) * 2019-05-09 2020-11-10 深圳大普微电子科技有限公司 一种神经网络硬件加速器
CN111915003B (zh) * 2019-05-09 2024-03-22 深圳大普微电子科技有限公司 一种神经网络硬件加速器

Also Published As

Publication number Publication date
US20170177347A1 (en) 2017-06-22
TW201729079A (zh) 2017-08-16
EP3391198B1 (en) 2023-09-13
TWI738681B (zh) 2021-09-11
EP3391198A1 (en) 2018-10-24
WO2017112191A1 (en) 2017-06-29
EP3391198A4 (en) 2019-07-31
US10114642B2 (en) 2018-10-30

Similar Documents

Publication Publication Date Title
CN107003921B (zh) 具有有限状态机控制的可重配置测试访问端口
CN108369509B (zh) 用于基于通道的跨步分散操作的指令和逻辑
CN109791513B (zh) 用于检测数值累加误差的指令和逻辑
TWI731892B (zh) 用於以通道為基礎的跨步儲存操作之指令及邏輯
CN108292229B (zh) 用于重新出现的相邻聚集的指令和逻辑
CN108369513A (zh) 用于加载-索引-和-收集操作的指令和逻辑
CN108351784B (zh) 用于在乱序处理器中进行有序处理的指令和逻辑
CN108292215A (zh) 用于加载-索引和预取-聚集操作的指令和逻辑
KR101923289B1 (ko) 스토어들을 소팅 및 리타이어링하기 위한 명령어와 로직
CN108351779A (zh) 用于安全指令执行流水线的指令和逻辑
CN108369516A (zh) 用于加载-索引和预取-分散操作的指令和逻辑
CN107003839B (zh) 用于移位和乘法器的指令执行方法、处理器和系统
CN108292232A (zh) 用于加载索引和分散操作的指令和逻辑
TW201723817A (zh) 用於取得多重向量元素操作之指令及邏輯
CN108369573A (zh) 用于设置多个向量元素的操作的指令和逻辑
CN108351785A (zh) 用于部分减少操作的指令和逻辑
CN108701101A (zh) 处理器系统管理中断事件的基于仲裁器的串行化
CN108369518A (zh) 用于位字段寻址和插入的指令和逻辑
TW201732619A (zh) 仿真的訊息通知中斷(msi)中斷處置
CN106575219A (zh) 针对用于处理运算的向量格式的指令和逻辑技术领域
TW201723815A (zh) 用於偶數與奇數向量取得操作之指令及邏輯
CN108292271B (zh) 用于向量置换的指令和逻辑
CN108351778A (zh) 用于检测浮点抵消效应的指令和逻辑
CN108369510A (zh) 用于以无序加载的置换的指令和逻辑
CN108292218A (zh) 用于向量位字段压缩和扩展的指令和逻辑

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
RJ01 Rejection of invention patent application after publication
RJ01 Rejection of invention patent application after publication

Application publication date: 20180731